/* ============================================================
   VC Activity Funnel Tracker — Personalization engine (v7)
   Independent per-user axes, all driven by data-* attрs + vars:
     --accent / --accent-rgb  (any colour, set inline per user)
     [data-mode=light|dark]
     [data-nav=sidebar|tabs|dropdown]
     [data-density=comfortable|compact]
   Themes dashboards + entry/edit/view panels uniformly.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Sora:wght@600;700;800&display=swap');

:root{
  --accent:#4f46e5; --accent-rgb:79,70,229;

  /* light-mode surface palette (overridden by [data-mode=dark]) */
  --bg:#eef1f7; --card:#ffffff; --card-soft:#f6f8fc;
  --ink:#0d1626; --ink-2:#33415a; --muted:#7180a0; --muted-2:#9aa6bd;
  --border:#e5e9f2; --border-soft:#eef1f8;
  --side-bg1:#171d36; --side-bg2:#12172b; --side-ink:#c4cce0; --side-ink-dim:#8c98b8;
  --head-bg:rgba(255,255,255,.82);

  --danger:#e11d48; --overdue:#e11d48; --ok:#15a36e; --warn:#f59e0b;
  --sh-xs:0 1px 2px rgba(13,22,38,.05);
  --sh-sm:0 1px 2px rgba(13,22,38,.06), 0 1px 3px rgba(13,22,38,.05);
  --sh-md:0 6px 18px rgba(13,22,38,.07), 0 2px 6px rgba(13,22,38,.04);
  --sh-lg:0 20px 50px rgba(13,22,38,.16);
  --radius:16px; --radius-sm:11px;
  --side-w:248px; --head-h:64px;

  /* density tokens (compact overrides below) */
  --pad-card:20px; --gap-cards:15px; --kpi-pad:18px; --kpi-num:30px;
  --row-pad:11px; --field-pad:11px; --container-pad:26px;
}

