/* ============================================================================
   AURORA — native design system (hand-written, no Tailwind/Bootstrap, §2/§13).
   Pure CSS. Design tokens + modern reset + the utility vocabulary the templates
   use + premium components + responsive variants + LIGHT/DARK themes.

   Theming model: surfaces, text and borders resolve through SEMANTIC tokens
   (--surface/--text/--border/...). The utility classes the templates already use
   (.bg-white, .text-slate-700, .border-slate-200, ...) are mapped onto those
   tokens, so a single [data-theme="dark"] override re-skins all 200+ templates
   with ZERO markup changes. Always-dark chrome (the sidebar) keeps literal slate.
   Fully responsive (sm 640 / md 768 / lg 1024 / xl 1280).
   ============================================================================ */

/* ---- 1. Design tokens -------------------------------------------------------- */
:root {
  /* Brand (indigo→violet) */
  --brand-50:#eef2ff; --brand-100:#e0e7ff; --brand-200:#c7d2fe; --brand-300:#a5b4fc;
  --brand-400:#818cf8; --brand-500:#6366f1; --brand-600:#4f46e5; --brand-700:#4338ca;
  --brand-800:#3730a3; --brand-900:#312e81;
  /* Slate neutrals */
  --slate-50:#f8fafc; --slate-100:#f1f5f9; --slate-200:#e2e8f0; --slate-300:#cbd5e1;
  --slate-400:#94a3b8; --slate-500:#64748b; --slate-600:#475569; --slate-700:#334155;
  --slate-800:#1e293b; --slate-900:#0f172a;
  /* Semantic accent ramps */
  --amber-50:#fffbeb; --amber-100:#fef3c7; --amber-200:#fde68a; --amber-300:#fcd34d;
  --amber-500:#f59e0b; --amber-600:#d97706; --amber-700:#b45309; --amber-800:#92400e;
  --amber-900:#78350f; --amber-950:#451a03;
  --emerald-50:#ecfdf5; --emerald-200:#a7f3d0; --emerald-300:#6ee7b7; --emerald-600:#059669;
  --emerald-700:#047857; --emerald-800:#065f46;
  --rose-50:#fff1f2; --rose-200:#fecdd3; --rose-400:#fb7185; --rose-500:#f43f5e;
  --rose-600:#e11d48; --rose-700:#be123c;
  --red-50:#fef2f2; --red-100:#fee2e2; --red-600:#dc2626; --red-700:#b91c1c;
  --green-500:#22c55e;

  /* ---- Semantic, theme-able tokens (LIGHT values == the originals) ---------- */
  --app-bg:#f1f5f9;          /* page background        (slate-100) */
  --surface:#ffffff;         /* cards / panels / inputs            */
  --surface-2:#f8fafc;       /* zebra / thead / raised  (slate-50) */
  --surface-3:#f1f5f9;       /* hover / chips          (slate-100) */
  --surface-glass:rgba(255,255,255,.9);   /* sticky header        */
  --surface-glass-2:rgba(255,255,255,.75);/* header (backdrop)    */
  --text:#0f172a;            /* primary       (slate-900/800)      */
  --text-muted:#334155;      /* strong body   (slate-700)          */
  --text-3:#475569;          /* body          (slate-600)          */
  --text-subtle:#64748b;     /* secondary     (slate-500)          */
  --text-faint:#94a3b8;      /* tertiary      (slate-400)          */
  --border:#e2e8f0;          /* hairline      (slate-200)          */
  --border-soft:#f1f5f9;     /* faint         (slate-100)          */
  --border-strong:#cbd5e1;   /* input border  (slate-300)          */
  --link:#4f46e5; --link-hover:#4338ca;
  /* Status surfaces (badges / alerts / tabs) */
  --success-bg:#ecfdf5; --success-fg:#047857; --success-bd:#a7f3d0;
  --warning-bg:#fffbeb; --warning-fg:#92400e; --warning-bd:#fde68a;
  --danger-bg:#fff1f2;  --danger-fg:#be123c;  --danger-bd:#fecdd3;
  --info-bg:#eef2ff;    --info-fg:#4338ca;    --info-bd:#c7d2fe;

  /* Radii / shadows / motion */
  --r-sm:.375rem; --r:.5rem; --r-md:.625rem; --r-lg:.75rem; --r-xl:1rem; --r-2xl:1.25rem; --r-full:9999px;
  --shadow-soft:0 1px 2px rgba(15,23,42,.04), 0 4px 16px -6px rgba(15,23,42,.10);
  --shadow-soft-md:0 6px 24px -8px rgba(15,23,42,.18), 0 2px 6px -2px rgba(15,23,42,.08);
  --shadow-soft-lg:0 24px 56px -20px rgba(15,23,42,.34), 0 8px 20px -10px rgba(15,23,42,.18);
  --ease:cubic-bezier(.4,0,.2,1);
  --font-sans:"Inter var","Inter",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;
}

