/* ============================================================
   LinkedERP AMO — design system
   Performance-first: GPU-friendly transforms/opacity only, no
   layout-thrashing animation, system font stack, hand-rolled SVG.
   ============================================================ */
:root{
  /* ============================================================
     LinkedERP AMO — Aurora Glass DARK tokens.
     Redefines the EXISTING token names to dark values so flipping
     :root restyles ~80% of the app. New tokens added at the end.
     ============================================================ */

  /* --- Brand red (UNCHANGED hue — the one warm signal) --- */
  --red:#E11B22;                 /* primary CTA base, active nav rail, focus hue, overdue */
  --red-d:#B3141A;               /* gradient bottom-stop / pressed */
  --red-hot:#FF4A4F;             /* NEW: gradient top-stop, lit-from-above red */
  --red-text:#FF8A8E;            /* NEW: legible red TEXT on near-black */
  --red-soft:rgba(225,27,34,.14);/* red wash on dark (was .08 on white) */
  --red-soft2:rgba(225,27,34,.16);/* red pill/banner fill */
  --red-glow:rgba(225,27,34,.45);/* NEW: THE glow — box-shadow color for every lit element */

  /* --- Text ink (cool off-white, never pure #fff) --- */
  --charcoal:#EAF0F7;            /* was darkest heading -> now BRIGHTEST text. h1-h4,.nm,.kv,strong cells */
  --ink:#EAF0F7;                 /* primary body text */
  --ink-2:#9FB0C3;               /* secondary — .muted, paragraphs, cells */
  --grey:#7E8DA0;                /* tertiary — .cap,.dim,labels,axis (>=4.5:1 on --bg-2) */
  --grey-2:#AEB6C2;              /* lifted tertiary — tier-silver text, hover hints */

  /* --- Lines: white-at-low-alpha (NEVER solid grey — this sells glass) --- */
  --line:rgba(220,232,248,.10);  /* resting border on every surface */
  --line-2:rgba(220,232,248,.18);/* strong border — inputs, hover, dividers, scale rest */

  /* --- Surfaces: glass over the aurora --- */
  --bg:#0B0E13;                  /* APP FLOOR — near-black, violet bias. body + canvas bleed */
  --bg-2:#161B26;                /* inset wells — th strip, seg track, input rest, drawer foot, scrollbar */
  --card:rgba(22,28,40,.55);     /* PRIMARY GLASS — paired w/ backdrop-filter in globalCss */
  --card-solid:#141925;          /* NEW: opaque fallback for toasts, selects, @supports-not(blur) */
  --card-2:rgba(30,38,54,.62);   /* NEW: RAISED GLASS — drawer, sticky th, topbar, active seg */
  --white:#fff;

  /* --- RAG / status (brightened to read on near-black) --- */
  --green:#34E6A8;               /* Health=Green, Held, on-track, scale s4/s5 */
  --green-soft:rgba(52,230,168,.14);
  --green-text:#5FF0BE;          /* NEW: text inside green pills */
  --amber:#FFC24D;               /* Health=Amber, watch, stars, scale s3, handed-over */
  --amber-soft:rgba(255,194,77,.14);
  --amber-text:#FFD27A;          /* NEW: text inside amber pills */
  --redrag:#FF5B53;              /* Health=Red / declining (brightened from #E2453B) */
  --blue:#5B8DEF;                /* Informational / planned / In Progress / SLA */
  --blue-soft:rgba(91,141,239,.16);
  --blue-text:#9DBEFF;           /* NEW: text inside blue pills */
  --violet:#9A7BFF;              /* NEW: aurora + categorical (BU tags, transcript tabs) — not a status */

  /* --- Tier swatches (lifted for dark) --- */
  --gold:#E6B649; --silver:#AEB6C2; --bronze:#D08A52;

  /* --- Elevation: inner rim-light lifts on dark, not a big drop --- */
  --shadow-sm:inset 0 1px 0 rgba(255,255,255,.05),0 1px 2px rgba(0,0,0,.40);
  --shadow:inset 0 1px 0 rgba(255,255,255,.06),0 6px 20px rgba(0,0,0,.45);
  --shadow-lg:inset 0 1px 0 rgba(255,255,255,.07),0 24px 60px rgba(0,0,0,.55);

  /* --- Geometry / motion (UNCHANGED — keeps layout identical) --- */
  --r:14px; --r-sm:10px; --r-lg:20px;
  --sb:248px;
  --ff:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --fast:.16s cubic-bezier(.4,0,.2,1); --med:.26s cubic-bezier(.4,0,.2,1);

  /* --- NEW: glass recipe + glow helpers reused across components --- */
  --glass-blur:saturate(140%) blur(18px);
  --glass-blur-strong:saturate(150%) blur(22px);
  --rim:inset 0 1px 0 rgba(255,255,255,.06);
  --hover-wash:rgba(255,255,255,.04);
  color-scheme:dark;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--ff);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:14px}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em;color:var(--charcoal)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#D4DAE2;border-radius:8px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--grey-2)}

