/* sherllympn — Atelier Rose Design System
   Direction: sophisticated feminine premium — warm neutrals, deep rose primary,
   champagne gold for verified/earned. Luxury cosmetics × fintech rigor.
   Reasons (every choice earns its place):
   - Deep Rose (not pink): mature, confident, feminine without being juvenile.
   - Champagne Gold (replaces green): "earned" feels aspirational & premium.
   - Ivory surfaces, plum ink: warm tones set Sherlly apart from default blue/gray SaaS.
   - Numbers in JetBrains Mono: tabular alignment for money columns.
   - Motion disciplined: page entry, card stagger, hover lift, focus ring, bar fill.
     Every animation explains state change — not decoration.
*/
:root{
  /* ── Palette ────────────────────────────────────────────────── */
  --bg:            #FBF7F3;            /* warm ivory */
  --bg-elev:       #FFFFFF;
  --bg-sunken:     #F3EAE0;            /* soft cream */
  --bg-tint:       #FCEEF0;            /* rose wash */

  --ink:           #2A1B24;            /* plum-charcoal (warm near-black) */
  --ink-2:         #4A3540;
  --ink-3:         #7A6570;
  --ink-4:         #A99AA2;

  --line:          #EDDFD6;
  --line-2:        #E0CEC2;

  --primary:       #B0365F;            /* deep rose */
  --primary-600:   #952C50;
  --primary-700:   #7D2441;
  --primary-50:    #FBE4EC;
  --primary-100:   #F7CCD9;

  --accent:        #C89B5C;            /* champagne gold (earned/verified) */
  --accent-600:    #AE8244;
  --accent-50:     #F8EEDC;

  --mauve:         #8B5A7D;            /* secondary accent — compliance chips */
  --mauve-50:      #F1E6EE;

  --warning:       #C37A1D;            /* warm amber */
  --warning-50:    #FBEBD4;
  --danger:        #B63A4A;            /* rose-red */
  --danger-50:     #FADFE3;
  --info:          #7A5595;            /* plum-info */
  --info-50:       #EEE2F2;

  /* Dark nav — warm plum, not cold navy */
  --nav-bg:        #1A1318;
  --nav-bg-2:      #241820;
  --nav-ink:       #D8C8CF;
  --nav-ink-dim:   #8E7882;
  --nav-active:    #3B2431;

  /* Typography */
  --f-display: 'Fraunces','Playfair Display',Georgia,serif;  /* headings — elegant serif */
  --f-sans:    'Inter Tight','Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --f-mono:    'JetBrains Mono','SF Mono',ui-monospace,Menlo,Consolas,monospace;

  /* Radius & shadow (warmer, softer than blue system) */
  --r-1: 6px; --r-2: 10px; --r-3: 14px; --r-4: 20px;
  --shadow-1: 0 1px 2px rgba(42,27,36,.05), 0 1px 1px rgba(42,27,36,.04);
  --shadow-2: 0 8px 20px -8px rgba(176,54,95,.15), 0 3px 8px rgba(42,27,36,.06);
  --shadow-3: 0 20px 44px -20px rgba(176,54,95,.28), 0 10px 22px -12px rgba(42,27,36,.12);

  /* Motion */
  --mo-fast: 140ms;  --mo-ui: 200ms;  --mo-med: 280ms;  --mo-slow: 420ms;
  --ease-std: cubic-bezier(.2,.8,.2,1);
  --ease-emp: cubic-bezier(.2,0,0,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  /* Spacing (8pt) */
  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important; }
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--f-sans); color:var(--ink);
  background:
    radial-gradient(1200px 600px at -10% -20%, rgba(200,155,92,.08), transparent 60%),
    radial-gradient(900px 500px at 110% 0%, rgba(176,54,95,.06), transparent 60%),
    var(--bg);
  background-attachment: fixed;
  -webkit-font-smoothing:antialiased;
  font-size:14px; line-height:1.5;
  font-feature-settings:"cv02","cv03","cv04","ss01";
}
a{ color:var(--primary); text-decoration:none; position:relative; transition:color var(--mo-ui) var(--ease-std); }
a:hover{ color:var(--primary-600); }
h1,h2,h3,h4{ font-family:var(--f-display); letter-spacing:-.015em; color:var(--ink); margin:0; font-weight:600; }
h1{ font-size:28px; line-height:1.15; }
h2{ font-size:19px; line-height:1.25; font-weight:600; }
h3{ font-size:15px; line-height:1.3; font-family:var(--f-sans); font-weight:650; letter-spacing:-.005em; }
.muted{ color:var(--ink-3); }
.mono,.num{ font-family:var(--f-mono); font-variant-numeric:tabular-nums; letter-spacing:-.01em; }

/* ── Layout ──────────────────────────────────────────────────── */
.app{ display:grid; grid-template-columns:248px 1fr; min-height:100vh; }
.sidebar{
  background:
    radial-gradient(600px 260px at 0% 0%, rgba(176,54,95,.18), transparent 60%),
    linear-gradient(180deg, var(--nav-bg) 0%, var(--nav-bg-2) 100%);
  color:var(--nav-ink); padding:var(--s-5) var(--s-3); position:sticky; top:0; height:100vh; overflow:auto;
  border-right:1px solid rgba(200,155,92,.08);
}
.sidebar .brand{
  display:flex; align-items:center; gap:14px;
  padding:6px var(--s-3) var(--s-5);
  position:relative;
}
.sidebar .brand::after{
  content:""; position:absolute; left:12px; right:12px; bottom:10px; height:1px;
  background:linear-gradient(90deg, transparent, rgba(200,155,92,.32), transparent);
  transform-origin:center; animation:brandLineIn var(--mo-slow) var(--ease-emp) both;
}
@keyframes brandLineIn{ from{ transform:scaleX(0); opacity:0; } to{ transform:scaleX(1); opacity:1; } }

