/* Cockpit Agence — thème "Papier chaud" (beige hybride A+B).
   Fond beige clair, teal primaire, corail en accent. Teintes pastel sur
   KPIs + cartes agents. Statuts assombris pour rester lisibles sur clair.
   Mobile-first, tab-bar bas. Thème unique (pas de bascule prefers-color-scheme). */
:root{
  --bg:#EAE1D1; --surface:#F8F2E7; --surface-2:#EBE0CD;
  --line:#DBCDB4; --line-strong:#C9B894;
  --text:#2B2620; --text-muted:#5E5749; --text-faint:#7A6E59;
  --primary:#0F8473; --success:#1F915F; --warning:#B0731C; --danger:#C8492F; --info:#356FA6;
  --accent:#D26A35; --on-primary:#FFFFFF;
  --f-sans:"Inter",system-ui,sans-serif; --f-mono:"JetBrains Mono",monospace; --f-hero:"IBM Plex Serif",Georgia,serif;
  --r-2:6px; --r-3:8px; --r-4:12px; --r-pill:999px;
  --sh-1:0 0 0 1px var(--line),0 2px 8px rgba(90,68,34,.10);
  --sh-2:0 0 0 1px var(--line-strong),0 10px 28px rgba(90,68,34,.18);
  --sh-glow:0 0 0 1px rgba(15,132,115,.40),0 0 18px rgba(15,132,115,.14);
  --sh-accent:0 0 16px rgba(210,106,53,.20);
  --t-fast:110ms; --t-base:180ms; --t-slow:320ms; --ease-out:cubic-bezier(.16,1,.3,1);
  --pad:clamp(12px,2.4vw,24px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);font-family:var(--f-sans);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;padding-bottom:72px}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--r-2)}

/* ---------- TOPBAR ---------- */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;
  padding:12px var(--pad);background:color-mix(in srgb,var(--bg) 85%,transparent);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:9px;font-weight:600;letter-spacing:-.012em;white-space:nowrap}
.brand .mark{width:18px;height:18px;border-radius:5px;background:linear-gradient(135deg,var(--primary),var(--info));box-shadow:0 0 12px rgba(15,132,115,.4)}
.brand small{color:var(--text-faint);font:500 11px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.08em}
.nav{display:flex;gap:2px;margin-left:8px}
.nav a{padding:7px 13px;border-radius:var(--r-2);font-size:14px;font-weight:500;color:var(--text-muted);transition:background var(--t-fast),color var(--t-fast)}
.nav a:hover{background:var(--surface-2);color:var(--text)}
.nav a.active{background:var(--surface-2);color:var(--text);box-shadow:inset 0 -2px 0 var(--primary)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.health{display:inline-flex;align-items:center;gap:7px;font:500 12px/1 var(--f-mono);color:var(--text-muted)}
.health .dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);animation:pulse 2.4s ease-in-out infinite}
.poll{font:500 11px/1 var(--f-mono);color:var(--text-faint);display:inline-flex;align-items:center;gap:6px}
.btn-new{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--r-2);
  background:var(--primary);color:var(--on-primary);font-weight:600;font-size:13px;min-height:38px;
  transition:transform var(--t-fast),box-shadow var(--t-fast)}
.btn-new:hover{box-shadow:var(--sh-glow)}
.btn-new:active{transform:translateY(1px)}
.icon-link{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--r-2);
  color:var(--text-faint);transition:background var(--t-fast),color var(--t-fast)}
.icon-link:hover{background:var(--surface-2);color:var(--text)}
@keyframes pulse{50%{opacity:.45}}

