/* ============================================================================
   Market Rights Lab — Shared Design System  ·  mrl.css  ·  v1.0
   ----------------------------------------------------------------------------
   ONE canonical stylesheet for every internal page (admin, portal, privacy,
   terms, 404). Extracted and elevated from the Design-3 "Soft Product"
   homepage so the whole product reads as one family instead of four
   slightly-different inline themes.

   HOW TO ADOPT (Codex):
     1. <link rel="stylesheet" href="/assets/mrl.css"> in <head>.
     2. Delete the page's inline :root token block + duplicated component CSS.
     3. Put page-specific overrides in external /assets/*.css files.
     4. This file is 'self' under the current CSP (style-src 'self'); no CSP
        change required. Google Fonts <link> stays in each page head.

   CONVENTIONS:
     - Color comes from tokens only. Never hard-code hex in a page.
     - Accent families: violet (primary), blue, amber, coral — each has a
       --soft-* fill and --ink-* text for badges/cards/dots.
     - Spacing scale: 4 / 8 / 12 / 16 / 20 / 24 / 32 / 40 / 56 / 72.
============================================================================ */

/* ---- 1. Tokens --------------------------------------------------------- */
:root{
  /* surfaces */
  --bg:#140E2E; --bg-2:#1A123A; --panel:#221A46; --panel-2:#2A2056; --panel-3:#1C1540;
  --ink:#F4F1FF; --ink-2:#E2DBFB; --muted:#ABA0D4; --muted-2:#8579AE;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.16); --line-3:rgba(255,255,255,.24);

  /* brand */
  --violet:#8B6CFF; --violet-2:#9C82FF; --violet-press:#7A57F5; --violet-12:rgba(139,108,255,.16); --violet-20:rgba(139,108,255,.26);
  --blue:#4F9CFF; --blue-2:#6FB0FF; --blue-12:rgba(79,156,255,.16);
  --grad:linear-gradient(120deg,#8266F7 0%,#5E76EE 55%,#4D74EC 100%);
  --grad-soft:linear-gradient(120deg,rgba(139,108,255,.18),rgba(79,156,255,.18));

  /* accent families */
  --soft-blue:var(--blue-12); --ink-blue:var(--blue-2);
  --amber:#F5B544; --amber-ink:#5a3d05; --amber-12:rgba(245,181,68,.16); --soft-amber:var(--amber-12); --ink-amber:var(--amber); --amber-bright:var(--amber);
  --coral:#FF6F7D; --coral-12:rgba(255,111,125,.16); --soft-coral:var(--coral-12); --ink-coral:var(--coral);
  --soft-violet:var(--violet-12); --ink-violet:var(--violet);
  --on-accent:#fff;

  /* radii */
  --r-xs:8px; --r:12px; --r-md:16px; --r-lg:20px; --r-xl:26px; --r-2xl:30px; --r-pill:999px; --motif:18px 18px 30px 18px;

  /* shadow */
  --shadow-sm:0 8px 24px -18px rgba(8,4,28,.65);
  --shadow:0 30px 70px -36px rgba(8,4,28,.75);
  --shadow-lg:0 44px 100px -48px rgba(8,4,28,.88);
  --glow:0 0 0 1px var(--line),0 20px 60px -28px rgba(139,108,255,.50);
  --ring:0 0 0 4px rgba(139,108,255,.30);

  /* layout */
  --max:1240px; --max-content:1160px; --max-narrow:980px; --sidebar:260px;
  --font-display:"Space Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
}

:root[data-theme="light"]{
  --bg:#F6F4FF; --bg-2:#EEEAFE; --panel:#FFFFFF; --panel-2:#F7F5FF; --panel-3:#F1EDFF;
  --ink:#171134; --ink-2:#2E2553; --muted:#5E5680; --muted-2:#857CA6;
  --line:#E7E2F7; --line-2:#D9D2F0; --line-3:#C8BEE8;
  --violet:#6D45E6; --violet-2:#7C57F0; --violet-press:#5C36CC; --violet-12:rgba(109,69,230,.10); --violet-20:rgba(109,69,230,.20);
  --blue:#2563EB; --blue-2:#3B76F5; --blue-12:rgba(37,99,235,.10);
  --grad:linear-gradient(120deg,#6D45E6 0%,#3E6EF0 55%,#2563EB 100%);
  --grad-soft:linear-gradient(120deg,rgba(109,69,230,.12),rgba(37,99,235,.12));
  --amber:#B5790A; --amber-12:rgba(181,121,10,.12); --soft-amber:var(--amber-12); --ink-amber:var(--amber); --amber-bright:var(--amber);
  --coral:#E0566A; --coral-12:rgba(224,86,106,.12); --soft-coral:var(--coral-12); --ink-coral:var(--coral);
  --on-accent:#fff;
  --shadow-sm:0 8px 24px -18px rgba(58,40,120,.28);
  --shadow:0 24px 60px -34px rgba(58,40,120,.30);
  --shadow-lg:0 40px 90px -44px rgba(58,40,120,.38);
  --glow:0 0 0 1px var(--line),0 20px 50px -30px rgba(109,69,230,.35);
  --ring:0 0 0 4px rgba(109,69,230,.18);
}

/* ---- 2. Base ----------------------------------------------------------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0;
  background:
    radial-gradient(circle at 88% -12%,rgba(139,108,255,.22),transparent 34rem),
    radial-gradient(circle at -8% 8%,rgba(79,156,255,.16),transparent 30rem),
    var(--bg);
  color:var(--ink);font-family:var(--font);
  line-height:1.62;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em;margin:0;color:var(--ink);font-weight:700}
p{margin:0 0 1em}
a{color:var(--violet);text-decoration:none}
a:hover{color:var(--violet-press)}
button,input,select,textarea{font:inherit;color:inherit}
::selection{background:var(--violet-20)}
hr{border:0;border-top:1px solid var(--line);margin:24px 0}
small{font-size:12px}
.mono{font-family:var(--mono);overflow-wrap:anywhere}
.muted{color:var(--muted)}
.center{text-align:center}
.hide{display:none !important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* skip link for a11y */
.skip-link{position:absolute;left:12px;top:-48px;z-index:100;background:var(--panel);color:var(--violet-2);border:1px solid var(--line-2);border-radius:var(--r-pill);padding:10px 14px;font-weight:800}
.skip-link:focus{top:12px;outline:3px solid rgba(139,108,255,.24)}

:focus-visible{outline:3px solid rgba(139,108,255,.38);outline-offset:2px;border-radius:6px}

/* ---- 3. Ambiance (signature gradient blobs) ---------------------------- */
.blob{position:absolute;border-radius:50%;filter:blur(64px);z-index:0;pointer-events:none}
.b1{width:560px;height:560px;background:var(--violet-2);opacity:.45;top:-220px;right:-120px}
.b2{width:480px;height:480px;background:var(--blue-2);opacity:.38;top:60px;left:-220px}
.b3{width:420px;height:420px;background:var(--violet-2);opacity:.30;bottom:-200px;left:30%}

/* ---- 4. Layout --------------------------------------------------------- */
.wrap{max-width:var(--max-content);margin:0 auto;padding:0 24px;position:relative;z-index:1}
.wrap.narrow{max-width:var(--max-narrow)}
.wrap.wide{max-width:var(--max)}
.row{display:flex;gap:12px;align-items:center}
.row.wrap-w{flex-wrap:wrap}
.spread{display:flex;align-items:center;justify-content:space-between;gap:16px}
.stack{display:flex;flex-direction:column;gap:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grow{flex:1;min-width:0}
.center-actions{justify-content:center;margin-top:22px}

/* ---- 5. Header / nav --------------------------------------------------- */
.site-header{position:sticky;top:0;z-index:30;background:rgba(20,14,46,.78);backdrop-filter:saturate(160%) blur(16px);border-bottom:1px solid var(--line)}
:root[data-theme="light"] .site-header{background:rgba(246,244,255,.86)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;height:76px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--ink);white-space:nowrap;flex:0 0 auto}
.mk{width:38px;height:38px;border-radius:11px 11px 18px 11px;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:700;flex:0 0 auto;box-shadow:0 16px 34px -22px rgba(139,108,255,.9)}
.nav-links{display:flex;align-items:center;gap:18px;min-width:0;flex-shrink:1;overflow-x:auto;scrollbar-width:none}
.nav-links::-webkit-scrollbar{display:none}
.nav-links a{color:var(--muted);font-size:14.5px;font-weight:600;white-space:nowrap;flex:0 0 auto}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--violet)}
.nav-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
/* Header never wraps mid-label; collapses to a scrollable strip on tablet/mobile (hamburger is a later ticket) */
@media(max-width:1000px){
  .nav{flex-wrap:wrap;height:auto;padding:12px 0;gap:10px 16px}
  .nav-links{order:3;width:100%;gap:18px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}
  .nav-links::-webkit-scrollbar{display:none}
}