.sidebar .brand-mark{
  width:56px; height:56px; border-radius:14px; display:grid; place-items:center; flex:none;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.28), transparent 52%),
    conic-gradient(from 200deg, #B0365F 0%, #C89B5C 45%, #D9B47E 55%, #B0365F 100%);
  color:#fff; font-weight:700; font-family:var(--f-display);
  font-size:22px; letter-spacing:-.04em; line-height:1;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.2),
    inset 0 -6px 14px rgba(26,19,24,.35),
    0 14px 30px -10px rgba(176,54,95,.6);
  text-shadow:0 1px 2px rgba(26,19,24,.3);
  position:relative; overflow:hidden;
  transition:transform var(--mo-med) var(--ease-spring), box-shadow var(--mo-ui);
  animation:brandMarkIn .6s var(--ease-spring) both;
}
@keyframes brandMarkIn{
  0%   { transform:scale(.55) rotate(-20deg); opacity:0; }
  60%  { transform:scale(1.08) rotate(4deg);  opacity:1; }
  100% { transform:scale(1)    rotate(0);     opacity:1; }
}
/* Soft gold sheen sweep every 6s */
.sidebar .brand-mark::before{
  content:""; position:absolute; inset:-30% -30%;
  background:linear-gradient(115deg, transparent 42%, rgba(255,255,255,.35) 50%, transparent 58%);
  transform:translateX(-120%);
  animation:brandSheen 6s ease-in-out infinite;
}
@keyframes brandSheen{
  0%,60%  { transform:translateX(-120%); }
  75%     { transform:translateX(120%); }
  100%    { transform:translateX(120%); }
}
.sidebar .brand:hover .brand-mark{
  transform:rotate(-4deg) scale(1.06);
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.28),
    inset 0 -6px 14px rgba(26,19,24,.35),
    0 18px 40px -10px rgba(200,155,92,.7);
}

.sidebar .brand-text{ display:flex; flex-direction:column; min-width:0;
  animation:brandTextIn .6s var(--ease-emp) .18s both; }
@keyframes brandTextIn{ from{ opacity:0; transform:translateX(-8px); } to{ opacity:1; transform:none; } }

