@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600;700&family=Manrope:wght@400;500;600;700;800&display=swap");

/* BECAS LMS - shared styles (light/dark) */

:root{
  --bg: #0b1220;
  --panel: #0f1a33;
  --panel2: #121f3b;
  --text: #e8eefc;
  --muted: rgba(232,238,252,.72);
  --border: rgba(255,255,255,.10);
  --shadow: 0 10px 25px rgba(0,0,0,.35);

  --primary: #2b6bff;
  --danger: #ff4d4d;
  --warning: #ffb020;
  --ok: #1fc96b;

  --radius: 14px;
  --radius2: 18px;

  --sidebarW: 270px;
  --maxW: 1200px;

  --font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", Inter, system-ui, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  --line-height: 1.5;
  --line-height-tight: 1.32;
  --letter-spacing: -0.011em;
  --letter-spacing-tight: -0.018em;
}

@media (prefers-color-scheme: light){
  :root{
    --bg: #f5f7ff;
    --panel: #ffffff;
    --panel2: #ffffff;
    --text: #0a1225;
    --muted: rgba(10,18,37,.7);
    --border: rgba(10,18,37,.10);
    --shadow: 0 10px 25px rgba(0,0,0,.08);
  }
}

:root[data-theme="light"]{
  --glass-bg: rgba(255,255,255,.74);
  --glass-border: rgba(255,255,255,.84);
  --glass-shadow: 0 12px 30px rgba(15,30,62,.14), 0 3px 10px rgba(15,30,62,.08);
  --surface-0: #eef3ff;
  --surface-1: rgba(255,255,255,.62);
  --text-0: #111c34;
  --text-1: rgba(17,28,52,.86);
  --muted: rgba(32,48,80,.64);
  --accent: #356fff;
  --bg: radial-gradient(1000px 560px at -10% 0%, rgba(122,162,255,.22), transparent 56%),
        radial-gradient(900px 560px at 100% -10%, rgba(73,214,255,.16), transparent 48%),
        var(--surface-0);
  --panel: var(--surface-1);
  --panel2: rgba(255,255,255,.56);
  --text: var(--text-0);
  --border: rgba(255,255,255,.75);
}

:root[data-theme="dark"]{
  --surface-0: #0a1224;
  --surface-1: rgba(14,23,44,.92);
  --text-0: #f2f6ff;
  --text-1: rgba(242,246,255,.92);
  --muted: rgba(214,225,248,.82);
  --bg: radial-gradient(1200px 600px at 10% -10%, rgba(122,162,255,.18), transparent 55%),
        radial-gradient(900px 560px at 90% 0%, rgba(73,214,255,.12), transparent 50%),
        var(--surface-0);
  --panel: var(--surface-1);
  --panel2: rgba(10,18,36,.68);
  --text: var(--text-0);
  --border: var(--glass-border);
}


/* ================================
   Glass Theme Tokens
================================ */
:root{
  --glass-bg: rgba(255,255,255,.10);
  --glass-border: rgba(255,255,255,.26);
  --glass-shadow: 0 10px 28px rgba(5,14,32,.30), 0 2px 10px rgba(5,14,32,.18);
  --glass-blur: 18px;

  --surface-bg: #0b1220;
  --glass-strong-bg: rgba(255,255,255,0.10);
  --glass-subtle-bg: rgba(255,255,255,0.06);
  --glass-border: rgba(255,255,255,0.18);
  --glass-border-strong: rgba(255,255,255,0.24);
  --shadow-1: 0 8px 20px rgba(4,12,28,.18);
  --shadow-2: 0 14px 30px rgba(4,12,28,.24);
  --shadow-3: 0 20px 44px rgba(4,12,28,.30);
  --blur-strong: 18px;
  --blur-subtle: 12px;

  --surface-0: #0a1224;
  --surface-1: rgba(14,23,44,.92);
  --text-0: #f2f6ff;
  --text-1: rgba(242,246,255,.92);
  --muted: rgba(214,225,248,.82);
  --divider: rgba(255,255,255,0.10);
  --accent: #7aa2ff;
  --accent-2: rgba(122,162,255,.45);

  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 22px;
  --radius-12: 12px;
  --radius-16: 16px;
  --radius-20: 20px;

  --s-1: 8px;
  --s-2: 12px;
  --s-3: 16px;
  --s-4: 20px;
  --s-5: 24px;
  --s-6: 32px;

  --space-1: var(--s-1);
  --space-2: var(--s-2);
  --space-3: var(--s-3);
  --space-4: var(--s-4);
  --space-5: var(--s-5);
  --space-6: var(--s-6);

  --bg: radial-gradient(1200px 600px at 10% -10%, rgba(122,162,255,.18), transparent 55%),
        radial-gradient(900px 560px at 90% 0%, rgba(73,214,255,.12), transparent 50%),
        var(--surface-0);
  --panel: var(--surface-1);
  --panel2: rgba(10,18,36,.68);
  --text: var(--text-0);
  --border: var(--glass-border);
  --shadow: var(--glass-shadow);

  --radius: var(--radius-12);
  --radius2: var(--radius-20);

  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (prefers-color-scheme: light){
  :root{
    --glass-bg: rgba(255,255,255,.74);
    --glass-border: rgba(255,255,255,.84);
    --glass-shadow: 0 12px 30px rgba(15,30,62,.14), 0 3px 10px rgba(15,30,62,.08);
    --glass-blur: 20px;

    --surface-0: #eef3ff;
    --surface-1: rgba(255,255,255,.62);
    --text-0: #111c34;
    --text-1: rgba(17,28,52,.86);
    --muted: rgba(32,48,80,.64);
    --accent: #356fff;

    --bg: radial-gradient(1000px 560px at -10% 0%, rgba(122,162,255,.22), transparent 56%),
          radial-gradient(900px 560px at 100% -10%, rgba(73,214,255,.16), transparent 48%),
          var(--surface-0);
    --panel: var(--surface-1);
    --panel2: rgba(255,255,255,.56);
    --text: var(--text-0);
    --border: rgba(255,255,255,.75);
  }
}

.glass,
.glass-subtle,
.glass-strong{
  background: var(--glass-subtle-bg);
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow-1);
  -webkit-backdrop-filter: blur(var(--blur-subtle)) saturate(160%);
  backdrop-filter: blur(var(--blur-subtle)) saturate(160%);
}

.glass-subtle{
  background: color-mix(in srgb, var(--glass-subtle-bg) 92%, transparent);
}

.glass-strong{
  background: color-mix(in srgb, var(--glass-strong-bg) 94%, rgba(255,255,255,.10));
  border-color: var(--glass-border-strong);
  -webkit-backdrop-filter: blur(var(--blur-strong)) saturate(160%);
  backdrop-filter: blur(var(--blur-strong)) saturate(160%);
}

.elev-1{ box-shadow: var(--shadow-1); }
.elev-2{ box-shadow: var(--shadow-2); }
.elev-3{ box-shadow: var(--shadow-3); }

.ring-focus:focus-visible{
  outline: none;
  border-color: color-mix(in srgb, var(--accent) 65%, white 15%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-2) 58%, transparent);
}


:root:not(.glass-mode), :root[data-glass="off"]{
  --glass-bg: color-mix(in srgb, var(--surface-1) 94%, var(--surface-0) 6%);
  --glass-border: rgba(255,255,255,.14);
  --glass-shadow: 0 8px 22px rgba(4,12,28,.18);
  --glass-blur: 0px;
}

:root:not(.glass-mode) .glass,
:root:not(.glass-mode) .glass-subtle,
:root:not(.glass-mode) .glass-strong,
:root[data-glass="off"] .glass,
:root[data-glass="off"] .glass-subtle,
:root[data-glass="off"] .glass-strong{
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}

:root[data-density="compact"], :root.density-compact{
  --space-3: 10px;
  --space-4: 14px;
  --space-5: 18px;
  --space-6: 20px;
}

:root[data-density="compact"] .table th,
:root[data-density="compact"] .table td{
  padding: 8px 6px;
}

:root[data-density="compact"] .btn{
  padding-top: 9px;
  padding-bottom: 9px;
}

*{ box-sizing: border-box; }
html,body{ height:100%; }
body{
  margin:0;
  font-family: var(--font);
  line-height: var(--line-height);
  letter-spacing: var(--letter-spacing);
  background: var(--bg);
  color: var(--text);
}

a{ color: inherit; text-decoration: none; }
img{ max-width:100%; height:auto; display:block; }

.bg{
  min-height:100%;
  display:grid;
  place-items:center;
  padding: 24px;
}

.h1,
.h2,
.h3{
  line-height: var(--line-height-tight);
  letter-spacing: var(--letter-spacing-tight);
  margin-top: 0;
}
.h1{ margin: 14px 0 10px; font-size: 28px; font-weight: 700; }
.small{ font-size: 12px; }
.muted{ color: var(--muted); }

.auth-page{ width:100%; display:grid; place-items:center; }
.auth-card{
  width: min(520px, 100%);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding: var(--space-6);
}
.brand{ display:flex; gap: 12px; align-items:center; }
.brand-logo{ width: 92px; height:auto; border-radius: 10px; background:#fff; padding:8px; }
.brand-title .app-name{ font-weight: 800; font-size: 18px; }
.brand-title .app-subtitle{ font-size: 12px; color: var(--muted); }

.form{ display:flex; flex-direction:column; gap: var(--space-3); margin-top: var(--space-4); }
.label{ font-size: 13px; color: var(--muted); }
.input, select, textarea{
  width:100%;
  padding: 12px 14px;
  background: var(--panel2);
  border: 1px solid var(--border);
  border-radius: var(--radius-16);
  color: var(--text);
  box-shadow: inset 0 1px 1px rgba(255,255,255,.08), inset 0 -1px 2px rgba(7,16,36,.16);
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
  outline: none;
}
.input:focus, select:focus, textarea:focus{
  border-color: color-mix(in srgb, var(--accent) 62%, white 16%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent), inset 0 1px 1px rgba(255,255,255,.09);
}
textarea{ min-height: 96px; resize: vertical; }

.btn{
  appearance:none;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.05);
  color: var(--text);
  padding: 11px 16px;
  border-radius: 999px;
  cursor:pointer;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: transform .14s ease, filter .2s ease, background-color .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.btn:hover{ filter: brightness(1.05); transform: translateY(-1px); }
.btn:active{ transform: scale(.98); }
.btn:disabled{ opacity:.6; cursor:not-allowed; }

.btn.primary{
  border-color: color-mix(in srgb, var(--accent) 65%, white 15%);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 78%, white 22%) 0%, color-mix(in srgb, var(--accent) 100%, #2f63ef 0%) 100%);
  color: #fff;
  box-shadow: 0 8px 16px color-mix(in srgb, var(--accent) 30%, transparent);
}
.btn.primary:hover{ box-shadow: 0 10px 20px color-mix(in srgb, var(--accent) 34%, transparent); }
.btn.danger{
  border-color: rgba(255,77,77,.45);
  background: rgba(255,77,77,.18);
}
.btn.ok{
  border-color: rgba(31,201,107,.45);
  background: rgba(31,201,107,.18);
}
.btn.ghost{ background: transparent; }

.icon-btn{
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--glass-border) 80%, transparent);
  background: color-mix(in srgb, var(--glass-bg) 88%, rgba(255,255,255,.08));
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(8,18,38,.12);
  transition: transform .14s ease, background-color .2s ease, border-color .2s ease, box-shadow .2s ease, filter .2s ease;
}
.icon-btn:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 36%, var(--glass-border) 64%);
  box-shadow: 0 14px 28px rgba(8,18,38,.16);
}
.icon-btn:active{ transform: scale(.98); }
.icon-svg{
  width: 22px;
  height: 22px;
  display: inline-flex;
}
.icon-svg svg{
  width: 100%;
  height: 100%;
  display: block;
}