/* ---- 1b. DARK theme — re-skins every semantic token (set via <html data-theme>) */
:root[data-theme="dark"]{
  color-scheme:dark;
  --app-bg:#0a0f1c;
  --surface:#121a2b;
  --surface-2:#0d1525;
  --surface-3:#1c2740;
  --surface-glass:rgba(16,22,38,.86);
  --surface-glass-2:rgba(16,22,38,.72);
  --text:#e9eefa;
  --text-muted:#c2cce0;
  --text-3:#aab7cd;
  --text-subtle:#8593ab;
  --text-faint:#697892;
  --border:rgba(148,163,184,.16);
  --border-soft:rgba(148,163,184,.10);
  --border-strong:rgba(148,163,184,.26);
  --link:#a5b4fc; --link-hover:#c7d2fe;
  --success-bg:rgba(16,185,129,.14); --success-fg:#6ee7b7; --success-bd:rgba(16,185,129,.30);
  --warning-bg:rgba(245,158,11,.15); --warning-fg:#fcd34d; --warning-bd:rgba(245,158,11,.32);
  --danger-bg:rgba(244,63,94,.15);   --danger-fg:#fda4af;  --danger-bd:rgba(244,63,94,.34);
  --info-bg:rgba(99,102,241,.18);    --info-fg:#a5b4fc;    --info-bd:rgba(99,102,241,.36);
  --shadow-soft:0 1px 2px rgba(0,0,0,.30), 0 4px 16px -6px rgba(0,0,0,.50);
  --shadow-soft-md:0 6px 24px -8px rgba(0,0,0,.60), 0 2px 6px -2px rgba(0,0,0,.40);
  --shadow-soft-lg:0 24px 56px -20px rgba(0,0,0,.70), 0 8px 20px -10px rgba(0,0,0,.50);
}

/* ---- 2. Modern reset / base ------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box;border:0 solid var(--border)}
*{margin:0}
html{-webkit-text-size-adjust:100%;line-height:1.5;font-family:var(--font-sans);tab-size:4}
html.h-full{height:100%}
body{min-height:100%;line-height:inherit;color:var(--text);background:var(--app-bg)}
body.h-full{height:100%}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:600}
img,svg,video,canvas{display:block;max-width:100%;height:auto}
svg{height:auto}
button,input,optgroup,select,textarea{font:inherit;color:inherit;margin:0}
button,select{text-transform:none}
button,[type=button],[type=submit]{-webkit-appearance:button;background:none;cursor:pointer}
:disabled{cursor:default}
table{border-collapse:collapse}
ul,ol{list-style:none;padding:0}
hr{border-top-width:1px;color:var(--border)}
[hidden]{display:none}
::placeholder{color:var(--text-faint);opacity:1}
:focus-visible{outline:2px solid var(--brand-500);outline-offset:2px}
::selection{background:var(--brand-100);color:var(--brand-800)}
/* Refined scrollbars */
*{scrollbar-width:thin;scrollbar-color:var(--slate-300) transparent}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:9999px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:var(--slate-400);background-clip:content-box}

/* Top navigation progress bar (injected by app.js) */
#app-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--brand-500),var(--brand-400));
  box-shadow:0 0 10px rgba(99,102,241,.6);opacity:0;transition:width .2s var(--ease),opacity .35s var(--ease)}
#app-progress.is-active{opacity:1}

/* ---- 3. Layout / display ---------------------------------------------------- */
.block{display:block}.inline{display:inline}.inline-flex{display:inline-flex}
.flex{display:flex}.grid{display:grid}.table{display:table}.hidden{display:none}
.\!flex{display:flex!important}
.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}
.grow{flex-grow:1}.shrink-0{flex-shrink:0}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}
.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}
.self-end{align-self:flex-end}
.grid-flow-col{grid-auto-flow:column}
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}
.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.col-span-2{grid-column:span 2/span 2}

.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}
.inset-0{inset:0}.inset-y-0{top:0;bottom:0}.top-0{top:0}.top-5{top:1.25rem}.right-4{right:1rem}.left-0{left:0}
.-right-12{right:-3rem}.-top-12{top:-3rem}
.z-30{z-index:30}.z-40{z-index:40}
.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}
.min-h-full{min-height:100%}

/* ---- 4. Sizing -------------------------------------------------------------- */
.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}
.w-9{width:2.25rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-20{width:5rem}.w-24{width:6rem}
.w-28{width:7rem}.w-32{width:8rem}.w-40{width:10rem}.w-48{width:12rem}.w-56{width:14rem}
.w-64{width:16rem}.w-full{width:100%}.w-1\/2{width:50%}
.min-w-0{min-width:0}.min-w-\[10rem\]{min-width:10rem}.min-w-\[12rem\]{min-width:12rem}.min-w-\[14rem\]{min-width:14rem}
.max-w-md{max-width:28rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}
.max-w-3xl{max-width:48rem}.max-w-5xl{max-width:64rem}
.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}
.h-9{height:2.25rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-56{height:14rem}.h-full{height:100%}

/* ---- 5. Spacing (margin / padding) ----------------------------------------- */
.mx-auto{margin-left:auto;margin-right:auto}.my-16{margin-top:4rem;margin-bottom:4rem}
.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}
.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}
.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.-mt-3{margin-top:-.75rem}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}
.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.-mb-px{margin-bottom:-1px}
.p-0{padding:0}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}
.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}
.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}
.px-5{padding-left:1.25rem;padding-right:1.25rem}
.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}
.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}
.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}
.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}
.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}
.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}
.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pl-5{padding-left:1.25rem}.pr-5{padding-right:1.25rem}
.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}
.gap-x-4{column-gap:1rem}.gap-x-6{column-gap:1.5rem}.gap-y-1{row-gap:.25rem}.gap-y-2{row-gap:.5rem}.gap-y-3{row-gap:.75rem}
.space-y-0\.5>*+*{margin-top:.125rem}.space-y-1>*+*{margin-top:.25rem}.space-y-2>*+*{margin-top:.5rem}
.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-5>*+*{margin-top:1.25rem}.space-y-6>*+*{margin-top:1.5rem}