.sidebar .brand-name{
  font-family:var(--f-display); font-weight:600; letter-spacing:-.02em;
  color:#fff; font-size:22px; line-height:1.05;
  background:linear-gradient(180deg, #FFFFFF 0%, #F1D9DF 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.sidebar .brand-sub{
  color:var(--accent); font-size:9.5px; margin-top:6px;
  text-transform:uppercase; letter-spacing:.18em; font-weight:600;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  opacity:0; animation:brandSubIn .5s var(--ease-emp) .32s forwards;
}
@keyframes brandSubIn{ from{ opacity:0; transform:translateY(3px); } to{ opacity:1; transform:none; } }
.sidebar .brand-sub::before{
  content:""; display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--accent); margin-right:8px; vertical-align:middle;
  box-shadow:0 0 8px rgba(200,155,92,.8);
  animation:brandDot 2.4s ease-in-out infinite;
}
@keyframes brandDot{
  0%,100%{ box-shadow:0 0 0 0 rgba(200,155,92,.6); }
  50%    { box-shadow:0 0 0 5px rgba(200,155,92,0); }
}
.nav-section{ color:var(--nav-ink-dim); font-size:10.5px; text-transform:uppercase; letter-spacing:.14em; padding:var(--s-5) var(--s-3) var(--s-2); font-weight:600; }
.nav-link{
  display:flex; align-items:center; gap:10px; padding:9px var(--s-3); border-radius:8px;
  color:var(--nav-ink); position:relative; font-weight:500;
  transition:background var(--mo-ui) var(--ease-std), color var(--mo-ui), transform var(--mo-fast);
}
.nav-link:hover{ background:rgba(200,155,92,.08); color:#fff; text-decoration:none; transform:translateX(2px); }
.nav-link.active{ background:var(--nav-active); color:#fff; }
.nav-link.active::before{
  content:""; position:absolute; left:0; top:8px; bottom:8px; width:3px; border-radius:0 3px 3px 0;
  background:linear-gradient(180deg,#B0365F,#C89B5C);
  box-shadow:0 0 12px rgba(200,155,92,.45);
}
.nav-ico{ width:18px; height:18px; opacity:.85; }

.main{ min-width:0; display:flex; flex-direction:column; }
.topbar{
  background:rgba(255,255,255,.82); backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
  padding:var(--s-3) var(--s-5); display:flex; justify-content:space-between; align-items:center;
  position:sticky; top:0; z-index:10;
}
.topbar .crumbs{ color:var(--ink-3); font-size:13px; font-weight:500; }
.topbar .user-chip{
  display:flex; align-items:center; gap:10px; padding:6px 12px 6px 6px;
  border-radius:999px; background:var(--bg-sunken); border:1px solid var(--line);
  transition:box-shadow var(--mo-ui), transform var(--mo-fast);
}
.topbar .user-chip:hover{ box-shadow:var(--shadow-2); transform:translateY(-1px); }
.avatar{
  width:28px; height:28px; border-radius:50%;
  background:conic-gradient(from 200deg, #B0365F, #C89B5C 55%, #B0365F);
  color:#fff; display:grid; place-items:center; font-size:11px; font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.2);
}

.content{
  padding:var(--s-6); max-width:1400px; width:100%;
  animation:pageEnter var(--mo-slow) var(--ease-emp);
  position:relative;
}
@keyframes pageEnter{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }

/* Ambient gold-dust particle layer behind every page — subtle, always on */
.main::before{
  content:""; position:fixed; inset:0 0 0 248px; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 18%, rgba(200,155,92,.28), transparent 60%),
    radial-gradient(1.5px 1.5px at 78% 42%, rgba(176,54,95,.22), transparent 60%),
    radial-gradient(2px 2px at 40% 72%, rgba(200,155,92,.18), transparent 60%),
    radial-gradient(1px 1px at 88% 82%, rgba(200,155,92,.22), transparent 60%),
    radial-gradient(1.5px 1.5px at 22% 88%, rgba(176,54,95,.18), transparent 60%);
  background-size: 720px 720px;
  opacity:.6;
  animation:dust 28s ease-in-out infinite alternate;
}
@media (max-width:980px){ .main::before{ inset:0; } }
@keyframes dust{ from{ transform:translate(0,0); } to{ transform:translate(22px,-18px); } }
.main > *{ position:relative; z-index:1; }

/* Page-header h1 — universal entry shimmer + underline grow on every page */
.page-header .title h1{
  display:inline-block; position:relative;
  background:linear-gradient(100deg, var(--ink) 0%, var(--primary) 45%, var(--accent) 60%, var(--ink) 80%);
  background-size:240% 100%;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:pageH1In .7s var(--ease-emp) both, pageH1Shine 9s ease-in-out 1.4s infinite;
}
@keyframes pageH1In{
  0%  { opacity:0; transform:translateY(10px); letter-spacing:.02em; filter:blur(6px); }
  100%{ opacity:1; transform:none;             letter-spacing:-.015em; filter:blur(0); }
}
@keyframes pageH1Shine{
  0%,70%  { background-position:0% 50%; }
  85%     { background-position:100% 50%; }
  100%    { background-position:100% 50%; }
}
.page-header .title::after{
  content:""; display:block; height:2px; width:0; margin-top:8px;
  background:linear-gradient(90deg, var(--primary), var(--accent), transparent);
  animation:pageHUnder .9s var(--ease-emp) .5s forwards;
  box-shadow:0 0 8px rgba(200,155,92,.35);
}
@keyframes pageHUnder{ to{ width:84px; } }
.page-header .title .sub{ animation:fadeUp .55s var(--ease-emp) .32s both; }

/* Button: subtle gold glint across primary action every 8s */
.btn-primary::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(115deg, transparent 42%, rgba(255,255,255,.28) 50%, transparent 58%);
  transform:translateX(-130%);
  animation:btnGlint 8s ease-in-out 2s infinite;
}
@keyframes btnGlint{
  0%,70%{ transform:translateX(-130%); }
  85%   { transform:translateX(130%); }
  100%  { transform:translateX(130%); }
}

/* Nav link hover — subtle gold sheen sweep */
.nav-link::after{
  content:""; position:absolute; inset:0; border-radius:8px; pointer-events:none;
  background:linear-gradient(115deg, transparent 42%, rgba(200,155,92,.14) 50%, transparent 58%);
  transform:translateX(-120%); transition:transform .6s var(--ease-emp);
}
.nav-link:hover::after{ transform:translateX(120%); }

.page-header{ display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:var(--s-5); gap:var(--s-4); flex-wrap:wrap; }
.page-header .title{ display:flex; flex-direction:column; gap:4px; }
.page-header .sub{ color:var(--ink-3); font-size:13px; }

/* ── KPI cards ───────────────────────────────────────────────── */
.kpi-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:var(--s-4); margin-bottom:var(--s-5); }
.kpi{
  background:var(--bg-elev); border:1px solid var(--line); border-radius:var(--r-3);
  padding:var(--s-4) var(--s-5); position:relative; overflow:hidden;
  transition:transform var(--mo-ui) var(--ease-std), box-shadow var(--mo-ui), border-color var(--mo-ui);
  box-shadow:var(--shadow-1);
}
.kpi::before{
  content:""; position:absolute; inset:0 0 auto 0; height:2px;
  background:linear-gradient(90deg, transparent, var(--primary), var(--accent), transparent);
  opacity:0; transition:opacity var(--mo-med) var(--ease-std);
}
.kpi:hover{ transform:translateY(-2px); box-shadow:var(--shadow-2); border-color:var(--line-2); }
.kpi:hover::before{ opacity:.9; }
.kpi .label{ font-size:11px; color:var(--ink-3); text-transform:uppercase; letter-spacing:.1em; font-weight:600; }
.kpi .value{
  font-family:var(--f-display); font-variant-numeric:tabular-nums; font-weight:600;
  font-size:30px; color:var(--ink); margin-top:6px; letter-spacing:-.02em; line-height:1.1;
}
.kpi .hint{ font-size:12px; color:var(--ink-3); margin-top:4px; }
.kpi.attn{
  border-color:#E8B878; background:linear-gradient(180deg, #FDF5E7 0%, var(--bg-elev) 60%);
}
.kpi.attn .label{ color:var(--accent-600); }
.kpi.attn::after{
  content:""; position:absolute; top:14px; right:14px; width:8px; height:8px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 0 rgba(200,155,92,.5); animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow:0 0 0 0 rgba(200,155,92,.45); }
  50%    { box-shadow:0 0 0 8px rgba(200,155,92,0); }
}
.kpi.good{
  border-color:#E7C9AE; background:linear-gradient(180deg, #FBF1E4 0%, var(--bg-elev) 60%);
}
.kpi.good .label{ color:var(--accent-600); }
.kpi.bad { border-color:#ECBCC2; background:linear-gradient(180deg, #FCE8EB 0%, var(--bg-elev) 60%); }
.kpi-spark{
  position:absolute; right:-8px; bottom:-14px; font-family:var(--f-display);
  font-size:120px; font-weight:700; color:var(--primary); opacity:.05;
  pointer-events:none; line-height:1; letter-spacing:-.04em;
}

/* ── Cards / sections ───────────────────────────────────────── */
.card{
  background:var(--bg-elev); border:1px solid var(--line); border-radius:var(--r-3);
  overflow:hidden; box-shadow:var(--shadow-1);
  transition:box-shadow var(--mo-ui), border-color var(--mo-ui);
}
.card:hover{ border-color:var(--line-2); }
.card-head{
  padding:var(--s-4) var(--s-5); border-bottom:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:center; gap:var(--s-3);
  background:linear-gradient(180deg, rgba(247,228,234,.3) 0%, transparent 100%);
}
.card-head .title{ font-weight:650; font-size:14px; color:var(--ink); font-family:var(--f-sans); letter-spacing:-.005em; }
.card-head .sub{ color:var(--ink-3); font-size:12px; }
.card-body{ padding:var(--s-5); }
.card-body.tight{ padding:0; }

.grid-2{ display:grid; grid-template-columns:2fr 1fr; gap:var(--s-4); }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:var(--s-4); }
@media (max-width:980px){ .grid-2,.grid-3{ grid-template-columns:1fr; } .app{ grid-template-columns:1fr; } .sidebar{ position:static; height:auto; } }
@media (max-width:640px){ .content{ padding:var(--s-4); } .kpi .value{ font-size:26px; } h1{ font-size:24px; } }

/* ── Tables ─────────────────────────────────────────────────── */
table.t{ width:100%; border-collapse:separate; border-spacing:0; font-size:13px; }
table.t th, table.t td{ padding:11px var(--s-4); text-align:left; border-bottom:1px solid var(--line); }
table.t th{
  font-weight:600; color:var(--ink-3); font-size:11px; text-transform:uppercase; letter-spacing:.08em;
  background:var(--bg-sunken);
}
table.t tbody tr{ transition:background var(--mo-fast); }
table.t tbody tr:hover{ background:var(--bg-tint); }
table.t td.num, table.t th.num{ text-align:right; font-family:var(--f-mono); font-variant-numeric:tabular-nums; }