.row{ display:flex; gap: 10px; flex-wrap: wrap; }
.row > *{ flex: 1 1 200px; }

.msg{
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  font-size: 13px;
  color: var(--text);
}
.msg.error{
  border-color: rgba(255,77,77,.45);
  background: rgba(255,77,77,.22);
  color: #4b0a0a;
  font-weight: 600;
}
.msg.ok{
  border-color: rgba(31,201,107,.45);
  background: rgba(31,201,107,.22);
  color: #07391f;
  font-weight: 600;
}

@media (prefers-color-scheme: dark){
  .msg.error{ color: #ffdede; }
  .msg.ok{ color: #ddffe9; }
}

.auth-footer{ margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border); }

/* App shell */
.app-body{ min-height:100%; }
.app-root{
  min-height: 100vh;
  display:flex;
  flex-direction: column;
}

.topbar{
  position: sticky;
  top:0;
  z-index: 15;
  background: var(--panel);
  border-bottom: 1px solid color-mix(in srgb, var(--glass-border) 62%, transparent);
}
.topbar-inner{
  max-width: var(--maxW);
  margin: 0 auto;
  padding: 12px 16px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 14px;
  border-bottom: 1px solid color-mix(in srgb, var(--glass-border) 42%, transparent);
}
.topbar-left{ display:flex; align-items:center; gap: 12px; min-width: 0; flex: 1 1 auto; }
.topbar-logo{
  width: 52px;
  background:#fff;
  padding: 6px;
  border-radius: 14px;
  box-shadow: 0 10px 22px rgba(10,20,42,.12);
}
.topbar-title{ display:flex; flex-direction:column; min-width: 0; }
.topbar-title strong{ font-size: 16px; white-space: nowrap; overflow:hidden; text-overflow: ellipsis; }
.topbar-title span{ font-size: 12px; color: var(--muted); white-space: nowrap; overflow:hidden; text-overflow: ellipsis; }
.topbar-right{
  display:flex;
  gap: 8px;
  align-items:center;
  flex-wrap: nowrap;
  justify-content: flex-end;
  flex: 0 0 auto;
}
.topbar-action-btn,
.notif-bell.btn{
  padding: 0;
  min-width: 48px;
  width: 48px;
  height: 48px;
  border-radius: 999px;
}
.topbar-menu-btn{
  flex: 0 0 auto;
}
.notif-bell{ position: relative; }
.notif-dot{
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #ef4444;
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
}
.chip{
  font-size: 12px;
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(255,255,255,.04);
  max-width: 280px;
  overflow:hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
@media (max-width: 980px){
  .topbar-inner{
    padding: 10px 12px;
    gap: 10px;
  }
  .topbar-logo{
    width: 44px;
    border-radius: 12px;
  }
  .topbar-right .chip:last-of-type{
    display: none;
  }
}
@media (max-width: 640px){
  .topbar-right .chip{
    display: none;
  }
  .topbar-title strong{
    font-size: 15px;
  }
  .topbar-title span{
    font-size: 11px;
  }
}

#verifyResult .verify-details-row > *{
  flex: 1 1 100%;
}

#verifyResult .verify-detail-chip{
  max-width: none;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  border-radius: 14px;
}

#verifyResult .verify-link{
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* Layout with sidebar (desktop) */
.shell{
  max-width: var(--maxW);
  width:100%;
  margin: 0 auto;
  display:grid;
  grid-template-columns: var(--sidebarW) 1fr;
  gap: 14px;
  padding: 14px 16px 22px;
}
@media (max-width: 980px){
  .shell{ grid-template-columns: 1fr; padding-bottom: 22px; }
}

/* Sidebar */
.sidebar{
  background: var(--panel);
  border: 1px solid color-mix(in srgb, var(--glass-border) 72%, transparent);
  border-radius: var(--radius2);
  padding: 12px;
  height: fit-content;
  position: sticky;
  top: 84px;
}
@media (max-width: 980px){
  .sidebar{ display:none; }
}

.nav-title{
  font-weight: 800;
  margin: 4px 6px 10px;
  font-size: 13px;
  color: var(--muted);
}
.nav-btn{
  width:100%;
  text-align:left;
  display:flex;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 10px 10px 14px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  cursor:pointer;
  font-weight: 650;
  position: relative;
  overflow: hidden;
  transition: background-color .2s ease, border-color .2s ease, transform .15s ease;
}
.nav-btn::before{
  content: "";
  position: absolute;
  left: 6px;
  top: 50%;
  width: 3px;
  height: 64%;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 82%, white 18%);
  box-shadow: 0 0 10px color-mix(in srgb, var(--accent) 44%, transparent);
  transform: translateY(-50%) scaleY(.35);
  opacity: 0;
  transition: transform .2s ease, opacity .2s ease;
}
.nav-btn:hover{ background: color-mix(in srgb, var(--glass-bg) 66%, transparent); transform: translateX(1px); }
.nav-btn.active{
  border-color: color-mix(in srgb, var(--accent) 45%, var(--glass-border) 55%);
  background: color-mix(in srgb, var(--accent) 17%, var(--glass-bg) 83%);
}
.nav-btn.active::before{
  opacity: 1;
  transform: translateY(-50%) scaleY(1);
}

/* Content */
.content{
  background: var(--panel);
  border: 1px solid color-mix(in srgb, var(--glass-border) 72%, transparent);
  border-radius: var(--radius2);
  padding: var(--space-5);
  min-height: 520px;
}
.card{
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4);
  transition: transform .22s ease, box-shadow .24s ease, border-color .22s ease, background-color .22s ease;
}
@media (hover: hover){
  .card:hover{
    transform: translateY(-2px);
    box-shadow: 0 18px 36px rgba(6,16,38,.24);
    border-color: color-mix(in srgb, var(--glass-border) 86%, white 14%);
  }
}
.card + .card{ margin-top: var(--space-3); }

.h2{ margin: 0 0 var(--space-3); font-size: 20px; font-weight: 650; }
.h3{ margin: 0 0 10px; font-size: 16px; color: var(--muted); font-weight: 600; }

.table{
  width:100%;
  border-collapse: collapse;
  font-size: 13px;
}
.table th,.table td{
  border-bottom: 1px solid var(--border);
  padding: 10px 6px;
  text-align:left;
  vertical-align: top;
}
.table th{ color: var(--muted); font-weight: 800; }
.table tbody tr{ transition: background-color .2s ease; }
.table tbody tr:hover{ background: color-mix(in srgb, var(--glass-subtle-bg) 78%, transparent); }

.student-cell{ min-width: 150px; }
.student-id-line{
  font-weight: 700;
  line-height: 1.3;
  word-break: break-word;
}
.student-name-line{
  margin-top: 4px;
  line-height: 1.35;
  word-break: break-word;
}

.kpi-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
@media (max-width: 980px){
  .kpi-grid{ grid-template-columns: repeat(2, 1fr); }
}
.kpi{
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
}
.kpi .k{ color: var(--muted); font-size: 12px; font-weight: 800; }
.kpi .v{ font-size: 18px; font-weight: 900; margin-top: 6px; }

.seg{
  display:flex;
  gap: 6px;
  background: color-mix(in srgb, var(--glass-subtle-bg) 78%, transparent);
  border: 1px solid var(--border);
  padding: 4px;
  border-radius: 999px;
}
.seg button{
  border: 0;
  background: transparent;
  color: var(--muted);
  border-radius: 999px;
  padding: 6px 10px;
  font-weight: 900;
  cursor: pointer;
}
.seg button.active{
  background: rgba(43,107,255,.16);
  color: var(--text);
}