/* ---- 6. Buttons -------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border-radius:var(--r-pill);padding:11px 20px;font-weight:750;font-size:14.5px;background:var(--grad);color:#fff;border:1px solid transparent;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s,filter .15s;white-space:nowrap;box-shadow:0 18px 34px -24px rgba(139,108,255,.9)}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px);color:#fff}
.btn.ghost,.btn.secondary{background:var(--panel);color:var(--violet-2);border-color:var(--line-2);box-shadow:none}
.btn.ghost:hover,.btn.secondary:hover{border-color:var(--violet);color:var(--violet-2);filter:none}
.btn.neutral{background:var(--panel);color:var(--ink);border-color:var(--line-2);box-shadow:none}
.btn.neutral:hover{border-color:var(--line-3);background:var(--panel-2)}
.btn.danger{background:var(--panel);color:var(--coral);border-color:var(--coral-12);box-shadow:none}
.btn.danger:hover{background:var(--soft-coral);border-color:var(--coral)}
.btn.white{background:#fff;color:var(--violet-press);border-color:#fff}
.btn.white:hover{background:#f2efff;filter:none}
.btn.lg{min-height:54px;padding:14px 26px;font-size:16px}
.btn.sm{min-height:36px;padding:7px 14px;font-size:13px}
.btn.icon{padding:0;width:40px;height:40px;min-height:40px}
.btn[disabled]{opacity:.5;cursor:not-allowed}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border:1px solid var(--line-2);border-radius:var(--r-pill);background:var(--panel);color:var(--ink-2);font-weight:800;font-size:12px;padding:8px 13px;cursor:pointer;box-shadow:none}
.theme-toggle:hover{border-color:var(--violet);color:var(--violet-2)}
.nav-links .theme-toggle{margin-left:-8px}

/* ---- 7. Chips, pills, badges, dots ------------------------------------ */
.eyebrow{font-size:13px;font-weight:700;color:var(--violet)}
.chip{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--violet-press);background:var(--violet-12);padding:7px 14px;border-radius:var(--r-pill)}
.pill{display:inline-flex;align-items:center;gap:6px;min-height:28px;border:1px solid var(--violet-20);border-radius:var(--r-pill);padding:4px 12px;color:var(--violet-press);background:var(--violet-12);font-size:12px;font-weight:800}
.pill.blue{color:var(--ink-blue);background:var(--soft-blue);border-color:var(--line-2)}
.pill.amber{color:var(--ink-amber);background:var(--soft-amber);border-color:var(--line-2)}
.pill.coral{color:var(--ink-coral);background:var(--soft-coral);border-color:var(--line-2)}
.pill.violet{color:var(--ink-violet);background:var(--soft-violet);border-color:var(--line-2)}
.pill.neutral{color:var(--muted);background:var(--panel);border-color:var(--line-2)}
.pill.ghost{color:var(--muted);background:var(--panel);border-color:var(--line-2)}