/* ---------- utilities ---------- */
.muted{color:var(--ink-2)} .dim{color:var(--grey)}
.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
.row{display:flex;align-items:center}.col{display:flex;flex-direction:column}
.gap4{gap:4px}.gap8{gap:8px}.gap12{gap:12px}.gap16{gap:16px}.gap24{gap:24px}
.wrap{flex-wrap:wrap}.between{justify-content:space-between}.center{justify-content:center}
.grow{flex:1}.right{margin-left:auto}.nowrap{white-space:nowrap}
.hide{display:none!important}
.t-r{text-align:right}.t-c{text-align:center}
.cap{text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700;color:var(--grey)}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ---------- login ---------- */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.login-hero{position:relative;background:linear-gradient(155deg,#16191E 0%,#23272E 55%,#2C313A 100%);overflow:hidden;color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:54px 56px}
.login-hero .mesh{position:absolute;inset:0;opacity:.5;pointer-events:none}
.login-hero .glow{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(225,27,34,.34),transparent 62%);filter:blur(20px);top:-120px;right:-120px;animation:float 16s ease-in-out infinite}
.login-hero .glow.b{background:radial-gradient(circle,rgba(45,108,223,.20),transparent 64%);bottom:-160px;left:-120px;top:auto;right:auto;animation-duration:21s}
@keyframes float{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(0,28px,0)}}
.login-hero .brandline{display:flex;align-items:center;gap:13px;position:relative}
.login-hero .brandline img{height:30px;filter:brightness(0) invert(1)}
.login-hero .htag{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:#C7CDDA;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);padding:5px 12px;border-radius:30px;width:fit-content}
.login-hero h1{color:#fff;font-size:40px;line-height:1.08;letter-spacing:-.025em;margin:20px 0 14px;max-width:15ch}
.login-hero h1 b{color:#fff;position:relative}
.login-hero h1 .u{background:linear-gradient(transparent 68%,rgba(225,27,34,.55) 0)}
.login-hero p.lead{color:#AEB6C6;font-size:15px;max-width:42ch;line-height:1.6}
.login-hero .pillars{display:flex;gap:10px;flex-wrap:wrap;position:relative}
.login-hero .pillar{flex:1;min-width:130px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:14px 15px}
.login-hero .pillar .k{font-size:12px;color:#C7CDDA;font-weight:600}
.login-hero .pillar .v{font-size:12.5px;color:#8A93A4;margin-top:3px}
.login-hero .foot{font-size:12px;color:#727C8C;position:relative}
.login-form-side{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--card)}
.login-card{width:100%;max-width:392px}
.login-card .lc-logo{display:none}
.login-card h2{font-size:25px;letter-spacing:-.02em}
.login-card .sub{color:var(--ink-2);margin:6px 0 26px;font-size:14px}
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:var(--r-sm);background:var(--bg-2);transition:border-color var(--fast),box-shadow var(--fast),background var(--fast);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 3.5px var(--red-soft)}
.field textarea{resize:vertical;min-height:74px;line-height:1.55}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:var(--r-sm);font-weight:600;font-size:14px;transition:transform var(--fast),box-shadow var(--fast),background var(--fast),border-color var(--fast);white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 2px 8px rgba(225,27,34,.28)}
.btn-primary:hover{background:var(--red-d);box-shadow:0 4px 14px rgba(225,27,34,.34)}
.btn-ghost{background:var(--card);color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--grey-2);background:var(--bg-2)}
.btn-soft{background:var(--red-soft);color:var(--red-d)}
.btn-soft:hover{background:rgba(225,27,34,.14)}
.btn-block{width:100%}
.btn-sm{padding:7px 12px;font-size:12.5px;border-radius:8px}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none}
.login-err{background:var(--red-soft2);color:#A3271F;border:1px solid #F3C9C4;padding:10px 13px;border-radius:var(--r-sm);font-size:13px;margin-bottom:15px}
.login-demo{margin-top:18px;padding:13px 15px;border:1px dashed var(--line);border-radius:var(--r-sm);font-size:12.5px;color:var(--ink-2);background:var(--bg-2)}
.login-demo b{color:var(--ink)}

/* ---------- app shell ---------- */
.app{display:grid;grid-template-columns:var(--sb) 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#1B1E24,#23272F);color:#C9D0DB;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:30}
.sb-brand{display:flex;align-items:center;gap:11px;padding:20px 20px 18px;border-bottom:1px solid rgba(255,255,255,.07)}
.sb-brand img{height:26px;filter:brightness(0) invert(1)}
.sb-brand .bt{font-size:11px;font-weight:700;letter-spacing:.16em;color:#7d8696;border-left:1px solid rgba(255,255,255,.16);padding-left:11px}
.sb-nav{flex:1;overflow-y:auto;padding:12px 12px 18px}
.sb-nav::-webkit-scrollbar{width:0}
.sb-sec{font-size:10.5px;font-weight:700;letter-spacing:.13em;color:#5d6675;padding:14px 12px 7px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9.5px 12px;border-radius:9px;color:#AEB6C3;font-weight:500;font-size:13.5px;transition:color var(--fast),background var(--fast);position:relative;margin-bottom:1px}
.nav-item svg{width:18px;height:18px;flex:none;opacity:.85}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:linear-gradient(90deg,rgba(225,27,34,.20),rgba(225,27,34,.05));color:#fff}
.nav-item.active::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;border-radius:3px;background:var(--red)}
.nav-item .badge{margin-left:auto;background:var(--red);color:#fff;font-size:10.5px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px}
.nav-item .badge.amber{background:var(--amber)}
.sb-user{padding:13px 14px;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--red),#F2604F);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:none}
.sb-user .un{font-size:13px;font-weight:600;color:#fff;line-height:1.2}
.sb-user .ur{font-size:11px;color:#828c9c}
.sb-user button{margin-left:auto;color:#828c9c;padding:6px;border-radius:7px;transition:color var(--fast),background var(--fast)}
.sb-user button:hover{color:#fff;background:rgba(255,255,255,.08)}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{height:60px;background:rgba(255,255,255,.85);backdrop-filter:saturate(150%) blur(8px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 26px;position:sticky;top:0;z-index:20}
.topbar h1{font-size:18px;letter-spacing:-.02em}
.topbar .crumb{font-size:12.5px;color:var(--grey);font-weight:500}
.content{padding:24px 26px 60px;max-width:1320px;width:100%;margin:0 auto}
.page-head{margin-bottom:20px}
.page-head h2{font-size:22px;letter-spacing:-.022em}
.page-head .ph-sub{color:var(--ink-2);font-size:13.5px;margin-top:3px}

/* fade/slide for view switches — opacity+transform only */
.view-enter{animation:viewin .3s cubic-bezier(.22,.61,.36,1)}
@keyframes viewin{from{opacity:0;transform:translate3d(0,8px,0)}to{opacity:1;transform:none}}

/* ---------- cards ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm)}
.card-pad{padding:18px}
.grid{display:grid;gap:16px}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:17px 18px;position:relative;overflow:hidden;transition:transform var(--fast),box-shadow var(--fast);box-shadow:var(--shadow-sm)}
.kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.kpi .kl{font-size:12px;color:var(--ink-2);font-weight:600;display:flex;align-items:center;gap:7px}
.kpi .kv{font-size:30px;font-weight:760;letter-spacing:-.03em;margin-top:9px;line-height:1;color:var(--charcoal)}
.kpi .kv small{font-size:15px;font-weight:600;color:var(--grey);letter-spacing:0}
.kpi .kf{margin-top:9px;font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.kpi .accent{position:absolute;left:0;top:0;bottom:0;width:4px}
.kpi .ic{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;position:absolute;top:16px;right:16px;opacity:.92}
.kpi .ic svg{width:17px;height:17px}
.delta{font-weight:700;font-size:12px;display:inline-flex;align-items:center;gap:3px}
.delta.up{color:var(--green)}.delta.down{color:var(--redrag)}.delta.flat{color:var(--grey)}

/* ---------- badges ---------- */
.badge-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:30px;letter-spacing:.01em;white-space:nowrap;line-height:1.4}
.rag-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex:none}
.b-green{background:var(--green-soft);color:#157a48}.b-green .rag-dot{background:var(--green)}
.b-amber{background:var(--amber-soft);color:#8a6410}.b-amber .rag-dot{background:var(--amber)}
.b-red{background:var(--red-soft2);color:#b0291f}.b-red .rag-dot{background:var(--redrag)}
.b-grey{background:#EEF1F5;color:#5a6472}.b-grey .rag-dot{background:var(--grey)}
.b-blue{background:var(--blue-soft);color:#1d4fa8}.b-blue .rag-dot{background:var(--blue)}
.tier{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:700;padding:3px 9px 3px 7px;border-radius:7px}
.tier::before{content:"";width:7px;height:7px;border-radius:2px}
.tier-Gold{background:#FBF2D9;color:#8a6810}.tier-Gold::before{background:var(--gold)}
.tier-Silver{background:#EEF1F5;color:#56606e}.tier-Silver::before{background:var(--silver)}
.tier-Bronze{background:#F6ECE2;color:#8a5a32}.tier-Bronze::before{background:var(--bronze)}
.trend{font-weight:700;font-size:12px;display:inline-flex;align-items:center;gap:3px}
.trend.Improving{color:var(--green)}.trend.Declining{color:var(--redrag)}.trend.Stable{color:var(--grey)}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg-2);border:1px solid var(--line);border-radius:30px;padding:4px 11px;font-size:12px;font-weight:500;color:var(--ink)}

/* ---------- tables ---------- */
.tbl-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.tbl-tools{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.search{position:relative;flex:1;min-width:200px;max-width:340px}
.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--grey)}
.search input{width:100%;padding:9px 12px 9px 34px;border:1.5px solid var(--line);border-radius:9px;background:var(--bg-2)}
.search input:focus{outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 3px var(--red-soft)}
.seg{display:inline-flex;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.seg button{padding:6px 11px;border-radius:7px;font-size:12.5px;font-weight:600;color:var(--ink-2);transition:color var(--fast),background var(--fast)}
.seg button.on{background:#fff;color:var(--charcoal);box-shadow:var(--shadow-sm)}
.fsel{padding:8px 11px;border:1.5px solid var(--line);border-radius:9px;background:var(--bg-2);font-weight:500;font-size:12.5px;color:var(--ink);max-width:170px}
.fsel:focus{outline:none;border-color:var(--red)}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--grey);padding:11px 16px;border-bottom:1px solid var(--line);background:var(--bg-2);position:sticky;top:0;white-space:nowrap}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line-2);font-size:13.5px;vertical-align:middle}
tbody tr{transition:background var(--fast)}
tbody tr:hover{background:var(--bg-2)}
tbody tr:last-child td{border-bottom:none}
tr.clickable{cursor:pointer}
.cell-strong{font-weight:600;color:var(--charcoal)}
.cell-sub{font-size:11.5px;color:var(--grey);margin-top:1px}
td .row{gap:8px}

/* ---------- detail / 360 ---------- */
.c360{display:grid;grid-template-columns:1fr;gap:16px}
.c360-head{background:linear-gradient(120deg,#fff,var(--bg-2));border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;box-shadow:var(--shadow-sm)}
.c360-head .nm{font-size:23px;font-weight:760;letter-spacing:-.02em;color:var(--charcoal)}
.c360-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;margin-top:16px}
.c360-grid .m .l{font-size:11px;color:var(--grey);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.c360-grid .m .v{font-size:14px;font-weight:600;color:var(--ink);margin-top:4px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sec-title{font-size:13px;font-weight:700;color:var(--charcoal);display:flex;align-items:center;gap:8px;margin-bottom:13px}
.sec-title .ct{margin-left:auto;font-size:11px;color:var(--grey);font-weight:600}
.list-row{display:flex;align-items:flex-start;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-2)}
.list-row:last-child{border-bottom:none}
.list-row .lr-main{flex:1;min-width:0}
.list-row .lr-t{font-size:13px;font-weight:600;color:var(--ink)}
.list-row .lr-s{font-size:12px;color:var(--ink-2);margin-top:2px}

/* score ring + bars */
.ring-wrap{display:flex;align-items:center;gap:20px}
.dim-bars{display:flex;flex-direction:column;gap:11px;flex:1}
.dim-bar .db-top{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px}
.dim-bar .db-top .dn{font-weight:600;color:var(--ink)}
.dim-bar .db-top .ds{font-weight:700;color:var(--charcoal)}
.dim-track{height:7px;background:var(--line-2);border-radius:5px;overflow:hidden}
.dim-fill{height:100%;border-radius:5px;transform-origin:left;transition:width .6s cubic-bezier(.22,.61,.36,1)}

/* ---------- scorecard editor ---------- */
.score-dim{border:1px solid var(--line);border-radius:var(--r);padding:16px;margin-bottom:13px;transition:border-color var(--fast),box-shadow var(--fast)}
.score-dim:hover{border-color:var(--grey-2)}
.score-dim .sd-h{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}
.score-dim .sd-h .wt{font-size:11px;font-weight:700;color:var(--grey);background:var(--bg-2);border:1px solid var(--line);padding:2px 8px;border-radius:20px}
.score-dim .q{font-size:12px;color:var(--ink-2);margin-top:3px;line-height:1.45}
.scale{display:flex;gap:7px}
.scale button{flex:1;padding:10px 0;border:1.5px solid var(--line);border-radius:9px;font-weight:700;font-size:15px;color:var(--ink-2);background:var(--bg-2);transition:all var(--fast);position:relative}
.scale button .sl{display:block;font-size:9px;font-weight:600;letter-spacing:.02em;margin-top:2px;text-transform:uppercase;opacity:.7}
.scale button:hover{border-color:var(--grey-2);color:var(--ink)}
.scale button.sel{color:#fff;border-color:transparent}
.scale button.sel.s1,.scale button.sel.s2{background:var(--redrag)}
.scale button.sel.s3{background:var(--amber)}
.scale button.sel.s4,.scale button.sel.s5{background:var(--green)}
.score-live{position:sticky;top:76px}
.score-gauge{display:flex;flex-direction:column;align-items:center;padding:8px 0 4px}
.score-num{font-size:46px;font-weight:800;letter-spacing:-.04em;line-height:1}
.evidence-warn{font-size:11.5px;color:var(--redrag);margin-top:6px;display:none}
.score-dim.missing .evidence-warn{display:block}
.score-dim.missing{border-color:#F3C9C4}

/* ---------- drawer ---------- */
.drawer-mask{position:fixed;inset:0;background:rgba(20,26,36,.42);backdrop-filter:blur(2px);opacity:0;pointer-events:none;transition:opacity var(--med);z-index:50}
.drawer-mask.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:min(560px,94vw);background:var(--card);box-shadow:var(--shadow-lg);transform:translate3d(100%,0,0);transition:transform var(--med);z-index:51;display:flex;flex-direction:column}
.drawer.open{transform:translate3d(0,0,0)}
.drawer.wide{width:min(820px,96vw)}
.drawer-head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-size:17px}
.drawer-head .dh-sub{font-size:12px;color:var(--grey)}
.drawer-head .x{margin-left:auto;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--grey);transition:all var(--fast)}
.drawer-head .x:hover{background:var(--bg);color:var(--ink)}
.drawer-body{flex:1;overflow-y:auto;padding:20px 22px}
.drawer-foot{padding:15px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;background:var(--bg-2)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
.form-warn{background:var(--amber-soft);border:1px solid #F0D89B;color:#8a6410;padding:10px 13px;border-radius:var(--r-sm);font-size:12.5px;margin-bottom:14px}

/* ---------- board ---------- */
.board-block{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);overflow:hidden}
.bb-head{padding:15px 19px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.bb-head .bb-i{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center}
.bb-head h3{font-size:15px}
.bb-head .bb-q{margin-left:auto;font-size:11.5px;font-weight:600;color:var(--grey)}
.bb-body{padding:18px 19px}
.bigstat{display:flex;align-items:baseline;gap:10px}
.bigstat .bs-n{font-size:40px;font-weight:800;letter-spacing:-.03em;line-height:1}
.bigstat .bs-u{font-size:13px;color:var(--ink-2);font-weight:500}
.rag-strip{display:flex;height:12px;border-radius:7px;overflow:hidden;margin:16px 0 8px;background:var(--line-2)}
.rag-strip i{display:block;height:100%;transition:width .7s cubic-bezier(.22,.61,.36,1)}
.rag-legend{display:flex;gap:16px;flex-wrap:wrap}
.rag-legend .rl{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600}
.rag-legend .rl b{font-size:14px}
.mini-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:13px}
.mini-row:last-child{border-bottom:none}
.mini-row .mr-v{font-weight:700;color:var(--charcoal)}
.red-strip{display:flex;flex-direction:column}
.red-cust{display:flex;align-items:center;gap:13px;padding:13px 19px;border-bottom:1px solid var(--line-2)}
.red-cust:last-child{border-bottom:none}
.red-cust:hover{background:var(--bg-2)}
.red-cust .rc-score{width:46px;height:46px;border-radius:11px;background:var(--red-soft2);color:#b0291f;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px;flex:none}

/* ---------- misc ---------- */
.skeleton{background:linear-gradient(90deg,#EEF1F5 25%,#F6F8FA 37%,#EEF1F5 63%);background-size:400% 100%;animation:sk 1.3s ease infinite;border-radius:8px}
@keyframes sk{0%{background-position:100% 50%}100%{background-position:0 50%}}
.sk-card{height:104px;border-radius:var(--r)}
.sk-row{height:46px;margin-bottom:8px}
.empty{text-align:center;padding:46px 20px;color:var(--ink-2)}
.empty .ei{width:54px;height:54px;border-radius:15px;background:var(--bg);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--grey-2)}
.empty h4{font-size:15px;color:var(--ink);margin-bottom:5px}
.empty p{font-size:13px;max-width:340px;margin:0 auto 16px}
.toast-wrap{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:80}
.toast{background:var(--charcoal);color:#fff;padding:13px 17px;border-radius:11px;box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:11px;max-width:380px;animation:toastin .3s cubic-bezier(.22,.61,.36,1)}
.toast.ok{background:#15512f}.toast.err{background:#7a1d16}.toast.warn{background:#7a5510}
.toast svg{width:18px;height:18px;flex:none}
@keyframes toastin{from{opacity:0;transform:translate3d(0,16px,0)}to{opacity:1;transform:none}}
.warn-banner{background:var(--amber-soft);border:1px solid #F0D89B;color:#7a5510;padding:11px 15px;border-radius:var(--r-sm);font-size:13px;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.warn-banner.red{background:var(--red-soft2);border-color:#F3C9C4;color:#a3271f}
.spin{width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:sp .6s linear infinite;display:inline-block}
@keyframes sp{to{transform:rotate(360deg)}}
.matrix{display:grid;grid-template-columns:auto repeat(3,1fr);gap:6px}
.matrix .mh{font-size:11px;font-weight:700;color:var(--grey);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;padding:6px}
.matrix .mc{border-radius:9px;padding:11px 12px;min-height:74px;border:1px solid var(--line)}
.matrix .mc .mc-n{font-size:13px;font-weight:700}
.matrix .mc .mc-c{font-size:11px;margin-top:3px;opacity:.85}
.matrix .rk{display:flex;align-items:center;font-size:12px;font-weight:700;color:var(--ink-2);padding-right:6px;justify-content:flex-end}
.print-only{display:none}

/* touchpoints planner */
.tp-group{margin-bottom:20px}
.tp-group-h{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--grey);margin-bottom:11px;display:flex;align-items:center;gap:8px}
.tp-group-h .ct{background:var(--bg-2);border:1px solid var(--line);border-radius:20px;padding:1px 9px;font-size:11px;color:var(--ink-2)}
.tp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.tp-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:15px 16px;transition:transform var(--fast),box-shadow var(--fast)}
.tp-card.clickable{cursor:pointer}
.tp-card.clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.tp-dots{display:flex;gap:6px;margin-top:4px}
.tp-dot{flex:1;text-align:center;font-size:10px;font-weight:700;padding:4px 0;border-radius:6px;background:var(--bg-2);border:1px solid var(--line);color:var(--grey-2);letter-spacing:.02em}
.tp-dot.on{background:var(--green-soft);border-color:#bfe6cf;color:#157a48}
.radar-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:10px}
.radar-item{border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:var(--bg-2);transition:border-color var(--fast),transform var(--fast)}
.radar-item.clickable{cursor:pointer}
.radar-item.clickable:hover{border-color:var(--grey-2);transform:translateY(-1px)}
.radar-item.nogap{border-left:3px solid var(--redrag)}

@media(max-width:1080px){.two-col{grid-template-columns:1fr}.board-top{grid-template-columns:1fr!important}}
@media(max-width:920px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform var(--med);width:260px}
  .sidebar.open{transform:none}
  .login-wrap{grid-template-columns:1fr}.login-hero{display:none}
  .login-card .lc-logo{display:flex;margin-bottom:22px}
  .form-grid{grid-template-columns:1fr}
  .menu-btn{display:flex!important}
}
.menu-btn{display:none;width:36px;height:36px;border-radius:9px;align-items:center;justify-content:center;color:var(--ink);border:1px solid var(--line)}

@media print{
  .sidebar,.topbar,.tbl-tools,.menu-btn,.no-print,.drawer,.drawer-mask{display:none!important}
  .app{display:block}.content{max-width:none;padding:0}
  .print-only{display:block}
  body{background:#fff;font-size:12px}
  .card,.board-block,.kpi,.tbl-wrap{box-shadow:none;border-color:#ddd;break-inside:avoid}
  .board-top{grid-template-columns:1fr 1fr 1fr!important}
}

/* ============================================================

   AURORA GLASS — DARK THEME (appended; overrides win by source order)

   LinkedERP AMO — Aurora Glass (Dark)

   ============================================================ */

/* ============================================================
   AURORA GLASS — global dark treatment.
   Append AFTER the existing base styles; relies on the flipped :root.
   ============================================================ */

/* Floor: near-black + a static aurora gradient that doubles as the
   reduced-motion / pre-canvas fallback so there is never a flat black flash. */
body{
  background:var(--bg);
  background-image:
    radial-gradient(60% 50% at 18% 0%,rgba(225,27,34,.10),transparent 60%),
    radial-gradient(52% 46% at 86% 26%,rgba(40,70,165,.12),transparent 62%),
    radial-gradient(50% 50% at 52% 100%,rgba(120,70,210,.10),transparent 64%);
  background-attachment:fixed;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{color:var(--charcoal);letter-spacing:-.02em}

/* Scrollbars — dark track, glassy thumb */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--bg-2)}
::-webkit-scrollbar-thumb{background:rgba(220,232,248,.16);border-radius:8px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:rgba(220,232,248,.28)}
*{scrollbar-color:rgba(220,232,248,.18) var(--bg-2)}

/* ---------- GLASS UTILITY (the signature) ----------
   .card/.kpi/.tbl-wrap/.board-block/.login-card etc get frosted glass +
   the 1px white-alpha rim that catches the aurora. */
.card,.kpi,.tbl-wrap,.board-block,.login-card,.c360-head,.tp-card{
  -webkit-backdrop-filter:var(--glass-blur);
  backdrop-filter:var(--glass-blur);
}
/* Fallback: opaque cards where blur is unsupported (no unreadable transparency). */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .card,.kpi,.tbl-wrap,.board-block,.login-card,.c360-head,.tp-card,
  .topbar,.drawer,thead th{background:var(--card-solid)!important}
}

/* Glow utilities (opt-in) */
.glow-red{box-shadow:0 4px 18px var(--red-glow)}
.u-rim{box-shadow:var(--rim)}

/* Native option menus can't be glass — force a solid dark surface. */
select,option{background:var(--card-solid);color:var(--ink)}

/* Keyboard focus baseline (light bloom, no layout shift) */
:focus-visible{outline:none;box-shadow:0 0 0 1px var(--red),0 0 0 4px var(--red-glow)}

/* Selection */
::selection{background:rgba(225,27,34,.35);color:#fff}

/* Reduced motion: kill view-enter slide + skeleton shimmer; canvas self-disables */
@media(prefers-reduced-motion:reduce){
  .view-enter{animation:none}
  .skeleton{animation:none}
  *{transition-duration:.001ms!important}
}

/* Print (base @media print already inverts to white) — glass off for paper */
@media print{
  body{background:#fff!important;background-image:none!important;color:#111}
  #aurora{display:none!important}
  .card,.kpi,.tbl-wrap,.board-block{backdrop-filter:none!important;background:#fff!important}
}

/* --- aurora canvas layer --- */

#aurora{position:fixed;inset:0;width:100%;height:100%;z-index:-1;pointer-events:none;display:block}
/* #root must establish its own stacking context above the canvas */
#root{position:relative;z-index:0}
/* When JS hasn't run / reduced-motion: the body gradient (globalCss) shows through. */

/* --- component dark overrides --- */

.sidebar{background:linear-gradient(180deg,rgba(13,17,24,.82),rgba(9,12,18,.92));border-right:1px solid var(--line);-webkit-backdrop-filter:var(--glass-blur-strong);backdrop-filter:var(--glass-blur-strong)}.sb-brand{border-bottom:1px solid var(--line)}.sb-user{border-top:1px solid var(--line)}

.nav-item{color:var(--ink-2)}.nav-item:hover{background:var(--hover-wash);color:var(--ink)}.nav-item.active{background:linear-gradient(90deg,rgba(225,27,34,.22),rgba(225,27,34,.04));color:#fff;box-shadow:inset 2px 0 12px -4px var(--red-glow)}.nav-item.active::before{background:var(--red);box-shadow:0 0 10px var(--red-glow)}.nav-item .badge{background:var(--red);color:#fff;box-shadow:0 0 8px var(--red-glow)}.nav-item .badge.amber{background:var(--amber);color:#1a1205;box-shadow:none}

.topbar{background:var(--card-2);border-bottom:1px solid var(--line);-webkit-backdrop-filter:var(--glass-blur-strong);backdrop-filter:var(--glass-blur-strong)}.topbar h1{color:var(--charcoal)}.topbar .crumb{color:var(--grey)}

.card{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.card:hover{border-color:var(--line-2)}

.kpi{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.kpi:hover{transform:translateY(-2px);border-color:var(--line-2);box-shadow:var(--shadow)}.kpi .kl{color:var(--ink-2)}.kpi .kv{color:var(--charcoal);font-variant-numeric:tabular-nums}.kpi .kv small{color:var(--grey)}.kpi .kf{color:var(--ink-2)}.kpi .ic{background:var(--hover-wash)}

.btn-primary{background:linear-gradient(180deg,var(--red-hot),var(--red));color:#fff;box-shadow:var(--rim),0 4px 18px var(--red-glow);border:1px solid rgba(255,255,255,.10)}.btn-primary:hover{background:linear-gradient(180deg,#FF5B60,var(--red));box-shadow:var(--rim),0 6px 26px var(--red-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-ghost{background:var(--card-2);color:var(--ink);border:1px solid var(--line-2)}.btn-ghost:hover{border-color:var(--grey);background:var(--hover-wash)}.btn-soft{background:var(--red-soft);color:var(--red-text);border:1px solid rgba(225,27,34,.22)}.btn-soft:hover{background:var(--red-soft2)}

.field input,.field select,.field textarea{background:var(--bg-2);border:1.5px solid var(--line-2);color:var(--ink)}.field input::placeholder,.field textarea::placeholder{color:var(--grey)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--red);background:var(--hover-wash);box-shadow:0 0 0 1px var(--red),0 0 0 4px var(--red-glow)}.search input{background:var(--bg-2);border:1.5px solid var(--line-2);color:var(--ink)}.search input:focus{border-color:var(--red);background:var(--hover-wash);box-shadow:0 0 0 1px var(--red),0 0 0 4px var(--red-glow)}.search svg{color:var(--grey)}.fsel{background:var(--bg-2);border:1.5px solid var(--line-2);color:var(--ink)}.fsel:focus{border-color:var(--red)}

.seg{background:var(--bg-2);border:1px solid var(--line)}.seg button{color:var(--ink-2)}.seg button.on{background:var(--card-2);color:var(--charcoal);box-shadow:var(--shadow-sm)}

.b-green{background:var(--green-soft);color:var(--green-text)}.b-green .rag-dot{background:var(--green)}.b-amber{background:var(--amber-soft);color:var(--amber-text)}.b-amber .rag-dot{background:var(--amber)}.b-red{background:var(--red-soft2);color:var(--red-text)}.b-red .rag-dot{background:var(--redrag)}.b-grey{background:rgba(220,232,248,.08);color:var(--ink-2)}.b-grey .rag-dot{background:var(--grey)}.b-blue{background:var(--blue-soft);color:var(--blue-text)}.b-blue .rag-dot{background:var(--blue)}

.tier-Gold{background:rgba(230,182,73,.14);color:var(--gold)}.tier-Gold::before{background:var(--gold)}.tier-Silver{background:rgba(220,232,248,.08);color:var(--silver)}.tier-Silver::before{background:var(--silver)}.tier-Bronze{background:rgba(208,138,82,.14);color:var(--bronze)}.tier-Bronze::before{background:var(--bronze)}.chip{background:var(--bg-2);border:1px solid var(--line);color:var(--ink-2)}

.tbl-wrap{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.tbl-tools{border-bottom:1px solid var(--line)}thead th{background:var(--card-2);color:var(--grey);border-bottom:1px solid var(--line);-webkit-backdrop-filter:var(--glass-blur-strong);backdrop-filter:var(--glass-blur-strong)}tbody td{border-bottom:1px solid var(--line);color:var(--ink-2)}tbody tr:hover{background:var(--hover-wash)}.cell-strong{color:var(--charcoal)}.cell-sub{color:var(--grey)}

.drawer-mask{background:rgba(5,8,13,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.drawer{background:var(--card-2);box-shadow:var(--shadow-lg);border-left:1px solid var(--line-2);-webkit-backdrop-filter:var(--glass-blur-strong);backdrop-filter:var(--glass-blur-strong)}.drawer-head{border-bottom:1px solid var(--line)}.drawer-head .dh-sub{color:var(--grey)}.drawer-head .x{color:var(--grey)}.drawer-head .x:hover{background:var(--hover-wash);color:var(--ink)}.drawer-foot{background:var(--bg-2);border-top:1px solid var(--line)}.form-warn{background:var(--amber-soft);border:1px solid rgba(255,194,77,.30);color:var(--amber-text)}

.score-dim{border:1px solid var(--line)}.score-dim:hover{border-color:var(--line-2)}.score-dim.missing{border-color:rgba(225,27,34,.35)}.score-dim .sd-h .wt{background:var(--bg-2);border:1px solid var(--line);color:var(--grey)}.score-dim .q{color:var(--ink-2)}.evidence-warn{color:var(--red-text)}.score-num{color:var(--charcoal);font-variant-numeric:tabular-nums}

.scale button{background:var(--bg-2);border:1.5px solid var(--line-2);color:var(--ink-2)}.scale button:hover{border-color:var(--grey);color:var(--ink)}.scale button.sel{color:#fff;border-color:transparent}.scale button.sel.s1,.scale button.sel.s2{background:var(--redrag);box-shadow:0 0 12px rgba(255,91,83,.4)}.scale button.sel.s3{background:var(--amber);color:#1a1205;box-shadow:0 0 12px rgba(255,194,77,.35)}.scale button.sel.s4,.scale button.sel.s5{background:var(--green);color:#04150d;box-shadow:0 0 12px rgba(52,230,168,.35)}

.board-block{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.bb-head{border-bottom:1px solid var(--line)}.bb-head .bb-i{background:var(--hover-wash)}.bb-head .bb-q{color:var(--grey)}.bigstat .bs-n{color:var(--charcoal);font-variant-numeric:tabular-nums}.bigstat .bs-u{color:var(--ink-2)}.rag-strip{background:rgba(220,232,248,.10)}.mini-row{border-bottom:1px solid var(--line);color:var(--ink-2)}.mini-row .mr-v{color:var(--charcoal)}.red-cust{border-bottom:1px solid var(--line)}.red-cust:hover{background:var(--hover-wash)}.red-cust .rc-score{background:var(--red-soft2);color:var(--red-text);box-shadow:inset 0 0 0 1px rgba(225,27,34,.25)}

.matrix .mh{color:var(--grey)}.matrix .mc{background:var(--bg-2);border:1px solid var(--line)}.matrix .rk{color:var(--ink-2)}

.tp-card{background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.tp-card.clickable:hover{transform:translateY(-2px);border-color:var(--line-2);box-shadow:var(--shadow)}.tp-dot{background:var(--bg-2);border:1px solid var(--line);color:var(--grey)}.tp-dot.on{background:var(--green-soft);border-color:rgba(52,230,168,.30);color:var(--green-text)}.tp-group-h{color:var(--grey)}.tp-group-h .ct{background:var(--bg-2);border:1px solid var(--line);color:var(--ink-2)}

.radar-item{background:var(--bg-2);border:1px solid var(--line)}.radar-item.clickable:hover{border-color:var(--line-2);transform:translateY(-1px)}.radar-item.nogap{border-left:3px solid var(--redrag);box-shadow:inset 2px 0 10px -6px var(--red-glow)}

.c360-head{background:linear-gradient(120deg,rgba(30,38,54,.62),rgba(22,28,40,.45));border:1px solid var(--line-2);box-shadow:var(--shadow-sm)}.c360-head .nm{color:var(--charcoal)}.c360-grid .m .l{color:var(--grey)}.c360-grid .m .v{color:var(--ink)}.sec-title{color:var(--charcoal)}.sec-title .ct{color:var(--grey)}.list-row{border-bottom:1px solid var(--line)}.list-row .lr-t{color:var(--ink)}.list-row .lr-s{color:var(--ink-2)}.dim-track{background:rgba(220,232,248,.10)}

.toast{background:var(--card-solid);color:var(--ink);border:1px solid var(--line-2);box-shadow:var(--shadow-lg)}.toast.ok{background:rgba(8,40,28,.96);border-color:rgba(52,230,168,.30)}.toast.err{background:rgba(48,12,12,.96);border-color:rgba(225,27,34,.35)}.toast.warn{background:rgba(44,32,8,.96);border-color:rgba(255,194,77,.30)}.warn-banner{background:var(--amber-soft);border:1px solid rgba(255,194,77,.30);color:var(--amber-text)}.warn-banner.red{background:var(--red-soft2);border-color:rgba(225,27,34,.30);color:var(--red-text)}

.menu-btn{background:var(--card-2);border:1px solid var(--line-2);color:var(--ink)}.skeleton{background:linear-gradient(90deg,rgba(220,232,248,.06) 25%,rgba(220,232,248,.12) 37%,rgba(220,232,248,.06) 63%);background-size:400% 100%}.empty .ei{background:var(--bg-2);color:var(--grey-2)}.empty h4{color:var(--ink)}.delta.up{color:var(--green)}.delta.down{color:var(--redrag)}.delta.flat{color:var(--grey)}.trend.Improving{color:var(--green)}.trend.Declining{color:var(--redrag)}.trend.Stable{color:var(--grey)}

/* --- login (dark) --- */

/* ============================================================
   LOGIN — the dark hero is already dark; the FORM SIDE was the light
   half that must invert. Make it glass over the aurora; keep the hero
   mesh+glow but recolor the form panel.
   ============================================================ */

/* Hero keeps its dark gradient but deepens to match the new floor */
.login-hero{background:linear-gradient(155deg,#0B0E13 0%,#141925 55%,#1B2233 100%)}
.login-hero .mesh{opacity:.35}                    /* dim the grid so it whispers */
.login-hero .glow{background:radial-gradient(circle,var(--red-glow),transparent 62%);filter:blur(26px);opacity:.9}
.login-hero .glow.b{background:radial-gradient(circle,rgba(91,141,239,.30),transparent 64%)}
.login-hero h1 .u{background:linear-gradient(transparent 68%,rgba(225,27,34,.65) 0)}
.login-hero .htag{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#C7CDDA}

/* Form side: was background:var(--card) WHITE — now floats as glass over aurora */
.login-form-side{
  background:linear-gradient(180deg,rgba(13,17,24,.72),rgba(9,12,18,.86));
  -webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);
}
.login-card{
  background:var(--card-2);border:1px solid var(--line-2);border-radius:var(--r-lg);
  padding:30px 30px 34px;box-shadow:var(--shadow-lg);
  -webkit-backdrop-filter:var(--glass-blur-strong);backdrop-filter:var(--glass-blur-strong);
}
.login-card h2{color:var(--charcoal)}
.login-card .sub{color:var(--ink-2)}

/* Inputs: dark well -> "lights up" red on focus (light bloom, no layout shift) */
.field input,.field select,.field textarea{
  background:var(--bg-2);border:1.5px solid var(--line-2);color:var(--ink);
}
.field input::placeholder,.field textarea::placeholder{color:var(--grey)}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--red);background:var(--hover-wash);
  box-shadow:0 0 0 1px var(--red),0 0 0 4px var(--red-glow);
}

/* Error / demo notes recolored for dark */
.login-err{background:var(--red-soft2);color:var(--red-text);border:1px solid rgba(225,27,34,.30)}
.login-demo{background:var(--bg-2);border:1px dashed var(--line-2);color:var(--ink-2)}
.login-demo b{color:var(--ink)}

/* Mobile: hero hidden in base CSS; ensure the standalone form side reads as floor */
@media(max-width:920px){
  .login-form-side{background:var(--bg)}
  .login-card .lc-logo{filter:brightness(0) invert(1)}
}

/* --- touchpoint calendar --- */

.tp-cal{margin-bottom:16px}
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.cal-nav{display:flex;align-items:center;gap:8px}
.cal-title{font-size:14px;font-weight:700;color:var(--charcoal);min-width:128px;text-align:center}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px;font-size:11.5px;color:var(--ink-2);font-weight:600}
.cal-legend span{display:inline-flex;align-items:center;gap:6px}
.cd-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.cd-dot.s-planned{background:var(--blue)}.cd-dot.s-progress{background:var(--violet)}
.cd-dot.s-held{background:var(--green)}.cd-dot.s-overdue{background:var(--redrag)}
.cd-dot.s-renewal{background:var(--amber)}
.cal-dow{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;margin-bottom:6px}
.cal-dow b{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--grey);text-align:center}
.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:100px;gap:6px}
.cal-day{min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);padding:7px 8px;display:flex;flex-direction:column;gap:4px;cursor:pointer;transition:border-color var(--fast),background var(--fast),transform var(--fast)}
.cal-day:hover{border-color:var(--line-2);background:var(--hover-wash);transform:translateY(-1px)}
.cal-day.cal-out{opacity:.4;cursor:default}
.cal-day.cal-out:hover{transform:none;border-color:var(--line);background:var(--bg-2)}
.cal-day.cal-today{border-color:var(--red);box-shadow:0 0 0 1px var(--red),0 4px 16px var(--red-glow)}
.cal-daynum{font-size:12px;font-weight:700;color:var(--ink-2);font-variant-numeric:tabular-nums;align-self:flex-end}
.cal-today .cal-daynum{color:var(--red-text)}
.cal-ev{font-size:10.5px;font-weight:600;line-height:1.2;padding:3px 6px;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid transparent}
.cal-ev.s-planned{background:var(--blue-soft);color:var(--blue-text);border-color:rgba(91,141,239,.25)}
.cal-ev.s-progress{background:rgba(154,123,255,.16);color:#C3B0FF;border-color:rgba(154,123,255,.28)}
.cal-ev.s-held{background:var(--green-soft);color:var(--green-text);border-color:rgba(52,230,168,.28)}
.cal-ev.s-overdue{background:var(--red-soft2);color:var(--red-text);border-color:rgba(225,27,34,.30)}
.cal-ev.s-renewal{background:var(--amber-soft);color:var(--amber-text);border-color:rgba(255,194,77,.28)}
.cal-more{font-size:10px;font-weight:700;color:var(--grey);padding-left:2px}
@media(max-width:680px){.cal-grid{grid-auto-rows:62px}.cal-ev{display:none}.cal-day::after{content:attr(data-count);font-size:10px;color:var(--blue-text);align-self:flex-start}}

/* calendar + Outlook-style forward agenda, side by side */
.tp-cal-wrap{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px;align-items:start;margin-bottom:16px}
.tp-cal-wrap .tp-cal{margin-bottom:0}
.tp-agenda{display:flex;flex-direction:column;min-width:0;align-self:stretch;max-height:560px}
.agenda-scroll{overflow-y:auto;flex:1;margin:0 -4px;padding:2px 4px;display:flex;flex-direction:column;gap:14px}
.agenda-group{display:flex;flex-direction:column;gap:6px}
.agenda-group-h{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--grey);display:flex;align-items:center;gap:6px;position:sticky;top:0;background:var(--card);padding:2px 0;z-index:1}
.agenda-group-h .ct{margin-left:auto;font-size:11px;color:var(--grey);font-weight:700}
.agenda-group.is-overdue .agenda-group-h{color:var(--red-text)}
.agenda-item{display:flex;align-items:center;gap:10px;padding:7px 8px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);cursor:pointer;transition:border-color var(--fast),background var(--fast),transform var(--fast)}
.agenda-item:hover{border-color:var(--line-2);background:var(--hover-wash);transform:translateX(2px)}
.agenda-date{display:flex;flex-direction:column;align-items:center;line-height:1.05;min-width:30px;font-variant-numeric:tabular-nums}
.agenda-date b{font-size:14px;font-weight:800;color:var(--ink)}
.agenda-date i{font-size:9.5px;font-style:normal;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--grey)}
.agenda-item .cd-dot{flex:none}
.agenda-main{display:flex;flex-direction:column;min-width:0;gap:1px}
.agenda-cust{font-size:12.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agenda-type{font-size:11px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agenda-empty{font-size:12.5px;color:var(--ink-2);display:flex;align-items:center;gap:8px;padding:12px 4px}
/* Board → Team ops: two supporting bar visuals */
.ops-two{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:1080px){.ops-two{grid-template-columns:1fr}}
@media(max-width:900px){.tp-cal-wrap{grid-template-columns:1fr}.tp-agenda{max-height:420px}}