.kpi-delta{ font-size: 11px; font-weight: 900; margin-top: 8px; }
.kpi-delta.pos{ color: #34d399; }
.kpi-delta.neg{ color: #f87171; }

.work-queue{ display:grid; gap:8px; margin-top: 10px; }
.work-queue-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
  border:1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  text-decoration:none;
  color: inherit;
}

.heatmap{
  margin-top: 10px;
  display:grid;
  grid-template-columns: repeat(6, minmax(64px, 1fr));
  gap: 8px;
}
.heatmap-cell{
  border:1px solid var(--border);
  border-radius: 8px;
  padding: 10px 6px;
  text-align:center;
  font-size: 11px;
  font-weight: 900;
}
.heatmap-cell.l0{ background: rgba(255,255,255,.03); }
.heatmap-cell.l1{ background: rgba(251,191,36,.18); }
.heatmap-cell.l2{ background: rgba(245,158,11,.22); }
.heatmap-cell.l3{ background: rgba(52,211,153,.2); }
.heatmap-cell.l4{ background: rgba(16,185,129,.28); }

.hr{ height:1px; background: var(--border); margin: 14px 0; }
.sidebar .nav-title{
  padding-bottom: 8px;
  border-bottom: 1px solid color-mix(in srgb, var(--glass-border) 36%, transparent);
}

.sidebar .nav-btn + .nav-btn{
  margin-top: 6px;
}


.bottom-nav{
  display:none !important;
}

/* Modal */
.modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 100;
  display:grid;
  place-items:center;
  padding: 18px;
  animation: modal-fade-in .22s ease;
}
.modal{
  width: min(760px, 100%);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  overflow:hidden;
  animation: modal-slide-up .24s cubic-bezier(.2,.8,.2,1);
}
@keyframes modal-fade-in{
  from{ opacity: 0; }
  to{ opacity: 1; }
}
@keyframes modal-slide-up{
  from{ opacity: 0; transform: translateY(10px) scale(.985); }
  to{ opacity: 1; transform: translateY(0) scale(1); }
}
.modal-head{
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.modal-head strong{ font-size: 14px; }
.modal-body{ padding: 14px; max-height: 70vh; overflow:auto; }
.modal-actions{ padding: 12px 14px; border-top: 1px solid var(--border); display:flex; justify-content:flex-end; gap: 10px; }
.workspace-menu-modal{
  width: min(560px, 100%);
  border-radius: 32px;
  overflow: hidden;
}
.workspace-menu-modal .modal-head{
  padding: 14px 16px;
}
.workspace-menu-modal .modal-head .btn{
  width: 44px;
  height: 44px;
  min-width: 44px;
  padding: 0;
  border-radius: 999px;
}
.workspace-menu-body{
  padding-top: 10px;
}
.workspace-menu-panel{
  display: grid;
  gap: 14px;
}
.workspace-menu-intro{
  display: grid;
  gap: 6px;
}
.workspace-menu-label{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
}
.workspace-menu-brand{
  display: grid;
  gap: 3px;
}
.workspace-menu-brand strong{
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.04em;
}
.workspace-menu-brand span{
  color: var(--muted);
  font-size: 13px;
}
.workspace-menu-meta{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.workspace-menu-search-input{
  margin-top: 2px;
}
.workspace-menu-list{
  display: grid;
  gap: 10px;
}
.workspace-menu-item{
  width: 100%;
  text-align: left;
  border: 1px solid color-mix(in srgb, var(--glass-border) 80%, transparent);
  border-radius: 22px;
  padding: 16px 18px;
  background: color-mix(in srgb, var(--glass-bg) 92%, transparent);
  color: var(--text);
  cursor: pointer;
  transition: transform .14s ease, border-color .2s ease, background-color .2s ease, box-shadow .2s ease;
}
.workspace-menu-item:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 42%, var(--glass-border) 58%);
  box-shadow: 0 14px 28px rgba(8,18,38,.12);
}
.workspace-menu-item.active{
  border-color: color-mix(in srgb, var(--accent) 48%, var(--glass-border) 52%);
  background: color-mix(in srgb, var(--accent) 10%, var(--glass-bg) 90%);
}
.workspace-menu-item-copy{
  display: grid;
  gap: 4px;
}
.workspace-menu-item-copy strong{
  font-size: 16px;
}
.workspace-menu-item-copy span{
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.workspace-menu-empty{
  border: 1px dashed var(--border);
  border-radius: 20px;
  padding: 18px;
  color: var(--muted);
  text-align: center;
}
@media (max-width: 540px){
  .workspace-menu-modal{
    width: min(100%, 100%);
    border-radius: 28px;
  }
  .workspace-menu-brand strong{
    font-size: 22px;
  }
}

/* Print helpers */
.print-area{ background: #fff; color:#000; padding: 12px; border-radius: 8px; }


/* Glassy surface upgrades (minimal overrides) */
.auth-card,
.card,
.kpi,
.kpi2,
.chart-card,
.menu-card,
.announce-item,
.driver-item,
.simple-item,
.palette,
.modal,
.table{
  background: var(--glass-bg);
  border-color: var(--glass-border);
  box-shadow: var(--glass-shadow);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(130%);
  backdrop-filter: blur(var(--glass-blur)) saturate(130%);
}

.bottom-nav,
.menu-search,
.palette-head,
.palette-meta,
.modal-head,
.modal-actions{
  background: color-mix(in srgb, var(--glass-bg) 82%, transparent);
}

.topbar,
.sidebar,
.content{
  background: var(--panel);
}

.table th,
.table td,
.modal-head,
.modal-actions,
.palette-head,
.palette-meta,
.palette-item{
  border-color: color-mix(in srgb, var(--glass-border) 65%, transparent);
}

.h3,
.table th,
.brand-title .app-subtitle,
.topbar-title span,
.nav-title,
.palette-meta,
.auto-refresh,
.muted{
  color: var(--text-1);
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))){
  .glass,
  .glass-subtle,
  .glass-strong,
  .auth-card,
  .card,
  .kpi,
  .kpi2,
  .chart-card,
  .menu-card,
  .announce-item,
  .driver-item,
  .simple-item,
  .palette,
  .modal,
  .table{
    background: color-mix(in srgb, var(--glass-subtle-bg) 92%, var(--surface-0) 8%);
    border: 1px solid color-mix(in srgb, var(--glass-border) 72%, rgba(0,0,0,.12));
    box-shadow: 0 8px 22px rgba(0,0,0,.16);
  }
}


/* ================================
   Mobile upgrades (2026-02) 
   - "Today" cards
   - Quick actions
   - Touch ergonomics
================================ */

:where(button, .btn, .nav-btn){
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

:focus-visible{
  outline: 2px solid rgba(43,107,255,.70);
  outline-offset: 2px;
}

/* Slightly larger tap targets on phones */
@media (max-width: 540px){
  .content{ padding: 12px; }
  .card{ padding: 14px; }
  .btn{ padding: 13px 14px; border-radius: 14px; }
  .nav-btn{ padding: 12px 12px; }
  .chip{ max-width: 220px; }
  .kpi .v{ font-size: 20px; }
  .kpi-grid{ grid-template-columns: 1fr; }
}

/* Dashboard: Today header + hero */
.today-row{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.today-row .today-title{
  display:flex;
  flex-direction:column;
  gap: 2px;
  min-width: 0;
}
.today-row .today-title strong{
  font-size: 16px;
  letter-spacing: .2px;
}
.today-row .today-title span{
  font-size: 12px;
  color: var(--muted);
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--muted);
  background: rgba(255,255,255,.04);
}
.pill.ok{
  border-color: rgba(31,201,107,.45);
  background: rgba(31,201,107,.14);
  color: var(--text);
}
.pill.warn{
  border-color: rgba(255,176,32,.45);
  background: rgba(255,176,32,.14);
  color: var(--text);
}
.pill.danger{
  border-color: rgba(255,77,77,.45);
  background: rgba(255,77,77,.14);
  color: var(--text);
}

.card.hero{
  position: relative;
  overflow: hidden;
  border-color: rgba(43,107,255,.28);
  background:
    radial-gradient(1200px 300px at 0% 0%, rgba(43,107,255,.25), transparent 55%),
    radial-gradient(800px 260px at 100% 0%, rgba(31,201,107,.14), transparent 55%),
    rgba(255,255,255,.04);
}
.card.hero::after{
  content:"";
  position:absolute;
  right:-60px;
  top:-70px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  transform: rotate(12deg);
}

/* Quick actions */
.qa-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
@media (max-width: 980px){
  .qa-grid{ grid-template-columns: repeat(2, 1fr); }
}
.qa-btn{
  width:100%;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  cursor:pointer;
  font-weight: 900;
}
.qa-btn:hover{ filter: brightness(1.05); transform: translateY(-1px); }
.qa-btn:active{ transform: scale(.98); }
.qa-left{ display:flex; align-items:center; gap: 10px; min-width: 0; }
.qa-icon{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display:grid;
  place-items:center;
  background: rgba(43,107,255,.16);
  border: 1px solid rgba(43,107,255,.22);
  flex: 0 0 auto;
  font-size: 18px;
}
.qa-text{ min-width: 0; display:flex; flex-direction:column; gap: 2px; text-align:left; }
.qa-text .qa-title{ font-size: 13px; white-space: nowrap; overflow:hidden; text-overflow: ellipsis; }
.qa-text .qa-sub{ font-size: 11px; color: var(--muted); font-weight: 800; white-space: nowrap; overflow:hidden; text-overflow: ellipsis; }
.qa-arrow{ color: var(--muted); font-weight: 900; }

/* "More" page menu cards */
.menu-search{
  position: sticky;
  top: 0;
  background: var(--panel);
  padding: 0 0 12px;
  z-index: 2;
}
.menu-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
@media (max-width: 980px){
  .menu-grid{ grid-template-columns: repeat(2, 1fr); }
}
.menu-card{
  width:100%;
  text-align:left;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  border-radius: var(--radius);
  padding: 12px;
  cursor:pointer;
  font-weight: 900;
}
.menu-card:hover{ filter: brightness(1.05); transform: translateY(-1px); }
.menu-card:active{ transform: scale(.98); }
.menu-card .t{ font-size: 13px; margin: 0 0 4px; }
.menu-card .d{ font-size: 11px; color: var(--muted); font-weight: 800; margin:0; }

/* Nicer lists inside cards */
.card ul{
  margin: 10px 0 0;
  padding-left: 18px;
}
.card li{ margin: 6px 0; }



/* ================================
   Reports / Analytics UI
   (mobile-first filters + charts)
================================ */

.report-section{ margin-top: 12px; }

.report-toolbar .filter-row{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 10px;
}
.report-toolbar .filter-item{
  flex: 1 1 170px;
  min-width: 160px;
}
.report-toolbar .filter-label{
  font-size: 11px;
  color: var(--muted);
  font-weight: 900;
  margin: 0 0 6px;
}
.chip-row{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
}
.chip-btn{
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  border-radius: 999px;
  padding: 8px 10px;
  font-weight: 950;
  cursor:pointer;
  user-select:none;
}
.chip-btn:hover{ filter: brightness(1.06); }
.chip-btn:active{ transform: translateY(1px); }
.chip-btn.active{
  border-color: rgba(43,107,255,.42);
  background: rgba(43,107,255,.16);
}

.toolbar-actions{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  align-items:center;
  margin-top: 12px;
}
.auto-refresh{
  display:flex;
  align-items:center;
  gap: 8px;
  color: var(--muted);
  font-weight: 900;
}
.auto-refresh input{
  width: 18px;
  height: 18px;
}

.segmented{
  display:flex;
  flex-wrap:wrap;
  gap: 8px;
}
.seg-btn{
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 12px;
  font-weight: 950;
  cursor:pointer;
}
.seg-btn:hover{ filter: brightness(1.06); }
.seg-btn:active{ transform: translateY(1px); }
.seg-btn.active{
  border-color: rgba(43,107,255,.42);
  background: rgba(43,107,255,.16);
}

.kpi2-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-top: 10px;
}
@media (max-width: 980px){
  .kpi2-grid{ grid-template-columns: repeat(2, 1fr); }
}
.kpi2{
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  border-radius: var(--radius);
  padding: 12px;
}
.kpi2.clickable{ cursor:pointer; }
.kpi2.clickable:hover{ filter: brightness(1.06); }
.kpi2-label{
  font-size: 11px;
  color: var(--muted);
  font-weight: 950;
}
.kpi2-value{
  font-size: 18px;
  font-weight: 1000;
  margin-top: 4px;
}
.kpi2-deltas{
  display:flex;
  flex-wrap:wrap;
  gap: 6px;
  margin-top: 10px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  font-size: 11px;
  font-weight: 950;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.06);
  color: var(--text);
  white-space: nowrap;
}
.badge.ok{
  border-color: rgba(31,201,107,.35);
  background: rgba(31,201,107,.12);
}
.badge.danger{
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.12);
}
.badge.warn{
  border-color: rgba(245,158,11,.35);
  background: rgba(245,158,11,.12);
}

.report-grid2{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 12px;
}
@media (max-width: 980px){
  .report-grid2{ grid-template-columns: 1fr; }
}