/* ---------- LAYOUT ---------- */
.wrap{max-width:1280px;margin:0 auto;padding:var(--pad)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin:28px 0 12px}
.section-head h2{position:relative;padding-left:13px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);font-family:var(--f-mono)}
.section-head h2::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:13px;border-radius:2px;background:linear-gradient(180deg,var(--primary),var(--info))}
.section-head .meta{font:500 12px/1 var(--f-mono);color:var(--text-faint)}
.empty{padding:24px;text-align:center;color:var(--text-muted);background:var(--surface);border-radius:var(--r-4);box-shadow:var(--sh-1);font-size:14px}

/* ---------- VERDICT ---------- */
.verdict{display:flex;align-items:flex-start;gap:13px;padding:15px 18px;border-radius:var(--r-4);
  background:linear-gradient(100deg,color-mix(in srgb,var(--success) 12%,var(--surface)),var(--surface) 60%);
  box-shadow:var(--sh-1);border-left:3px solid var(--success)}
.verdict[data-level="warn"]{border-left-color:var(--warning);
  background:linear-gradient(100deg,color-mix(in srgb,var(--warning) 14%,var(--surface)),var(--surface) 60%)}
.verdict[data-level="danger"]{border-left-color:var(--danger);
  background:linear-gradient(100deg,color-mix(in srgb,var(--danger) 14%,var(--surface)),var(--surface) 60%)}
.verdict .v-dot{margin-top:5px;width:9px;height:9px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);flex:none;animation:pulse 2.4s ease-in-out infinite}
.verdict[data-level="warn"] .v-dot{background:var(--warning);box-shadow:0 0 8px var(--warning)}
.verdict[data-level="danger"] .v-dot{background:var(--danger);box-shadow:0 0 8px var(--danger)}
.verdict p{font-size:15px;color:var(--text);line-height:1.5}
.verdict b{font-weight:600}
.verdict .accent{color:var(--accent)}

/* ---------- KPI GRID ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border-radius:var(--r-4);overflow:hidden;box-shadow:var(--sh-1);margin-top:14px}
.kpi{--kpi:var(--primary);background:linear-gradient(180deg,color-mix(in srgb,var(--kpi) 17%,var(--surface)),var(--surface) 72%);
  padding:20px 18px 16px;display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--kpi);opacity:.95}
.kpi:nth-child(1){--kpi:var(--info)}
.kpi:nth-child(2){--kpi:var(--primary)}
.kpi:nth-child(3){--kpi:var(--success)}
.kpi:nth-child(4),.kpi.action{--kpi:var(--accent)}
.kpi .k-label{font:500 11px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.08em;color:color-mix(in srgb,var(--kpi) 55%,var(--text-faint))}
.kpi .k-num{font:600 38px/1 var(--f-hero);font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--kpi)}
.kpi .k-num .sub{font-size:18px;color:color-mix(in srgb,var(--kpi) 45%,var(--text-faint))}
.kpi .k-foot{font:400 12px/1.3 var(--f-sans);color:var(--text-muted);display:flex;align-items:center;gap:6px}
.kpi .spark{display:inline-flex;gap:2px;align-items:flex-end;height:14px}
.kpi .spark i{width:3px;background:var(--kpi);border-radius:1px;display:block;opacity:.85}
.delta{font:500 11px/1 var(--f-mono)}
.delta.up{color:var(--success)} .delta.down{color:var(--danger)}
.k-cta{margin-top:2px;align-self:flex-start;font:600 12px/1 var(--f-sans);color:var(--accent);
  padding:6px 0;border-bottom:1px solid transparent;transition:border-color var(--t-fast)}
.k-cta:hover{border-color:var(--accent)}

/* ---------- TWO-COL ---------- */
.cols{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}