.pill{
  display:inline-flex; align-items:center; gap:6px; padding:3px 10px; border-radius:999px;
  font-size:11px; font-weight:600; border:1px solid; letter-spacing:.02em;
  transition:transform var(--mo-fast);
}
.pill:hover{ transform:translateY(-1px); }
.pill-ok   { background:var(--accent-50);  color:var(--accent-600); border-color:#E3C18E; }
.pill-warn { background:var(--warning-50); color:#8F5500;           border-color:#EFC17A; }
.pill-bad  { background:var(--danger-50);  color:#7A1F2B;           border-color:#E8B2B9; }
.pill-info { background:var(--info-50);    color:#4C3163;           border-color:#D4C0DC; }
.pill-rose { background:var(--primary-50); color:var(--primary-700); border-color:#EDB8CB; }
.pill-mute { background:var(--bg-sunken);  color:var(--ink-3);      border-color:var(--line-2); }

/* ── Buttons & forms ────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:10px;
  border:1px solid var(--line-2); background:var(--bg-elev); color:var(--ink);
  font-weight:600; font-size:13px; cursor:pointer; position:relative; overflow:hidden;
  transition:transform var(--mo-fast), background var(--mo-ui), box-shadow var(--mo-ui), border-color var(--mo-ui);
}
.btn:hover{ background:var(--bg-sunken); border-color:var(--line-2); box-shadow:var(--shadow-1); }
.btn:active{ transform:translateY(1px); }
.btn-primary{
  background:linear-gradient(180deg, #BC4570 0%, var(--primary) 100%);
  color:#fff; border-color:var(--primary-600);
  box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 6px 14px -6px rgba(176,54,95,.45);
}
.btn-primary:hover{ background:linear-gradient(180deg, var(--primary) 0%, var(--primary-600) 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 10px 20px -8px rgba(176,54,95,.55); }
.btn-primary::after{
  content:""; position:absolute; inset:0; background:radial-gradient(120px 60px at var(--mx,50%) var(--my,50%), rgba(255,255,255,.25), transparent 70%);
  opacity:0; transition:opacity var(--mo-ui);
}
.btn-primary:hover::after{ opacity:1; }
.btn-gold{
  background:linear-gradient(180deg, #D4AA6F 0%, var(--accent) 100%);
  color:#fff; border-color:var(--accent-600);
  box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 6px 14px -6px rgba(200,155,92,.45);
}
.btn-ghost{ background:transparent; border-color:transparent; color:var(--ink-3); }
.btn-ghost:hover{ color:var(--ink); background:var(--bg-sunken); }
.btn-sm{ padding:6px 12px; font-size:12px; }

.input, select, textarea{
  width:100%; padding:10px 12px; border:1px solid var(--line-2); border-radius:10px;
  font:inherit; background:#fff; color:var(--ink);
  transition:border-color var(--mo-ui), box-shadow var(--mo-ui), background var(--mo-ui);
}
.input:hover, select:hover{ border-color:#D8BDAE; }
.input:focus, select:focus, textarea:focus{
  outline:none; border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(176,54,95,.14);
}
label{ display:block; font-size:11px; color:var(--ink-3); font-weight:600;
  margin-bottom:6px; text-transform:uppercase; letter-spacing:.06em; }

/* ── Flash messages ─────────────────────────────────────────── */
.flash{
  display:flex; gap:10px; align-items:flex-start;
  padding:12px 14px; border-radius:10px; border:1px solid;
  margin-bottom:var(--s-4); animation:slideDown var(--mo-med) var(--ease-emp);
  box-shadow:var(--shadow-1);
}
.flash-ok   { background:var(--accent-50); border-color:#E3C18E; color:var(--accent-600); }
.flash-error{ background:var(--danger-50); border-color:#E8B2B9; color:#7A1F2B; }
@keyframes slideDown{ from{opacity:0; transform:translateY(-6px);} to{opacity:1; transform:none;} }

/* ── Auth screen ────────────────────────────────────────────── */
.auth-wrap{ min-height:100vh; display:grid; grid-template-columns:1.1fr 1fr; }
@media (max-width:900px){ .auth-wrap{ grid-template-columns:1fr; } .auth-art{ display:none; } }
.auth-art{
  background:
    radial-gradient(1200px 600px at -10% 110%, rgba(200,155,92,.26), transparent 60%),
    radial-gradient(900px 500px at 110% -10%, rgba(176,54,95,.40), transparent 60%),
    linear-gradient(155deg, #1A1318 0%, #2A1B24 50%, #3B2431 100%);
  color:#fff; position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:space-between; padding:var(--s-7);
}
.auth-art::before{
  /* subtle "gold dust" texture — meaningful: brand character signal */
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(200,155,92,.5), transparent),
    radial-gradient(1px 1px at 70% 60%, rgba(200,155,92,.35), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(176,54,95,.4), transparent),
    radial-gradient(1px 1px at 85% 25%, rgba(200,155,92,.45), transparent);
  background-size: 380px 380px; opacity:.55;
  animation:drift 18s ease-in-out infinite alternate;
}
@keyframes drift{ from{ transform:translate(0,0); } to{ transform:translate(12px,-10px); } }
.auth-art .brand{ display:flex; gap:12px; align-items:center; position:relative; z-index:2; }
.auth-art .brand-mark{
  width:56px; height:56px; border-radius:14px; position:relative; overflow:hidden;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.28), transparent 52%),
    conic-gradient(from 200deg, #B0365F 0%, #C89B5C 45%, #D9B47E 55%, #B0365F 100%);
  display:grid; place-items:center; font-weight:700; font-family:var(--f-display); font-size:22px; color:#fff; letter-spacing:-.04em;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.22),
    inset 0 -6px 14px rgba(26,19,24,.35),
    0 14px 30px -8px rgba(176,54,95,.65);
  text-shadow:0 1px 2px rgba(26,19,24,.3);
  animation:brandMarkIn .7s var(--ease-spring) both;
}
.auth-art .brand-mark::before{
  content:""; position:absolute; inset:-30% -30%;
  background:linear-gradient(115deg, transparent 42%, rgba(255,255,255,.4) 50%, transparent 58%);
  transform:translateX(-120%);
  animation:brandSheen 6s ease-in-out 1.2s infinite;
}
.auth-art .pitch h1{ animation:fadeUp .7s var(--ease-emp) .25s both; }
.auth-art .pitch p { animation:fadeUp .7s var(--ease-emp) .38s both; }
.auth-art .pitch{ max-width:500px; position:relative; z-index:2; }
.auth-art .pitch h1{
  color:#fff; font-size:38px; line-height:1.1; letter-spacing:-.02em; font-weight:500;
  font-family:var(--f-display);
}
.auth-art .pitch h1 em{ font-style:italic; color:var(--accent); }
.auth-art .pitch p{ color:#C6B4BA; margin-top:14px; font-size:14px; line-height:1.6; }
.auth-art .principles{ display:grid; gap:10px; margin-top:26px; max-width:500px; }
.auth-art .principle{
  display:flex; gap:12px; align-items:flex-start; font-size:13.5px; color:#D8C4CA;
  animation:slideInL var(--mo-slow) var(--ease-emp) both;
}
.auth-art .principle:nth-child(1){ animation-delay:200ms; }
.auth-art .principle:nth-child(2){ animation-delay:300ms; }
.auth-art .principle:nth-child(3){ animation-delay:400ms; }
.auth-art .principle:nth-child(4){ animation-delay:500ms; }
@keyframes slideInL{ from{ opacity:0; transform:translateX(-10px); } to{ opacity:1; transform:none; } }
.auth-art .principle .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--accent); margin-top:7px; flex:none;
  box-shadow:0 0 0 4px rgba(200,155,92,.2);
}
.auth-art .chip{
  display:inline-flex; gap:8px; align-items:center; padding:6px 12px; border-radius:999px;
  background:rgba(200,155,92,.12); color:var(--accent); font-size:12px; font-weight:600;
  border:1px solid rgba(200,155,92,.25); letter-spacing:.02em;
}
.auth-form-wrap{ display:grid; place-items:center; padding:var(--s-7); }
.auth-form{ width:100%; max-width:400px; }
.auth-form h2{ font-size:26px; margin-bottom:6px; font-family:var(--f-display);
  animation:fadeUp .55s var(--ease-emp) .2s both; }
.auth-form .sub{ animation:fadeUp .55s var(--ease-emp) .28s both; }
.auth-form .field{ animation:fadeUp .55s var(--ease-emp) both; }
.auth-form .field:nth-of-type(1){ animation-delay:.36s; }
.auth-form .field:nth-of-type(2){ animation-delay:.44s; }
.auth-form .submit{ animation:fadeUp .55s var(--ease-emp) .54s both, submitGlow 3.6s ease-in-out .9s infinite; }
.auth-foot{ animation:fadeUp .55s var(--ease-emp) .7s both; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(8px); } to{ opacity:1; transform:none; } }
@keyframes submitGlow{
  0%,100%{ box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 6px 14px -6px rgba(176,54,95,.45); }
  50%    { box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 14px 26px -8px rgba(200,155,92,.55); }
}
.auth-form .sub{ color:var(--ink-3); margin-bottom:var(--s-5); }
.auth-form .field{ margin-bottom:var(--s-3); }
.auth-form .field input{ height:44px; }
.auth-form .submit{ width:100%; justify-content:center; height:46px; font-size:14px; margin-top:4px; }
.auth-foot{ font-size:11.5px; color:var(--ink-3); margin-top:var(--s-5); text-align:center; line-height:1.5; }

/* ── List items ─────────────────────────────────────────────── */
.list{ display:flex; flex-direction:column; }
.list-row{
  padding:12px var(--s-5); border-bottom:1px solid var(--line);
  display:flex; justify-content:space-between; align-items:center; gap:var(--s-3);
  transition:background var(--mo-fast);
}
.list-row:hover{ background:var(--bg-tint); }
.list-row:last-child{ border-bottom:none; }
.list-row .lead{ display:flex; flex-direction:column; }
.list-row .lead strong{ font-weight:600; font-size:13.5px; color:var(--ink); }
.list-row .lead span{ color:var(--ink-3); font-size:12px; margin-top:2px; }
.list-row .meta{ color:var(--ink-3); font-size:12px; }

/* ── Progress bar ───────────────────────────────────────────── */
.bar{ height:6px; background:var(--bg-sunken); border-radius:999px; overflow:hidden; position:relative; }
.bar > span{
  display:block; height:100%;
  background:linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
  border-radius:inherit;
  transition:width var(--mo-slow) var(--ease-std);
  box-shadow:0 0 8px rgba(200,155,92,.4);
}

/* ── Utilities ─────────────────────────────────────────────── */
.flex{ display:flex; } .items-center{ align-items:center; } .justify-between{ justify-content:space-between; }
.gap-1{gap:4px;} .gap-2{gap:8px;} .gap-3{gap:12px;} .gap-4{gap:16px;}
.mt-2{margin-top:8px;} .mt-3{margin-top:12px;} .mt-4{margin-top:16px;} .mt-5{margin-top:24px;}
.w-full{width:100%;} .text-right{text-align:right;} .text-center{text-align:center;}
.hide-sm{ display:initial; } @media (max-width:640px){ .hide-sm{ display:none; } }

/* ── Motion primitives ──────────────────────────────────────── */
.reveal{ opacity:0; transform:translateY(8px); animation:reveal var(--mo-slow) var(--ease-emp) forwards; }
.reveal.d1{ animation-delay:60ms; }
.reveal.d2{ animation-delay:120ms; }
.reveal.d3{ animation-delay:180ms; }
.reveal.d4{ animation-delay:240ms; }
@keyframes reveal{ to{ opacity:1; transform:none; } }

.skeleton{
  background:linear-gradient(90deg, var(--bg-sunken) 25%, var(--bg-tint) 37%, var(--bg-sunken) 63%);
  background-size:400% 100%; animation:shimmer 1.4s ease-in-out infinite; border-radius:6px;
}
@keyframes shimmer{ 0%{background-position:100% 0;} 100%{background-position:-100% 0;} }

/* Count-up animation for KPI values (JS-driven) */
.kpi .value[data-count]{ font-variant-numeric:tabular-nums; }

/* Focus-visible ring — consistent across keyboard nav */
:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(176,54,95,.25); border-radius:8px; }

/* Selection color — brand-aligned */
::selection{ background:var(--primary-100); color:var(--primary-700); }

/* ── Dashboard masthead ──────────────────────────────────── */
.masthead{
  position:relative; overflow:hidden; isolation:isolate;
  border-radius:var(--r-4);
  padding:var(--s-7) var(--s-6);
  margin-bottom:var(--s-6);
  background:
    linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,.2) 100%),
    linear-gradient(135deg, #2A1B24 0%, #3B2431 55%, #1A1318 100%);
  color:#fff;
  box-shadow:0 24px 60px -30px rgba(26,19,24,.5), 0 10px 22px -12px rgba(176,54,95,.35);
  border:1px solid rgba(200,155,92,.2);
  animation:mhIn .7s var(--ease-emp) both;
}
@keyframes mhIn{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:none; } }

.mh-glow{ position:absolute; border-radius:50%; filter:blur(60px); pointer-events:none; z-index:-1; }
.mh-glow-1{
  width:380px; height:380px; top:-160px; left:-80px;
  background:radial-gradient(circle, rgba(176,54,95,.55), transparent 62%);
  animation:mhFloat1 14s ease-in-out infinite alternate;
}
.mh-glow-2{
  width:420px; height:420px; top:-120px; right:-140px;
  background:radial-gradient(circle, rgba(200,155,92,.5), transparent 62%);
  animation:mhFloat2 17s ease-in-out infinite alternate;
}
@keyframes mhFloat1{ from{ transform:translate(0,0); } to{ transform:translate(40px,30px); } }
@keyframes mhFloat2{ from{ transform:translate(0,0); } to{ transform:translate(-50px,40px); } }

.mh-mesh{
  position:absolute; inset:0; pointer-events:none; z-index:-1; opacity:.35;
  background-image:
    radial-gradient(1px 1px at 15% 30%, rgba(200,155,92,.7), transparent),
    radial-gradient(1px 1px at 70% 55%, rgba(255,255,255,.5),   transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(176,54,95,.6),  transparent),
    radial-gradient(1px 1px at 85% 20%, rgba(200,155,92,.5),  transparent),
    radial-gradient(1px 1px at 55% 15%, rgba(255,255,255,.4),  transparent);
  background-size:360px 360px;
  animation:mhDrift 20s ease-in-out infinite alternate;
}
@keyframes mhDrift{ from{ transform:translate(0,0); } to{ transform:translate(18px,-14px); } }

.mh-inner{ display:flex; align-items:flex-end; justify-content:space-between; gap:var(--s-5); flex-wrap:wrap; position:relative; }
.mh-left{ display:flex; flex-direction:column; gap:14px; min-width:0; }
.mh-right{ display:flex; gap:10px; flex-wrap:wrap; animation:mhFade .7s var(--ease-emp) .5s both; }
@keyframes mhFade{ from{ opacity:0; transform:translateY(6px); } to{ opacity:1; transform:none; } }

.mh-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  color:var(--accent); font-size:10.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase;
  animation:mhFade .6s var(--ease-emp) .1s both;
}
.mh-dot{
  width:7px; height:7px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 10px rgba(200,155,92,.9);
  animation:mhDot 2.4s ease-in-out infinite;
}
@keyframes mhDot{
  0%,100%{ box-shadow:0 0 0 0 rgba(200,155,92,.7), 0 0 10px rgba(200,155,92,.8); }
  50%    { box-shadow:0 0 0 8px rgba(200,155,92,0), 0 0 12px rgba(200,155,92,.9); }
}