/* color-coded event/category badge */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:800;letter-spacing:.01em;padding:3px 9px;border-radius:8px;color:var(--violet-press);background:var(--violet-12);white-space:nowrap}
.badge.blue{color:var(--ink-blue);background:var(--soft-blue)}
.badge.amber{color:var(--ink-amber);background:var(--soft-amber)}
.badge.coral{color:var(--ink-coral);background:var(--soft-coral)}
.badge.violet{color:var(--ink-violet);background:var(--soft-violet)}
.badge.gray{color:var(--muted);background:var(--panel-3)}

/* status dot */
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--muted-2);flex:0 0 auto}
.dot.ok{background:var(--violet);box-shadow:0 0 0 4px rgba(139,108,255,.18)}
.dot.warn{background:var(--amber-bright);box-shadow:0 0 0 4px rgba(244,183,64,.16)}
.dot.bad{background:#d8604c;box-shadow:0 0 0 4px rgba(216,96,76,.14)}

/* ---- 8. Panels / cards ------------------------------------------------- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-2xl);box-shadow:var(--shadow);min-width:0}
.panel.flat{box-shadow:none}
.panel-head{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;align-items:flex-start;flex-wrap:wrap}
.panel-head h2,.panel-head h3{font-size:17px;line-height:1.25}
.panel-head p{margin:5px 0 0;color:var(--muted);font-size:13px}
.panel-body{padding:20px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px}
.card.soft{background:var(--panel-2)}
.card h3{font-size:15px;line-height:1.25}
.callout{background:var(--violet-12);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:14px 16px;color:var(--violet-press);font-weight:700}
.callout.amber{background:var(--soft-amber);border-color:var(--line-2);color:var(--ink-amber)}

/* ---- 9. KPI cards ------------------------------------------------------ */
.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px}
.kpi{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 16px 14px;overflow:hidden;min-height:118px;display:flex;flex-direction:column;gap:8px}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--violet)}
.kpi.blue::before{background:var(--blue)} .kpi.amber::before{background:var(--amber-bright)} .kpi.coral::before{background:var(--coral)} .kpi.violet::before{background:var(--violet)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.kpi-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em;font-weight:800}
.kpi-ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--violet-12);color:var(--violet-press)}
.kpi.blue .kpi-ico{background:var(--soft-blue);color:var(--ink-blue)} .kpi.amber .kpi-ico{background:var(--soft-amber);color:var(--ink-amber)} .kpi.coral .kpi-ico{background:var(--soft-coral);color:var(--ink-coral)} .kpi.violet .kpi-ico{background:var(--soft-violet);color:var(--ink-violet)}
.kpi-num{font-size:28px;font-weight:800;line-height:1;letter-spacing:-.02em}
.kpi-foot{display:flex;align-items:center;gap:8px;margin-top:auto}
.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:800;padding:2px 7px;border-radius:var(--r-pill)}
.kpi-delta.up{color:var(--violet);background:var(--violet-12)}
.kpi-delta.down{color:var(--ink-coral);background:var(--soft-coral)}
.kpi-delta.flat{color:var(--muted);background:var(--panel-3)}
.kpi-sub{color:var(--muted-2);font-size:12px}
.kpi-spark{position:absolute;right:10px;bottom:10px;width:64px;height:26px;opacity:.9}