/* ---------- ATTENTION LIST ---------- */
.attn{display:grid;gap:1px;background:var(--line);border-radius:var(--r-4);overflow:hidden;box-shadow:var(--sh-1)}
.attn-row{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--surface);transition:background var(--t-fast)}
.attn-row:hover{background:var(--surface-2)}
.attn-row .ico{width:28px;height:28px;border-radius:var(--r-2);display:grid;place-items:center;flex:none;font-size:14px}
.ico.warn{background:color-mix(in srgb,var(--warning) 14%,transparent);color:var(--warning)}
.ico.deci{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.ico.info{background:color-mix(in srgb,var(--info) 14%,transparent);color:var(--info)}
.attn-row .txt{flex:1;min-width:0}
.attn-row .txt b{font-weight:600;font-size:14px}
.attn-row .txt span{display:block;font-size:12.5px;color:var(--text-muted)}
.attn-row .go{flex:none;min-width:44px;min-height:36px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--r-2);background:var(--surface-2);font:600 12px/1 var(--f-sans);color:var(--text);
  box-shadow:inset 0 0 0 1px var(--line);transition:box-shadow var(--t-fast)}
.attn-row .go:hover{box-shadow:inset 0 0 0 1px var(--primary);color:var(--primary)}

/* ---------- SIDE PANEL ---------- */
.panel{background:var(--surface);border-radius:var(--r-4);box-shadow:var(--sh-1);padding:16px}
.panel h3{font:500 11px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin-bottom:12px}
.org{display:grid;gap:9px}
.org-node{display:flex;align-items:center;gap:9px;font-size:13.5px}
.org-node .od{width:8px;height:8px;border-radius:50%;flex:none}
.od.on{background:var(--primary);box-shadow:0 0 7px var(--primary);animation:pulse 2.4s ease-in-out infinite}
.od.off{background:var(--text-faint)}
.org-node.child{padding-left:18px;color:var(--text-muted);font-size:13px}
.org-node .count{margin-left:auto;font:500 11px/1 var(--f-mono);color:var(--text-faint)}

/* ---------- AGENT BAND ---------- */
.agent-band{display:grid;gap:1px;background:var(--line);border-radius:var(--r-4);overflow:hidden}
.agent-row{display:grid;grid-template-columns:38px 1fr 52px auto;align-items:center;gap:11px;
  padding:11px 16px;background:var(--surface);transition:background var(--t-fast)}
.agent-row:hover{background:var(--surface-2)}
.av-wrap{position:relative;width:38px;height:38px}
.a-av{width:38px;height:38px;border-radius:50%;object-fit:cover;display:block;
  background:var(--surface-2);box-shadow:0 0 0 2px var(--agent,var(--line)),0 0 12px -4px var(--agent,transparent)}
/* fallback : pas d'image -> pastille couleur d'agent avec l'initiale gérée en CSS */
.a-av.av-fallback{visibility:hidden}
.av-wrap .ad{position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;border-radius:50%;
  box-shadow:0 0 0 2px var(--surface)}