.mh-title{
  font-family:var(--f-display); font-weight:500;
  font-size:clamp(46px, 6.4vw, 84px);
  line-height:.98; letter-spacing:-.04em;
  color:#fff; margin:0;
  position:relative;
}
.mh-title .mh-word{
  display:inline-block; position:relative;
  background:linear-gradient(100deg, #FFFFFF 0%, #F7E1D9 35%, #E8C68C 58%, #FFFFFF 78%);
  background-size:220% 100%;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  animation:mhWord .9s var(--ease-emp) .15s both, mhShine 7s ease-in-out 1.2s infinite;
}
@keyframes mhWord{
  0%  { opacity:0; transform:translateY(18px); filter:blur(6px); letter-spacing:.02em; }
  100%{ opacity:1; transform:none;             filter:blur(0);   letter-spacing:-.035em; }
}
@keyframes mhShine{
  0%,60%{ background-position:0% 50%; }
  80%   { background-position:100% 50%; }
  100%  { background-position:100% 50%; }
}
.mh-title::after{
  content:""; display:block; height:2px; width:0; margin-top:16px;
  background:linear-gradient(90deg, var(--primary), var(--accent), transparent);
  animation:mhUnder 1s var(--ease-emp) .6s forwards;
  box-shadow:0 0 10px rgba(200,155,92,.4);
}
@keyframes mhUnder{ to{ width:160px; } }

.mh-kicker{
  font-family:var(--f-sans); font-weight:500;
  color:rgba(255,255,255,.82);
  font-size:clamp(14px, 1.2vw, 17px);
  letter-spacing:.02em;
  animation:mhFade .6s var(--ease-emp) .55s both;
}
.mh-kicker b, .mh-kicker strong{ color:var(--accent); font-weight:600; }

.mh-meta{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  color:rgba(255,255,255,.72); font-size:13.5px; font-weight:500;
  animation:mhFade .6s var(--ease-emp) .4s both;
}
.mh-sep{ color:rgba(255,255,255,.35); }
.mh-chip{
  display:inline-flex; align-items:center; gap:6px; padding:4px 10px; border-radius:999px;
  background:rgba(200,155,92,.16); color:var(--accent);
  border:1px solid rgba(200,155,92,.32); font-size:11.5px; font-weight:600; letter-spacing:.02em;
}
.mh-chip::before{
  content:""; width:6px; height:6px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 3px rgba(200,155,92,.2);
  animation:mhDot 2.4s ease-in-out infinite;
}
.mh-btn{ backdrop-filter:saturate(140%) blur(6px); }
.mh-btn:not(.btn-primary){
  background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.22);
}
.mh-btn:not(.btn-primary):hover{ background:rgba(255,255,255,.14); color:#fff; }

@media (max-width:640px){
  .masthead{ padding:var(--s-5) var(--s-4); }
  .mh-title{ font-size:38px; }
  .mh-right{ width:100%; }
  .mh-right .btn{ flex:1; justify-content:center; }
}

/* ── Help Center grid ─────────────────────────────────────── */
.help-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:var(--s-4); margin-top:var(--s-4); }
.help-card{
  position:relative; background:var(--bg-elev); border:1px solid var(--line);
  border-radius:var(--r-3); padding:var(--s-5); min-height:150px;
  box-shadow:var(--shadow-1); color:var(--ink);
  transition:transform var(--mo-ui) var(--ease-std), box-shadow var(--mo-ui), border-color var(--mo-ui);
  display:flex; flex-direction:column; gap:6px; overflow:hidden;
}
.help-card:not(.help-card-static):hover{ transform:translateY(-2px); box-shadow:var(--shadow-3); border-color:var(--primary-100); text-decoration:none; }
.help-card:not(.help-card-static):hover .help-arrow{ opacity:1; transform:translateX(4px); }
.help-card::after{
  content:""; position:absolute; inset:0 0 auto 0; height:2px;
  background:linear-gradient(90deg, transparent, var(--primary), var(--accent), transparent);
  opacity:0; transition:opacity var(--mo-ui);
}
.help-card:not(.help-card-static):hover::after{ opacity:.9; }
.help-ico{
  width:44px; height:44px; border-radius:12px; color:#fff;
  display:grid; place-items:center; font-size:20px; font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.15), 0 6px 14px -6px rgba(176,54,95,.3);
  margin-bottom:4px;
}
.help-title{ font-weight:650; font-size:15px; color:var(--ink); letter-spacing:-.005em; font-family:var(--f-sans); }
.help-sub{ color:var(--ink-3); font-size:13px; line-height:1.55; }
.help-arrow{ position:absolute; right:var(--s-5); bottom:var(--s-5); color:var(--primary); font-size:18px; opacity:0; transition:opacity var(--mo-ui), transform var(--mo-ui) var(--ease-std); }
.help-card-static{ cursor:default; background:linear-gradient(180deg, var(--bg-tint) 0%, var(--bg-elev) 100%); border-color:var(--primary-100); }