/* ---- 10. Sidebar app shell -------------------------------------------- */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.sidebar{position:sticky;top:0;align-self:start;height:100vh;display:flex;flex-direction:column;gap:6px;padding:20px 16px;background:rgba(20,14,46,.74);backdrop-filter:saturate(150%) blur(14px);border-right:1px solid var(--line);min-width:0;max-width:100vw}
:root[data-theme="light"] .sidebar{background:rgba(255,255,255,.76)}
.side-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:16px;padding:6px 8px 14px;color:var(--ink)}
.side-group{margin-top:10px;padding:0 8px;color:var(--muted-2);font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.07em}
.side-nav{display:flex;flex-direction:column;gap:3px;margin-top:6px}
.side-link{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:12px;color:var(--ink-2);font-size:14px;font-weight:700;cursor:pointer}
.side-link svg{width:18px;height:18px;flex:0 0 auto;color:var(--muted)}
.side-link:hover{background:var(--violet-12);color:var(--violet-press)}
.side-link.active{background:var(--grad);color:#fff}
.side-link.active svg{color:#fff}
.side-link .count{margin-left:auto;font-size:11px;font-weight:800;background:rgba(0,0,0,.06);padding:1px 8px;border-radius:var(--r-pill)}
.side-link.active .count{background:rgba(255,255,255,.22)}
.side-foot{margin-top:auto;padding:12px 8px 4px;color:var(--muted);font-size:11.5px;border-top:1px solid var(--line)}
.app-main{min-width:0;display:flex;flex-direction:column;overflow:hidden}
.app-main .b1{right:0}
.app-main .b2{left:0}
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 28px;background:rgba(20,14,46,.78);backdrop-filter:saturate(160%) blur(16px);border-bottom:1px solid var(--line)}
:root[data-theme="light"] .topbar{background:rgba(246,244,255,.86)}
.topbar h1{font-size:20px;letter-spacing:-.01em}
.topbar .sub{color:var(--muted);font-size:12.5px;margin-top:2px}
.app-body{padding:26px 28px 60px;position:relative}
.section-stack{display:flex;flex-direction:column;gap:18px}
.side-link{border:0;background:none;text-align:left;width:100%}
.top-search{width:230px}
.admin-login{max-width:980px;margin:40px auto 0}

/* ---- 10b. Public verification page ------------------------------------ */
.verify-page{position:relative;min-height:calc(100vh - 76px);padding:72px 0 84px;overflow:hidden}
.verify-hero{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}
.verify-hero h1{font-size:clamp(34px,6vw,64px);line-height:.98;max-width:760px}
.verify-hero p{max-width:680px;font-size:17px}
.admin-login .login-grid{display:grid;grid-template-columns:minmax(280px,480px) 1fr;gap:18px;align-items:start}

/* ---- 11. Tables -------------------------------------------------------- */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r-lg);max-width:100%;background:var(--panel)}
.table-wrap.table-empty-wrap{overflow:visible}
.table-wrap.table-empty-wrap table.data{min-width:0}
table.data{width:100%;border-collapse:collapse;min-width:720px;font-size:13px}
table.data th{position:sticky;top:0;z-index:1;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:800;background:var(--panel-2);text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
table.data td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
table.data tr:last-child td{border-bottom:0}
table.data tbody tr{transition:background .12s}
table.data tbody tr:hover{background:var(--panel-3)}
table.data td strong{display:block;color:var(--ink);font-weight:700}
table.data td small{display:block;color:var(--muted);margin-top:2px}
.t-time{color:var(--ink-2);font-weight:600;white-space:nowrap}
.t-expand{cursor:pointer;color:var(--violet);font-weight:800;font-size:12px;background:none;border:0;padding:2px 4px}
.drawer-row td{background:var(--panel-3);padding:0}
.drawer{padding:14px 16px;font-family:var(--mono);font-size:12px;color:var(--ink-2);white-space:pre-wrap;overflow-wrap:anywhere;max-height:300px;overflow:auto}
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;flex-wrap:wrap}
.pager .info{color:var(--muted);font-size:12.5px}
.readiness{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.readiness li{display:flex;align-items:center;gap:10px;padding:11px 4px;border-bottom:1px solid var(--line);font-size:13.5px}
.readiness li:last-child{border-bottom:0}
.readiness .lab{color:var(--ink-2);font-weight:700}
.readiness .val{margin-left:auto;color:var(--muted);font-weight:700;text-align:right}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.admin-check,.checkline{display:flex;flex-direction:row;align-items:flex-start;gap:10px;color:var(--ink-2);font-size:12.5px;font-weight:750;line-height:1.45}
.admin-check input,.checkline input{width:18px;min-height:18px;flex:0 0 auto;margin-top:2px}

/* ---- 12. Forms --------------------------------------------------------- */
.field{display:flex;flex-direction:column;gap:6px}
.field > span,label.field-label{color:var(--ink-2);font-size:12px;font-weight:800}
input,select,textarea{width:100%;min-height:46px;border:1.5px solid var(--line-2);border-radius:14px;background:var(--panel-3);color:var(--ink);padding:10px 14px;font-size:14.5px;font-weight:600;outline:none;transition:.15s}
input::placeholder{color:var(--muted-2);font-weight:500}
input:focus,select:focus,textarea:focus{border-color:var(--violet);box-shadow:var(--ring)}
textarea{min-height:120px;line-height:1.5;resize:vertical}
.input-wrap{position:relative;display:flex;align-items:center}
.input-wrap svg{position:absolute;left:14px;width:18px;height:18px;color:var(--muted-2);pointer-events:none}
.input-wrap input{padding-left:42px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235b6f69' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:40px}

/* ---- 13. Status banners ------------------------------------------------ */
.status{padding:10px 13px;border-radius:var(--r-md);background:var(--soft-blue);color:var(--ink-blue);font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}
.status.warning{background:var(--soft-amber);color:var(--ink-amber)}
.status.error{background:var(--soft-coral);color:var(--ink-coral)}
.status.success{background:var(--violet-12);color:var(--violet-press)}

/* ---- 14. Tabs / segmented --------------------------------------------- */
.tabs{display:flex;gap:8px;flex-wrap:wrap}
.tab{border:1px solid var(--line-2);border-radius:var(--r-pill);background:var(--panel);color:var(--ink);padding:8px 15px;font-size:13px;font-weight:800;cursor:pointer;transition:.12s}
.tab:hover{border-color:var(--line-3)}
.tab.active{background:var(--grad);border-color:transparent;color:#fff}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ---- 15. Legal doc layout (sticky TOC) -------------------------------- */
.doc-layout{display:grid;grid-template-columns:240px 1fr;gap:36px;align-items:start}
.doc-hero{position:relative;overflow:hidden;padding:86px 0 72px}
.legal-page main{position:relative;padding:46px 0 70px}
.legal-page .doc-hero{max-width:60ch;padding:0;margin:0 0 26px}
.legal-page .doc-hero h1{font-size:clamp(30px,4.4vw,44px);line-height:1.08;margin:14px 0 12px}
.legal-page .doc-hero p{color:var(--muted);margin:0;font-size:16px}
.legal-page .blob{opacity:.32}
.toc{position:sticky;top:96px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);padding:16px;font-size:13.5px}
.toc strong{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}
.toc a{display:block;padding:6px 10px;border-radius:9px;color:var(--ink-2);font-weight:600;border-left:2px solid transparent}
.toc a:hover{background:var(--violet-12);color:var(--violet-press)}
.toc a.active{background:var(--violet-12);color:var(--violet-press);border-left-color:var(--violet)}
.doc-article{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-2xl);box-shadow:var(--shadow);padding:34px 40px}
.doc-article section{scroll-margin-top:96px}
.doc-article h2{font-size:21px;margin:30px 0 10px;display:flex;align-items:baseline;gap:10px}
.doc-article section:first-child h2{margin-top:0}
.doc-article h2 .num{font-size:13px;font-weight:800;color:var(--violet);background:var(--violet-12);min-width:26px;height:26px;border-radius:8px;display:inline-grid;place-items:center;flex:0 0 auto}
.doc-article p,.doc-article li{color:var(--muted)}
.doc-article strong{color:var(--ink)}
.doc-article ul{margin:0 0 12px;padding-left:18px}
.doc-article li{margin-bottom:6px}
.doc-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:14px;color:var(--muted);font-size:13px}

