:root{
  --bg:#0b1220; --bg2:#0f1830; --panel:#121c33; --panel2:#16213d;
  --line:#1f2c49; --line2:#26345a;
  --txt:#e8eefb; --muted:#92a2c4; --muted2:#6c7da3;
  --accent:#2563eb; --accent2:#3b82f6; --accent-soft:#1d3a8a33;
  --green:#16a34a; --green-soft:#16a34a22;
  --amber:#d97706; --amber-soft:#d9770622;
  --red:#dc2626; --red-soft:#dc262622;
  --cyan:#0891b2; --violet:#7c3aed; --pink:#db2777;
  --radius:14px; --radius-sm:10px;
  --shadow:0 10px 30px -12px rgba(0,0,0,.55);
  --shadow-lg:0 24px 60px -18px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:radial-gradient(1200px 700px at 80% -10%,#16264e 0%,transparent 55%),
             radial-gradient(900px 600px at -10% 110%,#10203f 0%,transparent 50%),
             var(--bg);
  color:var(--txt);-webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#27375f;border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-track{background:transparent}
.svg-i{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;flex:none}
.svg-i.sm{width:15px;height:15px}
.svg-i.lg{width:22px;height:22px}

/* ====== LOGIN ====== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:100%;max-width:920px;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr}
.login-side{padding:42px 38px;background:
  radial-gradient(600px 300px at 110% -20%,#2a4fae55,transparent 60%),
  linear-gradient(160deg,#16224080,#0d1730);border-right:1px solid var(--line);position:relative}
.login-side h1{font-size:30px;font-weight:800;letter-spacing:-.6px;line-height:1.1;margin-top:18px}
.login-side .grad{background:linear-gradient(90deg,#60a5fa,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-side p{color:var(--muted);margin-top:14px;font-size:14.5px;line-height:1.6}
.login-feats{margin-top:26px;display:flex;flex-direction:column;gap:12px}
.login-feat{display:flex;gap:11px;align-items:center;font-size:13.5px;color:#cdd9f2}
.login-feat .fi{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--accent-soft);color:#8fb4ff;flex:none}
.brand{display:flex;align-items:center;gap:11px}
.brand-logo{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:grid;place-items:center;box-shadow:0 8px 22px -8px #2563ebcc}
.brand-name{font-weight:800;font-size:18px;letter-spacing:-.3px}
.brand-sub{font-size:11px;color:var(--muted);letter-spacing:.5px;text-transform:uppercase}
.login-main{padding:40px 36px}
.login-main h2{font-size:20px;font-weight:700}
.login-main .lead{color:var(--muted);font-size:13.5px;margin-top:6px;margin-bottom:22px}
.accounts{display:flex;flex-direction:column;gap:11px}
.acct{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--panel);transition:.16s;text-align:left;width:100%}
.acct:hover{border-color:var(--accent2);transform:translateY(-1px);box-shadow:var(--shadow)}
.acct .av{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:15px;color:#fff;flex:none}
.acct .ai{flex:1;display:flex;flex-direction:column;min-width:0}
.acct .an{font-weight:600;font-size:15px}
.acct .at{font-size:12.5px;color:var(--muted);margin-top:2px}
.acct .ar{font-size:11px;color:#8fb4ff;background:var(--accent-soft);padding:3px 9px;border-radius:20px;font-weight:600}
.acct .go{color:var(--muted2)}
.login-extra{margin-top:18px;padding-top:16px;border-top:1px dashed var(--line);font-size:12px;color:var(--muted2);line-height:1.6}

/* ====== APP SHELL ====== */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#0e1830,#0b1220);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-top{padding:18px 16px 14px;border-bottom:1px solid var(--line)}
.company-pill{margin-top:13px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.company-pill .cn{font-weight:600;font-size:13.5px}
.company-pill .cc{font-size:11.5px;color:var(--muted);margin-top:2px;display:flex;align-items:center;gap:5px}
.nav{padding:12px 10px;flex:1;overflow-y:auto}
.nav-group{font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted2);padding:12px 12px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);
  font-size:14px;font-weight:500;transition:.13s;width:100%;text-align:left;position:relative}
.nav-item:hover{background:var(--panel);color:var(--txt)}
.nav-item.active{background:linear-gradient(90deg,var(--accent-soft),transparent);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--accent2)}
.nav-item .badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:20px}
.nav-item .badge.alt{background:var(--amber)}
.side-bottom{padding:12px;border-top:1px solid var(--line)}
.user-chip{display:flex;align-items:center;gap:10px;padding:9px;border-radius:11px;background:var(--panel);border:1px solid var(--line)}
.user-chip .av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;flex:none}
.user-chip .ui{flex:1;min-width:0;display:flex;flex-direction:column}
.user-chip .un{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-chip .ut{font-size:11px;color:var(--muted)}
.user-chip .sw{color:var(--muted2);padding:6px;border-radius:8px}
.user-chip .sw:hover{background:var(--panel2);color:var(--txt)}

/* ====== MAIN ====== */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:62px;display:flex;align-items:center;gap:16px;padding:0 26px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:#0b1220cc;backdrop-filter:blur(10px);z-index:20}
.page-title{font-size:18px;font-weight:700;letter-spacing:-.3px}
.page-sub{font-size:12.5px;color:var(--muted);margin-top:1px}
.topbar .search{margin-left:auto;display:flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:8px 12px;width:240px;color:var(--muted)}
.topbar .search input{background:none;border:none;outline:none;color:var(--txt);width:100%;font-size:13.5px}
.icon-btn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--muted);
  background:var(--panel);border:1px solid var(--line);position:relative}