.agent-row .ad{width:10px;height:10px;border-radius:50%}
.ad.work{background:var(--agent,var(--primary));box-shadow:0 0 0 2px var(--surface),0 0 8px var(--agent,var(--primary));animation:pulse 2.4s ease-in-out infinite}
.ad.rest{background:var(--text-faint)}
.agent-row .who{display:flex;flex-direction:column;gap:2px;min-width:0}
.agent-row .who b{font-weight:600;font-size:14px;line-height:1.2}
.agent-row .who span{font-size:11px;color:var(--text-faint);font-family:var(--f-mono);
  letter-spacing:.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.agent-row .load{height:5px;border-radius:99px;background:var(--surface-2);overflow:hidden}
.agent-row .load i{display:block;height:100%;background:var(--primary);border-radius:99px}
.agent-row .st{font:500 11px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:right}
.agent-row .run{min-width:44px;min-height:40px;padding:0 13px;display:inline-flex;align-items:center;gap:6px;justify-content:center;
  border-radius:var(--r-2);background:var(--surface-2);font:600 12px/1 var(--f-sans);
  box-shadow:inset 0 0 0 1px var(--line);transition:box-shadow var(--t-fast),color var(--t-fast)}
.agent-row .run:hover{box-shadow:inset 0 0 0 1px var(--primary);color:var(--primary)}

/* ---------- TEAM (vue agents, mascottes larges) ---------- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:8px}
.team-card{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;
  padding:22px 16px 16px;background:color-mix(in srgb,var(--agent,var(--primary)) 9%,var(--surface));border-radius:var(--r-4);
  box-shadow:inset 0 0 0 1px var(--line);overflow:hidden;transition:transform var(--t-fast),box-shadow var(--t-fast)}
.team-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--agent,var(--primary))}
.team-card::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120px 80px at 50% -10%,color-mix(in srgb,var(--agent,transparent) 18%,transparent),transparent 70%)}
.team-card:hover{transform:translateY(-2px);box-shadow:inset 0 0 0 1px var(--agent,var(--line)),0 8px 24px -12px var(--agent,transparent)}
.tc-av{width:76px;height:76px;border-radius:50%;object-fit:cover;background:var(--surface-2);
  box-shadow:0 0 0 2px var(--agent,var(--line)),0 0 20px -6px var(--agent,transparent)}
.tc-name{font:600 14px/1.2 var(--f-sans);color:var(--text)}
.tc-role{font:400 11.5px/1.4 var(--f-sans);color:var(--text-muted);min-height:2.6em}
.tc-state{position:absolute;top:10px;right:10px;font:600 9px/1 var(--f-mono);text-transform:uppercase;
  letter-spacing:.06em;padding:4px 7px;border-radius:99px;background:var(--surface-2);color:var(--text-faint)}
.tc-state.work{background:color-mix(in srgb,var(--agent) 18%,transparent);color:var(--agent)}
.tc-run{margin-top:2px;min-height:36px;padding:0 14px;border-radius:var(--r-2);background:var(--surface-2);
  font:600 12px/1 var(--f-sans);box-shadow:inset 0 0 0 1px var(--line);
  transition:box-shadow var(--t-fast),color var(--t-fast)}
.tc-run:hover{box-shadow:inset 0 0 0 1px var(--agent,var(--primary));color:var(--agent,var(--primary))}

/* ---------- PROJECT CARDS ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.proj-card{position:relative;display:grid;gap:13px;background:var(--surface);border-radius:var(--r-3);
  box-shadow:var(--sh-1);padding:16px 18px 15px;text-align:left;width:100%;
  transition:box-shadow var(--t-fast),transform var(--t-fast)}
.proj-card::before{content:"";position:absolute;left:0;top:16px;bottom:16px;width:2px;border-radius:2px;
  background:var(--text-faint);transition:width var(--t-fast),background var(--t-fast)}
.proj-card[data-s="active"]::before{background:var(--success)}
.proj-card[data-s="scoped"]::before{background:var(--primary)}
.proj-card[data-s="review"]::before{background:var(--info)}
.proj-card[data-s="scoping"]::before{background:var(--warning)}
.proj-card[data-s="paused"]::before,.proj-card[data-s="archived"]::before{background:var(--text-faint)}
.proj-card[data-s="delivered"]::before{background:var(--success)}
.proj-card:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.proj-card:hover::before{width:3px}
.proj-card:focus-visible{outline:0;box-shadow:var(--sh-glow)}
.pc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-left:8px}
.pc-name{font:600 15px/1.25 var(--f-sans);letter-spacing:-.012em}
.pc-pill{display:inline-flex;align-items:center;gap:6px;font:500 11px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.07em;padding:4px 9px;border-radius:var(--r-pill);white-space:nowrap;background:var(--surface-2);color:var(--text-faint)}
.pc-pill .d{width:6px;height:6px;border-radius:50%;background:var(--text-faint)}
.pc-pill[data-s="active"],.pc-pill[data-s="delivered"]{color:var(--success);background:color-mix(in srgb,var(--success) 12%,transparent)}
.pc-pill[data-s="active"] .d,.pc-pill[data-s="delivered"] .d{background:var(--success);box-shadow:0 0 6px var(--success);animation:pulse 2.4s ease-in-out infinite}
.pc-pill[data-s="scoped"]{color:var(--primary);background:color-mix(in srgb,var(--primary) 12%,transparent)}
.pc-pill[data-s="scoped"] .d{background:var(--primary);box-shadow:0 0 6px var(--primary);animation:pulse 2.4s ease-in-out infinite}
.pc-pill[data-s="review"]{color:var(--info);background:color-mix(in srgb,var(--info) 12%,transparent)}
.pc-pill[data-s="review"] .d{background:var(--info)}
.pc-pill[data-s="scoping"]{color:var(--warning);background:color-mix(in srgb,var(--warning) 12%,transparent)}
.pc-pill[data-s="scoping"] .d{background:var(--warning);box-shadow:0 0 6px var(--warning);animation:pulse 2.4s ease-in-out infinite}

/* phases frieze */
.phases{display:flex;align-items:center;gap:0;padding-left:8px}
.ph{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;position:relative}
.ph .pd{width:10px;height:10px;border-radius:50%;background:var(--surface-2);box-shadow:inset 0 0 0 1.5px var(--line);z-index:1}
.ph.done .pd{background:var(--primary);box-shadow:0 0 6px rgba(15,132,115,.5)}
.ph.cur .pd{background:var(--surface);box-shadow:0 0 0 2px var(--primary),0 0 8px rgba(15,132,115,.4)}
.ph .pl{font:500 9px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint);white-space:nowrap}
.ph.cur .pl{color:var(--primary)}
.ph::after{content:"";position:absolute;top:5px;left:50%;width:100%;height:1.5px;background:var(--line);z-index:0}
.ph.done::after{background:var(--primary)}
.ph:last-child::after{display:none}