/* ---------- DARK MODE ---------- */
body[data-mode="dark"]{
  --bg:#0b1020; --card:#141b2e; --card-soft:#1b2436;
  --ink:#e8edf6; --ink-2:#c2cbe0; --muted:#8794ad; 
  --muted-2:#6b7896;
  --border:#283349; --border-soft:#212c40;
  --side-bg1:#0d1322; --side-bg2:#0a0f1c; --side-ink:#aeb9d2; 
  --side-ink-dim:#768099;
  --head-bg:rgba(15,21,38,.85);
  --sh-xs:0 1px 2px rgba(0,0,0,.4);
  --sh-sm:0 1px 3px rgba(0,0,0,.45);
  --sh-md:0 8px 22px rgba(0,0,0,.5);
  --sh-lg:0 24px 60px rgba(0,0,0,.6);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  /* accent-derived tokens — declared here so they pick up the per-user
     inline --accent set on <body>, not the :root default */
  --accent-d:color-mix(in srgb, var(--accent) 82%, #000);
  --accent-2:color-mix(in srgb, var(--accent) 70%, #fff);
  --grad:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 62%, #ffffff));
  --soft:rgba(var(--accent-rgb), .10);
  --soft-2:rgba(var(--accent-rgb), .16);
  --ring:rgba(var(--accent-rgb), .22);
  margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background .2s,color .2s}
a{color:var(--accent);text-decoration:none;transition:color .15s}
a:hover{color:var(--accent-d)}
::selection{background:var(--soft-2)}

/* ===================== App shell ===================== */
.app-shell{display:flex;min-height:100vh}
.sidebar{position:fixed;inset:0 auto 0 0;width:var(--side-w);z-index:60;display:flex;flex-direction:column;
  background:radial-gradient(420px 220px at 20% -5%, var(--soft-2), transparent 70%),linear-gradient(180deg,var(--side-bg1),var(--side-bg2));
  color:var(--side-ink);border-right:1px solid rgba(255,255,255,.06)}
.side-brand{display:flex;align-items:center;gap:11px;padding:18px 20px;height:var(--head-h);font-family:'Sora',sans-serif;font-weight:800;font-size:15.5px;letter-spacing:-.01em;color:#fff;border-bottom:1px solid rgba(255,255,255,.06)}
.logo-dot{width:13px;height:24px;border-radius:6px;background:var(--grad);box-shadow:0 0 0 4px var(--soft-2);flex:0 0 auto}
.brand-name{line-height:1.15}
.nav-dd-toggle{display:none;align-items:center;gap:9px;margin:10px 14px;padding:9px 12px;border-radius:11px;border:0;cursor:pointer;background:var(--soft-2);color:#fff;font-weight:600;font-size:13.5px}
.nav-dd-toggle svg{width:18px;height:18px}
.side-nav{flex:1;overflow-y:auto;padding:14px 12px}
.nav-group{margin-bottom:16px}
.nav-cap{font-size:10.5px;font-weight:700;letter-spacing:.10em;text-transform:uppercase;color:var(--side-ink-dim);padding:0 12px 8px}
.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;margin-bottom:2px;border-radius:11px;color:var(--side-ink);font-size:13.5px;font-weight:500;position:relative;transition:background .15s,color .15s}
.nav-link .ic{width:18px;height:18px;flex:0 0 auto;opacity:.85}
.nav-link:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-link.active{background:var(--grad);color:#fff;box-shadow:0 6px 16px var(--ring)}
.nav-link.active .ic{opacity:1}
.side-user{display:flex;align-items:center;gap:11px;padding:14px 16px;border-top:1px solid rgba(255,255,255,.07)}
.avatar{width:36px;height:36px;border-radius:11px;flex:0 0 auto;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;background:var(--grad);box-shadow:0 4px 12px var(--ring)}
.avatar.sm{width:32px;height:32px;border-radius:9px;font-size:12px}
.su-meta{flex:1;min-width:0}
.su-name{font-size:13px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.su-role{font-size:11px;color:var(--side-ink-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.su-logout{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;color:#ff9aab;transition:background .15s,color .15s}
.su-logout svg{width:18px;height:18px}
.su-logout:hover{background:rgba(255,122,146,.14);color:#ff7d92}
.side-scrim{display:none}

.content{flex:1;min-width:0;margin-left:var(--side-w);display:flex;flex-direction:column}
.page-head{position:sticky;top:0;z-index:30;height:var(--head-h);display:flex;align-items:center;gap:14px;padding:0 var(--container-pad);background:var(--head-bg);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--border-soft)}
.page-title{font-family:'Sora',sans-serif;font-size:18px;font-weight:800;letter-spacing:-.02em;margin:0;flex:1;color:var(--ink)}
.page-user{display:flex;align-items:center;gap:10px}
.pu-name{font-size:13px;color:var(--ink-2);font-weight:600}
.menu-btn{display:none;background:none;border:0;cursor:pointer;color:var(--ink-2);padding:6px;border-radius:8px}
.menu-btn svg{width:22px;height:22px;display:block}
.container{max-width:1240px;width:100%;margin:0 auto;padding:var(--container-pad) var(--container-pad) 8px;flex:1}

h1{font-family:'Sora',sans-serif;font-size:19px;font-weight:700;letter-spacing:-.01em;margin:0 0 18px;color:var(--ink)}
h2{font-family:'Sora',sans-serif;font-size:16px;font-weight:700;letter-spacing:-.01em;margin:0 0 14px;color:var(--ink)}
h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin:22px 0 10px;color:var(--muted)}
.muted{color:var(--muted)}
.flash{background:var(--soft);color:var(--accent-d);border:1px solid var(--soft-2);padding:12px 16px;border-radius:12px;margin-bottom:18px;font-weight:500;box-shadow:var(--sh-xs)}
body[data-mode="dark"] .flash{color:var(--accent-2)}
.card{background:var(--card);border:1px solid var(--border-soft);border-radius:var(--radius);padding:var(--pad-card);margin-bottom:18px;box-shadow:var(--sh-md)}

/* KPI */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(176px,1fr));gap:var(--gap-cards);margin-bottom:18px}
.kpi{text-align:left;position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border-soft);box-shadow:var(--sh-sm);padding:var(--kpi-pad)}
.kpi::before{content:"";position:absolute;left:0;top:var(--kpi-pad);bottom:var(--kpi-pad);width:4px;border-radius:4px;background:var(--grad)}
.kpi .num{font-family:'Sora',sans-serif;font-size:var(--kpi-num);font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1.1;padding-left:12px}
.kpi.alert::before{background:linear-gradient(180deg,#fb7185,#e11d48)}
.kpi.alert .num{color:var(--danger)}
.kpi .lbl{font-size:12px;color:var(--muted);margin-top:6px;font-weight:500;padding-left:12px}
.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:16px;margin-bottom:18px}

/* Tables */
table.data,table.mini{width:100%;border-collapse:separate;border-spacing:0}
table.data th,table.data td{border-bottom:1px solid var(--border-soft);padding:var(--row-pad) 12px;text-align:left;font-size:13px;color:var(--ink-2)}
table.data th{background:var(--card-soft);color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:11px;border-bottom:1px solid var(--border)}
table.data tbody tr{transition:background .12s}
table.data tbody tr:hover{background:var(--soft)}
table.data th:first-child{border-top-left-radius:10px}
table.data th:last-child{border-top-right-radius:10px}
table.mini td{padding:8px 6px;border-bottom:1px solid var(--border-soft)}
.r{text-align:right}
.overdue{color:var(--overdue);font-weight:700}
.ops{font-size:12px;background:var(--soft);color:var(--accent-d);padding:3px 10px;border-radius:8px;font-weight:600;border:1px solid var(--soft-2)}
body[data-mode="dark"] .ops{color:var(--accent-2)}

/* Forms */
.form .row{display:flex;gap:16px;margin-bottom:4px;flex-wrap:wrap}
.form .row>div{flex:1;min-width:200px}
.form label{display:block;font-size:12px;color:var(--ink-2);margin:14px 0 6px;font-weight:600}
.form .row label{margin-top:0}
.form input,.form select,.form textarea{width:100%;padding:var(--field-pad) 13px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:var(--card);color:var(--ink);transition:border-color .15s,box-shadow .15s,background .15s}
.form input::placeholder,.form textarea::placeholder{color:var(--muted-2)}
.form input:hover,.form select:hover,.form textarea:hover{border-color:var(--accent-2)}
.form input:focus,.form select:focus,.form textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px var(--ring);background:var(--card)}
.form input[readonly]{background:var(--card-soft)!important;color:var(--muted)!important;cursor:not-allowed}
.form .chk{display:inline-flex;align-items:center;gap:7px;margin:6px 18px 6px 0;color:var(--ink-2);font-weight:500}
.form input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}
.form button{margin-top:12px;padding:11px 20px;background:var(--grad);color:#fff;border:0;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;box-shadow:0 6px 16px var(--ring);transition:transform .12s,filter .15s}
.form button:hover{transform:translateY(-1px);filter:brightness(1.04)}
.btn-secondary{display:inline-block;margin-left:8px;padding:11px 18px;background:var(--card-soft);color:var(--ink-2);border-radius:var(--radius-sm);font-weight:600;border:1px solid var(--border);transition:background .15s;cursor:pointer}
.btn-secondary:hover{background:var(--border-soft);color:var(--ink)}
.contact-row{display:flex;gap:8px;margin-bottom:8px}
.contact-row input{flex:1}
.actions{display:flex;gap:10px;align-items:center}
.actions form{display:inline}
.link-danger{background:none;border:0;color:var(--danger);cursor:pointer;padding:0;font-size:13px;font-weight:600}
.link-danger:hover{text-decoration:underline}
.foot{text-align:center;color:var(--muted);font-size:12px;padding:22px 26px}

/* Toolbar */
.toolbar{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.toolbar h1{margin:0;flex:1}
.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--card);box-shadow:var(--sh-xs)}
.view-toggle button{background:var(--card);border:0;padding:9px 16px;cursor:pointer;font-size:13px;color:var(--muted);font-weight:600;transition:all .15s}
.view-toggle button.active{background:var(--grad);color:#fff}
.btn-primary{background:var(--grad);color:#fff;border:0;padding:11px 18px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:600;box-shadow:0 6px 16px var(--ring);transition:transform .12s,filter .15s}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.04)}

/* Decks */
.deck{display:grid;grid-template-columns:repeat(auto-fill,minmax(298px,1fr));gap:18px}
.deck-card{background:var(--card);border:1px solid var(--border-soft);border-left:5px solid var(--accent);border-radius:var(--radius);padding:18px;box-shadow:var(--sh-md);transition:transform .15s,box-shadow .15s;position:relative}
.deck-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.deck-card h3{margin:0 0 6px;font-size:15px;font-weight:700;text-transform:none;letter-spacing:-.01em;color:var(--ink)}
.deck-card .sub{font-size:12px;color:var(--muted);margin-bottom:12px}
.deck-card .meta{font-size:13px;line-height:1.8;color:var(--ink-2)}
.deck-card .meta b{color:var(--muted);font-weight:600}
.deck-actions{display:flex;gap:8px;margin-top:16px;border-top:1px solid var(--border-soft);padding-top:12px}
.deck-actions button{flex:1;background:var(--card-soft);border:1px solid var(--border-soft);border-radius:9px;padding:8px;cursor:pointer;font-size:12px;font-weight:600;color:var(--ink-2);transition:background .15s,border-color .15s}
.deck-actions button:hover{background:var(--soft);border-color:var(--border)}
.deck-actions .del{color:var(--danger)}
.badge{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.02em}
.lvl-1{--lvl:#e11d48} .lvl-2{--lvl:#f97316} .lvl-3{--lvl:#eab308} .lvl-4{--lvl:#84cc16} .lvl-5{--lvl:#15a36e}
.deck-card.lvl-1,.deck-card.lvl-2,.deck-card.lvl-3,.deck-card.lvl-4,.deck-card.lvl-5{border-left-color:var(--lvl)}
.levelbar{display:flex;gap:4px;margin-top:10px}
.levelbar span{flex:1;height:8px;border-radius:4px;background:var(--border)}
.levelbar span.on{background:var(--lvl)}
.level-pill{background:var(--lvl);color:#fff}
.dl-ok{--dl:var(--accent)} .dl-soon{--dl:#f59e0b} .dl-done{--dl:#15a36e} .dl-over{--dl:#e11d48} .dl-late{--dl:#9f1239}
.deck-card.dl-ok{border-left-color:var(--dl)} .deck-card.dl-soon{border-left-color:var(--dl)} .deck-card.dl-done{border-left-color:var(--dl)} .deck-card.dl-over{border-left-color:var(--dl)}
.deck-card.dl-late{border-left-color:var(--dl)}
.dl-tag{background:var(--dl);color:#fff}

/* ===== Panels: entry / edit / view ===== */
.panel-overlay{position:fixed;inset:0;background:rgba(8,12,24,.55);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .22s;z-index:80}
.panel-overlay.open{opacity:1;visibility:visible}
.panel{position:fixed;top:0;right:0;height:100%;width:min(560px,100%);background:var(--card);box-shadow:-24px 0 70px rgba(8,12,24,.5);transform:translateX(100%);transition:transform .3s cubic-bezier(.2,.85,.25,1);z-index:81;display:flex;flex-direction:column;overflow:hidden}
.panel.open{transform:translateX(0)}
.panel>form{display:flex;flex-direction:column;flex:1;min-height:0}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:var(--grad);color:#fff;flex-shrink:0}
.panel-head h2{margin:0;font-size:16.5px;color:#fff;font-weight:700;letter-spacing:-.01em}
.panel-head .x{background:rgba(255,255,255,.18);border:0;color:#fff;font-size:20px;cursor:pointer;line-height:1;width:32px;height:32px;border-radius:9px;transition:background .15s}
.panel-head .x:hover{background:rgba(255,255,255,.3)}
.panel-body{padding:22px 24px;overflow-y:auto;flex:1 1 auto;min-height:0}
.panel-body h3{display:flex;align-items:center;gap:10px;margin:24px 0 12px;padding-top:18px;border-top:1px solid var(--border-soft);color:var(--accent-d);font-size:11.5px}
body[data-mode="dark"] .panel-body h3{color:var(--accent-2)}
.panel-body h3:first-child{border-top:0;padding-top:0;margin-top:0}
.panel-foot{padding:16px 24px;border-top:1px solid var(--border-soft);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0;background:var(--card)}
.panel.danger .panel-head{background:linear-gradient(135deg,#fb7185,#e11d48)}

/* read-only view rows (the "view" panel) */
.detail-row{display:flex;padding:11px 0;border-bottom:1px solid var(--border-soft);font-size:14px}
.detail-row .k{width:150px;color:var(--muted);font-weight:600;flex-shrink:0}
.detail-row .v{flex:1;color:var(--ink)}
.contact-chip{background:var(--card-soft);border:1px solid var(--border-soft);border-radius:12px;padding:11px 13px;margin-bottom:8px}
.contact-chip .nm{font-weight:600;color:var(--ink)}
.contact-chip .dt{font-size:12px;color:var(--muted)}
.comment-item{background:var(--card-soft);border-left:3px solid var(--accent);padding:10px 13px;margin-bottom:8px;border-radius:0 10px 10px 0;color:var(--ink-2)}
.comment-item .cdate{font-size:11px;color:var(--muted)}
.hidden{display:none !important}

.click{cursor:pointer;transition:background .12s,transform .12s,box-shadow .15s}
.kpi.click:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
tr.click:hover{background:var(--soft)}
.kpi.click .num{text-decoration:none}
.kpi.click::after{content:'View ▸';display:block;font-size:10px;color:var(--muted);margin-top:8px;font-weight:600;letter-spacing:.03em;padding-left:12px}
.last-comment{margin-top:12px;padding:9px 12px;background:var(--card-soft);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;font-size:12px;color:var(--ink-2)}
.last-comment .cdate{display:block;font-size:10px;color:var(--muted);margin-bottom:3px}
td .cdate{font-size:10px;color:var(--muted)}
.kpi.money::before{background:linear-gradient(180deg,#34d399,#15a36e)}
.kpi.money .num{font-size:23px;color:#0e9e68}
body[data-mode="dark"] .kpi.money .num{color:#34d399}
.kpi.money::after{content:''}
.fc-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}
.fc-row input[name="fc_text[]"]{flex:1}
.existing-comments{margin-bottom:12px}
.pie-legend{margin-top:16px;display:flex;flex-direction:column;gap:7px}
.leg-item{font-size:13px;color:var(--ink-2)}
.leg-dot{display:inline-block;width:12px;height:12px;border-radius:4px;margin-right:9px;vertical-align:middle}
.filter-bar{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.period-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--card);box-shadow:var(--sh-xs)}
.period-toggle button{background:var(--card);border:0;padding:9px 16px;cursor:pointer;font-size:13px;color:var(--muted);font-weight:600;border-right:1px solid var(--border-soft);transition:all .15s}
.period-toggle button:last-child{border-right:0}
.period-toggle button.active{background:var(--grad);color:#fff}
.date-range{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap}
.date-range label,.date-basis label{font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:4px;font-weight:600}
.date-range input,.date-basis select{padding:9px 10px;border:1px solid var(--border);border-radius:9px;background:var(--card);color:var(--ink)}
.date-basis{display:flex;gap:14px;flex-wrap:wrap;margin-left:auto}
.top3{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.top3-row{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--card-soft);border-radius:12px;border-left:4px solid #15a36e}
.top3-rank{font-family:'Sora',sans-serif;font-size:20px;font-weight:800;width:30px;text-align:center;color:var(--muted)}
.top3-name{flex:1;font-weight:600;color:var(--ink)}
.top3-amt{font-weight:800;color:#0e9e68}
body[data-mode="dark"] .top3-amt{color:#34d399}
.svc-block{border:1px solid var(--border-soft);border-radius:12px;padding:12px 14px;margin-bottom:8px;background:var(--card-soft)}
.svc-fields{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}
.svc-detail{padding:9px 12px;background:var(--card-soft);border-radius:9px;margin-bottom:6px}
.svc-progress{height:8px;background:var(--border);border-radius:5px;overflow:hidden;margin:6px 0 12px}
.svc-progress-bar{height:100%;background:linear-gradient(90deg,#34d399,#15a36e)}
.custom-svc-add{margin:10px 0;padding:12px;border:1px dashed var(--border);border-radius:12px;background:var(--card-soft)}
.custom-svc-add .row{display:flex;gap:8px;align-items:center}
#svcSelected .svc-block,#customSvcList .svc-block{margin-top:8px}
.svc-ticklist{display:flex;flex-direction:column;gap:2px;padding:10px;border:1px solid var(--border);border-radius:12px;background:var(--card);max-height:220px;overflow:auto}
.svc-tick{display:flex;align-items:center;justify-content:flex-start;gap:10px;margin:0;padding:6px;font-weight:500;cursor:pointer;text-align:left;width:100%;border-radius:8px;transition:background .12s;color:var(--ink-2)}
.svc-tick input[type=checkbox]{flex:0 0 auto;width:16px;height:16px;margin:0;accent-color:var(--accent)}
.svc-tick:hover{background:var(--card-soft)}
.kpi.click{cursor:pointer}
.kpi.sel{outline:2px solid var(--accent);outline-offset:-2px;box-shadow:var(--sh-lg)}
.studybar{display:inline-flex;gap:3px;vertical-align:middle;margin:0 6px}
.studybar span{width:16px;height:8px;border-radius:3px;background:var(--border)}
.studybar span.on{background:#15a36e}
.study-line{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:12px;color:var(--ink-2)}
.btn-xs{padding:4px 9px;font-size:11px}

/* ===================== Appearance settings ===================== */
.pref-card h2{margin-bottom:14px}
.pref-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.swatch-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.swatch{width:38px;height:38px;border-radius:12px;border:2px solid var(--border);background:var(--sw);cursor:pointer;position:relative;transition:transform .12s,box-shadow .15s;padding:0}
.swatch:hover{transform:translateY(-2px)}
.swatch.on{border-color:var(--ink);box-shadow:0 0 0 3px var(--soft-2)}
.swatch.on::after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.swatch-custom{display:inline-flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;font-size:11px;color:var(--muted);font-weight:600}
.swatch-custom input[type=color]{width:38px;height:38px;border:2px dashed var(--border);border-radius:12px;background:var(--card);cursor:pointer;padding:2px}
.seg{display:inline-flex;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--card);box-shadow:var(--sh-xs)}
.seg-btn{background:var(--card);border:0;padding:10px 18px;cursor:pointer;font-size:13px;color:var(--muted);font-weight:600;transition:all .15s}
.seg-btn.on{background:var(--grad);color:#fff}
.nav-choices{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}
.nav-choice{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px;border:1px solid var(--border);border-radius:14px;background:var(--card);cursor:pointer;text-align:left;transition:transform .12s,box-shadow .15s,border-color .15s}
.nav-choice:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.nav-choice.on{border-color:var(--accent);box-shadow:0 0 0 3px var(--soft-2)}
.nc-name{font-weight:700;font-size:14px;color:var(--ink)}
.nc-desc{font-size:11.5px;color:var(--muted)}
.navmini{width:100%;height:46px;border-radius:8px;background:var(--card-soft);border:1px solid var(--border-soft);display:flex;overflow:hidden;margin-bottom:8px}
.navmini i{display:block}
.navmini-sidebar{padding:0}
.navmini-sidebar i:first-child{width:22%;height:100%;background:var(--grad)}
.navmini-sidebar i:not(:first-child){flex:1;border-left:6px solid var(--border)}
.navmini-tabs{flex-direction:column}
.navmini-tabs i:first-child{height:34%;background:var(--grad)}
.navmini-tabs i:not(:first-child){flex:1}
.navmini-dd{align-items:flex-start;padding:7px}
.navmini-dd i{width:30px;height:10px;border-radius:3px;background:var(--grad)}
.settings-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:22px;padding-top:18px;border-top:1px solid var(--border-soft);flex-wrap:wrap}

/* ===================== Login ===================== */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:radial-gradient(900px 600px at 18% 10%, var(--soft-2), transparent 60%),radial-gradient(800px 600px at 85% 90%, var(--soft), transparent 55%),linear-gradient(160deg,#1b2440 0%,#141a30 60%,#10162a 100%)}
.login-card{position:relative;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);padding:36px 32px 32px;border-radius:22px;width:368px;max-width:100%;box-shadow:0 30px 80px rgba(8,12,28,.55);border:1px solid rgba(255,255,255,.6);animation:rise .5s cubic-bezier(.2,.8,.2,1) both}
.login-card::before{content:"";position:absolute;inset:0;border-radius:22px;padding:1px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;pointer-events:none}
.login-card h1{font-family:'Sora',sans-serif;font-size:20px;font-weight:800;margin:0 0 6px;text-align:center;letter-spacing:-.02em;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-card form{margin-top:14px}
.login-card label{display:block;margin:14px 0 6px;font-size:12px;font-weight:600;color:var(--muted)}
.login-card input{width:100%;padding:12px 13px;border:1px solid var(--border);border-radius:12px;font-size:14px;background:#fbfcff;transition:border-color .15s,box-shadow .15s}
.login-card input:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 4px var(--ring);background:#fff}
.login-card button{width:100%;margin-top:22px;padding:13px;background:var(--grad);color:#fff;border:0;border-radius:12px;cursor:pointer;font-size:15px;font-weight:600;box-shadow:0 8px 22px var(--ring);transition:transform .12s,box-shadow .15s,filter .15s}
.login-card button:hover{transform:translateY(-1px);filter:brightness(1.04)}
.error{background:#fff1f3;color:var(--danger);padding:10px 12px;border-radius:10px;font-size:13px;border:1px solid #fbd5dd;font-weight:500}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ===================== NAV LAYOUT: TABS ===================== */
body[data-nav="tabs"] .app-shell{display:block}
body[data-nav="tabs"] .sidebar{position:sticky;top:0;inset:auto;width:auto;flex-direction:row;align-items:center;height:auto;
  background:var(--card);color:var(--ink-2);border-right:0;border-bottom:1px solid var(--border);padding:0 18px;gap:8px;box-shadow:var(--sh-sm)}
body[data-nav="tabs"] .side-brand{height:auto;padding:14px 14px 14px 4px;border-bottom:0;color:var(--ink);flex:0 0 auto}
body[data-nav="tabs"] .nav-dd-toggle{display:none}
body[data-nav="tabs"] .side-nav{display:flex;flex-direction:row;align-items:center;gap:2px;padding:0;overflow:visible;flex:1}
body[data-nav="tabs"] .nav-group{display:flex;align-items:center;gap:2px;margin:0}
body[data-nav="tabs"] .nav-cap{display:none}
body[data-nav="tabs"] .nav-link{padding:8px 12px;font-size:13px;color:var(--ink-2);border-radius:9px}
body[data-nav="tabs"] .nav-link .ic{width:16px;height:16px}
body[data-nav="tabs"] .nav-link.active{background:var(--soft);color:var(--accent-d);box-shadow:none}
body[data-mode="dark"][data-nav="tabs"] .nav-link.active{color:var(--accent-2)}
body[data-nav="tabs"] .nav-link:hover{background:var(--card-soft);color:var(--ink)}
body[data-nav="tabs"] .side-user{border-top:0;padding:8px 4px 8px 8px;flex:0 0 auto}
body[data-nav="tabs"] .su-meta{display:none}
body[data-nav="tabs"] .content{margin-left:0}
body[data-nav="tabs"] .menu-btn{display:none!important}
@media (max-width:820px){
  body[data-nav="tabs"] .nav-link span{display:none}
  body[data-nav="tabs"] .side-nav{overflow-x:auto}
}

/* ===================== NAV LAYOUT: DROPDOWN ===================== */
body[data-nav="dropdown"] .app-shell{display:block}
body[data-nav="dropdown"] .sidebar{position:sticky;top:0;inset:auto;width:auto;flex-direction:row;align-items:center;height:auto;
  background:var(--card);color:var(--ink-2);border-right:0;border-bottom:1px solid var(--border);padding:0 18px;gap:10px;box-shadow:var(--sh-sm);z-index:60}
body[data-nav="dropdown"] .side-brand{height:auto;padding:14px 6px;border-bottom:0;color:var(--ink);flex:1}
body[data-nav="dropdown"] .nav-dd-toggle{display:inline-flex;order:3;margin:0;background:var(--soft);color:var(--accent-d)}
body[data-mode="dark"][data-nav="dropdown"] .nav-dd-toggle{color:var(--accent-2)}
body[data-nav="dropdown"] .side-nav{
  position:absolute;top:calc(100% + 8px);right:18px;width:260px;flex-direction:column;gap:0;
  background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--sh-lg);
  padding:10px;max-height:0;overflow:hidden;opacity:0;visibility:hidden;transition:opacity .18s,max-height .22s}
body[data-nav="dropdown"].dd-open .side-nav{max-height:75vh;overflow:auto;opacity:1;visibility:visible}
body[data-nav="dropdown"] .nav-cap{padding:8px 10px 4px}
body[data-nav="dropdown"] .nav-link{color:var(--ink-2)}
body[data-nav="dropdown"] .nav-link:hover{background:var(--card-soft);color:var(--ink)}
body[data-nav="dropdown"] .nav-link.active{background:var(--soft);color:var(--accent-d);box-shadow:none}
body[data-mode="dark"][data-nav="dropdown"] .nav-link.active{color:var(--accent-2)}
body[data-nav="dropdown"] .side-user{order:2;border-top:0;padding:8px;flex:0 0 auto}
body[data-nav="dropdown"] .su-meta{display:none}
body[data-nav="dropdown"] .content{margin-left:0}
body[data-nav="dropdown"] .menu-btn{display:none!important}

/* ===================== DENSITY: COMPACT ===================== */
body[data-density="compact"]{
  --pad-card:14px; --gap-cards:11px; --kpi-pad:13px; --kpi-num:25px;
  --row-pad:7px; --field-pad:9px; --container-pad:18px;
}
body[data-density="compact"] .card{margin-bottom:13px}
body[data-density="compact"] .deck{gap:12px}
body[data-density="compact"] .deck-card{padding:14px}
body[data-density="compact"] .form label{margin:10px 0 4px}
body[data-density="compact"] h1{margin-bottom:13px}

/* ===================== Mobile (sidebar nav only) ===================== */
@media (max-width:980px){
  body[data-nav="sidebar"] .sidebar{transform:translateX(-100%);transition:transform .25s ease;box-shadow:24px 0 60px rgba(8,12,24,.4)}
  body[data-nav="sidebar"].nav-open .sidebar{transform:translateX(0)}
  body[data-nav="sidebar"].nav-open .side-scrim{display:block;position:fixed;inset:0;background:rgba(8,12,24,.5);z-index:55}
  body[data-nav="sidebar"] .content{margin-left:0}
  body[data-nav="sidebar"] .menu-btn{display:grid;place-items:center}
  .pu-name{display:none}
}
@media (max-width:640px){.container{padding:18px 16px 8px}.page-head{padding:0 16px}}