/* ── Requirements reference item ──────────────────────────── */
.req-item{
  padding:var(--s-4); border:1px solid var(--line); border-radius:var(--r-2);
  background:linear-gradient(180deg, rgba(251,228,236,.25) 0%, var(--bg-elev) 40%);
}
.req-head{ display:flex; justify-content:space-between; gap:var(--s-3); flex-wrap:wrap; align-items:flex-start; }
.req-title{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; font-size:14px; }
.req-title strong{ color:var(--ink); font-weight:650; font-size:14.5px; }
.req-scopes{ display:flex; gap:6px; flex-wrap:wrap; }
.req-scope{
  display:inline-flex; align-items:center; gap:6px; padding:3px 10px; border-radius:999px;
  background:var(--accent-50); color:var(--accent-600); border:1px solid #E3C18E;
  font-size:11.5px; font-weight:600;
}
.req-meta{ display:grid; grid-template-columns:1fr 1fr; gap:var(--s-3); margin-top:10px; font-size:13px; color:var(--ink-2); }
@media (max-width:640px){ .req-meta{ grid-template-columns:1fr; } }
.req-note{
  margin-top:10px; padding:8px 12px; border-left:3px solid var(--accent);
  background:var(--accent-50); border-radius:0 6px 6px 0; font-size:12.5px; color:var(--ink-2);
  line-height:1.55;
}
.req-lbl{
  display:block; font-size:10.5px; color:var(--ink-3); text-transform:uppercase;
  letter-spacing:.08em; font-weight:600; margin-bottom:2px;
}

