:root{
  --bg:#f4f6fb; --panel:#ffffff; --ink:#0f172a; --muted:#64748b; --line:#e6eaf2;
  --brand:#0e7c86; --brand2:#16a4b1; --brand-ink:#063b41;
  --accent:#3b82f6; --good:#16a34a; --warn:#f59e0b; --bad:#dc2626; --info:#0ea5e9;
  --purple:#7c3aed; --shadow:0 1px 2px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.06);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.hidden{display:none!important}

/* ---------- LANDING PAGE ---------- */
#login{position:fixed;inset:0;overflow:hidden;z-index:50;
  background:radial-gradient(1100px 650px at 80% -8%,#13525a 0%,#0b2e33 42%,#06181b 100%);color:#eafcff}
.lp{max-width:1180px;height:100%;margin:0 auto;padding:0 22px;display:flex;flex-direction:column}
/* single-screen: hide marketing sections */
.lp-ai,.lp-feats,.lp-modules{display:none!important}
.lp-nav{display:flex;align-items:center;justify-content:space-between;padding:18px 4px}
.lp-logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:19px}
.lp-logo .mark{width:34px;height:34px;border-radius:9px;background:#16a4b1;color:#042024;display:grid;place-items:center;font-weight:900}
.lp-links{display:flex;align-items:center;gap:22px;font-size:14px}
.lp-links a{color:#bfeef2;cursor:pointer}.lp-links a:hover{color:#fff}
.lp-cta-sm{background:#16a4b1;color:#042024!important;padding:8px 16px;border-radius:9px;font-weight:700}
.lp-hero{position:relative;flex:1;display:grid;grid-template-columns:1fr .82fr .82fr;gap:30px;align-items:center;padding:8px 4px 22px;min-height:0}
.lp-hero-art{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.lp-hero-art svg{width:100%;max-width:330px;max-height:52vh}
.lp-art-cap{font-size:12px;color:#9fdbe2;text-align:center;background:rgba(127,240,216,.08);border:1px solid rgba(127,240,216,.18);padding:6px 12px;border-radius:20px}
.lp-badge{display:inline-block;background:rgba(127,240,216,.12);border:1px solid rgba(127,240,216,.3);color:#7ff0d8;
  font-size:12px;font-weight:700;padding:6px 13px;border-radius:20px;margin-bottom:14px}
.lp-badge.dark{background:#ecfeff;border-color:#cffafe;color:#0b3b41}
.lp-hero-text h1{font-size:40px;line-height:1.08;margin:0 0 14px;letter-spacing:-.5px}
.lp-hero-text h1 .grad{background:linear-gradient(90deg,#7ff0d8,#16a4b1);-webkit-background-clip:text;background-clip:text;color:transparent}
.lp-hero-text p{color:#bfe6ea;font-size:16px;line-height:1.6;margin:0 0 24px;max-width:560px}
.lp-hero-stats{display:flex;gap:30px;margin-bottom:26px}
.lp-hero-stats b{display:block;font-size:26px;color:#fff}.lp-hero-stats span{font-size:12px;color:#8fc4cb}
.lp-cta-row{display:flex;gap:12px;flex-wrap:wrap}
.lp-cta{display:inline-block;background:#16a4b1;color:#042024;font-weight:800;padding:13px 22px;border-radius:11px;cursor:pointer;font-size:15px}
.lp-cta:hover{background:#1cc0cf}
.lp-cta.ghost{background:transparent;border:1px solid rgba(127,240,216,.4);color:#7ff0d8}
.lp-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:-1}
.lp-orb.o1{width:340px;height:340px;background:#0e7c86;top:-40px;right:-60px}
.lp-orb.o2{width:260px;height:260px;background:#13525a;bottom:-40px;left:-40px}
/* sign-in card */
.lp-signin{background:#fff;color:var(--ink);border-radius:18px;padding:28px;box-shadow:0 30px 70px rgba(0,0,0,.4)}
.lp-signin h2{margin:0 0 4px;font-size:21px}
.lp-signin .sub{color:var(--muted);margin:0 0 18px;font-size:13px}
.role-select{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#fbfdff;
  appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%2364748b' stroke-width='1.6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}
/* AI section */
.lp-ai{display:grid;grid-template-columns:.9fr 1.1fr;gap:40px;align-items:center;padding:50px 4px;border-top:1px solid rgba(127,240,216,.12)}
.lp-ai-art{display:grid;place-items:center}
.lp-ai-art svg{width:100%;max-width:420px}
.nd{animation:pulse 2.4s ease-in-out infinite}.nd.n2{animation-delay:.5s}.nd.n3{animation-delay:1s}.nd.n4{animation-delay:1.5s}
@keyframes pulse{0%,100%{opacity:.5;r:6}50%{opacity:1}}
.check{stroke-dasharray:90;stroke-dashoffset:90;animation:draw 2.5s ease forwards 0.6s}
@keyframes draw{to{stroke-dashoffset:0}}
.lp-ai-text h2{font-size:30px;margin:14px 0 12px;line-height:1.2}
.lp-ai-text p{color:#bfe6ea;line-height:1.6;margin:0 0 16px}
.lp-ai-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.lp-ai-list li{background:rgba(127,240,216,.07);border:1px solid rgba(127,240,216,.18);border-radius:10px;padding:11px 14px;font-size:14px}
.lp-ai-list b{color:#fff}
/* feature cards */
.lp-feats{padding:50px 4px;text-align:center;border-top:1px solid rgba(127,240,216,.12)}
.lp-h2{font-size:30px;margin:0 0 8px}.lp-sub{color:#8fc4cb;margin:0 0 30px}
.lp-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:left}
.lp-card{background:rgba(255,255,255,.05);border:1px solid rgba(127,240,216,.16);border-radius:16px;padding:22px;transition:.2s}
.lp-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.08)}
.lp-ico{width:56px;height:56px;border-radius:14px;background:#eafcff;display:grid;place-items:center;margin-bottom:14px}
.lp-ico svg{width:32px;height:32px}
.lp-card h3{margin:0 0 6px;font-size:16px;color:#fff}.lp-card p{margin:0;color:#a9d4d9;font-size:13px;line-height:1.5}
/* modules */
.lp-modules{padding:50px 4px;text-align:center;border-top:1px solid rgba(127,240,216,.12)}
.lp-pillars{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;max-width:900px;margin:0 auto 36px}
.lp-pill{background:rgba(255,255,255,.06);border:1px solid rgba(127,240,216,.18);color:#d8fbff;font-size:13px;padding:8px 14px;border-radius:20px}
.lp-final{background:linear-gradient(120deg,#0e7c86,#0b3b41);border-radius:18px;padding:34px;margin-bottom:24px}
.lp-final h3{margin:0 0 16px;font-size:22px;color:#fff}
.lp-foot{color:#6fa8af;font-size:12px}
@media(max-width:960px){#login{overflow-y:auto}.lp{height:auto;min-height:100%}.lp-hero{grid-template-columns:1fr;gap:22px;padding:16px 4px 28px}.lp-hero-art{display:none}.lp-ai{grid-template-columns:1fr}.lp-cards{grid-template-columns:repeat(2,1fr)}.lp-hero-text h1{font-size:32px}.lp-ai-art{order:-1}}
@media(max-width:560px){.lp-cards{grid-template-columns:1fr}.lp-links a:not(.lp-cta-sm){display:none}.lp-hero-stats{gap:18px}}

/* ---------- (legacy login card styles kept for fallback) ---------- */
#login-legacy{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1200px 600px at 20% -10%,#13525a 0%,#0b2e33 45%,#071e22 100%);padding:20px;z-index:50}
.login-card{width:100%;max-width:920px;background:var(--panel);border-radius:20px;overflow:hidden;
  display:grid;grid-template-columns:1.05fr .95fr;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.login-hero{padding:42px 38px;color:#eafcff;background:linear-gradient(160deg,#0e7c86,#0b3b41)}
.login-hero .logo{display:flex;align-items:center;gap:12px;font-weight:800;font-size:20px;letter-spacing:.3px}
.login-hero .logo .mark{width:38px;height:38px;border-radius:10px;background:#eafcff;color:#0e7c86;
  display:grid;place-items:center;font-weight:900}
.login-hero h1{font-size:26px;margin:26px 0 8px;line-height:1.2}
.login-hero p{color:#bfeef2;margin:0 0 22px}
.login-hero ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.login-hero li{display:flex;gap:10px;align-items:flex-start;color:#d8fbff;font-size:13px}
.login-hero li b{color:#fff}
.tickmark{color:#7ff0d8;font-weight:900}
.login-form{padding:42px 38px}
.login-form h2{margin:0 0 4px;font-size:20px}
.login-form .sub{color:var(--muted);margin:0 0 22px}
.field{margin-bottom:10px}
.field label{display:block;font-size:11px;font-weight:600;color:var(--muted);margin-bottom:4px}
.field input,.field select{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fbfdff}
.field input:focus,.field select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(14,124,134,.15)}
.role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:6px}
.role-opt{border:1px solid var(--line);border-radius:10px;padding:10px;cursor:pointer;background:#fbfdff;transition:.15s}
.role-opt b{display:block;font-size:13px}
.role-opt span{font-size:11px;color:var(--muted)}
.role-opt.sel{border-color:var(--brand);background:#ecfeff;box-shadow:0 0 0 3px rgba(14,124,134,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:10px;
  padding:11px 16px;font-weight:700;font-size:14px;background:var(--brand);color:#fff;width:100%}
.btn:hover{background:#0a656e}
.btn.sec{background:#eef2f7;color:var(--ink)}
.login-foot{margin-top:16px;font-size:12px;color:var(--muted);text-align:center}
.mfa-note{margin-top:10px;font-size:12px;color:var(--muted);display:flex;gap:8px;align-items:center;background:#f1f7f8;
  border:1px dashed var(--line);padding:8px 10px;border-radius:8px}

/* ---------- APP SHELL ---------- */
#app{display:grid;grid-template-columns:204px 1fr;grid-template-rows:54px 1fr;height:100vh;
  grid-template-areas:"side top" "side main"}
.sidebar{grid-area:side;background:#0b2e33;color:#cfe9ec;overflow-y:auto;display:flex;flex-direction:column}
.brand{display:flex;align-items:center;gap:9px;padding:11px 13px;font-weight:800;font-size:14px;color:#fff;position:sticky;top:0;background:#0b2e33;z-index:2}
.brand .mark{width:26px;height:26px;border-radius:7px;background:#16a4b1;display:grid;place-items:center;color:#042024;font-weight:900;font-size:13px}
.brand small{display:block;font-size:9px;font-weight:600;color:#7fc7cf;letter-spacing:.3px}
.nav-group{padding:3px 8px}
.nav-group .gtitle{font-size:9.5px;text-transform:uppercase;letter-spacing:.6px;color:#6fb3bb;padding:7px 8px 5px;
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none;border-radius:7px}
.nav-group .gtitle:hover{color:#bfeef2;background:#0f3d44}
.gchev{font-size:13px;line-height:1;transition:transform .18s;color:#9fd3da}
.nav-group.closed .gchev{transform:rotate(-90deg)}
.nav-group.closed .nav-items{display:none}
#app.collapsed .nav-items{display:block!important}
.nav-item{display:flex;align-items:center;gap:9px;padding:6px 9px;border-radius:8px;color:#cfe9ec;font-size:12px;cursor:pointer}
.nav-item .ico{width:18px;text-align:center;font-size:13px}
.nav-item:hover{background:#0f3d44}
.nav-item.active{background:#16a4b1;color:#042024;font-weight:700}
.nav-item .badge{margin-left:auto;background:#0e7c86;color:#fff;font-size:10px;padding:1px 7px;border-radius:20px}
.nav-item.active .badge{background:#063b41;color:#fff}

.topbar{grid-area:top;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 16px}
.hamb{display:none;border:none;background:none;font-size:20px}
.navtoggle{border:none;background:var(--brand);border-radius:9px;width:36px;height:36px;font-size:18px;font-weight:700;color:#fff;display:grid;place-items:center;box-shadow:0 1px 3px rgba(14,124,134,.4)}
.navtoggle:hover{background:#0a656e}
.navtoggle:active{transform:scale(.94)}
/* collapsed icon-only sidebar (desktop) */
@media(min-width:861px){#app.collapsed{grid-template-columns:64px 1fr}}
#app.collapsed .brand{justify-content:center;padding:14px 0}
#app.collapsed .brand>div{display:none}
#app.collapsed .nav-group{padding:6px 8px}
#app.collapsed .nav-group .gtitle{display:none}
#app.collapsed .nav-group+.nav-group{border-top:1px solid #103d44;margin-top:4px;padding-top:8px}
#app.collapsed .nav-item{justify-content:center;padding:9px 0}
#app.collapsed .nav-item span:not(.ico){display:none}
#app.collapsed .nav-item .ico{width:auto;font-size:17px}
#app.collapsed .sidebar nav+div+div{display:none}
.crumb{font-weight:700;font-size:15px}
.crumb small{display:block;font-size:11px;color:var(--muted);font-weight:500}
.top-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.searchbox{display:flex;align-items:center;gap:8px;background:#f1f5f9;border-radius:9px;padding:7px 10px;color:var(--muted);min-width:200px}
.searchbox input{border:none;background:none;outline:none;font-size:13px;width:100%}
.icon-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;position:relative}
.icon-btn .dot{position:absolute;top:6px;right:7px;width:8px;height:8px;border-radius:50%;background:var(--bad)}
.who{display:flex;align-items:center;gap:9px;cursor:pointer;padding:4px 8px;border-radius:9px}
.who:hover{background:#f1f5f9}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px}
.who b{font-size:13px}.who span{font-size:11px;color:var(--muted)}

.main{grid-area:main;overflow-y:auto;padding:20px 22px 60px}
.page-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:21px}
.page-head p{margin:2px 0 0;color:var(--muted);font-size:13px}
.page-head .ph-actions{margin-left:auto;display:flex;gap:8px}
.pill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;display:inline-block}
.pill.good{background:#dcfce7;color:#166534}.pill.warn{background:#fef3c7;color:#92400e}
.pill.bad{background:#fee2e2;color:#991b1b}.pill.info{background:#e0f2fe;color:#075985}
.pill.muted{background:#eef2f7;color:#475569}.pill.purple{background:#ede9fe;color:#5b21b6}

/* KPI tiles */
.kpis{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .k-ico{position:absolute;right:10px;top:10px;font-size:18px;opacity:.5}
.kpi .k-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kpi .k-val{font-size:26px;font-weight:800;margin-top:4px}
.kpi .k-sub{font-size:11px;margin-top:4px;color:var(--muted)}
.kpi .k-trend{font-weight:700}
.kpi .up{color:var(--bad)} .kpi .down{color:var(--good)}
.kpi .strip{position:absolute;left:0;top:0;bottom:0;width:4px}
/* compact KPI tiles (command center) — 8 per row */
.kpis.compact{grid-template-columns:repeat(8,1fr);gap:8px;margin-bottom:12px}
.kpis.compact .kpi{padding:9px 24px 9px 11px;border-radius:10px;min-width:0}
.kpis.compact .kpi .strip{width:3px}
.kpis.compact .kpi .k-ico{font-size:13px;top:8px;right:8px}
.kpis.compact .kpi .k-label{font-size:9.5px;letter-spacing:.2px;white-space:normal;overflow-wrap:anywhere;line-height:1.25}
.kpis.compact .kpi .k-val{font-size:18px;margin-top:3px;overflow-wrap:anywhere}
.kpis.compact .kpi .k-sub{font-size:10px;margin-top:2px;white-space:normal;overflow-wrap:anywhere;line-height:1.3}
@media(max-width:1200px){.kpis.compact{grid-template-columns:repeat(4,1fr)}}
@media(max-width:680px){.kpis.compact{grid-template-columns:repeat(2,1fr)}}

/* cards/grid */
.grid{display:grid;gap:14px}
.g-2{grid-template-columns:repeat(2,1fr)} .g-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card .c-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}
.card .c-head h3{margin:0;font-size:14px}
.card .c-head .c-act{margin-left:auto;font-size:12px;color:var(--brand);font-weight:600;cursor:pointer}
.card .c-body{padding:16px}
.chart-wrap{position:relative;height:260px}
.chart-sm{height:220px}

/* tables */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);
  padding:10px 14px;border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0;background:#fafbfe}
table.tbl td{padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
table.tbl tr:hover td{background:#f8fafc}
table.tbl tr:last-child td{border-bottom:none}
.linkish{color:var(--brand);font-weight:600}

/* toolbar above tables */
.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.toolbar .grow{flex:1}
.btn-sm{padding:8px 12px;border-radius:9px;border:1px solid var(--line);background:#fff;font-weight:600;font-size:13px;color:var(--ink)}
.btn-sm.brand{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-sm.brand:hover{background:#0a656e}
.chiprow{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.chip{font-size:12px;padding:6px 12px;border-radius:20px;border:1px solid var(--line);background:#fff;cursor:pointer}
.chip.on{background:#ecfeff;border-color:var(--brand);color:var(--brand-ink);font-weight:700}

/* workflow */
.flow{display:flex;align-items:center;gap:0;flex-wrap:wrap;margin:4px 0}
.flow .step{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#f1f5f9;border-radius:8px;font-size:12px;font-weight:600}
.flow .step.done{background:#dcfce7;color:#166534}
.flow .step.cur{background:var(--brand);color:#fff}
.flow .arr{color:var(--muted);padding:0 8px;font-weight:700}

/* feature list / placeholder modules */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.feat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;box-shadow:var(--shadow)}
.feat .f-ico{font-size:20px}.feat h4{margin:8px 0 4px;font-size:14px}.feat p{margin:0;color:var(--muted);font-size:12px}

/* AI copilot */
.copilot{display:grid;grid-template-columns:1fr 320px;gap:14px}
.chatwin{display:flex;flex-direction:column;height:62vh}
.chatlog{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:80%;padding:11px 14px;border-radius:14px;font-size:13px;line-height:1.5}
.msg.ai{background:#f1f7f8;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.msg.me{background:var(--brand);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chatbar{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}
.chatbar input{flex:1;padding:11px 12px;border:1px solid var(--line);border-radius:10px;font-size:14px}
.suggest{display:flex;flex-direction:column;gap:8px}
.suggest .s{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:12px;cursor:pointer}
.suggest .s:hover{border-color:var(--brand);background:#ecfeff}

/* risk matrix */
.rmatrix{border-collapse:collapse;width:100%;font-size:12px;text-align:center}
.rmatrix td,.rmatrix th{border:1px solid #fff;padding:10px;font-weight:700;color:#fff}
.rmatrix th{background:#0b2e33;color:#cfe9ec;font-weight:600}
.rmatrix .axis{background:#0b2e33;color:#cfe9ec;font-weight:600}
.r-lo{background:#22c55e}.r-md{background:#eab308}.r-hi{background:#f97316}.r-cr{background:#dc2626}
.rm-cell{position:relative;cursor:pointer;transition:.12s;user-select:none}
.rm-cell:hover{outline:3px solid rgba(15,23,42,.55);outline-offset:-3px;filter:brightness(1.06)}
.rm-count{position:absolute;top:3px;right:4px;background:rgba(0,0,0,.45);color:#fff;font-size:9px;font-weight:700;min-width:14px;height:14px;line-height:14px;border-radius:8px;padding:0 3px}

.foot{margin-top:26px;text-align:center;color:var(--muted);font-size:11px}

/* row actions + editor modal */
table.tbl tfoot td{border-top:1px solid var(--line)}
.rowbtn{border:1px solid var(--line);background:#fff;border-radius:7px;padding:3px 8px;margin-right:4px;cursor:pointer;font-size:13px}
.rowbtn:hover{background:#f1f5f9}
.rowbtn.del:hover{background:#fee2e2;border-color:#fecaca}
#modal{position:fixed;inset:0;background:rgba(7,18,20,.55);display:none;align-items:center;justify-content:center;z-index:60;padding:20px}
#modal.show{display:flex}
.modal-card{background:#fff;border-radius:16px;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.modal-head{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0;font-size:15px}
.modal-head .x{margin-left:auto;cursor:pointer;font-size:22px;line-height:1;color:var(--muted)}
.modal-head .x:hover{color:var(--ink)}
.modal-body{padding:18px;overflow:auto}
.modal-foot{display:flex;gap:8px;justify-content:flex-end;padding:13px 18px;border-top:1px solid var(--line)}
.modal-foot .btn-sm{padding:9px 16px}
.other-in{margin-top:8px}
.form2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.form2 .field-full{grid-column:1 / -1}
.modal-body textarea{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:9px;font-size:13px;font-family:inherit;resize:vertical;background:#fbfdff}
.modal-body textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(14,124,134,.15)}
.req{color:var(--bad);font-weight:800}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--bad);box-shadow:0 0 0 3px rgba(220,38,38,.12)}
.form-err{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:8px;padding:8px 12px;font-size:12px;margin-bottom:12px}
.form-create{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink);margin-top:8px;cursor:pointer}
.form-create input{width:auto}
@media(max-width:560px){.form2{grid-template-columns:1fr}}
.dash-filterbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--muted);background:#eef6f7;border:1px solid var(--line);border-radius:9px;padding:7px 12px;margin-bottom:12px}
.dash-filterbar b{color:var(--ink)}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%2364748b' stroke-width='1.6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
.jump-sel{appearance:none;-webkit-appearance:none;border:1px solid var(--line);background:#fff;border-radius:9px;padding:7px 30px 7px 12px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%2364748b' stroke-width='1.6'/></svg>");background-repeat:no-repeat;background-position:right 10px center}
.dash-sel{appearance:none;-webkit-appearance:none;border:1px solid var(--line);background:#fff;border-radius:9px;padding:8px 30px 8px 12px;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%2364748b' stroke-width='1.6'/></svg>");background-repeat:no-repeat;background-position:right 10px center}

/* responsive */
@media(max-width:1024px){.copilot{grid-template-columns:1fr}.g-2,.g-3{grid-template-columns:1fr}}
@media(max-width:860px){
  #app{grid-template-columns:1fr;grid-template-areas:"top" "main"}
  .sidebar{position:fixed;inset:0 auto 0 0;width:262px;z-index:40;transform:translateX(-100%);transition:.25s;grid-area:unset}
  .sidebar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.4)}
  .hamb{display:block}.navtoggle{display:none}.searchbox{display:none}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35}
}
@media(max-width:560px){.login-card{grid-template-columns:1fr}.login-hero{display:none}.who b,.who span{display:none}}

/* ---------- portal additions (Laravel build) ---------- */
.flash-ok{background:#dcfce7;color:#166534;border:1px solid #bbf7d0;border-radius:10px;padding:10px 14px;font-size:13px;margin-bottom:14px}
.flash-err{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:10px;padding:10px 14px;font-size:13px;margin-bottom:14px}
.ind-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-bottom:18px}
.ind-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px;box-shadow:var(--shadow);cursor:pointer;display:flex;gap:10px;align-items:flex-start;transition:.15s}
.ind-card:hover{border-color:var(--brand)}
.ind-card.sel{border-color:var(--brand);background:#ecfeff;box-shadow:0 0 0 3px rgba(14,124,134,.12)}
.ind-card .i-ico{font-size:22px}
.ind-card b{display:block;font-size:13px}
.ind-card span{font-size:11px;color:var(--muted)}
.ind-card .i-count{margin-left:auto;font-size:10px;font-weight:700;background:#eef2f7;color:#475569;border-radius:20px;padding:2px 8px;white-space:nowrap}
.ind-card input{display:none}
.mod-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;border:1px solid var(--line);background:#fff;border-radius:20px;padding:5px 11px;margin:0 6px 6px 0}
.mod-chip.on{background:#ecfeff;border-color:var(--brand);color:var(--brand-ink);font-weight:600}
.mod-chip.core{background:#f0fdf4;border-color:#86efac;color:#166534}
.ovr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:8px}
.ovr-row{display:flex;align-items:center;gap:8px;font-size:12px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 10px}
.ovr-row select{margin-left:auto;font-size:11px;border:1px solid var(--line);border-radius:7px;padding:3px 6px;background:#fbfdff}
.sw{display:inline-flex;align-items:center;gap:10px;cursor:pointer}
.sw input{display:none}
.sw .track{width:40px;height:22px;border-radius:20px;background:#cbd5e1;position:relative;transition:.15s}
.sw .track::after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:.15s}
.sw input:checked + .track{background:var(--brand)}
.sw input:checked + .track::after{left:21px}
.bars{display:flex;align-items:flex-end;gap:10px;height:170px;padding:10px 4px 0}
.bars .bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}
.bars .bar i{display:block;width:100%;max-width:46px;background:linear-gradient(180deg,var(--brand2),var(--brand));border-radius:6px 6px 0 0}
.bars .bar b{font-size:12px}
.bars .bar span{font-size:10px;color:var(--muted)}
.hbar{display:flex;align-items:center;gap:10px;margin-bottom:9px;font-size:12px}
.hbar .lbl{width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right;color:var(--muted)}
.hbar .trk{flex:1;background:#eef2f7;border-radius:6px;height:14px;overflow:hidden}
.hbar .trk i{display:block;height:100%;border-radius:6px;background:var(--brand2)}
.hbar b{width:26px}
.sev-row{display:flex;gap:10px;flex-wrap:wrap}
.sev-box{flex:1;min-width:100px;text-align:center;border-radius:10px;padding:12px 8px;color:#fff}
.sev-box b{display:block;font-size:22px}
.sev-box span{font-size:11px;opacity:.9}
.list-item{display:flex;gap:10px;align-items:center;padding:9px 16px;border-bottom:1px solid var(--line);font-size:13px}
.list-item:last-child{border-bottom:none}
.list-item .li-sub{color:var(--muted);font-size:11px}
.list-item .li-when{margin-left:auto;color:var(--muted);font-size:11px;white-space:nowrap}
.rolematrix td:first-child{font-weight:600}
.tag-mini{display:inline-block;background:#eef2f7;border-radius:6px;font-size:10px;padding:2px 7px;margin:1px 2px 1px 0;color:#334155}