.pc-prog{display:flex;align-items:center;gap:12px;padding-left:8px}
.pc-track{flex:1;height:6px;border-radius:99px;background:var(--surface-2);overflow:hidden}
.pc-bar{height:100%;border-radius:99px;background:var(--primary);width:0;transition:width var(--t-slow) var(--ease-out)}
.pc-pct{font:600 22px/1 var(--f-hero);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.pc-pct .sub{font-size:12px;color:var(--text-faint)}

.pc-tasks{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px 0 0 8px;border-top:1px solid var(--line)}
.pc-col .cl{display:flex;align-items:center;gap:6px;font:500 10px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.pc-col.todo .cl{color:var(--primary)} .pc-col.def .cl{color:var(--accent)}
.pc-col .cl .b{font-size:11px}
.pc-col li{list-style:none;font:400 12px/1.45 var(--f-sans);color:var(--text-muted);display:flex;gap:6px;margin-bottom:3px}
.pc-col li::before{content:"·";color:var(--text-faint)}
.pc-col.def li::before{content:"◇";color:var(--accent);font-size:10px}
.pc-col li.none::before{content:"";}
.pc-col li.none{color:var(--text-faint);opacity:.65}
.pc-foot{display:flex;justify-content:space-between;font:500 11px/1 var(--f-mono);color:var(--text-faint);padding-left:8px}

.proj-card.ghost{display:grid;place-items:center;min-height:160px;background:transparent;
  box-shadow:none;border:1.5px dashed var(--line-strong);color:var(--text-muted);gap:8px}
.proj-card.ghost::before{display:none}
.proj-card.ghost:hover{border-color:var(--primary);color:var(--primary);transform:none}
.proj-card.ghost .plus{font-size:26px;font-weight:300;line-height:1}

/* ---------- MISSIONS ---------- */
.mission-list{display:grid;gap:1px;background:var(--line);border-radius:var(--r-4);overflow:hidden;box-shadow:var(--sh-1)}
.mission-row{display:grid;grid-template-columns:1fr auto;gap:12px;padding:15px 18px;background:var(--surface);transition:background var(--t-fast)}
.mission-row:hover{background:var(--surface-2)}
.mission-row .m-title{font:600 15px/1.3 var(--f-sans)}
.mission-row .m-meta{font:500 12px/1 var(--f-mono);color:var(--text-faint);margin-top:6px;display:flex;gap:14px;flex-wrap:wrap}
.mission-row .m-tjm{font:600 18px/1 var(--f-hero);color:var(--accent);font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}
.mission-row .m-tjm small{display:block;font:500 10px/1 var(--f-mono);color:var(--text-faint);margin-top:4px}

/* ---------- MODALE NOUVEAU PROJET ---------- */
.overlay{position:fixed;inset:0;z-index:100;background:rgba(40,30,18,.55);backdrop-filter:blur(3px);
  display:grid;place-items:center;padding:var(--pad)}
.modal{width:100%;max-width:520px;background:var(--surface);border-radius:var(--r-4);box-shadow:var(--sh-2);
  padding:24px;display:grid;gap:16px;animation:modal-in var(--t-base) var(--ease-out)}
@keyframes modal-in{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}
.modal h2{font:600 19px/1.2 var(--f-hero);letter-spacing:-.01em}
.modal .hint{font-size:13px;color:var(--text-muted);margin-top:-8px}
.field{display:grid;gap:6px}
.field label{font:500 11px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint)}
.field input,.field textarea{background:var(--bg);border:1px solid var(--line);border-radius:var(--r-2);
  padding:11px 13px;color:var(--text);font:400 14px/1.5 var(--f-sans);width:100%;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,132,115,.18)}