/* Charts */
.chart-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 12px;
}
@media (max-width: 980px){
  .chart-grid{ grid-template-columns: 1fr; }
}
.chart-card{
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: 12px;
}
.chart-head{
  display:flex;
  align-items:baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.chart-title{ font-weight: 1000; }
.chart-body{ width: 100%; overflow:hidden; }
.chart{
  width: 100%;
  height: 260px;
  touch-action: manipulation;
  user-select:none;
}
.chart-gridline{
  stroke: rgba(255,255,255,.12);
  stroke-width: 1;
}
.chart-xlab{
  fill: rgba(255,255,255,.55);
  font-size: 12px;
  font-weight: 900;
}
.chart-line{
  fill: none;
  stroke: rgba(43,107,255,.9);
  stroke-width: 3;
}
.chart-line.s1{ stroke: rgba(31,201,107,.85); }
.chart-line.s2{ stroke: rgba(245,158,11,.85); }
.chart-line.dashed{
  stroke-dasharray: 6 6;
  opacity: .85;
}
.chart-area{
  fill: rgba(43,107,255,.16);
  stroke: none;
}
.chart-dot{
  fill: rgba(43,107,255,.95);
  stroke: rgba(255,255,255,.9);
  stroke-width: 1;
  cursor:pointer;
}
.chart-dot.s1{ fill: rgba(31,201,107,.9); }
.chart-dot.s2{ fill: rgba(245,158,11,.9); }

.chart-bar{ fill: rgba(43,107,255,.8); }
.chart-bar.s1{ fill: rgba(31,201,107,.75); }
.chart-bar.s2{ fill: rgba(239,68,68,.62); }
.chart-bar.neg{ opacity: .85; }
.chart-hit{ fill: transparent; cursor:pointer; }

/* Donut */
.donut-bg{ stroke: rgba(255,255,255,.10); }
.donut-slice{
  stroke: rgba(43,107,255,.85);
  cursor:pointer;
  transform-origin: 150px 130px;
  transform: rotate(-90deg);
}
.donut-slice.s1{ stroke: rgba(31,201,107,.85); }
.donut-slice.s2{ stroke: rgba(245,158,11,.85); }
.donut-slice.s3{ stroke: rgba(239,68,68,.85); }
.donut-slice.s4{ stroke: rgba(168,85,247,.85); }
.donut-slice.s5{ stroke: rgba(14,165,233,.85); }
.donut-slice.s6{ stroke: rgba(244,114,182,.85); }
.donut-slice.s7{ stroke: rgba(234,179,8,.85); }

.donut-center{ fill: rgba(255,255,255,.65); font-size: 12px; font-weight: 950; }
.donut-center.big{ fill: rgba(255,255,255,.92); font-size: 18px; font-weight: 1000; }

.donut-legend{ cursor:pointer; }
.donut-swatch{ fill: rgba(43,107,255,.85); }
.donut-swatch.s1{ fill: rgba(31,201,107,.85); }
.donut-swatch.s2{ fill: rgba(245,158,11,.85); }
.donut-swatch.s3{ fill: rgba(239,68,68,.85); }
.donut-swatch.s4{ fill: rgba(168,85,247,.85); }
.donut-swatch.s5{ fill: rgba(14,165,233,.85); }
.donut-swatch.s6{ fill: rgba(244,114,182,.85); }
.donut-swatch.s7{ fill: rgba(234,179,8,.85); }
.donut-label{ fill: rgba(255,255,255,.72); font-size: 12px; font-weight: 900; }

/* Drill + lists */
.driver-list{
  display:flex;
  flex-direction:column;
  gap: 8px;
  margin-top: 10px;
}
.driver-item{
  width: 100%;
  text-align:left;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  border-radius: var(--radius);
  padding: 10px 12px;
  display:flex;
  justify-content: space-between;
  gap: 10px;
  cursor:pointer;
}
.driver-item:hover{ filter: brightness(1.06); }
.driver-item:active{ transform: translateY(1px); }
.driver-left{ min-width: 0; }
.driver-title{
  font-weight: 1000;
  font-size: 13px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.driver-sub{
  font-size: 11px;
  color: var(--muted);
  font-weight: 900;
  margin-top: 2px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.driver-right{ font-weight: 1000; }

.table.compact th,
.table.compact td{
  padding: 8px 10px;
  font-size: 12px;
}
.click-row{ cursor:pointer; }
.click-row:hover{ background: rgba(255,255,255,.04); }

.id-cell{
  display:flex;
  align-items:center;
  gap: 8px;
}

.btn.small{
  padding: 8px 10px;
  font-size: 12px;
}
.btn.ghost{
  background: transparent;
  border-color: rgba(255,255,255,.18);
}
.btn.ghost:hover{
  background: rgba(255,255,255,.06);
}

.simple-list{
  display:flex;
  flex-direction:column;
  gap: 10px;
  margin-top: 10px;
}
.simple-item{
  display:flex;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
}
.simple-left{ min-width: 0; }
.simple-title{ font-weight: 1000; font-size: 13px; }
.simple-sub{
  font-size: 11px;
  color: var(--muted);
  font-weight: 900;
  margin-top: 2px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.simple-right{ font-weight: 1000; white-space: nowrap; }


/* ================================
   Modern Navigation Enhancements
   - Favorites / Recents
   - Command Palette (Ctrl/⌘+K)
================================ */

.kbd{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  font-size: 11px;
  font-weight: 900;
  color: var(--muted);
  border: 1px solid var(--border);
  border-bottom-width: 2px;
  border-radius: 10px;
  padding: 6px 10px;
  background: rgba(255,255,255,.04);
}

.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 1000;
  color: var(--text);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.06);
}

/* Favorites pin button on menu cards */
.menu-card{
  position: relative;
}
.pin-btn{
  position: absolute;
  top: 10px;
  right: 10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  cursor:pointer;
  font-size: 16px;
}
.pin-btn:hover{ filter: brightness(1.07); }
.menu-card.pinned{
  border-color: rgba(43,107,255,.35);
  background: rgba(43,107,255,.10);
}

/* Recents as chips */
.recent-row{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.recent-chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text);
  font-weight: 900;
  cursor:pointer;
  font-size: 12px;
}
.recent-chip:hover{ filter: brightness(1.06); }

/* Command palette overlay */
.palette-backdrop{
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(0,0,0,.55);
  display:grid;
  place-items: start center;
  padding: 18px;
}
.palette{
  width: min(920px, 100%);
  margin-top: 8vh;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.palette-head{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 12px;
  border-bottom: 1px solid var(--border);
}
.palette-input{
  flex: 1 1 auto;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel2);
  color: var(--text);
  outline:none;
  font-weight: 900;
}
.palette-meta{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}
.palette-list{
  max-height: min(54vh, 520px);
  overflow:auto;
}
.palette-item{
  width:100%;
  text-align:left;
  padding: 12px 12px;
  border: 0;
  border-bottom: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  cursor:pointer;
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 10px;
}
.palette-item:hover{ background: rgba(255,255,255,.04); }
.palette-item.active{ background: rgba(43,107,255,.14); }
.palette-item .pi-left{ min-width:0; }
.palette-item .pi-title{ font-weight: 1000; font-size: 13px; }
.palette-item .pi-sub{
  font-weight: 800;
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.palette-item .pi-right{
  font-weight: 1000;
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
}

/* Mobile sizing */
@media (max-width: 540px){
  .palette{ margin-top: 4vh; }
  .palette-input{ padding: 13px 12px; font-size: 14px; }
  .pin-btn{ width: 38px; height: 38px; border-radius: 14px; }
}


/* ================================
   Announcements
================================ */

.announce-list{
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
}
.announce-item{
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
}
.announce-top{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 10px;
}
.announce-title{
  font-weight: 1000;
  font-size: 14px;
  margin: 0;
}
.announce-meta{
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
  margin-top: 4px;
}
.announce-body{
  margin-top: 10px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.45;
  white-space: pre-wrap;
}
.tag-row{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.tag{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  font-size: 11px;
  font-weight: 900;
  color: var(--muted);
}
.tag.ok{ border-color: rgba(31,201,107,.45); color: var(--text); background: rgba(31,201,107,.14); }
.tag.warn{ border-color: rgba(255,176,32,.45); color: var(--text); background: rgba(255,176,32,.14); }
.tag.primary{ border-color: rgba(43,107,255,.45); color: var(--text); background: rgba(43,107,255,.14); }



/* Toggle switch (Admin > More) */
.switch{
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
}
.switch input{
  opacity: 0;
  width: 0;
  height: 0;
}
.switch .slider{
  position: absolute;
  cursor: pointer;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.20);
  transition: .2s;
  border-radius: 999px;
}
.switch .slider:before{
  position: absolute;
  content: "";
  height: 18px;
  width: 18px;
  left: 3px;
  top: 50%;
  transform: translateY(-50%);
  background: #fff;
  transition: .2s;
  border-radius: 50%;
}
.switch input:checked + .slider{
  background: rgba(43,107,255,.45);
  border-color: rgba(43,107,255,.60);
}
.switch input:checked + .slider:before{
  transform: translate(20px, -50%);
}


.skeleton{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  background: linear-gradient(100deg, rgba(255,255,255,.08) 30%, rgba(255,255,255,.18) 45%, rgba(255,255,255,.08) 60%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.2s linear infinite;
}
.skeleton.text,
.skeleton-line{ height: 12px; border-radius: 999px; }
.skeleton.text.lg{ height: 18px; }
.skeleton.block,
.skeleton-box{ height: 120px; }
@keyframes skeleton-shimmer{
  from{ background-position: 200% 0; }
  to{ background-position: -200% 0; }
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  .modal, .modal-backdrop, .skeleton{
    animation: none !important;
  }
  .card:hover, .btn:hover, .qa-btn:hover, .menu-card:hover{
    transform: none !important;
  }
}

/* Dashboard widgets (range, sparkline, activity) */
.seg{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 4px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255,255,255,.04);
}
.seg button{
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-weight: 900;
  padding: 7px 11px;
  cursor: pointer;
}
.seg button.active{
  background: rgba(43,107,255,.16);
  color: var(--text);
}

.spark{
  margin-top: 8px;
  height: 26px;
  color: rgba(43,107,255,.95);
}
.spark svg{
  width: 100%;
  height: 100%;
  display:block;
}

.activity-item{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  color: var(--text);
  background: rgba(255,255,255,.03);
}
.activity-icon{
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display:grid;
  place-items:center;
  background: rgba(43,107,255,.14);
  border: 1px solid rgba(43,107,255,.25);
}
.activity-main{ min-width: 0; }

.skip-link{
  position: absolute;
  left: 10px;
  top: -44px;
  z-index: 9999;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--border);
  transition: top .15s ease;
}
.skip-link:focus{ top: 10px; }

:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.chip--pending{ border-color: rgba(255,176,32,.45); color: var(--warning); }
.chip--approved{ border-color: rgba(31,201,107,.45); color: var(--ok); }
.chip--rejected{ border-color: rgba(255,77,77,.45); color: var(--danger); }
.chip--overdue{ border-color: rgba(255,77,77,.45); color: var(--danger); }
.chip--softlock{ border-color: rgba(122,162,255,.45); color: var(--accent); }

.table-wrap{
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 12px;
  max-height: 62vh;
}
.table thead th{
  position: sticky;
  top: 0;
  z-index: 1;
  background: color-mix(in srgb, var(--panel) 92%, transparent);
}
.table tr:nth-child(even){
  background: color-mix(in srgb, var(--panel2) 35%, transparent);
}
.density-compact .table th,
.density-compact .table td{
  padding-top: 7px;
  padding-bottom: 7px;
  font-size: 12px;
}

.empty-state{ text-align: center; }
.empty-ic{ font-size: 28px; margin-bottom: 8px; }

/* Student home (Today) */
.home-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.card-row{
  display:flex;
  flex-wrap: wrap;
  align-items:center;
  gap: 8px;
  margin-top: 8px;
}
.meter{
  width: 100%;
  height: 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--panel2) 65%, transparent);
  border: 1px solid var(--border);
  overflow: hidden;
  margin: 10px 0 6px;
}
.meter-bar{
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--ok));
}
@media (min-width: 980px){
  .home-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.next-class-actions{
  margin-top: 10px;
}
.next-class-actions .btn{
  min-height: 38px;
}
.reminder-row .input{
  padding: 8px 10px;
  min-height: 36px;
}
.reminder-row input[type="checkbox"]{
  width: 18px;
  height: 18px;
}
.student-photo{
  flex: 0 0 auto;
  width: 72px;
  height: 72px;
  border-radius: 18px;
  object-fit: cover;
  border: 1px solid var(--divider, var(--border));
  background: color-mix(in srgb, var(--panel2) 55%, transparent);
  box-shadow: 0 10px 24px rgba(6,16,38,.14);
}
.student-photo--sm{
  width: 56px;
  height: 56px;
  border-radius: 14px;
}
.student-photo--md{
  width: 72px;
  height: 72px;
}
.student-photo--lg{
  width: 96px;
  height: 96px;
  border-radius: 22px;
}
.student-photo--placeholder{
  display: grid;
  place-items: center;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent) 24%, var(--panel2)),
    color-mix(in srgb, var(--ok) 18%, var(--panel2))
  );
}
.student-profile-hero{
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.student-profile-hero{
  margin-bottom: 18px;
}
.student-home-hero{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}
.student-profile-copy{
  min-width: 0;
  flex: 1 1 240px;
}
.student-home-hero-copy{
  min-width: 0;
  width: 100%;
  flex: 0 1 auto;
}
.student-profile-name{
  display: block;
  font-size: 18px;
  font-weight: 700;
}
.student-profile-photo-note{
  margin-top: 6px;
}
.student-home-hero-copy .today-row{
  margin-bottom: 4px;
}
.student-home-id{
  margin-top: 6px;
}
.student-home-center-logo{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--border);
  object-fit: cover;
}
.verify-photo{
  width:72px;
  height:72px;
  border-radius:12px;
  object-fit:cover;
  border:1px solid var(--divider, var(--border));
  background: color-mix(in srgb, var(--panel2) 55%, transparent);
}
.verify-photo--placeholder{
  display:grid;
  place-items:center;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.verify-shell{
  width:min(1120px, 100%);
  margin:0 auto;
  padding:24px;
  display:grid;
  gap:16px;
}
.verify-hero{
  display:grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
  gap:16px;
  align-items:stretch;
}
.verify-hero-copy{
  display:grid;
  gap:10px;
  align-content:start;
}
.verify-lead{
  max-width: 60ch;
}
.verify-stat-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:10px;
}
.verify-stat-card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:14px;
  background: rgba(255,255,255,.05);
  display:grid;
  gap:6px;
}
.verify-stat-label{
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.verify-stat-value{
  font-size: 18px;
  font-weight: 1000;
}
.verify-stat-copy{
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
}
.verify-panel{
  display:grid;
  gap:14px;
}
.verify-form{
  display:grid;
  gap:12px;
}
.verify-form-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}
.verify-result-shell{
  display:grid;
  gap:14px;
}
.verify-message{
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:14px;
  background: rgba(255,255,255,.05);
}
.verify-message--pending{
  border-color: rgba(43,107,255,.35);
  background: rgba(43,107,255,.10);
}
.verify-message--success{
  border-color: rgba(31,201,107,.35);
  background: rgba(31,201,107,.10);
}
.verify-message--warn{
  border-color: rgba(255,176,32,.42);
  background: rgba(255,176,32,.12);
}
.verify-message--error{
  border-color: rgba(255,77,77,.42);
  background: rgba(255,77,77,.12);
}
.verify-identity{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
}
.verify-identity-copy{
  display:grid;
  gap:6px;
}
.verify-status-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.verify-detail-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
}
.verify-detail-card{
  border:1px solid var(--border);
  border-radius: var(--radius);
  padding:12px;
  background: rgba(255,255,255,.04);
  min-width: 0;
}
.verify-detail-label{
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.verify-detail-value{
  margin-top: 6px;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.45;
  word-break: break-word;
}
.verify-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.dashboard-split{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}
.tabbar{
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.feed{
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.feed-item{
  padding: 12px;
}
.feed-meta{
  font-size: 12px;
  color: var(--muted);
  margin-top: 4px;
}
.progress-map{
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.wallet-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.wallet-card{
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.wallet-actions{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}
.qr-box{
  width: fit-content;
  max-width: 100%;
  margin-top: 10px;
  padding: 10px;
}
.qr-box svg,
.qr-box canvas{
  width: 164px;
  height: 164px;
  display:block;
}
@media (min-width: 980px){
  .wallet-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 980px){
  .verify-hero,
  .verify-form-grid,
  .dashboard-split{
    grid-template-columns: 1fr;
  }

  .verify-detail-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 640px){
  .student-profile-hero,
  .student-home-hero{
    align-items: flex-start;
  }

  .verify-shell{
    padding:14px;
  }

  .verify-stat-grid,
  .verify-detail-grid{
    grid-template-columns: 1fr;
  }
}
.share-row{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.share-row .btn{
  min-height: 40px;
}

/* Instructor attendance */
.att-list{ display:grid; gap:10px; margin-top:10px; }
.att-row .row{ flex-wrap:wrap; }
.att-row .btn{ min-height:44px; min-width:92px; }
.session-sheet textarea.input{ width:100%; }
.att-row .today-row .btn{ min-height:40px; }
.sparkline{ font-size:22px; letter-spacing:1px; line-height:1; }

/* Certificates UX readability + stepper */
.certs-modern .muted{ opacity: 1; font-weight: 540; }
.cert-modal-overlay{ position:fixed; inset:0; background:rgba(0,0,0,.55); z-index:9999; display:flex; align-items:center; justify-content:center; padding:12px; }
.cert-modal{ max-width:860px; width:100%; max-height:90vh; overflow:auto; }
.cert-step{ padding:8px 10px; border-left:3px solid var(--line); color:var(--muted); font-weight:650; }
.cert-step--active{ border-left-color:var(--accent); color:var(--text); background:color-mix(in srgb, var(--accent) 10%, transparent); }
.cert-progress-label{ font-weight:700; color:var(--text); margin:10px 0; }
.cert-student-list{ max-height:180px; overflow:auto; color:var(--text); }
.cert-student-list li{ margin:4px 0; }
.cert-render-badge{ font-weight:700; cursor:pointer; }
.cert-render-badge.warn{ border-color: rgba(255,176,32,.55); color: var(--warning); }
.cert-render-badge.error{ border-color: rgba(255,77,77,.6); color: var(--danger); }
.cert-diag-panel .msg{ margin-bottom:8px; font-weight:650; }
:root[data-theme="dark"] .muted{ color:#cfd6ee; }
:root[data-theme="dark"] .table th{ color:#e3e9ff; }
:root[data-theme="dark"] .table td{ color:#f2f5ff; }
:root[data-theme="dark"] .small{ color:#d9e0ff; }

/* ================================
   Obsidian Ivory Theme
================================ */
:root:not([data-theme-preset]),
:root[data-theme-preset="obsidian-ivory"]{
  --bg-0: #0B0D10;
  --bg-1: #141922;
  --surface-1: #1D2430;
  --surface-2: #252E3D;

  --paper-1: #F4EFE6;
  --paper-2: #FBF8F2;
  --paper-3: #EFE7D8;

  --text-strong: #F7F2E9;
  --text-muted: #B9B2A5;
  --text-dark: #171411;
  --text-dark-soft: rgba(23,20,17,.68);

  --accent-premium: #C6A56A;
  --accent-premium-soft: #E7D6AF;
  --accent-center: #6E86FF;

  --success: #5C9C85;
  --warning: #D3A14C;
  --danger: #C96E6E;

  --border-soft: rgba(255,255,255,.08);
  --border-warm: rgba(198,165,106,.22);
  --line: rgba(198,165,106,.22);

  --radius: 20px;
  --radius2: 24px;
  --radius-12: 12px;
  --radius-16: 14px;
  --radius-20: 20px;

  --shadow-soft: 0 12px 36px rgba(0,0,0,.28);
  --shadow-lift: 0 18px 50px rgba(0,0,0,.34);

  --font: "Manrope", -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", Inter, system-ui, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
  --font-display: "Cormorant Garamond", "Playfair Display", "Fraunces", Georgia, serif;

  --surface-0: var(--bg-0);
  --glass-bg: rgba(20,25,34,.84);
  --glass-strong-bg: rgba(20,25,34,.92);
  --glass-subtle-bg: rgba(20,25,34,.74);
  --glass-border: rgba(255,255,255,.08);
  --glass-border-strong: rgba(198,165,106,.22);
  --glass-shadow: var(--shadow-soft);
  --shadow-1: var(--shadow-soft);
  --shadow-2: var(--shadow-lift);
  --shadow-3: 0 26px 72px rgba(0,0,0,.42);
  --blur-strong: 18px;
  --blur-subtle: 12px;

  --bg: radial-gradient(1000px 520px at 14% -8%, rgba(198,165,106,.14), transparent 58%),
        radial-gradient(900px 480px at 100% 0%, rgba(110,134,255,.12), transparent 52%),
        linear-gradient(180deg, #11151d 0%, #0b0d10 100%);
  --panel: rgba(20,25,34,.92);
  --panel2: rgba(37,46,61,.74);
  --text: var(--text-strong);
  --text-0: var(--text-strong);
  --text-1: var(--text-muted);
  --muted: var(--text-muted);
  --divider: var(--border-soft);
  --border: var(--border-soft);
  --accent: var(--accent-premium);
  --accent-2: rgba(198,165,106,.28);
  --primary: var(--accent-premium);
  --ok: var(--success);
  color-scheme: dark;
}

:root:not([data-theme-preset]) body,
:root[data-theme-preset="obsidian-ivory"] body{
  background: var(--bg);
  color: var(--text-strong);
}

:root:not([data-theme-preset]) .bg,
:root[data-theme-preset="obsidian-ivory"] .bg{
  background:
    radial-gradient(720px 360px at 16% 10%, rgba(198,165,106,.10), transparent 56%),
    radial-gradient(680px 320px at 100% 0%, rgba(110,134,255,.08), transparent 52%);
}

:root:not([data-theme-preset]) .auth-card,
:root[data-theme-preset="obsidian-ivory"] .auth-card{
  background: linear-gradient(180deg, rgba(251,248,242,.98) 0%, rgba(244,239,230,.96) 100%);
  border: 1px solid var(--border-warm);
  box-shadow: var(--shadow-lift);
  color: var(--text-dark);
}

:root:not([data-theme-preset]) .auth-card .label,
:root:not([data-theme-preset]) .auth-card .muted,
:root[data-theme-preset="obsidian-ivory"] .auth-card .label,
:root[data-theme-preset="obsidian-ivory"] .auth-card .muted{
  color: var(--text-dark-soft);
}

:root:not([data-theme-preset]) .brand-logo,
:root:not([data-theme-preset]) .topbar-logo,
:root[data-theme-preset="obsidian-ivory"] .brand-logo,
:root[data-theme-preset="obsidian-ivory"] .topbar-logo{
  background: linear-gradient(180deg, var(--paper-2) 0%, var(--paper-1) 100%);
  border: 1px solid rgba(23,20,17,.08);
  box-shadow: 0 14px 28px rgba(15,12,10,.12);
}

:root:not([data-theme-preset]) .brand-title .app-name,
:root:not([data-theme-preset]) .verify-hero .h1,
:root:not([data-theme-preset]) .verify-stat-value,
:root[data-theme-preset="obsidian-ivory"] .brand-title .app-name,
:root[data-theme-preset="obsidian-ivory"] .verify-hero .h1,
:root[data-theme-preset="obsidian-ivory"] .verify-stat-value{
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: .01em;
}

:root:not([data-theme-preset]) .brand-title .app-name,
:root[data-theme-preset="obsidian-ivory"] .brand-title .app-name{
  font-size: 28px;
  color: var(--text-dark);
}

:root:not([data-theme-preset]) .input,
:root:not([data-theme-preset]) select,
:root:not([data-theme-preset]) textarea,
:root[data-theme-preset="obsidian-ivory"] .input,
:root[data-theme-preset="obsidian-ivory"] select,
:root[data-theme-preset="obsidian-ivory"] textarea{
  background: rgba(255,255,255,.78);
  color: var(--text-dark);
  border-color: rgba(23,20,17,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72), 0 2px 12px rgba(9,8,6,.04);
}

:root:not([data-theme-preset]) .input:focus,
:root:not([data-theme-preset]) select:focus,
:root:not([data-theme-preset]) textarea:focus,
:root[data-theme-preset="obsidian-ivory"] .input:focus,
:root[data-theme-preset="obsidian-ivory"] select:focus,
:root[data-theme-preset="obsidian-ivory"] textarea:focus{
  border-color: rgba(198,165,106,.6);
  box-shadow: 0 0 0 3px rgba(198,165,106,.18), inset 0 1px 0 rgba(255,255,255,.8);
}

:root:not([data-theme-preset]) .btn,
:root[data-theme-preset="obsidian-ivory"] .btn{
  background: rgba(29,36,48,.04);
  color: var(--text-dark);
  border-color: rgba(23,20,17,.12);
}

:root:not([data-theme-preset]) .btn.primary,
:root[data-theme-preset="obsidian-ivory"] .btn.primary{
  background: linear-gradient(180deg, #d8bc8b 0%, var(--accent-premium) 100%);
  border-color: rgba(198,165,106,.62);
  color: var(--text-dark);
  box-shadow: 0 12px 24px rgba(198,165,106,.22);
}

:root:not([data-theme-preset]) .btn.primary:hover,
:root[data-theme-preset="obsidian-ivory"] .btn.primary:hover{
  box-shadow: 0 16px 28px rgba(198,165,106,.26);
}

:root:not([data-theme-preset]) .btn.danger,
:root[data-theme-preset="obsidian-ivory"] .btn.danger{
  border-color: rgba(201,110,110,.42);
  background: rgba(201,110,110,.12);
  color: #7b3333;
}

:root:not([data-theme-preset]) .topbar,
:root:not([data-theme-preset]) .sidebar,
:root[data-theme-preset="obsidian-ivory"] .topbar,
:root[data-theme-preset="obsidian-ivory"] .sidebar{
  background: linear-gradient(180deg, rgba(20,25,34,.96) 0%, rgba(11,13,16,.94) 100%);
  border-color: rgba(255,255,255,.06);
  box-shadow: 0 18px 40px rgba(0,0,0,.18);
}

:root:not([data-theme-preset]) .topbar-inner,
:root[data-theme-preset="obsidian-ivory"] .topbar-inner{
  border-bottom-color: rgba(255,255,255,.06);
}

:root:not([data-theme-preset]) .topbar-title strong,
:root[data-theme-preset="obsidian-ivory"] .topbar-title strong{
  color: var(--text-strong);
}

:root:not([data-theme-preset]) .topbar-title span,
:root:not([data-theme-preset]) .nav-title,
:root[data-theme-preset="obsidian-ivory"] .topbar-title span,
:root[data-theme-preset="obsidian-ivory"] .nav-title{
  color: rgba(247,242,233,.68);
}

:root:not([data-theme-preset]) .topbar .btn,
:root:not([data-theme-preset]) .sidebar .btn,
:root:not([data-theme-preset]) .topbar .icon-btn,
:root:not([data-theme-preset]) .sidebar .icon-btn,
:root[data-theme-preset="obsidian-ivory"] .topbar .btn,
:root[data-theme-preset="obsidian-ivory"] .sidebar .btn,
:root[data-theme-preset="obsidian-ivory"] .topbar .icon-btn,
:root[data-theme-preset="obsidian-ivory"] .sidebar .icon-btn{
  background: rgba(255,255,255,.05);
  color: var(--text-strong);
  border-color: rgba(255,255,255,.08);
  box-shadow: none;
}

:root:not([data-theme-preset]) .nav-btn,
:root[data-theme-preset="obsidian-ivory"] .nav-btn{
  color: var(--text-strong);
  border-radius: 18px;
}

:root:not([data-theme-preset]) .nav-btn::before,
:root[data-theme-preset="obsidian-ivory"] .nav-btn::before{
  left: 10px;
  width: 6px;
  background: var(--accent-premium);
  box-shadow: none;
}

:root:not([data-theme-preset]) .nav-btn:hover,
:root[data-theme-preset="obsidian-ivory"] .nav-btn:hover{
  background: rgba(255,255,255,.05);
  transform: translateX(0);
}

:root:not([data-theme-preset]) .nav-btn.active,
:root[data-theme-preset="obsidian-ivory"] .nav-btn.active{
  background: linear-gradient(90deg, rgba(198,165,106,.18) 0%, rgba(255,255,255,.05) 100%);
  border-color: rgba(198,165,106,.24);
}

:root:not([data-theme-preset]) .content,
:root[data-theme-preset="obsidian-ivory"] .content{
  background: linear-gradient(180deg, rgba(244,239,230,.98) 0%, rgba(251,248,242,.98) 100%);
  border-color: rgba(23,20,17,.08);
  color: var(--text-dark);
  box-shadow: 0 24px 60px rgba(0,0,0,.18);
}

:root:not([data-theme-preset]) .card,
:root:not([data-theme-preset]) .menu-card,
:root:not([data-theme-preset]) .announce-item,
:root:not([data-theme-preset]) .driver-item,
:root:not([data-theme-preset]) .simple-item,
:root:not([data-theme-preset]) .table,
:root:not([data-theme-preset]) .modal,
:root[data-theme-preset="obsidian-ivory"] .card,
:root[data-theme-preset="obsidian-ivory"] .menu-card,
:root[data-theme-preset="obsidian-ivory"] .announce-item,
:root[data-theme-preset="obsidian-ivory"] .driver-item,
:root[data-theme-preset="obsidian-ivory"] .simple-item,
:root[data-theme-preset="obsidian-ivory"] .table,
:root[data-theme-preset="obsidian-ivory"] .modal{
  background: rgba(255,251,245,.88);
  border-color: rgba(23,20,17,.08);
  box-shadow: 0 12px 30px rgba(9,8,6,.08);
  color: var(--text-dark);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

:root:not([data-theme-preset]) .content .muted,
:root:not([data-theme-preset]) .content .label,
:root:not([data-theme-preset]) .card .muted,
:root:not([data-theme-preset]) .card .label,
:root:not([data-theme-preset]) .table th,
:root:not([data-theme-preset]) .table td,
:root[data-theme-preset="obsidian-ivory"] .content .muted,
:root[data-theme-preset="obsidian-ivory"] .content .label,
:root[data-theme-preset="obsidian-ivory"] .card .muted,
:root[data-theme-preset="obsidian-ivory"] .card .label,
:root[data-theme-preset="obsidian-ivory"] .table th,
:root[data-theme-preset="obsidian-ivory"] .table td{
  color: var(--text-dark-soft);
  border-color: rgba(23,20,17,.08);
}

:root:not([data-theme-preset]) .card.hero,
:root:not([data-theme-preset]) .kpi,
:root:not([data-theme-preset]) .kpi2,
:root:not([data-theme-preset]) .chart-card,
:root[data-theme-preset="obsidian-ivory"] .card.hero,
:root[data-theme-preset="obsidian-ivory"] .kpi,
:root[data-theme-preset="obsidian-ivory"] .kpi2,
:root[data-theme-preset="obsidian-ivory"] .chart-card{
  background:
    radial-gradient(860px 240px at 0% 0%, rgba(198,165,106,.14), transparent 58%),
    linear-gradient(180deg, rgba(29,36,48,.98) 0%, rgba(20,25,34,.98) 100%);
  border-color: rgba(198,165,106,.22);
  color: var(--text-strong);
  box-shadow: var(--shadow-soft);
}

:root:not([data-theme-preset]) .card.hero .muted,
:root:not([data-theme-preset]) .kpi .muted,
:root:not([data-theme-preset]) .kpi2 .muted,
:root:not([data-theme-preset]) .chart-card .muted,
:root[data-theme-preset="obsidian-ivory"] .card.hero .muted,
:root[data-theme-preset="obsidian-ivory"] .kpi .muted,
:root[data-theme-preset="obsidian-ivory"] .kpi2 .muted,
:root[data-theme-preset="obsidian-ivory"] .chart-card .muted{
  color: rgba(247,242,233,.72);
}

:root:not([data-theme-preset]) .card.hero::after,
:root[data-theme-preset="obsidian-ivory"] .card.hero::after{
  background: radial-gradient(circle, rgba(231,214,175,.20) 0%, rgba(231,214,175,0) 68%);
}

:root:not([data-theme-preset]) .chip,
:root:not([data-theme-preset]) .pill,
:root[data-theme-preset="obsidian-ivory"] .chip,
:root[data-theme-preset="obsidian-ivory"] .pill{
  border-color: rgba(198,165,106,.22);
  background: rgba(198,165,106,.10);
  color: var(--text-dark);
}

:root:not([data-theme-preset]) .chip.ok,
:root:not([data-theme-preset]) .pill.ok,
:root[data-theme-preset="obsidian-ivory"] .chip.ok,
:root[data-theme-preset="obsidian-ivory"] .pill.ok{
  color: #1e4e3e;
  background: rgba(92,156,133,.16);
  border-color: rgba(92,156,133,.28);
}

:root:not([data-theme-preset]) .verify-shell,
:root[data-theme-preset="obsidian-ivory"] .verify-shell{
  padding-top: 32px;
  padding-bottom: 48px;
}

:root:not([data-theme-preset]) .verify-hero,
:root[data-theme-preset="obsidian-ivory"] .verify-hero{
  background:
    radial-gradient(720px 220px at 0% 0%, rgba(198,165,106,.14), transparent 60%),
    linear-gradient(180deg, rgba(20,25,34,.98) 0%, rgba(11,13,16,.96) 100%);
  border-color: rgba(198,165,106,.20);
  color: var(--text-strong);
}

:root:not([data-theme-preset]) .verify-hero .muted,
:root:not([data-theme-preset]) .verify-hero .verify-stat-copy,
:root:not([data-theme-preset]) .verify-hero .verify-stat-label,
:root[data-theme-preset="obsidian-ivory"] .verify-hero .muted,
:root[data-theme-preset="obsidian-ivory"] .verify-hero .verify-stat-copy,
:root[data-theme-preset="obsidian-ivory"] .verify-hero .verify-stat-label{
  color: rgba(247,242,233,.72);
}

:root:not([data-theme-preset]) .verify-stat-card,
:root[data-theme-preset="obsidian-ivory"] .verify-stat-card{
  background: rgba(251,248,242,.08);
  border-color: rgba(198,165,106,.18);
}

:root:not([data-theme-preset]) .verify-panel,
:root[data-theme-preset="obsidian-ivory"] .verify-panel{
  background: linear-gradient(180deg, rgba(251,248,242,.98) 0%, rgba(244,239,230,.98) 100%);
  border-color: rgba(198,165,106,.18);
  color: var(--text-dark);
}

:root:not([data-theme-preset]) .verify-panel .muted,
:root:not([data-theme-preset]) .verify-panel .label,
:root[data-theme-preset="obsidian-ivory"] .verify-panel .muted,
:root[data-theme-preset="obsidian-ivory"] .verify-panel .label{
  color: var(--text-dark-soft);
}

:root:not([data-theme-preset]) .verify-message,
:root[data-theme-preset="obsidian-ivory"] .verify-message{
  background: rgba(255,255,255,.56);
  border-color: rgba(198,165,106,.16);
}

:root:not([data-theme-preset]) .cert-modal,
:root:not([data-theme-preset]) .certs-modern .card,
:root[data-theme-preset="obsidian-ivory"] .cert-modal,
:root[data-theme-preset="obsidian-ivory"] .certs-modern .card{
  background: linear-gradient(180deg, rgba(251,248,242,.99) 0%, rgba(244,239,230,.99) 100%);
  border-color: rgba(198,165,106,.22);
  color: var(--text-dark);
}

:root:not([data-theme-preset]) .cert-modal .muted,
:root:not([data-theme-preset]) .certs-modern .muted,
:root[data-theme-preset="obsidian-ivory"] .cert-modal .muted,
:root[data-theme-preset="obsidian-ivory"] .certs-modern .muted{
  color: var(--text-dark-soft);
}

:root:not([data-theme-preset]) .cert-step,
:root[data-theme-preset="obsidian-ivory"] .cert-step{
  border-left-color: rgba(198,165,106,.24);
  color: var(--text-dark-soft);
}

:root:not([data-theme-preset]) .cert-step--active,
:root[data-theme-preset="obsidian-ivory"] .cert-step--active{
  border-left-color: var(--accent-premium);
  color: var(--text-dark);
  background: rgba(198,165,106,.10);
}

:root:not([data-theme-preset]) .cert-render-badge,
:root[data-theme-preset="obsidian-ivory"] .cert-render-badge{
  border-color: rgba(198,165,106,.22);
  background: rgba(198,165,106,.10);
  color: var(--text-dark);
}

/* ================================
   Obsidian Ivory Luxe Layer
================================ */
:root:not([data-theme-preset]),
:root[data-theme-preset="obsidian-ivory"]{
  --luxe-metal: rgba(231,214,175,.48);
  --luxe-metal-soft: rgba(198,165,106,.20);
  --luxe-ink: #15120e;
  --luxe-ink-soft: rgba(21,18,14,.66);
  --luxe-dark-card: linear-gradient(180deg, rgba(30,36,45,.98) 0%, rgba(14,17,22,.98) 100%);
  --luxe-paper-card: linear-gradient(180deg, rgba(252,249,244,.99) 0%, rgba(243,236,225,.99) 100%);
}

:root:not([data-theme-preset]) body::before,
:root:not([data-theme-preset]) body::after,
:root[data-theme-preset="obsidian-ivory"] body::before,
:root[data-theme-preset="obsidian-ivory"] body::after{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
}

:root:not([data-theme-preset]) body::before,
:root[data-theme-preset="obsidian-ivory"] body::before{
  background:
    radial-gradient(880px 420px at 12% 10%, rgba(198,165,106,.12), transparent 58%),
    radial-gradient(720px 360px at 100% 0%, rgba(110,134,255,.08), transparent 54%),
    radial-gradient(540px 280px at 50% 120%, rgba(198,165,106,.06), transparent 60%);
  opacity: .92;
}

:root:not([data-theme-preset]) body::after,
:root[data-theme-preset="obsidian-ivory"] body::after{
  background:
    linear-gradient(90deg, rgba(255,255,255,.03) 0, rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.025) 0, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 48px 48px, 48px 48px;
  opacity: .18;
  mask-image: radial-gradient(circle at center, black 12%, transparent 86%);
}

:root:not([data-theme-preset]) .auth-page,
:root[data-theme-preset="obsidian-ivory"] .auth-page{
  padding: 24px 0;
}

:root:not([data-theme-preset]) .auth-card,
:root[data-theme-preset="obsidian-ivory"] .auth-card{
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: 38px 34px 30px;
  border-radius: 28px;
  background:
    radial-gradient(420px 140px at 0% 0%, rgba(231,214,175,.34), transparent 62%),
    radial-gradient(320px 160px at 100% 0%, rgba(255,255,255,.46), transparent 58%),
    var(--luxe-paper-card);
  box-shadow:
    0 34px 72px rgba(0,0,0,.28),
    0 10px 24px rgba(198,165,106,.10);
}

:root:not([data-theme-preset]) .auth-card::before,
:root[data-theme-preset="obsidian-ivory"] .auth-card::before{
  content:"";
  position:absolute;
  inset: 12px;
  border-radius: 20px;
  border: 1px solid rgba(198,165,106,.16);
  pointer-events:none;
}

:root:not([data-theme-preset]) .auth-card::after,
:root[data-theme-preset="obsidian-ivory"] .auth-card::after{
  content:"";
  position:absolute;
  left: 34px;
  right: 34px;
  top: 20px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(198,165,106,0) 0%, rgba(198,165,106,.85) 24%, rgba(231,214,175,.95) 50%, rgba(198,165,106,.85) 76%, rgba(198,165,106,0) 100%);
  opacity: .92;
}

:root:not([data-theme-preset]) .brand,
:root[data-theme-preset="obsidian-ivory"] .brand{
  gap: 18px;
  margin-bottom: 10px;
}

:root:not([data-theme-preset]) .brand-logo,
:root[data-theme-preset="obsidian-ivory"] .brand-logo{
  width: 100px;
  padding: 10px;
  border-radius: 18px;
}

:root:not([data-theme-preset]) .brand-title,
:root[data-theme-preset="obsidian-ivory"] .brand-title{
  display:grid;
  gap: 4px;
}

:root:not([data-theme-preset]) .brand-title .app-subtitle,
:root[data-theme-preset="obsidian-ivory"] .brand-title .app-subtitle{
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 10px;
}

:root:not([data-theme-preset]) .auth-card .h1,
:root[data-theme-preset="obsidian-ivory"] .auth-card .h1{
  font-size: 34px;
  margin-top: 20px;
  margin-bottom: 12px;
  font-weight: 700;
  color: var(--luxe-ink);
}

:root:not([data-theme-preset]) .auth-card .label,
:root[data-theme-preset="obsidian-ivory"] .auth-card .label{
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 10px;
  font-weight: 800;
}

:root:not([data-theme-preset]) .auth-card .btn.primary,
:root[data-theme-preset="obsidian-ivory"] .auth-card .btn.primary{
  min-height: 56px;
  margin-top: 6px;
  font-weight: 800;
  letter-spacing: .03em;
  text-transform: uppercase;
}

:root:not([data-theme-preset]) .auth-footer,
:root[data-theme-preset="obsidian-ivory"] .auth-footer{
  border-top-color: rgba(198,165,106,.16);
  margin-top: 18px;
  padding-top: 16px;
}

:root:not([data-theme-preset]) .msg,
:root[data-theme-preset="obsidian-ivory"] .msg{
  background: rgba(255,255,255,.62);
  border-color: rgba(198,165,106,.16);
  color: var(--luxe-ink);
}

:root:not([data-theme-preset]) .topbar,
:root:not([data-theme-preset]) .sidebar,
:root[data-theme-preset="obsidian-ivory"] .topbar,
:root[data-theme-preset="obsidian-ivory"] .sidebar{
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(24,29,37,.97) 0%, rgba(10,12,16,.96) 100%);
}

:root:not([data-theme-preset]) .topbar::before,
:root:not([data-theme-preset]) .sidebar::before,
:root[data-theme-preset="obsidian-ivory"] .topbar::before,
:root[data-theme-preset="obsidian-ivory"] .sidebar::before{
  content:"";
  position:absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(198,165,106,0) 0%, rgba(198,165,106,.48) 18%, rgba(231,214,175,.72) 50%, rgba(198,165,106,.48) 82%, rgba(198,165,106,0) 100%);
  pointer-events:none;
}

:root:not([data-theme-preset]) .topbar::after,
:root[data-theme-preset="obsidian-ivory"] .topbar::after{
  content:"";
  position:absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.05) 0%, transparent 55%);
  pointer-events:none;
}

:root:not([data-theme-preset]) .topbar-inner,
:root[data-theme-preset="obsidian-ivory"] .topbar-inner{
  padding-top: 14px;
  padding-bottom: 14px;
}

:root:not([data-theme-preset]) .topbar-title strong,
:root[data-theme-preset="obsidian-ivory"] .topbar-title strong{
  font-size: 17px;
  letter-spacing: .02em;
}

:root:not([data-theme-preset]) .sidebar,
:root[data-theme-preset="obsidian-ivory"] .sidebar{
  padding: 16px 14px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.03),
    0 26px 50px rgba(0,0,0,.22);
}

:root:not([data-theme-preset]) .nav-title,
:root[data-theme-preset="obsidian-ivory"] .nav-title{
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: 10px;
}

:root:not([data-theme-preset]) .nav-btn,
:root[data-theme-preset="obsidian-ivory"] .nav-btn{
  min-height: 48px;
  border-radius: 18px;
  padding: 12px 14px 12px 18px;
}

:root:not([data-theme-preset]) .nav-btn.active,
:root[data-theme-preset="obsidian-ivory"] .nav-btn.active{
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 12px 24px rgba(0,0,0,.14);
}

:root:not([data-theme-preset]) .content,
:root[data-theme-preset="obsidian-ivory"] .content{
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  background:
    radial-gradient(640px 180px at 0% 0%, rgba(231,214,175,.18), transparent 60%),
    radial-gradient(460px 180px at 100% 0%, rgba(255,255,255,.38), transparent 58%),
    var(--luxe-paper-card);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    0 28px 60px rgba(0,0,0,.16);
}

:root:not([data-theme-preset]) .content::before,
:root[data-theme-preset="obsidian-ivory"] .content::before{
  content:"";
  position:absolute;
  inset: 14px;
  border-radius: 20px;
  border: 1px solid rgba(198,165,106,.14);
  pointer-events:none;
}

:root:not([data-theme-preset]) .card,
:root:not([data-theme-preset]) .menu-card,
:root:not([data-theme-preset]) .announce-item,
:root:not([data-theme-preset]) .driver-item,
:root:not([data-theme-preset]) .simple-item,
:root[data-theme-preset="obsidian-ivory"] .card,
:root[data-theme-preset="obsidian-ivory"] .menu-card,
:root[data-theme-preset="obsidian-ivory"] .announce-item,
:root[data-theme-preset="obsidian-ivory"] .driver-item,
:root[data-theme-preset="obsidian-ivory"] .simple-item{
  position: relative;
  overflow: hidden;
  border-radius: 22px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.54),
    0 12px 28px rgba(9,8,6,.08);
}

:root:not([data-theme-preset]) .table-wrap,
:root[data-theme-preset="obsidian-ivory"] .table-wrap{
  position: relative;
  overflow: auto;
  border-radius: 22px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.54),
    0 12px 28px rgba(9,8,6,.08);
  scrollbar-gutter: stable both-edges;
  -webkit-overflow-scrolling: touch;
}

:root:not([data-theme-preset]) .card::before,
:root:not([data-theme-preset]) .menu-card::before,
:root:not([data-theme-preset]) .announce-item::before,
:root:not([data-theme-preset]) .driver-item::before,
:root:not([data-theme-preset]) .simple-item::before,
:root[data-theme-preset="obsidian-ivory"] .card::before,
:root[data-theme-preset="obsidian-ivory"] .menu-card::before,
:root[data-theme-preset="obsidian-ivory"] .announce-item::before,
:root[data-theme-preset="obsidian-ivory"] .driver-item::before,
:root[data-theme-preset="obsidian-ivory"] .simple-item::before{
  content:"";
  position:absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(198,165,106,0) 0%, rgba(198,165,106,.34) 24%, rgba(255,255,255,.62) 50%, rgba(198,165,106,.34) 76%, rgba(198,165,106,0) 100%);
  pointer-events:none;
}

:root:not([data-theme-preset]) .card.hero,
:root:not([data-theme-preset]) .kpi,
:root:not([data-theme-preset]) .kpi2,
:root:not([data-theme-preset]) .chart-card,
:root[data-theme-preset="obsidian-ivory"] .card.hero,
:root[data-theme-preset="obsidian-ivory"] .kpi,
:root[data-theme-preset="obsidian-ivory"] .kpi2,
:root[data-theme-preset="obsidian-ivory"] .chart-card{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(720px 200px at 0% 0%, rgba(231,214,175,.14), transparent 60%),
    linear-gradient(180deg, rgba(34,40,49,.98) 0%, rgba(14,17,22,.98) 100%);
  border-color: rgba(198,165,106,.24);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.04),
    0 20px 42px rgba(0,0,0,.26);
}

:root:not([data-theme-preset]) .kpi::before,
:root:not([data-theme-preset]) .kpi2::before,
:root:not([data-theme-preset]) .chart-card::before,
:root[data-theme-preset="obsidian-ivory"] .kpi::before,
:root[data-theme-preset="obsidian-ivory"] .kpi2::before,
:root[data-theme-preset="obsidian-ivory"] .chart-card::before{
  content:"";
  position:absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(198,165,106,0) 0%, rgba(231,214,175,.88) 50%, rgba(198,165,106,0) 100%);
  opacity: .9;
}

:root:not([data-theme-preset]) .kpi .k,
:root:not([data-theme-preset]) .kpi2-label,
:root[data-theme-preset="obsidian-ivory"] .kpi .k,
:root[data-theme-preset="obsidian-ivory"] .kpi2-label{
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: 10px;
}

:root:not([data-theme-preset]) .kpi .v,
:root:not([data-theme-preset]) .kpi2-value,
:root[data-theme-preset="obsidian-ivory"] .kpi .v,
:root[data-theme-preset="obsidian-ivory"] .kpi2-value{
  font-size: 24px;
  letter-spacing: -.02em;
}

:root:not([data-theme-preset]) .today-row .today-title strong,
:root[data-theme-preset="obsidian-ivory"] .today-row .today-title strong{
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
  color: var(--luxe-ink);
}

:root:not([data-theme-preset]) .today-row .today-title span,
:root[data-theme-preset="obsidian-ivory"] .today-row .today-title span{
  color: var(--luxe-ink-soft);
}

:root:not([data-theme-preset]) .pill,
:root:not([data-theme-preset]) .badge,
:root[data-theme-preset="obsidian-ivory"] .pill,
:root[data-theme-preset="obsidian-ivory"] .badge{
  background: linear-gradient(180deg, rgba(255,255,255,.58) 0%, rgba(244,239,230,.78) 100%);
  border-color: rgba(198,165,106,.24);
  color: var(--luxe-ink);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

:root:not([data-theme-preset]) .qa-btn,
:root:not([data-theme-preset]) .menu-card,
:root[data-theme-preset="obsidian-ivory"] .qa-btn,
:root[data-theme-preset="obsidian-ivory"] .menu-card{
  background:
    radial-gradient(320px 120px at 0% 0%, rgba(231,214,175,.14), transparent 62%),
    linear-gradient(180deg, rgba(252,249,244,.98) 0%, rgba(243,236,225,.98) 100%);
  border-color: rgba(198,165,106,.18);
  color: var(--luxe-ink);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.72),
    0 14px 28px rgba(9,8,6,.08);
}

:root:not([data-theme-preset]) .qa-btn:hover,
:root:not([data-theme-preset]) .menu-card:hover,
:root[data-theme-preset="obsidian-ivory"] .qa-btn:hover,
:root[data-theme-preset="obsidian-ivory"] .menu-card:hover{
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.8),
    0 20px 34px rgba(9,8,6,.12);
}

:root:not([data-theme-preset]) .qa-icon,
:root[data-theme-preset="obsidian-ivory"] .qa-icon{
  background: linear-gradient(180deg, rgba(231,214,175,.32) 0%, rgba(198,165,106,.18) 100%);
  border-color: rgba(198,165,106,.24);
  color: var(--luxe-ink);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.36);
}