/* ---- 6. Typography ---------------------------------------------------------- */
.font-sans{font-family:var(--font-sans)}.font-mono{font-family:var(--font-mono)}
.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}
.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}
.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}
.text-\[11px\]{font-size:11px;line-height:1rem}
.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}
.italic{font-style:italic}.uppercase{text-transform:uppercase}
.tracking-tight{letter-spacing:-.015em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}
.leading-snug{line-height:1.375}
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}
.break-all{word-break:break-all}.underline{text-decoration-line:underline}
.tabular-nums{font-variant-numeric:tabular-nums}
.list-disc{list-style-type:disc}.list-inside{list-style-position:inside}
.align-top{vertical-align:top}

/* ---- 7. Colors -------------------------------------------------------------- */
/* Literal-white / always-light chrome text (buttons, dark sidebar) — NOT themed. */
.text-white{color:#fff}.text-white\/10{color:rgba(255,255,255,.1)}
.text-slate-100{color:var(--slate-100)}.text-slate-200{color:var(--slate-200)}.text-slate-300{color:var(--slate-300)}
/* Body text — mapped onto theme tokens so it flips in dark mode. */
.text-slate-400{color:var(--text-faint)}.text-slate-500{color:var(--text-subtle)}.text-slate-600{color:var(--text-3)}
.text-slate-700{color:var(--text-muted)}.text-slate-800{color:var(--text)}.text-slate-900{color:var(--text)}
.text-brand-100{color:var(--brand-100)}.text-brand-600{color:var(--brand-600)}.text-brand-700{color:var(--brand-700)}
.text-amber-600{color:var(--amber-600)}.text-amber-700{color:var(--amber-700)}.text-amber-800{color:var(--amber-800)}
.text-amber-900{color:var(--amber-900)}.text-amber-950{color:var(--amber-950)}
.text-emerald-600{color:var(--emerald-600)}.text-emerald-700{color:var(--emerald-700)}.text-emerald-800{color:var(--emerald-800)}
.text-red-600{color:var(--red-600)}.text-red-700{color:var(--red-700)}
.text-rose-200{color:var(--rose-200)}.text-rose-500{color:var(--rose-500)}.text-rose-600{color:var(--rose-600)}.text-rose-700{color:var(--rose-700)}
/* Surfaces — mapped onto theme tokens. */
.bg-white{background-color:var(--surface)}.bg-white\/90{background-color:var(--surface-glass)}
.bg-slate-50{background-color:var(--surface-2)}.bg-slate-50\/60{background-color:var(--surface-2)}
.bg-slate-100{background-color:var(--surface-3)}
/* Always-dark chrome (sidebar / scrim) — NOT themed. */
.bg-slate-800{background-color:var(--slate-800)}
.bg-slate-900{background-color:var(--slate-900)}.bg-slate-900\/50{background-color:rgba(15,23,42,.5)}
.bg-brand-50{background-color:var(--brand-50)}.bg-brand-100{background-color:var(--brand-100)}
.bg-amber-50{background-color:var(--amber-50)}.bg-amber-100{background-color:var(--amber-100)}.bg-amber-500{background-color:var(--amber-500)}
.bg-emerald-50{background-color:var(--emerald-50)}.bg-red-50{background-color:var(--red-50)}
.bg-rose-50{background-color:var(--rose-50)}.bg-rose-500\/20{background-color:rgba(244,63,94,.2)}
.bg-green-500{background-color:var(--green-500)}
.border-slate-100{border-color:var(--border-soft)}.border-slate-200{border-color:var(--border)}
.border-slate-300{border-color:var(--border-strong)}.border-slate-700{border-color:var(--slate-700)}.border-slate-800{border-color:var(--slate-800)}
.border-brand-200{border-color:var(--brand-200)}
.border-amber-200{border-color:var(--amber-200)}.border-amber-300{border-color:var(--amber-300)}
.border-emerald-200{border-color:var(--emerald-200)}.border-emerald-300{border-color:var(--emerald-300)}

/* Gradients (the few combos templates use) */
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--g-from,transparent),var(--g-via,var(--g-to,transparent)),var(--g-to,transparent))}
.from-brand-400{--g-from:var(--brand-400)}.from-brand-600{--g-from:var(--brand-600)}.from-rose-500{--g-from:var(--rose-500)}
.via-brand-600{--g-via:var(--brand-600)}
.to-brand-600{--g-to:var(--brand-600)}.to-brand-800{--g-to:var(--brand-800)}.to-rose-700{--g-to:var(--rose-700)}

/* ---- 8. Borders / radius / rings / divide ----------------------------------- */
.border{border-width:1px}.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}.border-y{border-top-width:1px;border-bottom-width:1px}
.border-b-2{border-bottom-width:2px}.border-t-2{border-top-width:2px}.border-l-2{border-left-width:2px}
.border-dashed{border-style:dashed}
.rounded{border-radius:var(--r-sm)}.rounded-md{border-radius:var(--r-md)}.rounded-lg{border-radius:var(--r-lg)}
.rounded-xl{border-radius:var(--r-xl)}.rounded-2xl{border-radius:var(--r-2xl)}.rounded-full{border-radius:var(--r-full)}
.ring-1{box-shadow:0 0 0 1px var(--ring,var(--border))}
.ring-1.ring-inset{box-shadow:inset 0 0 0 1px var(--ring,var(--border))}
.ring-brand-100{--ring:var(--brand-100)}.ring-rose-400\/40{--ring:rgba(251,113,133,.4)}
.divide-y>*+*{border-top-width:1px}
.divide-slate-50>*+*{border-color:var(--border-soft)}.divide-slate-100>*+*{border-color:var(--border-soft)}