.field textarea{min-height:96px;resize:vertical}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}
.btn-ghost{padding:10px 16px;border-radius:var(--r-2);background:var(--surface-2);font-weight:600;font-size:13px;min-height:42px;
  box-shadow:inset 0 0 0 1px var(--line);transition:box-shadow var(--t-fast)}
.btn-ghost:hover{box-shadow:inset 0 0 0 1px var(--line-strong)}
.btn-primary{padding:10px 18px;border-radius:var(--r-2);background:var(--primary);color:var(--on-primary);font-weight:600;font-size:13px;min-height:42px;
  transition:transform var(--t-fast),box-shadow var(--t-fast)}
.btn-primary:hover{box-shadow:var(--sh-glow)}
.btn-primary:active{transform:translateY(1px)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.form-error{color:var(--danger);font-size:13px;min-height:18px}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100dvh;display:grid;place-items:center;padding:var(--pad)}
.login-card{width:100%;max-width:380px;background:var(--surface);border-radius:var(--r-4);box-shadow:var(--sh-2);padding:32px 28px;display:grid;gap:18px}
.login-card .brand{justify-content:center;font-size:18px}
.login-card .sub{text-align:center;color:var(--text-muted);font-size:13px;margin-top:-8px}
.login-card .form-error{text-align:center}

/* ---------- BOTTOM TAB-BAR (mobile) ---------- */
.tabbar{display:none}
@media(max-width:720px){
  .tabbar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:color-mix(in srgb,var(--bg) 94%,transparent);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:6px 4px env(safe-area-inset-bottom,6px)}
  .tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:7px 0;min-height:48px;
    font:500 10px/1 var(--f-mono);text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint)}
  .tabbar a.active{color:var(--primary)}
  .tabbar a .ti{width:20px;height:20px;border-radius:5px;display:grid;place-items:center;font-size:15px}
  .tabbar a.active .ti{background:color-mix(in srgb,var(--primary) 14%,transparent)}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1100px){ .cols{grid-template-columns:1fr} }
@media(max-width:720px){
  .nav{display:none}
  .btn-new span.lbl{display:none}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .kpi .k-num{font-size:30px}
  .poll{display:none}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .pc-bar{width:var(--target)!important}
}
[x-cloak]{display:none!important}