/* ---- 16. Empty / loading ---------------------------------------------- */
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty .ico{width:54px;height:54px;border-radius:16px;background:var(--violet-12);color:var(--violet-press);display:grid;place-items:center;margin:0 auto 14px}
.empty h3{font-size:16px;color:var(--ink-2);margin-bottom:4px}
.skeleton{position:relative;overflow:hidden;background:var(--panel-3);border-radius:8px;height:14px}
.skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);animation:mrl-shimmer 1.3s infinite}
@keyframes mrl-shimmer{100%{transform:translateX(100%)}}

/* ---- 16b. Auth pages --------------------------------------------------- */
.auth-page{position:relative;min-height:calc(100vh - 76px);padding:62px 0 74px;overflow:hidden}
.auth-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,480px);gap:30px;align-items:start}
.auth-copy{padding-top:24px;max-width:620px}
.auth-copy h1,.auth-title h1{font-size:clamp(34px,5vw,58px);line-height:1.02;margin:16px 0 14px}
.auth-copy p,.auth-title p{color:var(--muted);font-size:16px;max-width:58ch}
.auth-copy,.auth-title{min-width:0}
.auth-panel{position:relative;z-index:1}
.provider-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.provider-grid .btn:last-child:nth-child(odd){grid-column:1/-1}
.segmented{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:var(--panel-3);border:1px solid var(--line);border-radius:var(--r-lg);padding:6px}
.segmented.three{grid-template-columns:repeat(3,1fr)}
.segmented label{position:relative;display:block}
.segmented input{position:absolute;opacity:0;pointer-events:none}
.segmented span{display:grid;place-items:center;min-height:42px;border-radius:12px;color:var(--muted);font-weight:800;cursor:pointer}
.segmented input:checked + span{background:var(--grad);color:#fff;box-shadow:var(--shadow-sm)}
.auth-title{position:relative;z-index:1;margin-top:12px}
.mini-list{display:flex;flex-direction:column;gap:10px}
.mini-card{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:var(--r-lg);padding:13px 14px;background:var(--panel-2)}
.mini-card strong,.mini-card span,.mini-card small{display:block}
.mini-card span{color:var(--muted);font-size:12.5px;overflow-wrap:anywhere}
.mini-card small{color:var(--muted-2);font-size:11.5px;margin-top:3px}
.auth-actions{margin-top:16px}
.compact-grid{gap:12px}

/* ---- 17. Charts (dependency-free, inline SVG/CSS) --------------------- */
.chart-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-2xl);box-shadow:var(--shadow);padding:18px 20px}
.chart-card h3{font-size:15px}
.chart svg{display:block;width:100%;height:auto;overflow:visible}
.chart .grid line{stroke:var(--line);stroke-width:1}
.chart .area{fill:url(#mrlArea)}
.chart .line{fill:none;stroke:var(--violet);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.chart .pt{fill:#fff;stroke:var(--violet);stroke-width:2}
.spark{fill:none;stroke:var(--violet);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.funnel{display:flex;flex-direction:column;gap:10px}
.funnel-row{display:grid;grid-template-columns:160px 1fr 56px;gap:12px;align-items:center;font-size:13px}
.funnel-bar{height:30px;border-radius:9px;background:var(--grad);min-width:6px;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;color:#fff;font-weight:800;font-size:12px}
.funnel-row .lab{color:var(--ink-2);font-weight:700}
.funnel-row .pct{text-align:right;color:var(--muted);font-weight:800}
.legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px;font-size:12.5px;color:var(--muted)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.legend i{width:11px;height:11px;border-radius:3px;display:inline-block}
.bars{display:flex;flex-direction:column;gap:9px}
.bars-row{display:grid;grid-template-columns:130px 1fr 40px;gap:10px;align-items:center;font-size:12.5px}
.bars-row .lab{color:var(--ink-2);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bars-row .track{height:10px;border-radius:var(--r-pill);background:var(--panel-3);overflow:hidden}
.bars-row .fill{height:100%;border-radius:var(--r-pill);background:var(--grad)}
.bars-row .val{text-align:right;color:var(--muted);font-weight:800}

/* ---- 17b. GAP calculator + role panels -------------------------------- */
.tool-page{position:relative;overflow:hidden;padding:54px 0 74px;min-height:calc(100vh - 76px)}
.tool-hero{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);gap:22px;align-items:start}
.tool-copy h1{font-size:clamp(32px,4.8vw,58px);line-height:1.02;margin:16px 0 14px;max-width:12ch}
.tool-copy p{color:var(--muted);font-size:16px;max-width:58ch}
.formula{display:inline-flex;max-width:100%;overflow-wrap:anywhere;margin-top:12px;font-family:var(--mono);font-size:12.5px;color:var(--ink-2);background:var(--panel-3);border:1px solid var(--line);border-radius:var(--r);padding:8px 12px}
.calculator-hero{display:flex;flex-direction:column;gap:18px}
.calculator-intro{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:36px;align-items:end}
.calculator-intro h1{font-size:clamp(32px,3.3vw,44px);line-height:1.06;max-width:680px;margin-bottom:0}
.calculator-intro-note{max-width:560px;justify-self:end}
.calculator-intro-note p{font-size:15.5px;margin-bottom:0}
.calculator-panel{overflow:hidden}
.calculator-panel .panel-head{padding:20px 22px}
.calculator-panel .panel-head p{max-width:72ch}
.calculator-panel .panel-body{padding:22px}
.calculator-panel .calc-grid{grid-template-columns:minmax(320px,.86fr) minmax(0,1.14fr);gap:22px}
.calculator-panel .field-row{grid-template-columns:1fr}
.calculator-panel .field-row .pill{display:none}
.calculator-panel .metric-grid{grid-template-columns:repeat(3,minmax(150px,1fr));gap:14px}
.calculator-panel .metric{min-height:112px}
.calculator-panel .metric .value{font-size:clamp(22px,2.2vw,28px);overflow-wrap:anywhere}
.calculator-panel .grid-2{gap:14px}
.calculator-panel .card.soft{min-height:138px}
.calculator-panel .metric-value{font-size:clamp(22px,2vw,26px);overflow-wrap:anywhere}
.calc-grid{display:grid;grid-template-columns:1fr 1.08fr;gap:18px;align-items:start}
.field-row{display:grid;grid-template-columns:minmax(0,1fr) 120px;gap:10px;align-items:end}
.range-field input[type="range"]{padding:0;min-height:8px;border:0;background:var(--grad-soft)}
input[type="range"]{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:999px;outline:none}
input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--violet);border:3px solid #fff;box-shadow:0 2px 8px rgba(139,108,255,.34);cursor:pointer}
input[type="range"]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--violet);border:3px solid #fff;cursor:pointer}
.metric-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.metric{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel-2);padding:14px 15px;overflow:hidden}
.metric::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--violet)}
.metric.blue::before{background:var(--blue)}.metric.amber::before{background:var(--amber-bright)}.metric.violet::before{background:var(--violet)}.metric.coral::before{background:var(--coral)}
.metric .label{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:800}
.metric .value{font-size:clamp(21px,3vw,30px);font-weight:800;line-height:1.08;margin-top:7px;letter-spacing:0;font-variant-numeric:tabular-nums}
.metric .hint{font-size:11.5px;color:var(--muted-2);margin-top:4px}
.metric-value{font-size:clamp(20px,2.6vw,28px);font-weight:800;line-height:1.12;margin:4px 0 0;letter-spacing:-.01em;font-variant-numeric:tabular-nums;color:var(--ink)}
.calc-bars{display:flex;flex-direction:column;gap:18px}
.bar-heading{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:800;margin:0 0 8px}
.stack-bar{display:flex;height:38px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--panel-3)}
.seg{display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;min-width:0;color:#fff;white-space:nowrap;overflow:hidden}
.seg.price,.seg.net{background:var(--grad)}
.seg.dd{background:var(--blue-2);color:#fff}
.seg.fee{background:var(--amber-bright);color:#5a3d05}
.legend-swatch.violet{background:var(--violet)}.legend-swatch.blue{background:var(--blue-2)}.legend-swatch.amber{background:var(--amber-bright)}
.role-shell{position:relative;overflow:hidden;padding:32px 0 68px;min-height:calc(100vh - 76px)}
.role-title{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.role-title h1{font-size:clamp(26px,4vw,40px);line-height:1.08;margin:12px 0 4px}
.role-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.85fr);gap:18px;align-items:start}
.timeline{display:flex;flex-direction:column;gap:0}
.timeline-step{display:flex;gap:11px;padding:9px 0}
.timeline-step .dot{width:14px;height:14px;border:2px solid var(--line-3);margin-top:4px}
.timeline-step.done .dot{background:var(--violet);border-color:var(--violet)}
.timeline-step.now .dot{background:var(--amber-bright);border-color:var(--amber-bright)}
.timeline-step strong{display:block;font-size:13.5px}
.timeline-step small{display:block;color:var(--muted);font-size:12px}
.leaderboard{display:flex;flex-direction:column;gap:10px}
.leader-row{display:grid;grid-template-columns:minmax(110px,180px) 1fr auto;gap:10px;align-items:center;font-size:12.5px}
.leader-row .track{height:10px;border-radius:999px;background:var(--panel-3);overflow:hidden}
.leader-row .fill{height:100%;border-radius:999px;background:var(--grad)}
.worksheet-page{position:relative;overflow:hidden;padding:26px 0 70px}
.worksheet-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px;align-items:start}
.worksheet-sections{display:flex;flex-direction:column;gap:16px}
.worksheet-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow);overflow:hidden}
.worksheet-card h2{font-size:16px}
.worksheet-card .card-head{display:flex;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);align-items:flex-start}
.worksheet-card .card-body{padding:18px}
.item-row{display:grid;grid-template-columns:1.1fr 120px 120px 120px 40px;gap:10px;align-items:end;border:1px solid var(--line);border-radius:var(--r-lg);padding:10px;background:var(--panel-2)}
.funding-row{display:grid;grid-template-columns:1fr 140px 40px;gap:10px;align-items:end}
.sticky-summary{position:sticky;top:92px}
.role-empty{padding:34px 20px;text-align:center;color:var(--muted)}
.role-empty h3{font-size:17px;color:var(--ink-2);margin-bottom:6px}