/* ---- 9. Effects / motion ---------------------------------------------------- */
.shadow-soft{box-shadow:var(--shadow-soft)}.shadow-soft-lg{box-shadow:var(--shadow-soft-lg)}
.hover\:shadow-soft-md:hover{box-shadow:var(--shadow-soft-md)}
.backdrop-blur{backdrop-filter:blur(8px)}.backdrop-blur-sm{backdrop-filter:blur(4px)}
.opacity-50{opacity:.5}
.transition{transition:color .15s var(--ease),background-color .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease),transform .15s var(--ease),opacity .15s var(--ease)}
.transition-colors{transition:color .15s var(--ease),background-color .15s var(--ease),border-color .15s var(--ease)}
.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}
.pointer-events-none{pointer-events:none}
.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}

/* ---- 10. State variants ----------------------------------------------------- */
.hover\:-translate-y-0\.5:hover{transform:translateY(-.125rem)}
.hover\:bg-amber-200:hover{background-color:var(--amber-200)}
.hover\:bg-red-100:hover{background-color:var(--red-100)}
.hover\:bg-slate-50:hover{background-color:var(--surface-2)}
.hover\:bg-slate-100:hover{background-color:var(--surface-3)}
.hover\:bg-slate-700:hover{background-color:var(--slate-700)}
.hover\:bg-slate-800:hover{background-color:var(--slate-800)}
.hover\:border-brand-300:hover{border-color:var(--brand-300)}
.hover\:text-brand-500:hover{color:var(--brand-500)}
.hover\:text-slate-700:hover{color:var(--text-muted)}
.hover\:text-slate-900:hover{color:var(--text)}
.hover\:text-white:hover{color:#fff}
.hover\:underline:hover{text-decoration-line:underline}
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:ring-brand-500:focus{box-shadow:0 0 0 3px rgba(99,102,241,.35)}
.focus-visible\:ring-2:focus-visible{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--ring,var(--brand-500))}
.focus-visible\:ring-brand-500:focus-visible{--ring:var(--brand-500)}
.group:hover .group-hover\:bg-brand-100{background-color:var(--brand-100)}
.group:hover .group-hover\:text-brand-400{color:var(--brand-400)}
.group:hover .group-hover\:translate-x-0\.5{transform:translateX(.125rem)}
.peer:checked~.peer-checked\:block{display:block}
.file\:bg-slate-100::file-selector-button{background-color:var(--surface-3)}
.file\:border-0::file-selector-button{border:0}
.file\:font-medium::file-selector-button{font-weight:500}
.file\:mr-3::file-selector-button{margin-right:.75rem}
.file\:px-3::file-selector-button{padding-left:.75rem;padding-right:.75rem}
.file\:py-1\.5::file-selector-button{padding-top:.375rem;padding-bottom:.375rem}
.file\:rounded-lg::file-selector-button{border-radius:var(--r-lg)}
.file\:text-slate-700::file-selector-button{color:var(--text-muted)}
.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}
.hover\:file\:bg-slate-200:hover::file-selector-button{background-color:var(--border)}

/* ---- 11. Responsive --------------------------------------------------------- */
@media (min-width:640px){
  .sm\:inline{display:inline}.sm\:flex{display:flex}.sm\:gap-4{gap:1rem}.sm\:grow-0{flex-grow:0}
  .sm\:w-1\/3{width:33.333333%}.sm\:w-48{width:12rem}.sm\:w-64{width:16rem}.sm\:w-72{width:18rem}
  .sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .sm\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
  .sm\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}
  .sm\:col-span-2{grid-column:span 2/span 2}.sm\:col-span-3{grid-column:span 3/span 3}
  .sm\:col-span-4{grid-column:span 4/span 4}.sm\:col-span-5{grid-column:span 5/span 5}
}
@media (min-width:768px){
  .md\:flex{display:flex}.md\:hidden{display:none}.md\:inline{display:inline}.md\:flex-col{flex-direction:column}
  .md\:w-64{width:16rem}.md\:p-8{padding:2rem}
  .md\:px-4{padding-left:1rem;padding-right:1rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}
  .md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}
  .md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
  .md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}
  .md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}
}
@media (min-width:1024px){
  .lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}
  .lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}
  .lg\:col-span-2{grid-column:span 2/span 2}.lg\:col-span-3{grid-column:span 3/span 3}.lg\:col-span-6{grid-column:span 6/span 6}
}
@media (min-width:1280px){
  .xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@supports (backdrop-filter:blur(1px)){
  .supports-\[backdrop-filter\]\:bg-white\/75{background-color:var(--surface-glass-2)}
}

/* ============================================================================
   12. COMPONENTS — premium, native, theme-aware.
   ============================================================================ */

/* Cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-soft)}
.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-soft);font-weight:600;color:var(--text)}
.card-body{padding:1.25rem}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.25rem;
  box-shadow:var(--shadow-soft);transition:transform .16s var(--ease),box-shadow .16s var(--ease),border-color .16s var(--ease);position:relative;overflow:hidden}
.stat-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--brand-500),transparent);opacity:.85}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft-md);border-color:var(--brand-400)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:600;font-size:.875rem;line-height:1.25rem;padding:.5rem .9rem;border-radius:var(--r-lg);
  border:1px solid transparent;cursor:pointer;white-space:nowrap;text-decoration:none;
  transition:background-color .15s var(--ease),color .15s var(--ease),border-color .15s var(--ease),box-shadow .15s var(--ease),transform .05s var(--ease),filter .15s var(--ease)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--brand-500)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:linear-gradient(135deg,var(--brand-500),var(--brand-700));color:#fff;box-shadow:0 8px 18px -10px rgba(79,70,229,.85)}
.btn-primary:hover{filter:brightness(1.07)}
.btn-secondary{background:var(--surface);color:var(--text-muted);border-color:var(--border-strong);box-shadow:var(--shadow-soft)}
.btn-secondary:hover{background:var(--surface-3);border-color:var(--text-faint);color:var(--text)}
.btn-ghost{background:transparent;color:var(--text-3)}
.btn-ghost:hover{background:var(--surface-3);color:var(--text)}
.btn-danger{background:linear-gradient(135deg,var(--rose-500),var(--rose-700));color:#fff;box-shadow:0 8px 18px -10px rgba(225,29,72,.8)}
.btn-danger:hover{filter:brightness(1.06)}
.btn-sm{padding:.35rem .65rem;font-size:.8125rem;border-radius:var(--r-md);gap:.375rem}

/* Form controls */
.input,.select,.textarea{display:block;width:100%;background:var(--surface);color:var(--text);
  border:1px solid var(--border-strong);border-radius:var(--r-lg);padding:.55rem .75rem;font-size:.9rem;line-height:1.4;
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease),background-color .15s var(--ease);
  -webkit-appearance:none;appearance:none}