:root:not([data-theme-preset]) .table-wrap,
:root[data-theme-preset="obsidian-ivory"] .table-wrap{
  background: rgba(255,255,255,.62);
  border-color: rgba(198,165,106,.16);
}

:root:not([data-theme-preset]) .table thead th,
:root[data-theme-preset="obsidian-ivory"] .table thead th{
  background: linear-gradient(180deg, rgba(244,239,230,.98) 0%, rgba(236,227,212,.98) 100%);
  color: var(--luxe-ink-soft);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 10px;
  border-bottom-color: rgba(198,165,106,.18);
}

:root:not([data-theme-preset]) .table tbody tr:nth-child(even),
:root[data-theme-preset="obsidian-ivory"] .table tbody tr:nth-child(even){
  background: rgba(244,239,230,.42);
}

:root:not([data-theme-preset]) .table tbody tr:hover,
:root[data-theme-preset="obsidian-ivory"] .table tbody tr:hover{
  background: rgba(231,214,175,.18);
}

:root:not([data-theme-preset]) .verify-shell,
:root[data-theme-preset="obsidian-ivory"] .verify-shell{
  gap: 20px;
  padding-top: 36px;
  padding-bottom: 56px;
}

:root:not([data-theme-preset]) .verify-hero,
:root[data-theme-preset="obsidian-ivory"] .verify-hero{
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  background:
    radial-gradient(820px 220px at 0% 0%, rgba(231,214,175,.18), transparent 58%),
    radial-gradient(240px 160px at 100% 0%, rgba(255,255,255,.14), transparent 58%),
    linear-gradient(180deg, rgba(29,36,48,.98) 0%, rgba(14,17,22,.98) 100%);
}