/* ---- 18. Footer -------------------------------------------------------- */
.site-footer{border-top:1px solid var(--line);color:var(--muted);font-size:12.5px;padding:26px 0 42px;margin-top:40px}
.site-footer .foot{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
.site-footer a{color:var(--muted);font-weight:600}
.site-footer a:hover{color:var(--violet)}

/* ---- 19. Responsive ---------------------------------------------------- */
@media(max-width:1100px){
  .kpi-grid{grid-template-columns:repeat(3,1fr)}
  .doc-layout{grid-template-columns:1fr}
  .toc{position:static;display:flex;flex-wrap:wrap;gap:4px}
  .toc a{border-left:0}
  .calculator-panel .calc-grid{grid-template-columns:1fr}
}
@media(max-width:960px){
  .app{grid-template-columns:1fr}
  .sidebar{position:static;width:100%;height:auto;flex-direction:row;align-items:center;gap:8px;overflow-x:auto;overflow-y:hidden;border-right:0;border-bottom:1px solid var(--line);padding:10px 14px}
  .side-brand{padding:6px 8px;border:0}
  .side-group,.side-foot{display:none}
  .side-nav{flex-direction:row;margin-top:0}
  .side-link{padding:8px 12px;white-space:nowrap}
  .side-link .count{display:none}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .auth-shell{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}
  .tool-hero,.calc-grid,.role-grid,.worksheet-grid{grid-template-columns:1fr}
  .calculator-intro{grid-template-columns:1fr}
  .calculator-intro-note{justify-self:start;max-width:68ch}
  .sticky-summary{position:static}
}
@media(max-width:680px){
  .wrap{padding:0 16px}
  .nav{height:auto;min-height:62px;padding:10px 0;flex-wrap:nowrap}
  .brand{min-width:0}
  .nav-links{display:none}
  .nav-actions{margin-left:auto}
  .sidebar{display:grid;grid-template-columns:1fr;align-items:stretch;gap:10px;overflow-x:hidden;overflow-y:visible;padding:14px 16px}
  .side-brand{justify-content:flex-start;padding:0 0 4px}
  .sidebar .side-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%;margin:0}
  .side-link{min-height:44px;min-width:0;white-space:normal;border:1px solid var(--line);background:var(--panel-2)}
  .side-link span:not(.count){min-width:0;overflow:hidden;text-overflow:ellipsis}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .app-body,.topbar{padding-left:16px;padding-right:16px}
  .topbar{align-items:flex-start;flex-direction:column}
  .top-search{width:100%}
  .admin-login .login-grid{grid-template-columns:1fr}
  .app-main .blob{display:none}
  .doc-article{padding:22px 20px}
  .funnel-row{grid-template-columns:110px 1fr 44px}
  .auth-page{padding-top:34px}
  .auth-shell{width:100%;max-width:calc(100vw - 64px);overflow:hidden}
  .auth-copy,.auth-panel{width:100%;max-width:100%}
  .auth-copy h1,.auth-title h1{font-size:28px;line-height:1.1}
  .auth-copy h1,.auth-title h1,.auth-copy p,.auth-title p{max-width:100%;overflow-wrap:normal}
  .auth-copy p,.auth-title p{font-size:14.5px}
  .provider-grid{grid-template-columns:1fr}
  .mini-card{align-items:flex-start;flex-direction:column}
  .metric-grid{grid-template-columns:1fr}
  .calculator-panel .metric-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .item-row,.funding-row{grid-template-columns:1fr}
  .leader-row{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms !important;transition-duration:.001ms !important}}