.input::placeholder,.textarea::placeholder{color:var(--text-faint)}
.input:hover,.select:hover,.textarea:hover{border-color:var(--text-faint)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand-500);box-shadow:0 0 0 3px rgba(99,102,241,.22)}
.input:disabled,.select:disabled,.textarea:disabled{background:var(--surface-2);color:var(--text-subtle);cursor:not-allowed}
.textarea{min-height:6rem;resize:vertical}
.select{padding-right:2.25rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .65rem center;background-size:1rem}
.input-sm,.select-sm{padding-top:.3rem;padding-bottom:.3rem;font-size:.8125rem;border-radius:var(--r-md)}
.select-sm{padding-right:2rem}
.checkbox{width:1.05rem;height:1.05rem;border:1px solid var(--border-strong);border-radius:.35rem;accent-color:var(--brand-600);cursor:pointer}
.label{display:block;font-size:.8125rem;font-weight:600;color:var(--text-muted);margin-bottom:.3rem}
.field{margin-bottom:1rem}

/* Sidebar nav links (sidebar is always dark — literal slate, NOT themed) */
.nav-link{display:flex;align-items:center;gap:.7rem;padding:.55rem .75rem;border-radius:var(--r-lg);
  color:var(--slate-300);font-size:.9rem;font-weight:500;position:relative;
  transition:background-color .15s var(--ease),color .15s var(--ease)}
.nav-link svg{color:var(--slate-400);transition:color .15s var(--ease)}
.nav-link:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-link:hover svg{color:var(--brand-300)}
.nav-link-active{background:linear-gradient(90deg,rgba(99,102,241,.22),rgba(99,102,241,.04));color:#fff;font-weight:600}
.nav-link-active::before{content:"";position:absolute;left:-.75rem;top:.4rem;bottom:.4rem;width:3px;border-radius:9999px;background:linear-gradient(var(--brand-400),var(--brand-600))}
.nav-link-active svg{color:var(--brand-300)}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .55rem;border-radius:var(--r-full);
  font-size:.72rem;font-weight:600;line-height:1.4;border:1px solid transparent}
.badge-success{background:var(--success-bg);color:var(--success-fg);border-color:var(--success-bd)}
.badge-warning{background:var(--warning-bg);color:var(--warning-fg);border-color:var(--warning-bd)}
.badge-danger{background:var(--danger-bg);color:var(--danger-fg);border-color:var(--danger-bd)}
.badge-info{background:var(--info-bg);color:var(--info-fg);border-color:var(--info-bd)}
.badge-neutral{background:var(--surface-3);color:var(--text-3);border-color:var(--border)}

/* Alerts */
.alert{display:flex;gap:.6rem;padding:.8rem 1rem;border-radius:var(--r-lg);font-size:.875rem;border:1px solid transparent}
.alert-success{background:var(--success-bg);color:var(--success-fg);border-color:var(--success-bd)}
.alert-warning{background:var(--warning-bg);color:var(--warning-fg);border-color:var(--warning-bd)}
.alert-error{background:var(--danger-bg);color:var(--danger-fg);border-color:var(--danger-bd)}
.alert-info{background:var(--info-bg);color:var(--info-fg);border-color:var(--info-bd)}

/* Tables */
.table{width:100%;border-collapse:separate;border-spacing:0;font-size:.875rem}
.table thead th{text-align:left;font-weight:600;color:var(--text-subtle);font-size:.75rem;letter-spacing:.03em;
  text-transform:uppercase;padding:.6rem .75rem;background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}
.table tbody td{padding:.7rem .75rem;border-bottom:1px solid var(--border-soft);color:var(--text-muted);vertical-align:middle}
.table tbody tr{transition:background-color .12s var(--ease)}
.table tbody tr:hover{background:var(--surface-2)}
.table tbody tr:last-child td{border-bottom:0}

/* Tabs */
.tab{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .85rem;border-radius:var(--r-lg);
  font-size:.875rem;font-weight:600;color:var(--text-subtle);cursor:pointer;border:1px solid transparent;background:transparent;transition:all .15s var(--ease)}
.tab:hover{color:var(--text);background:var(--surface-3)}
.tab-active{color:var(--info-fg);background:var(--info-bg);border-color:var(--info-bd)}