:root:not([data-theme-preset]) .verify-hero::before,
:root[data-theme-preset="obsidian-ivory"] .verify-hero::before{
  content:"";
  position:absolute;
  inset: 14px;
  border-radius: 18px;
  border: 1px solid rgba(231,214,175,.14);
  pointer-events:none;
}

:root:not([data-theme-preset]) .verify-hero .h1,
:root[data-theme-preset="obsidian-ivory"] .verify-hero .h1{
  font-size: 42px;
  line-height: 1.02;
  margin-bottom: 16px;
}

:root:not([data-theme-preset]) .verify-stat-card,
:root[data-theme-preset="obsidian-ivory"] .verify-stat-card{
  position: relative;
  min-height: 120px;
  background: linear-gradient(180deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,.04) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

:root:not([data-theme-preset]) .verify-panel,
:root[data-theme-preset="obsidian-ivory"] .verify-panel{
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 18px 18px 20px;
}

:root:not([data-theme-preset]) .verify-panel::before,
:root[data-theme-preset="obsidian-ivory"] .verify-panel::before{
  content:"";
  position:absolute;
  inset: 12px;
  border-radius: 18px;
  border: 1px solid rgba(198,165,106,.14);
  pointer-events:none;
}

:root:not([data-theme-preset]) .verify-detail-card,
:root:not([data-theme-preset]) .verify-message,
:root[data-theme-preset="obsidian-ivory"] .verify-detail-card,
:root[data-theme-preset="obsidian-ivory"] .verify-message{
  background: rgba(255,255,255,.56);
  border-color: rgba(198,165,106,.16);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.68);
}

