/* VIGITEST — corporate tech (sobre, data-dense) · charte couleurs 2026 */
:root{
  /* Marque */
  --navy:#0B1B33; --navy2:#102845; --navy-700:#16223a; --navy-600:#1E3A5F;
  --blue:#1763C6; --blue-700:#114E9E; --blue-500:#3B6EC2; --blue-300:#6E8FCF; --blue-100:#DBEAFE; --blue-050:#EEF3FB;
  --blue-2:#36D0C4; --teal-500:#1FB5A8; --teal-200:#9FE7E0; --teal-050:#E3FAF7;
  --violet:#6D34D0; --violet-100:#ECE3FB; --title:#2E2A6B;
  /* Neutres */
  --ink:#1a2333; --mut:#5d6b85; --line:#e4e9f2; --bg:#f4f7fc; --bg-alt:#F8FAFD; --card:#ffffff;
  /* Sémantique tricolore (base / fond / texte) */
  --green:#16a34a; --green-bg:#DCFCE7; --green-text:#15803D;
  --amber:#d97706; --amber-bg:#FEF3C7; --amber-text:#B45309;
  --red:#dc2626;   --red-bg:#FEE2E2;   --red-text:#B91C1C;
  --info:#1763C6;  --info-bg:#EEF3FB;  --info-text:#114E9E;
  /* Alias de rôle */
  --primary:var(--blue); --accent:var(--blue-2); --success:var(--green); --warning:var(--amber); --danger:var(--red);
  --disp:'Space Grotesk',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif; --mono:'JetBrains Mono',monospace;
  --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{font-family:var(--disp);color:var(--navy);letter-spacing:-.01em}
.mono{font-family:var(--mono)}

/* ---------- App shell ---------- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,var(--navy),var(--navy2));color:#fff;padding:20px 14px;position:sticky;top:0;height:100vh;overflow:auto}
.brand{font-family:var(--disp);font-weight:700;font-size:20px;color:#fff;display:flex;align-items:center;gap:9px}
.brand .dot{width:10px;height:10px;border-radius:3px;background:linear-gradient(135deg,var(--blue),var(--blue-2));box-shadow:0 0 14px var(--blue-2)}
.brand .mark{width:28px;height:28px;flex:none}
.auth-hero .brand .mark{width:34px;height:34px}
.brand small{display:block;font-family:var(--body);font-weight:400;font-size:10px;color:rgba(255,255,255,.5);letter-spacing:.04em;margin-top:2px}
.nav{margin-top:22px;display:flex;flex-direction:column;gap:3px}
.nav a{color:rgba(255,255,255,.78);font-size:13.5px;font-weight:500;padding:9px 11px;border-radius:9px;display:flex;align-items:center;gap:10px;transition:.15s}
.nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.nav a.active{background:linear-gradient(135deg,rgba(23,99,198,.9),rgba(54,208,196,.7));color:#fff}
.nav .sep{margin:14px 8px 5px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.orgname{color:rgba(255,255,255,.6);font-size:11.5px;font-weight:500;margin:3px 0 2px 3px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.08)}
.submenu{margin:2px 0 4px 12px;border-left:2px solid rgba(54,208,196,.35);padding-left:6px;display:flex;flex-direction:column;gap:1px}
.submenu-title{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.55);padding:5px 8px 3px;font-weight:600}
.submenu a{color:rgba(255,255,255,.74);font-size:12.5px;font-weight:500;padding:6px 10px;border-radius:7px;display:block}
.submenu a:hover{background:rgba(255,255,255,.08);color:#fff}
.submenu a.subon{background:linear-gradient(135deg,rgba(23,99,198,.85),rgba(54,208,196,.6));color:#fff;font-weight:600}
.submenu details.navph{margin:1px 0}
.submenu details.navph>summary{list-style:none;cursor:pointer;color:rgba(255,255,255,.82);font-size:12.5px;font-weight:600;padding:6px 10px;border-radius:7px;display:flex;align-items:center;gap:7px;user-select:none}
.submenu details.navph>summary::-webkit-details-marker{display:none}
.submenu details.navph>summary::before{content:"▸";font-size:9px;color:rgba(255,255,255,.5);transition:transform .15s}
.submenu details.navph[open]>summary::before{transform:rotate(90deg)}
.submenu details.navph>summary:hover{background:rgba(255,255,255,.08);color:#fff}
.submenu details.navph>a{padding-left:24px;font-size:12px;color:rgba(255,255,255,.64)}
/* mise en évidence d'une zone du schéma depuis le sous-menu (?focus=KEY) */
.sreg.focus{z-index:6}
.sreg.focus .sreg-btn{animation:regpulse 1.1s ease-out 3;box-shadow:0 0 0 3px rgba(245,158,11,.95)}
@keyframes regpulse{0%{box-shadow:0 0 0 0 rgba(245,158,11,.9)}100%{box-shadow:0 0 0 16px rgba(245,158,11,0)}}
/* Parcours projet (voile/révélation) */
.journey{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 18px 20px;margin-bottom:18px}
.journey .jh{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.journey .jh h3{font-size:14px}
.journey .jh .jp{font-family:var(--disp);font-weight:700;color:var(--blue)}
.jflow{display:flex;flex-wrap:wrap;gap:8px;align-items:stretch;margin-top:14px}
.jstage{position:relative;flex:1 1 0;min-width:140px;border:1px solid var(--line);border-radius:10px;padding:13px 12px;background:#f8fafd;text-align:center;overflow:hidden;transition:.3s}
.jstage .jnum{font-family:var(--mono);font-size:10px;color:var(--mut)}
.jstage .jt{font-weight:700;color:var(--navy);font-size:12.5px;margin-top:2px}
.jstage .jd{font-size:10.5px;color:var(--mut);margin-top:3px;line-height:1.3}
.jstage .jchk{position:absolute;top:7px;right:9px;font-size:13px;font-weight:800}
.jstage.todo{filter:grayscale(.4)}
.jstage.todo::after{content:"";position:absolute;inset:0;background:rgba(11,27,51,.40)}
.jstage.todo .jchk{color:rgba(255,255,255,.85)}
.jstage.done{background:#fff;border-color:var(--blue-2);box-shadow:0 6px 18px -11px rgba(54,208,196,.7)}
.jstage.done .jchk{color:var(--green)}
.jarrow{align-self:center;color:#c3cee0;font-weight:800;font-size:16px}
/* Schéma image + voile/révélation par zone */
.schema-wrap{position:relative;max-width:1060px;margin:14px auto 0;line-height:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
/* zones cliquables superposées à l'image (toggle Exécuté) */
.sreg{position:absolute;margin:0;padding:0;border-radius:6px}
.sreg .sreg-btn{position:absolute;inset:0;width:100%;height:100%;border:0;cursor:pointer;border-radius:6px;background:rgba(11,27,51,.5);transition:background .35s ease,box-shadow .2s}
.sreg.done .sreg-btn{background:transparent}
.sreg.todo .sreg-btn:hover{background:rgba(11,27,51,.30);box-shadow:inset 0 0 0 2px rgba(255,255,255,.55)}
.sreg.done .sreg-btn:hover{background:rgba(54,208,196,.16);box-shadow:inset 0 0 0 2px rgba(54,208,196,.6)}
.sreg .schema-chk{z-index:3}
.sreg-go{position:absolute;bottom:-9px;right:-9px;z-index:4;width:20px;height:20px;border-radius:50%;background:var(--blue);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 1px 5px rgba(0,0,0,.3)}
.sreg-go:hover{background:var(--blue-2);transform:scale(1.12)}
.lg-go{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--blue);color:#fff;font-size:11px;font-weight:800}
.schema-img{display:block;width:100%;height:auto}
.schema-region{position:absolute;border-radius:6px;transition:background .5s ease, box-shadow .5s ease}
.schema-region.todo{background:rgba(11,27,51,.40)}
.schema-region.done{background:transparent;box-shadow:inset 0 0 0 2px rgba(54,208,196,.55)}
.schema-chk{position:absolute;top:4px;right:6px;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1}
.schema-legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;justify-content:center}
.schema-legend .lg{font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:20px;border:1px solid var(--line)}
.schema-legend .lg.done{background:#dcfce7;color:#15803d;border-color:#bbf7d0}
.schema-legend .lg.todo{background:#eef2f7;color:#7a899e}
/* ===== Schéma « Parcours du projet » v3 (natif, cliquable) ===== */
.smap{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 16px 18px;margin-bottom:18px}
.smap .jh{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.smap .jh h3{font-size:14px}
.smap .jh .jp{font-family:var(--disp);font-weight:700;color:var(--blue)}
.smap-rows,.smap{ }
.smap-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;align-items:stretch;margin-bottom:12px}
.smap-flow{align-items:center}
.smap-phase{position:relative;border:2px solid #d32f2f;border-radius:12px;padding:18px 11px 11px;background:#fff;min-width:200px}
.smap-phase>.ph-t{position:absolute;top:-10px;left:12px;background:#fff;padding:0 7px;color:#d32f2f;font-weight:800;font-size:11px;font-family:var(--disp)}
.smap-col{display:flex;flex-direction:column;gap:7px}
.smap-inner{display:flex;gap:7px;flex-wrap:wrap}
.smap-sub{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--mut);margin-bottom:2px;text-align:center}
.smap-arrow{align-self:center;color:#3B6EC2;font-weight:800;font-size:20px;flex:none}
.smap-bar{flex-basis:100%;text-align:center;font-weight:700;color:var(--navy);background:#f3f6fb;border:1px dashed var(--line);border-radius:8px;padding:8px}
.smap-info{flex:1 1 230px;border:1.5px dashed #3B6EC2;border-radius:12px;padding:12px 14px;background:#f7faff;font-size:11.5px;color:#16223a;line-height:1.5}
/* boîte-bouton */
.sbox{position:relative;display:flex;align-items:center;justify-content:center;gap:6px;text-align:center;min-height:40px;flex:1 1 auto;padding:8px 11px;border-radius:9px;border:1.5px solid;font-size:11.5px;font-weight:600;text-decoration:none;line-height:1.2;transition:transform .2s,box-shadow .2s,opacity .3s,filter .3s}
a.sbox{cursor:pointer}
a.sbox:hover{transform:translateY(-2px);box-shadow:0 8px 18px -11px rgba(0,0,0,.45)}
.sbox .sbl{display:inline-block}
.sb-blue{background:#6E8FCF;border-color:#3B6EC2;color:#fff}
.sb-white{background:#fff;border-color:#3B6EC2;color:#16223a}
.sb-orange{background:#FFF4E8;border-color:#F39C12;color:#7a4d00}
.sb-green{background:#EAF8EA;border-color:#3AA655;color:#1c5e2f}
.sb-grey{background:#F5F5F5;border-color:#BBBBBB;color:#333}
.sb-strat{background:#3B6EC2;border-color:#27508f;color:#fff;font-weight:800}
.sb-phasebar{background:#6E8FCF;border-color:#3B6EC2;color:#fff;font-weight:800;letter-spacing:.4px;flex:0 1 auto;padding:10px 22px}
.sb-phase-node{background:#fff;border:2px solid #d32f2f;color:#d32f2f;font-weight:800;flex:0 0 auto;writing-mode:vertical-rl;transform:rotate(180deg);padding:14px 9px;min-height:120px}
.sb-phase-node.is-done{transform:rotate(180deg)}
.sb-phase-node.is-done:hover{transform:rotate(180deg) translateX(2px)}
/* états : voile 50% tant que non fait */
.sbox.is-todo,.sbox.is-soon{opacity:.5;filter:grayscale(.6)}
.sbox.is-soon{cursor:default}
.sbox.is-done{opacity:1;filter:none;box-shadow:inset 0 0 0 2px var(--green),0 6px 16px -12px rgba(58,166,85,.85)}
.schk{position:absolute;top:-7px;right:-7px;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.ssoon{position:absolute;top:-7px;right:-7px;font-size:8.5px;font-weight:800;background:#0b1b33;color:#fff;border-radius:10px;padding:1px 6px;text-transform:uppercase;letter-spacing:.3px}
.smap-legend{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:10px;font-size:11.5px;color:var(--navy)}
.smap-legend>span{display:inline-flex;align-items:center;gap:6px}
.smap-legend .schk,.smap-legend .ssoon{position:static}
.lg-dot{width:12px;height:12px;border-radius:3px;display:inline-block;background:#6E8FCF;opacity:.5;filter:grayscale(.6)}
@media(max-width:760px){.smap-arrow{display:none}.sb-phase-node{writing-mode:horizontal-tb;transform:none;min-height:40px}.sb-phase-node.is-done,.sb-phase-node.is-done:hover{transform:none}}
/* Échelle de maturité TMMi */
.tmmi-scale{display:flex;gap:6px}
.tmmi-lv{flex:1;text-align:center;border:1px solid var(--line);border-radius:8px;padding:8px 4px;background:#f8fafd;position:relative;transition:.2s}
.tmmi-lv .n{display:block;font-family:var(--disp);font-weight:800;font-size:16px;color:var(--mut)}
.tmmi-lv .lb{display:block;font-size:9px;color:var(--mut);margin-top:2px;line-height:1.15}
.tmmi-lv.on{background:linear-gradient(135deg,var(--blue),var(--blue-2));border-color:var(--blue)}
.tmmi-lv.on .n,.tmmi-lv.on .lb{color:#fff}
.tmmi-lv.tgt{box-shadow:0 0 0 2px #f59e0b inset}
/* Base de connaissances — boutons par catégorie */
.kb-cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.kb-cats a{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;padding:8px 14px;border-radius:9px;border:1.5px solid var(--line);color:var(--navy);background:#fff;text-decoration:none;transition:.15s}
.kb-cats a:hover{border-color:var(--blue);color:var(--blue)}
.kb-cats a.on{background:linear-gradient(135deg,var(--blue),var(--blue-2));border-color:var(--blue);color:#fff}
.kb-cats a .n{font-size:10.5px;font-weight:700;background:rgba(11,27,51,.08);color:var(--mut);border-radius:20px;padding:1px 7px;min-width:18px;text-align:center}
.kb-cats a.on .n{background:rgba(255,255,255,.25);color:#fff}
/* Questionnaire d'audit (accordéons par axe) */
.auditax{border:1px solid var(--line);border-radius:8px;margin-bottom:8px;overflow:hidden}
.auditax>summary{cursor:pointer;list-style:none;padding:10px 12px;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;color:var(--navy);background:#f8fafd}
.auditax>summary::-webkit-details-marker{display:none}
.auditax[open]>summary{border-bottom:1px solid var(--line)}
.auditsec{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--mut);padding:9px 12px 2px}
.auditq{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:6px 12px;border-top:1px solid #eef2f7}
.auditq label{font-size:12.5px;color:#33415a;flex:1}
.auditq select{padding:5px 8px;font-size:12px;min-width:130px}
/* Champ lecture seule (plan de test) */
.field .ro{font-size:13.5px;color:#1f2a44;background:#f8fafd;border:1px solid var(--line);border-radius:8px;padding:9px 11px;min-height:20px;line-height:1.45;white-space:normal}
/* Drill-down dashboard */
.dd-bar{height:7px;border-radius:4px;background:var(--line);overflow:hidden;min-width:90px}
.dd-bar i{display:block;height:100%;border-radius:4px;background:var(--blue)}
.main{min-width:0;display:flex;flex-direction:column}
.topbar{height:58px;background:linear-gradient(90deg,#0B1B33 0%,#0A3A30 52%,#075E40 100%);border-bottom:1px solid rgba(0,0,0,.14);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 24px;position:sticky;top:0;z-index:20}
.tbtitle{min-width:0}
.topbar h1{font-size:18px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .userchip{color:rgba(255,255,255,.88)}
.topbar .userchip span{color:rgba(255,255,255,.92)}
.topbar .langsw a{color:rgba(255,255,255,.72)}
.topbar .langsw a.on{color:#fff}
/* En-tête de page : le nom du projet (descendu sous la barre) + la fonction */
.pagehead{margin-bottom:16px}
.pagehead h2{font-size:22px;font-weight:700;color:var(--navy);line-height:1.2}
.pagehead .pagesub{display:inline-block;margin-top:3px;font-size:13.5px;font-weight:600;color:var(--blue)}
.pagehead .pagesub::before{content:"\203A  ";color:var(--mut)}
.content{padding:24px}
.userchip{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--mut)}
.avatar{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--blue),var(--violet));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--disp)}
.langsw{font-family:var(--mono);font-size:11px}
.langsw a{color:var(--mut);padding:0 4px}
.langsw a.on{color:var(--navy);font-weight:700}

/* ---------- Cards / KPI ---------- */
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.kpi{position:relative;overflow:hidden}
.kpi .lbl{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--mut);font-weight:600}
.kpi .val{font-family:var(--disp);font-size:1.9rem;font-weight:700;margin-top:6px;line-height:1}
.kpi .bar{height:5px;border-radius:4px;background:var(--line);margin-top:12px;overflow:hidden}
.kpi .bar i{display:block;height:100%;border-radius:4px}
.kpi.g .val{color:var(--green)} .kpi.a .val{color:var(--amber)} .kpi.r .val{color:var(--red)}
.kpi.g .bar i{background:var(--green)} .kpi.a .bar i{background:var(--amber)} .kpi.r .bar i{background:var(--red)}
/* Control Panel : rangée KPI ultra-compacte (titre + chiffre sur une ligne) */
.kpis.compact .card{padding:9px 13px}
.kpi-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.kpis.compact .kpi .lbl{font-size:9.5px;letter-spacing:.03em}
.kpis.compact .kpi .val{font-size:1.05rem;margin:0;line-height:1.1}
.kpis.compact .kpi .bar{margin-top:5px;height:3px}
.kpi .kpi-sub{font-size:11.5px;color:var(--mut);margin-top:6px}
.data.sm th,.data.sm td{font-size:10.5px;padding:4px 8px}
.kpis.compact .kpi .kpi-sub{font-size:9.5px;margin-top:3px}
.kpi-sev .sevlist{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.kpi-sev .sevlist .badge{font-size:11px}
.kpis.compact .kpi-sev .sevlist{margin-top:4px;gap:4px}
.kpis.compact .kpi-sev .sevlist .badge{font-size:9.5px;padding:1px 5px}
a.card.kpi{display:block;text-decoration:none;color:inherit;cursor:pointer}
a.card.kpi:hover{border-color:var(--blue);box-shadow:0 8px 20px -12px rgba(23,99,198,.55);transform:translateY(-2px)}
/* Super Admin : 3 grands carrés (~5,3 cm) */
.sa-squares{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.sa-sq{width:200px;min-height:200px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:6px;text-decoration:none;color:inherit;transition:.2s}
.sa-sq .lbl{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--mut);font-weight:600;line-height:1.2}
.sa-sq .val{font-family:var(--disp);font-size:3rem;font-weight:700;line-height:1;color:var(--navy)}
.sa-sq .kpi-sub{font-size:11px;color:var(--mut)}
a.sa-sq{cursor:pointer}
a.sa-sq:hover{border-color:var(--blue);box-shadow:0 8px 20px -12px rgba(23,99,198,.55);transform:translateY(-2px)}
/* Super Admin : 2e ligne — cartes de hauteur égale */
.sa-bottom>.card{height:100%}
/* Titres des encadrés du Control Panel (tous rôles) en indigo-violet + gras */
.sa-squares .sa-sq .lbl,
.sa-bottom>.card>h3,
.dash-mid>.card>h3{color:var(--title);font-weight:800}
.section-h{display:flex;align-items:center;justify-content:space-between;margin:24px 0 12px}
.section-h h2{font-size:16px}

/* ---------- Tables (data-dense) ---------- */
table.data{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:13.5px}
table.data th{background:#eef3fb;color:var(--navy);text-align:left;padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.03em}
table.data td{padding:10px 12px;border-top:1px solid var(--line)}
table.data tr:hover td{background:#f8fafd}
.badge{display:inline-block;font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px}
.b-green{background:#dcfce7;color:#15803d}.b-amber{background:#fef3c7;color:#b45309}.b-red{background:#fee2e2;color:#b91c1c}.b-grey{background:#eef2f7;color:#5d6b85}.b-blue{background:#dbeafe;color:#1d4ed8}

/* ---------- Project tabs ---------- */
.ptabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:4px 0 20px;flex-wrap:wrap}
.ptabs a{padding:9px 15px;font-size:13.5px;font-weight:600;color:var(--mut);border-bottom:2px solid transparent;margin-bottom:-1px}
.ptabs a:hover{color:var(--navy)}
.ptabs a.on{color:var(--blue);border-bottom-color:var(--blue)}
.pill{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px;background:#eef3fb;color:var(--navy2)}
.prio-critical{color:var(--red);font-weight:700}.prio-high{color:var(--amber);font-weight:600}.prio-medium{color:var(--blue)}.prio-low{color:var(--mut)}
.cov-yes{color:var(--green);font-weight:700}.cov-no{color:var(--red)}
table.matrix td,table.matrix th{text-align:center}table.matrix td:first-child,table.matrix th:first-child{text-align:left}

/* ---------- Buttons / forms ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--body);font-weight:600;font-size:13.5px;border:1px solid var(--line);background:#fff;color:var(--navy);border-radius:9px;padding:9px 16px;cursor:pointer;transition:.15s}
.btn:hover{border-color:var(--blue);color:var(--blue)}
.btn.primary{background:linear-gradient(135deg,var(--blue),var(--blue-2));color:#fff;border:0}
.btn.primary:hover{filter:brightness(1.05);color:#fff}
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--mut);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:11px 13px;font-family:var(--body);font-size:14px;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(23,99,198,.12)}
.flash{padding:11px 15px;border-radius:9px;margin-bottom:14px;font-size:13.5px}
.flash.info{background:#e0f2fe;color:#075985}.flash.success{background:#dcfce7;color:#166534}.flash.error{background:#fee2e2;color:#991b1b}.flash.warning{background:#fef3c7;color:#92400e}

/* ---------- Auth / landing ---------- */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.auth-hero{background:linear-gradient(160deg,var(--navy),#0a3a6b 70%,var(--blue));color:#fff;padding:56px 48px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.auth-hero::after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(54,208,196,.35),transparent 70%);right:-160px;top:-120px}
.auth-hero .brand{font-size:26px}
.auth-hero h2{color:#fff;font-size:2rem;margin:24px 0 12px;max-width:440px;position:relative}
.auth-hero p{color:rgba(255,255,255,.8);max-width:430px;position:relative}
.auth-hero .feats{margin-top:28px;display:flex;flex-direction:column;gap:10px;position:relative}
.auth-hero .feats div{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.92)}
.auth-hero .feats .tick{width:22px;height:22px;border-radius:7px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;color:var(--blue-2)}
.auth-form{display:flex;align-items:center;justify-content:center;padding:40px}
.auth-card{width:100%;max-width:380px}
.auth-card h1{font-size:1.5rem;margin-bottom:6px}
.auth-card .muted{color:var(--mut);font-size:13.5px;margin-bottom:22px}
.auth-card .alt{margin-top:16px;font-size:13px;color:var(--mut);text-align:center}
@media(max-width:880px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto}.auth-wrap{grid-template-columns:1fr}.auth-hero{display:none}}