/* ── Compliance Guard banner ─────────────────────────────── */
.compliance-banner{
  display:flex; gap:14px; align-items:flex-start;
  padding:14px 18px; border-radius:var(--r-3); margin-bottom:var(--s-5);
  background:linear-gradient(180deg, #FAE0E4 0%, #FDEEF1 100%);
  border:1px solid #E8B2B9; color:#7A1F2B;
  box-shadow:0 10px 28px -14px rgba(182,58,74,.3);
}
.compliance-banner .cb-ico{
  width:40px; height:40px; border-radius:10px; flex:none;
  background:var(--danger); color:#fff; display:grid; place-items:center;
  font-size:20px; box-shadow:0 0 0 4px rgba(182,58,74,.15);
  animation:cbPulse 2.6s ease-in-out infinite;
}
@keyframes cbPulse{ 0%,100%{ box-shadow:0 0 0 0 rgba(182,58,74,.35); } 50%{ box-shadow:0 0 0 6px rgba(182,58,74,0); } }
.compliance-banner .cb-body{ flex:1; font-size:13px; line-height:1.5; }
.compliance-banner .cb-body strong{ display:block; font-size:13.5px; color:#661823; margin-bottom:3px; font-weight:650; }
.compliance-banner .cb-cta{
  display:inline-block; margin-top:8px; padding:6px 12px; background:var(--danger); color:#fff;
  border-radius:999px; font-weight:600; font-size:12px; letter-spacing:.02em;
  transition:transform var(--mo-fast), background var(--mo-ui);
}
.compliance-banner .cb-cta:hover{ background:#901D2A; color:#fff; text-decoration:none; transform:translateY(-1px); }

/* ── Dropzone (image upload) ──────────────────────────────── */
.dropzone{
  position:relative; aspect-ratio:1/1; border-radius:var(--r-3);
  background:
    linear-gradient(180deg, rgba(176,54,95,.04), rgba(200,155,92,.04)),
    repeating-linear-gradient(135deg, transparent 0 10px, rgba(176,54,95,.04) 10px 11px),
    var(--bg-elev);
  border:1.5px dashed var(--line-2);
  display:grid; place-items:center; cursor:pointer; overflow:hidden;
  transition:border-color var(--mo-ui), background var(--mo-ui), transform var(--mo-fast), box-shadow var(--mo-ui);
}
.dropzone:hover{ border-color:var(--primary); background-color:var(--bg-tint); }
.dropzone:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(176,54,95,.22); border-color:var(--primary); }
.dropzone.drag-over{
  border-color:var(--primary); border-style:solid;
  background:linear-gradient(180deg, rgba(176,54,95,.1), rgba(200,155,92,.08)), var(--bg-elev);
  transform:scale(1.015); box-shadow:var(--shadow-2);
}
.dropzone.has-image{ border-style:solid; border-color:var(--line); }
.dropzone.uploading{ border-color:var(--accent); }
.dropzone img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; border-radius:inherit;
  animation:imgIn var(--mo-med) var(--ease-emp);
}
@keyframes imgIn{ from{ opacity:0; transform:scale(.98); } to{ opacity:1; transform:none; } }
.dropzone.has-image .dz-hint{
  position:absolute; inset:auto 0 0 0; padding:10px 14px;
  background:linear-gradient(180deg, transparent 0%, rgba(26,19,24,.78) 100%);
  color:#fff; text-align:left; opacity:0; transition:opacity var(--mo-ui);
}
.dropzone.has-image:hover .dz-hint{ opacity:1; }
.dropzone.has-image .dz-ico{ display:none; }
.dropzone.has-image .dz-sub{ color:#D8C4CA; }
.dz-hint{ text-align:center; padding:var(--s-4); color:var(--ink-3); pointer-events:none; }
.dz-ico{ color:var(--primary); opacity:.85; margin-bottom:8px; }
.dz-title{ font-size:13.5px; color:var(--ink-2); }
.dz-title strong{ color:var(--primary); font-weight:600; }
.dz-sub{ font-size:11.5px; margin-top:4px; color:var(--ink-3); }
.dz-progress{
  position:absolute; left:0; right:0; bottom:0; height:3px; background:transparent; pointer-events:none;
}
.dz-progress > span{
  display:block; height:100%; width:0;
  background:linear-gradient(90deg, var(--primary), var(--accent));
  transition:width .15s linear; box-shadow:0 0 8px rgba(200,155,92,.5);
}
.dz-toast{
  position:absolute; top:10px; left:50%; transform:translate(-50%,-6px);
  padding:6px 12px; border-radius:999px; font-size:12px; font-weight:600;
  background:var(--ink); color:#fff; box-shadow:var(--shadow-2);
  opacity:0; pointer-events:none; transition:opacity var(--mo-ui), transform var(--mo-ui);
}
.dz-toast.show{ opacity:1; transform:translate(-50%,0); }
.dz-toast[data-kind="ok"]   { background:var(--accent-600); }
.dz-toast[data-kind="error"]{ background:var(--danger); }
.dz-remove{
  position:absolute; top:8px; right:8px; width:28px; height:28px; border-radius:50%;
  background:rgba(26,19,24,.8); color:#fff; border:none; cursor:pointer; font-size:18px; line-height:1;
  display:grid; place-items:center; transition:transform var(--mo-fast), background var(--mo-ui);
}
.dz-remove:hover{ background:var(--danger); transform:scale(1.08); }

/* Table thumbnails */
.tbl-thumb{ width:40px; height:40px; border-radius:8px; object-fit:cover; border:1px solid var(--line); display:block; }
.tbl-thumb-empty{
  display:grid; place-items:center; color:var(--ink-4); font-size:18px;
  background:var(--bg-sunken); border:1px dashed var(--line-2);
}

/* Scrollbar (subtle, warm) */
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:10px; border:2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover{ background:var(--primary-100); }
::-webkit-scrollbar-track{ background:transparent; }

/* Dashboard command center */
.ops-strip{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:var(--s-3);
  margin:calc(var(--s-6) * -0.55) var(--s-4) var(--s-6);
  position:relative;
  z-index:2;
}
.ops-tile{
  display:flex;
  align-items:center;
  gap:12px;
  min-height:86px;
  padding:14px;
  border-radius:18px;
  color:var(--ink);
  background:
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,255,255,.72)),
    radial-gradient(180px 90px at 15% 0%, rgba(200,155,92,.18), transparent 65%);
  border:1px solid rgba(237,223,214,.92);
  box-shadow:0 18px 44px -28px rgba(42,27,36,.42), inset 0 1px 0 rgba(255,255,255,.9);
  backdrop-filter:saturate(155%) blur(12px);
  -webkit-backdrop-filter:saturate(155%) blur(12px);
  overflow:hidden;
  transition:transform var(--mo-ui) var(--ease-spring), box-shadow var(--mo-ui), border-color var(--mo-ui);
}
.ops-tile::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(115deg, transparent 42%, rgba(255,255,255,.42) 50%, transparent 58%);
  transform:translateX(-130%);
  transition:transform .7s var(--ease-emp);
}
.ops-tile:hover{
  color:var(--ink);
  transform:translateY(-4px);
  border-color:rgba(200,155,92,.42);
  box-shadow:0 24px 52px -28px rgba(176,54,95,.55), 0 10px 22px -16px rgba(42,27,36,.18);
}
.ops-tile:hover::after{ transform:translateX(130%); }
.ops-hot{
  background:
    linear-gradient(135deg, rgba(255,255,255,.94), rgba(253,245,231,.82)),
    radial-gradient(180px 90px at 15% 0%, rgba(200,155,92,.28), transparent 65%);
  border-color:rgba(200,155,92,.38);
}
.ops-icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  flex:none;
  font-family:var(--f-display);
  font-weight:700;
  color:#fff;
  background:
    radial-gradient(120% 120% at 25% 15%, rgba(255,255,255,.35), transparent 55%),
    linear-gradient(135deg, var(--primary), var(--accent));
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.18), 0 12px 22px -14px rgba(176,54,95,.65);
}
.ops-copy{ display:flex; flex-direction:column; min-width:0; }
.ops-copy strong{ font-size:13.5px; font-weight:700; letter-spacing:-.01em; color:var(--ink); }
.ops-copy em{ margin-top:2px; font-style:normal; font-size:12px; line-height:1.35; color:var(--ink-3); }
@media (max-width:1100px){ .ops-strip{ grid-template-columns:repeat(2, minmax(0, 1fr)); margin-left:0; margin-right:0; } }
@media (max-width:640px){ .ops-strip{ grid-template-columns:1fr; margin-top:calc(var(--s-5) * -0.35); } }