.icon-btn:hover{color:var(--txt);border-color:var(--line2)}
.icon-btn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--red);border:2px solid var(--panel)}
.content{padding:24px 26px 60px;overflow-y:auto}
.theme-fab{position:fixed;top:18px;right:18px;z-index:60;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--panel);border:1px solid var(--line);color:var(--muted);box-shadow:var(--shadow)}
.theme-fab:hover{color:var(--txt);border-color:var(--line2)}

/* ====== UI PRIMITIVES ====== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 15px;border-radius:10px;font-size:13.5px;font-weight:600;
  background:var(--panel);border:1px solid var(--line);color:var(--txt);transition:.14s}
.btn:hover{border-color:var(--line2);background:var(--panel2)}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent;
  box-shadow:0 8px 20px -8px #2563ebaa}
.btn.primary:hover{filter:brightness(1.07)}
.btn.green{background:linear-gradient(135deg,#15803d,#16a34a);border-color:transparent;box-shadow:0 8px 20px -8px #16a34aaa}
.btn.ghost{background:transparent}
.btn.sm{padding:7px 11px;font-size:12.5px}
.btn.danger{color:#fca5a5;border-color:#5b1d1d;background:#2a1212}
.btn:disabled{opacity:.5;cursor:not-allowed}
.tag{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:20px;
  background:var(--panel2);color:var(--muted);border:1px solid var(--line)}
.tag.green{background:var(--green-soft);color:#4ade80;border-color:#16653433}
.tag.amber{background:var(--amber-soft);color:#fbbf24;border-color:#92400e33}
.tag.red{background:var(--red-soft);color:#f87171;border-color:#7f1d1d33}
.tag.blue{background:var(--accent-soft);color:#93c5fd;border-color:#1e40af33}
.tag.violet{background:#7c3aed22;color:#c4b5fd;border-color:#5b21b633}
.tag.cyan{background:#0891b222;color:#67e8f9;border-color:#155e7533}
.dot-i{width:8px;height:8px;border-radius:50%;display:inline-block}

.cards-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px}
.kpi{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);
  padding:18px;position:relative;overflow:hidden;transition:.15s}
.kpi:hover{border-color:var(--line2);transform:translateY(-2px)}
.kpi .k-ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;margin-bottom:14px}
.kpi .k-lbl{font-size:12.5px;color:var(--muted);font-weight:500}
.kpi .k-val{font-size:25px;font-weight:800;letter-spacing:-.6px;margin-top:3px}
.kpi .k-sub{font-size:12px;margin-top:8px;display:flex;align-items:center;gap:5px}
.kpi.clickable{cursor:pointer}
.up{color:#4ade80}.down{color:#f87171}

.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel-h{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.panel-h h3{font-size:15px;font-weight:700}
.panel-h .ph-sub{font-size:12px;color:var(--muted)}
.panel-b{padding:18px}
.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.grid-2b{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.section-gap{margin-top:18px}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted2);
  font-weight:600;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:.1s}
.tbl tbody tr.clickable:hover{background:var(--panel2)}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.avatar-xs{width:28px;height:28px;border-radius:50%;display:inline-grid;place-items:center;font-size:11px;font-weight:700;color:#fff}
.cell-name{display:flex;align-items:center;gap:9px}
.muted{color:var(--muted)}.muted2{color:var(--muted2)}
.mini-bar{height:6px;border-radius:6px;background:var(--line);overflow:hidden;min-width:70px}
.mini-bar>i{display:block;height:100%;border-radius:6px}

/* ====== KANBAN ====== */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:14px}
.kcol{flex:0 0 290px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;max-height:calc(100vh - 200px)}
.kcol.drop-hot{border-color:var(--accent2);box-shadow:0 0 0 2px var(--accent-soft) inset}
.kcol-h{padding:13px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.kcol-h .kc-name{font-size:13px;font-weight:700}
.kcol-h .kc-count{font-size:11px;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:1px 8px;font-weight:600}
.kcol-h .kc-sum{margin-left:auto;font-size:11.5px;color:var(--muted);font-weight:600}
.kcol-b{padding:11px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;flex:1}
.kcard{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:11px;padding:12px;
  cursor:grab;transition:.13s;border-left:3px solid var(--accent2)}
.kcard:hover{border-color:var(--line2);transform:translateY(-1px);box-shadow:var(--shadow)}
.kcard:active{cursor:grabbing}
.kcard.dragging{opacity:.4}
.kcard .kc-top{display:flex;justify-content:space-between;align-items:start;gap:8px}
.kcard .kc-client{font-size:13.5px;font-weight:600;line-height:1.3}
.kcard .kc-addr{font-size:11.5px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:4px}
.kcard .kc-sum{font-size:15px;font-weight:800;margin-top:10px;letter-spacing:-.3px}
.kcard .kc-meta{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}
.kcard .kc-days{margin-left:auto;font-size:11px;color:var(--muted2);display:flex;align-items:center;gap:4px}

/* ====== MEASURE / CALC ====== */
.measure-grid{display:grid;grid-template-columns:1fr 380px;gap:18px;align-items:start}
.constr-list{display:flex;flex-direction:column;gap:12px}
.constr{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.constr-h{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--panel2);border-bottom:1px solid var(--line)}
.constr-h .ci{width:34px;height:34px;border-radius:9px;background:var(--accent-soft);color:#8fb4ff;display:grid;place-items:center;flex:none}
.constr-h .cn{font-weight:600;font-size:13.5px}
.constr-h .cp{margin-left:auto;font-weight:800;font-size:15px}
.constr-body{padding:14px;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.fld{display:flex;flex-direction:column;gap:6px}
.fld.full{grid-column:1/-1}
.fld label{font-size:11.5px;color:var(--muted);font-weight:600}
.fld input,.fld select{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--txt);font-size:13.5px;outline:none}
.fld input:focus,.fld select:focus{border-color:var(--accent2)}
.fld .row2{display:flex;gap:8px;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{padding:7px 12px;border-radius:9px;border:1px solid var(--line);background:var(--bg2);font-size:12.5px;font-weight:600;color:var(--muted);transition:.12s}
.chip.on{background:var(--accent-soft);border-color:var(--accent2);color:#bfdbfe}
.chip:hover{border-color:var(--line2)}
.extras{display:flex;flex-wrap:wrap;gap:8px}
.ex-toggle{display:flex;align-items:center;gap:8px;padding:8px 11px;border:1px solid var(--line);border-radius:9px;background:var(--bg2);font-size:12.5px;font-weight:600;color:var(--muted)}
.ex-toggle.on{background:var(--green-soft);border-color:#16653455;color:#86efac}
.win-preview{aspect-ratio:1.25;background:linear-gradient(180deg,#0c1426,#0a1120);border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;gap:6px;grid-column:1/-1}
.win-sash{flex:1;border:2px solid #3b5079;border-radius:4px;background:linear-gradient(135deg,#13233f88,#0e1a3088);position:relative}
.win-sash.tilt::after{content:"";position:absolute;inset:6px;border:1.5px dashed #4a6aa0;border-radius:3px;clip-path:polygon(0 100%,50% 0,100% 100%)}
.win-sash.turn::before{content:"";position:absolute;top:6px;bottom:6px;right:7px;width:1.5px;background:#4a6aa0}
.summary{position:sticky;top:78px}
.sum-line{display:flex;justify-content:space-between;font-size:13px;padding:8px 0;border-bottom:1px solid var(--line);color:var(--muted)}
.sum-line.total{border-bottom:none;font-size:18px;font-weight:800;color:var(--txt);padding-top:14px}
.sum-line .v{color:var(--txt);font-weight:600;font-variant-numeric:tabular-nums}
.kp-doc{background:#fff;color:#1a2233;border-radius:10px;padding:26px 28px;font-size:13px;max-height:62vh;overflow-y:auto}
.kp-doc h2{font-size:18px;color:#0b1220}
.kp-doc .kp-co{display:flex;justify-content:space-between;border-bottom:2px solid #e5e9f0;padding-bottom:14px;margin-bottom:14px}
.kp-doc table{width:100%;border-collapse:collapse;margin:14px 0;font-size:12.5px}
.kp-doc th{background:#f1f4f9;text-align:left;padding:9px 10px;color:#475569;font-size:11px;text-transform:uppercase}
.kp-doc td{padding:9px 10px;border-bottom:1px solid #eef1f6}
.kp-doc .kp-tot{text-align:right;font-size:16px;font-weight:800;color:#0b1220;margin-top:6px}
.kp-doc .kp-pre{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:12px 14px;margin-top:14px;color:#1e3a8a}

/* ====== MODAL ====== */
.modal-bg{position:fixed;inset:0;background:#04070f99;backdrop-filter:blur(6px);display:grid;place-items:center;z-index:100;padding:24px;animation:fade .15s}
.modal{width:100%;max-width:620px;max-height:90vh;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line2);border-radius:18px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:pop .18s}
.modal.wide{max-width:780px}
.modal-h{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-h h3{font-size:17px;font-weight:700}
.modal-h .mh-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.modal-h .x{margin-left:auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--muted)}
.modal-h .x:hover{background:var(--panel);color:var(--txt)}
.modal-b{padding:20px 22px;overflow-y:auto}
.modal-f{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}}

.timeline{display:flex;flex-direction:column;gap:0}
.tl-item{display:flex;gap:12px;padding-bottom:16px;position:relative}
.tl-item::before{content:"";position:absolute;left:9px;top:20px;bottom:-4px;width:2px;background:var(--line)}
.tl-item:last-child::before{display:none}
.tl-dot{width:20px;height:20px;border-radius:50%;flex:none;display:grid;place-items:center;z-index:1}
.tl-c .tl-t{font-size:13px;font-weight:600}
.tl-c .tl-d{font-size:11.5px;color:var(--muted);margin-top:2px}

.stat-line{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}
.stat-line:last-child{border-bottom:none}
.empty{text-align:center;padding:50px 20px;color:var(--muted2)}
.empty .svg-i{width:42px;height:42px;margin:0 auto 14px;stroke-width:1.3;opacity:.5}

.tabs{display:flex;gap:4px;background:var(--bg2);border:1px solid var(--line);border-radius:11px;padding:4px;width:fit-content}
.tab{padding:8px 15px;border-radius:8px;font-size:13px;font-weight:600;color:var(--muted)}
.tab.on{background:var(--accent);color:#fff}
.tab:hover:not(.on){color:var(--txt)}

.perm-tbl td .yes{color:#4ade80}.perm-tbl td .no{color:#475569}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.legend span{display:flex;align-items:center;gap:6px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast .t{background:var(--panel2);border:1px solid var(--line2);border-radius:12px;padding:13px 18px;box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:11px;font-size:13.5px;font-weight:500;animation:toastin .25s;max-width:420px}
.toast .t.ok{border-color:#16653455}
.toast .t .ti{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;flex:none}
@keyframes toastin{from{opacity:0;transform:translateY(14px)}}

.bars{display:flex;flex-direction:column;gap:11px}
.bar-row{display:grid;grid-template-columns:130px 1fr auto;gap:12px;align-items:center;font-size:12.5px}
.bar-row .bl{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{height:24px;background:var(--bg2);border-radius:7px;overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:7px;display:flex;align-items:center;padding-left:9px;font-size:11px;font-weight:700;color:#fff;min-width:fit-content;transition:width .6s cubic-bezier(.2,.8,.2,1)}
.bar-row .bv{font-weight:700;font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}

.funnel-vis{display:flex;flex-direction:column;gap:7px}
.fv-row{display:flex;align-items:center;gap:12px}
.fv-bar{height:34px;border-radius:8px;display:flex;align-items:center;padding:0 13px;color:#fff;font-weight:700;font-size:13px;
  transition:width .6s cubic-bezier(.2,.8,.2,1);min-width:120px;justify-content:space-between;white-space:nowrap;gap:8px}
.fv-lbl{width:140px;font-size:12.5px;color:var(--muted);text-align:right;flex:none}
.fv-conv{font-size:11px;color:var(--muted2);width:54px;flex:none}

@media (max-width:1100px){.measure-grid{grid-template-columns:1fr}.summary{position:static}.grid-2{grid-template-columns:1fr}}
@media (max-width:920px){.login-card{grid-template-columns:1fr}.login-side{display:none}}
@media (max-width:760px){.shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-260px;z-index:50;transition:.2s;box-shadow:var(--shadow-lg)}
  .sidebar.open{left:0}.content{padding:16px}.topbar{padding:0 14px}.topbar .search{display:none}.menu-toggle{display:grid!important}}
.menu-toggle{display:none}

/* ====== LIGHT THEME ====== */
[data-theme="light"]{
  --bg:#eef1f8; --bg2:#e9eef6; --panel:#ffffff; --panel2:#f6f8fc;
  --line:#e3e8f1; --line2:#cdd8e8;
  --txt:#15233b; --muted:#5c6b86; --muted2:#8a98b2;
  --accent:#2563eb; --accent2:#3b82f6; --accent-soft:#2563eb14;
  --green:#16a34a; --green-soft:#16a34a16;
  --amber:#d97706; --amber-soft:#d9770618;
  --red:#dc2626; --red-soft:#dc262614;
  --shadow:0 10px 30px -14px rgba(20,40,80,.18);
  --shadow-lg:0 24px 60px -24px rgba(20,40,80,.28);
}
[data-theme="light"] body{
  background:radial-gradient(1200px 700px at 80% -10%,#dbe7ff 0%,transparent 55%),
             radial-gradient(900px 600px at -10% 110%,#e6edfb 0%,transparent 50%),
             var(--bg);
}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:#c5d0e2}
[data-theme="light"] .login-side{background:
  radial-gradient(600px 300px at 110% -20%,#cfe0ff88,transparent 60%),
  linear-gradient(160deg,#eef3fc,#ffffff)}
[data-theme="light"] .login-feat{color:#33415a}
[data-theme="light"] .sidebar{background:linear-gradient(180deg,#ffffff,#f3f6fc)}
[data-theme="light"] .nav-item.active{color:var(--accent)}
[data-theme="light"] .topbar{background:#ffffffcc}
[data-theme="light"] .btn.danger{color:#b91c1c;border-color:#f3c7c7;background:#fdecec}
[data-theme="light"] .tag.green{color:#15803d}
[data-theme="light"] .tag.amber{color:#b45309}
[data-theme="light"] .tag.red{color:#b91c1c}
[data-theme="light"] .tag.blue{color:#1d4ed8}
[data-theme="light"] .tag.violet{color:#6d28d9}
[data-theme="light"] .tag.cyan{color:#0e7490}
[data-theme="light"] .up{color:#15803d}
[data-theme="light"] .down{color:#dc2626}
[data-theme="light"] .perm-tbl td .yes{color:#15803d}
[data-theme="light"] .perm-tbl td .no{color:#94a3b8}
[data-theme="light"] .constr-h .ci{color:var(--accent)}
[data-theme="light"] .chip.on{color:#1d4ed8}
[data-theme="light"] .ex-toggle.on{color:#15803d;border-color:#16a34a55}
[data-theme="light"] .win-preview{background:linear-gradient(180deg,#eaf2ff,#dbe9ff)}
[data-theme="light"] .win-sash{border-color:#9fb4d6;background:linear-gradient(135deg,#ffffffaa,#e8f1fcaa)}
[data-theme="light"] .win-sash.tilt::after,[data-theme="light"] .win-sash.turn::before{border-color:#7088b0;background:#7088b0}
[data-theme="light"] .modal-bg{background:rgba(30,41,59,.35)}
[data-theme="light"] .toast .t.ok{border-color:#16a34a55}

/* ============ ДОСТУП ПО ССЫЛКЕ · ГЕЙТ + ШАРИНГ ============ */
.gate-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%,var(--panel2),transparent),var(--bg)}
.gate-card{width:100%;max-width:460px;text-align:center;background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-lg);padding:40px 34px}
.gate-icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px;
  background:var(--accent-soft);color:var(--accent2)}
.gate-icon svg{width:30px;height:30px}
.gate-card h1{font-size:23px;font-weight:800;margin:10px 0 12px;letter-spacing:-.01em}
.gate-card p{color:var(--muted);font-size:14px;line-height:1.6;margin-bottom:22px}
.gate-btn{display:inline-flex;align-items:center;gap:9px;padding:12px 20px;border-radius:12px;font-weight:700;font-size:14px;
  background:linear-gradient(135deg,#15803d,#16a34a);color:#fff;box-shadow:0 10px 24px -10px #16a34aaa}
.gate-btn:hover{filter:brightness(1.07)}
.gate-foot{margin-top:24px;padding-top:18px;border-top:1px dashed var(--line);font-size:12px;color:var(--muted2)}

.login-fabs{position:fixed;top:18px;right:18px;z-index:60;display:flex;gap:10px;align-items:center}
.login-fabs .theme-fab{position:static}
.share-fab{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 16px;border-radius:11px;font-weight:700;font-size:13px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:1px solid transparent;box-shadow:var(--shadow)}
.share-fab:hover{filter:brightness(1.08)}
.demo-banner{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:55;display:inline-flex;align-items:center;gap:8px;
  background:var(--panel2);border:1px solid var(--line2);border-radius:30px;padding:8px 16px;font-size:12.5px;color:var(--muted);box-shadow:var(--shadow)}
.demo-banner b{color:var(--txt)}

.share-opts{display:flex;flex-wrap:wrap;gap:8px}
.share-opt{flex:1;min-width:84px;padding:10px 8px;border:1px solid var(--line);border-radius:10px;background:var(--bg2);
  color:var(--muted);font-weight:600;font-size:13px;transition:.15s}
.share-opt:hover{border-color:var(--line2);color:var(--txt)}
.share-opt.on{background:var(--accent-soft);border-color:var(--accent2);color:var(--txt)}
.share-result{grid-column:1/-1;margin-top:6px;padding-top:14px;border-top:1px dashed var(--line);display:flex;flex-direction:column;gap:10px}
.share-result .label{font-size:11.5px;color:var(--muted);font-weight:600}
.share-url{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--txt);
  font-size:12.5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;resize:none;outline:none;word-break:break-all}
.share-url:focus{border-color:var(--accent2)}
.share-result .btn{justify-content:center}