/* Empty state + misc text helpers used in templates */
.empty-state{text-align:center;color:var(--text-subtle);padding:2.5rem 1rem}
.section-title{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);margin-bottom:.5rem}
.page-header{margin-bottom:1.5rem}
.block-title{font-weight:600;color:var(--text);margin-bottom:.4rem}
.muted{color:var(--text-subtle)}
.link{color:var(--link);font-weight:500}
.link:hover{color:var(--link-hover);text-decoration:underline}

/* ---- 12b. Theme toggle: show the icon for the action the click performs ----- */
.theme-icon--to-light{display:none}
:root[data-theme="dark"] .theme-icon--to-dark{display:none}
:root[data-theme="dark"] .theme-icon--to-light{display:block}

/* ============================================================================
   12c. DARK-MODE UTILITY OVERRIDES — status text/tints templates set inline
   (higher specificity via the attribute selector, so they win regardless of order).
   ============================================================================ */
:root[data-theme="dark"] .text-emerald-600,
:root[data-theme="dark"] .text-emerald-700,
:root[data-theme="dark"] .text-emerald-800{color:#6ee7b7}
:root[data-theme="dark"] .text-amber-600,
:root[data-theme="dark"] .text-amber-700,
:root[data-theme="dark"] .text-amber-800,
:root[data-theme="dark"] .text-amber-900,
:root[data-theme="dark"] .text-amber-950{color:#fcd34d}
:root[data-theme="dark"] .text-red-600,
:root[data-theme="dark"] .text-red-700{color:#fca5a5}
:root[data-theme="dark"] .text-rose-500,
:root[data-theme="dark"] .text-rose-600,
:root[data-theme="dark"] .text-rose-700{color:#fda4af}
:root[data-theme="dark"] .text-brand-600,
:root[data-theme="dark"] .text-brand-700{color:#a5b4fc}
:root[data-theme="dark"] .bg-brand-50,
:root[data-theme="dark"] .bg-brand-100{background-color:rgba(99,102,241,.16)}
:root[data-theme="dark"] .bg-amber-50,
:root[data-theme="dark"] .bg-amber-100{background-color:rgba(245,158,11,.14)}
:root[data-theme="dark"] .bg-emerald-50{background-color:rgba(16,185,129,.13)}
:root[data-theme="dark"] .bg-red-50,
:root[data-theme="dark"] .bg-rose-50{background-color:rgba(244,63,94,.13)}
:root[data-theme="dark"] .border-brand-200{border-color:rgba(99,102,241,.32)}
:root[data-theme="dark"] .border-amber-200,
:root[data-theme="dark"] .border-amber-300{border-color:rgba(245,158,11,.32)}
:root[data-theme="dark"] .border-emerald-200,
:root[data-theme="dark"] .border-emerald-300{border-color:rgba(16,185,129,.32)}
/* Lighter dropdown caret + scrollbars + selection on dark surfaces */
:root[data-theme="dark"] .select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}
:root[data-theme="dark"] *{scrollbar-color:var(--border-strong) transparent}
:root[data-theme="dark"] *::-webkit-scrollbar-thumb{background:var(--border-strong);background-clip:content-box}
:root[data-theme="dark"] ::selection{background:rgba(99,102,241,.4);color:#fff}

/* ============================================================================
   12d. MOTION POLISH — page-content entrance, drawer slide, backdrop fade,
   and a gated, smooth theme transition (app.js toggles html.theme-anim).
   ============================================================================ */
@keyframes auroraIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes auroraSlideInLeft{from{transform:translateX(-100%)}to{transform:none}}
@keyframes auroraFade{from{opacity:0}to{opacity:1}}
[data-shell] main{animation:auroraIn .42s var(--ease) both}
aside[data-sidebar].\!flex{animation:auroraSlideInLeft .26s var(--ease)}
[data-sidebar-backdrop]:not(.hidden){animation:auroraFade .2s var(--ease)}
html.theme-anim,html.theme-anim *,html.theme-anim *::before,html.theme-anim *::after{
  transition:background-color .28s var(--ease),border-color .28s var(--ease),color .22s var(--ease),fill .22s var(--ease)!important}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* ============================================================================
   12e. AUTH — modern split-screen (branded hero + form panel). ONE layout drives
   every sign-in / register / reset / MFA / SSO / platform-admin screen. The hero
   is a fixed dark panel (great in both themes); the form panel follows the theme.
   ============================================================================ */
.auth-shell{min-height:100vh;display:grid;grid-template-columns:1fr;background:var(--app-bg);
  --ac:#6366f1;--ac2:#7c3aed;--ac-soft:#a5b4fc;--ac-glow:99,102,241}
@media (min-width:1024px){.auth-shell{grid-template-columns:1.05fr 1fr}}

/* Per-page accent identity (set on .auth-shell via the auth_accent block). Drives
   the hero glow, eyebrow, check badges and the form card's primary button — so each
   sign-in screen has its own colour while sharing one layout. */
.auth-accent--indigo{--ac:#6366f1;--ac2:#7c3aed;--ac-soft:#a5b4fc;--ac-glow:99,102,241}
.auth-accent--emerald{--ac:#059669;--ac2:#0d9488;--ac-soft:#6ee7b7;--ac-glow:16,185,129}
.auth-accent--amber{--ac:#d97706;--ac2:#b45309;--ac-soft:#fcd34d;--ac-glow:245,158,11}
.auth-accent--violet{--ac:#7c3aed;--ac2:#6d28d9;--ac-soft:#c4b5fd;--ac-glow:139,92,246}
.auth-accent--rose{--ac:#e11d48;--ac2:#be123c;--ac-soft:#fda4af;--ac-glow:244,63,94}
.auth-accent--sky{--ac:#0284c7;--ac2:#2563eb;--ac-soft:#7dd3fc;--ac-glow:14,165,233}
.auth-accent--slate{--ac:#475569;--ac2:#334155;--ac-soft:#cbd5e1;--ac-glow:100,116,139}

/* Hero (left) — hidden below lg; the form panel shows a compact logo instead. */
.auth-hero{display:none}
@media (min-width:1024px){
  .auth-hero{display:flex;flex-direction:column;justify-content:space-between;gap:2rem;
    position:relative;overflow:hidden;padding:3rem 3.25rem;color:#fff;
    background:#0a0f1f;
    background:
      radial-gradient(900px 480px at 12% -8%,rgba(var(--ac-glow),.50),transparent 56%),
      radial-gradient(820px 520px at 110% 8%,rgba(var(--ac-glow),.26),transparent 55%),
      radial-gradient(700px 560px at 30% 120%,rgba(255,255,255,.05),transparent 60%),
      linear-gradient(180deg,#0a0f1f 0%,#0d1330 55%,#0a0f1f 100%)}
}
.auth-hero::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:42px 42px;-webkit-mask-image:radial-gradient(circle at 30% 18%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 18%,#000,transparent 75%)}
.auth-hero>*{position:relative;z-index:1}
.auth-hero-top{display:flex;align-items:center;gap:.75rem}
.auth-logo-name{font-weight:700;letter-spacing:-.01em;font-size:1.05rem}
.auth-eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:700;color:var(--ac-soft);margin-bottom:14px}
.auth-hero-title{font-size:clamp(28px,2.6vw,40px);line-height:1.08;font-weight:800;letter-spacing:-.02em;max-width:18ch;
  background:linear-gradient(180deg,#fff,#c7d0e6);-webkit-background-clip:text;background-clip:text;color:transparent}
.auth-hero-sub{margin-top:16px;max-width:46ch;color:#9aa6c2;font-size:15.5px;line-height:1.6}
.auth-hero-points{margin-top:28px;display:flex;flex-direction:column;gap:14px}
.auth-hero-points li{display:flex;align-items:flex-start;gap:.7rem;color:#dbe3f4;font-size:14.5px;font-weight:500}
.auth-hero-check{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:24px;height:24px;border-radius:9999px;
  background:rgba(var(--ac-glow),.22);border:1px solid rgba(var(--ac-glow),.5);color:var(--ac-soft)}
.auth-hero-check svg{width:14px;height:14px}
.auth-hero-foot{color:#64748b;font-size:13px}

/* Logo mark (shared by hero + mobile bar) */
.auth-logo{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:13px;line-height:1;
  background:linear-gradient(135deg,#818cf8,#6366f1 45%,#a855f7);color:#fff;font-weight:800;font-size:20px;
  box-shadow:0 14px 30px -12px rgba(99,102,241,.9),inset 0 1px 0 rgba(255,255,255,.35)}
.auth-logo--sm{width:34px;height:34px;border-radius:11px;font-size:17px}

/* Form panel (right) */
.auth-main{display:flex;flex-direction:column;min-height:100vh;padding:20px}
@media (min-width:640px){.auth-main{padding:28px 32px}}
.auth-main-bar{display:flex;align-items:center;gap:1rem}
.auth-mini-logo{display:inline-flex;align-items:center;gap:.6rem;color:var(--text)}
@media (min-width:1024px){.auth-mini-logo{display:none}}
.auth-actions{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.auth-card-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:24px 0}
.auth-card{width:100%;max-width:27rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-2xl);
  box-shadow:var(--shadow-soft-lg);padding:2rem;animation:auroraIn .42s var(--ease) both}
@media (min-width:480px){.auth-card{padding:2.25rem}}
.auth-tenant{display:inline-flex;align-items:center;gap:.45rem;margin-bottom:1.25rem;padding:.25rem .7rem;border-radius:9999px;
  font-size:.78rem;font-weight:600;color:var(--text-muted);background:var(--surface-3);border:1px solid var(--border)}
.auth-tenant-dot{width:.5rem;height:.5rem;border-radius:9999px;background:var(--green-500);box-shadow:0 0 0 3px rgba(34,197,94,.18)}
.auth-foot{color:var(--text-subtle);font-size:12.5px;text-align:center}
/* The form's primary button + focused fields adopt the page accent. */
.auth-card .btn-primary{background:linear-gradient(135deg,var(--ac),var(--ac2));box-shadow:0 8px 18px -10px rgba(var(--ac-glow),.85)}
.auth-card .input:focus,.auth-card .select:focus,.auth-card .textarea:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(var(--ac-glow),.22)}
.auth-card .checkbox{accent-color:var(--ac)}

/* ============================================================================
   13. ENTRY PORTAL / sign-in hub (templates/home/index.html.php).
   Intentionally a fixed dark hero — independent of the app light/dark theme.
   ============================================================================ */
.portal-body{margin:0;min-height:100vh;box-sizing:border-box;
  font-family:var(--font-sans);color:var(--slate-900);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background:#0a0f1f;
  background:
    radial-gradient(1100px 540px at 8% -10%,rgba(99,102,241,.40),transparent 58%),
    radial-gradient(980px 560px at 112% 4%,rgba(168,85,247,.30),transparent 55%),
    radial-gradient(800px 600px at 50% 120%,rgba(16,185,129,.16),transparent 60%),
    linear-gradient(180deg,#0a0f1f 0%,#0d1330 55%,#0a0f1f 100%);
  display:flex;align-items:center;justify-content:center;padding:56px 20px}
.portal{width:100%;max-width:920px}
.portal *{box-sizing:border-box}
.portal-hero{text-align:center;margin-bottom:34px}
.portal-badge{display:inline-flex;align-items:center;justify-content:center;width:66px;height:66px;border-radius:20px;line-height:1;
  background:linear-gradient(135deg,#818cf8,#6366f1 45%,#a855f7);color:#fff;font-weight:800;font-size:30px;
  box-shadow:0 16px 38px -10px rgba(99,102,241,.85),inset 0 1px 0 rgba(255,255,255,.35);margin-bottom:20px}
.portal-eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:700;color:#a5b4fc;margin:0 0 10px}
.portal-title{font-size:clamp(28px,4.4vw,38px);line-height:1.08;font-weight:800;margin:0;
  background:linear-gradient(180deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;color:transparent}
.portal-subtitle{margin:12px auto 0;max-width:560px;color:#94a3b8;font-size:15.5px;line-height:1.5}
.portal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:stretch}
@media (max-width:680px){.portal-grid{grid-template-columns:1fr}}
.portal-card{position:relative;display:flex;flex-direction:column;gap:11px;height:100%;
  background:rgba(255,255,255,.98);border:1px solid rgba(148,163,184,.18);border-radius:20px;padding:24px;overflow:hidden;text-decoration:none;color:inherit;
  box-shadow:0 24px 50px -28px rgba(2,6,23,.7);transition:transform .16s var(--ease),box-shadow .16s var(--ease),border-color .16s var(--ease)}
.portal-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;opacity:.9;background:linear-gradient(90deg,var(--accent,#6366f1),transparent)}
a.portal-card:hover{transform:translateY(-4px);box-shadow:0 34px 60px -26px rgba(2,6,23,.8);border-color:var(--accent,#6366f1)}
.portal-card--wide{grid-column:1 / -1}
.portal-card-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;flex:0 0 auto;
  background:var(--accent-soft,#eef2ff);color:var(--accent,#4f46e5)}
.portal-card-icon svg{width:24px;height:24px}
.portal-card-title{font-size:17.5px;font-weight:700;margin:0;color:#0f172a;letter-spacing:-.01em}
.portal-card-desc{margin:0;font-size:13.5px;color:#64748b;line-height:1.55}
.portal-card-cta{margin-top:auto;padding-top:6px;font-size:13.5px;font-weight:700;color:var(--accent,#4f46e5);display:inline-flex;align-items:center;gap:7px}
.portal-arrow{transition:transform .16s var(--ease);display:inline-block}
a.portal-card:hover .portal-arrow{transform:translateX(4px)}
.portal-chip{align-self:flex-start;font-size:12px;font-weight:600;color:#334155;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:3px 11px}
.portal-card--indigo{--accent:#4f46e5;--accent-soft:#eef2ff}
.portal-card--emerald{--accent:#059669;--accent-soft:#ecfdf5}
.portal-card--violet{--accent:#7c3aed;--accent-soft:#f5f3ff}
.portal-card--slate{--accent:#475569;--accent-soft:#f1f5f9}
.portal-form{margin-top:6px}
.portal-row{display:flex;gap:10px;flex-wrap:wrap}
.portal-input{flex:1 1 240px;min-width:0;background:#fff;color:#0f172a;font-size:15px;
  border:1px solid #cbd5e1;border-radius:12px;padding:12px 14px;outline:none;transition:border-color .15s,box-shadow .15s}
.portal-input::placeholder{color:#94a3b8}
.portal-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.25)}
.portal-btn{appearance:none;border:0;cursor:pointer;font-weight:600;font-size:15px;font-family:inherit;border-radius:12px;padding:12px 22px;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:filter .15s}
.portal-btn--primary{background:linear-gradient(135deg,#6366f1,#7c3aed);color:#fff;box-shadow:0 14px 26px -14px rgba(99,102,241,.85)}
.portal-btn--primary:hover{filter:brightness(1.07)}
.portal-btn--ghost{background:transparent;color:#4f46e5;padding:10px 4px;margin-top:8px}
.portal-btn--ghost:hover{text-decoration:underline}
.portal-error{margin:4px 0 12px;padding:10px 12px;border-radius:10px;background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;font-size:13.5px}
.portal-footer{margin-top:32px;display:flex;flex-direction:column;align-items:center;gap:14px;font-size:13px}
.portal-langs{background:rgba(255,255,255,.92);border:1px solid rgba(148,163,184,.3);padding:5px 6px;border-radius:12px;box-shadow:0 10px 24px -16px rgba(0,0,0,.6)}
.portal-foot-note{color:#64748b;margin:0;text-align:center}
.portal-diag{font-size:12px;color:#64748b;display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.portal-diag code{color:#94a3b8}

/* ============================================================================
   14. PRINT (invoices / reports — browser print-to-PDF). ALWAYS light, so a
   financial document prints identically regardless of the on-screen theme.
   ============================================================================ */
@media print{
  :root,:root[data-theme="dark"]{
    --app-bg:#fff;--surface:#fff;--surface-2:#fff;--surface-3:#fff;
    --text:#0f172a;--text-muted:#334155;--text-3:#475569;--text-subtle:#64748b;--text-faint:#94a3b8;
    --border:#e5e7eb;--border-soft:#eef2f7;--border-strong:#cbd5e1;color-scheme:light}
  body{background:#fff;color:#0f172a}
  [data-sidebar],[data-sidebar-backdrop],#app-progress{display:none!important}
  .card{box-shadow:none;border-color:#e5e7eb}
}

/* Font smoothing (used on body/layout roots) */
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