:root:not([data-theme-preset]) .verify-detail-value,
:root[data-theme-preset="obsidian-ivory"] .verify-detail-value{
  color: var(--luxe-ink);
}

:root:not([data-theme-preset]) .cert-modal-overlay,
:root[data-theme-preset="obsidian-ivory"] .cert-modal-overlay{
  background:
    radial-gradient(560px 220px at 50% 0%, rgba(198,165,106,.18), transparent 58%),
    rgba(5,6,9,.72);
  backdrop-filter: blur(12px);
}

:root:not([data-theme-preset]) .cert-modal,
:root[data-theme-preset="obsidian-ivory"] .cert-modal{
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.72),
    0 30px 80px rgba(0,0,0,.28);
}

:root:not([data-theme-preset]) .cert-modal::before,
:root[data-theme-preset="obsidian-ivory"] .cert-modal::before{
  content:"";
  position:absolute;
  inset: 14px;
  border-radius: 20px;
  border: 1px solid rgba(198,165,106,.16);
  pointer-events:none;
}

:root:not([data-theme-preset]) .cert-modal .h2,
:root:not([data-theme-preset]) .certs-modern .h2,
:root[data-theme-preset="obsidian-ivory"] .cert-modal .h2,
:root[data-theme-preset="obsidian-ivory"] .certs-modern .h2{
  font-family: var(--font-display);
  font-size: 34px;
  font-weight: 700;
  color: var(--luxe-ink);
}

:root:not([data-theme-preset]) .cert-progress-label,
:root[data-theme-preset="obsidian-ivory"] .cert-progress-label{
  color: var(--luxe-ink);
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
}

:root:not([data-theme-preset]) .cert-render-badge,
:root[data-theme-preset="obsidian-ivory"] .cert-render-badge{
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

@media (max-width: 980px){
  :root:not([data-theme-preset]) .auth-card,
  :root[data-theme-preset="obsidian-ivory"] .auth-card{
    padding: 34px 24px 24px;
    border-radius: 24px;
  }

  :root:not([data-theme-preset]) .content,
  :root[data-theme-preset="obsidian-ivory"] .content{
    border-radius: 22px;
    padding: 18px;
  }

  :root:not([data-theme-preset]) .verify-hero .h1,
  :root[data-theme-preset="obsidian-ivory"] .verify-hero .h1{
    font-size: 34px;
  }
}
