/* ===========================================================================
   ArchiCadia v3.0 — Console applicative — styles
   Hérite de la palette validée (thème clair chaud).
   =========================================================================== */

:root {
  --nuit:#0F1923; --marine:#1C2E42; --ocre:#C8914A; --ocre-d:#A97534;
  --bleu-cad:#4A7A9B; --ivoire:#F0EDE6; --ardoise:#6B7A8D;
  --bg:#F4F1EA; --surface:#FBFAF6; --surface-2:#FFFFFF;
  --text:#182634; --text-mut:#5C6B7A;
  --line:rgba(28,46,66,.12); --line-str:rgba(28,46,66,.20);
  --ok:#2E7D5B; --warn:#B5722A; --err:#B23A48;
  --r:13px;
  --f-display:"Syne",system-ui,sans-serif;
  --f-body:"Spectral",Georgia,serif;
  --f-mono:"IBM Plex Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--f-body);color:var(--text);background:var(--bg);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:46px 46px;background-attachment:fixed}
a{color:inherit;text-decoration:none}
svg{display:block}
.mono{font-family:var(--f-mono);letter-spacing:.04em}
.hidden{display:none!important}

/* ---------- Top bar ---------- */
.topbar{position:sticky;top:0;z-index:40;height:62px;display:flex;align-items:center;gap:18px;padding:0 22px;
  background:rgba(244,241,234,.9);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .brand{display:flex;align-items:center;gap:10px}
.topbar .brand .logo{width:32px;height:32px}
.topbar .brand b{font-family:var(--f-display);font-weight:800;font-size:1.12rem;color:var(--nuit)}
.topbar .spacer{margin-left:auto}
.plan-badge{font-family:var(--f-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;
  padding:5px 10px;border-radius:20px;border:1px solid var(--line-str);color:var(--text-mut)}
.plan-badge b{color:var(--ocre-d)}
.lang{display:flex;gap:2px;font-family:var(--f-mono);font-size:.7rem}
.lang a{padding:5px 9px;border:1px solid var(--line-str);border-radius:7px;color:var(--text-mut);cursor:pointer}
.lang a.on{background:var(--ocre);color:#fff;border-color:var(--ocre);font-weight:600}

/* ---------- Buttons ---------- */
.btn{font-family:var(--f-display);font-weight:700;font-size:.9rem;background:var(--ocre);color:#fff;
  padding:11px 18px;border-radius:9px;border:0;cursor:pointer;transition:transform .12s,box-shadow .2s}
.btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(200,145,74,.3)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn.ghost{background:transparent;color:var(--nuit);border:1px solid var(--line-str)}
.btn.ghost:hover{border-color:var(--ocre);box-shadow:none}
.btn.sm{padding:7px 12px;font-size:.8rem}
.btn.block{width:100%;justify-content:center;text-align:center}

/* ---------- Login ---------- */
.login-wrap{min-height:calc(100vh - 62px);display:grid;place-items:center;padding:30px}
.login-card{width:100%;max-width:400px;background:var(--surface-2);border:1px solid var(--line-str);
  border-radius:18px;padding:38px 34px;box-shadow:0 20px 60px rgba(28,46,66,.10)}
.login-card .logo{width:48px;height:48px;margin-bottom:18px}
.login-card h1{font-family:var(--f-display);font-weight:800;font-size:1.5rem;color:var(--nuit);margin-bottom:6px}
.login-card p.sub{color:var(--text-mut);font-size:.95rem;margin-bottom:24px}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--f-mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;
  color:var(--text-mut);margin-bottom:6px}
.field input,.field textarea,.field select{width:100%;font-family:var(--f-body);font-size:.95rem;color:var(--text);
  background:var(--surface);border:1px solid var(--line-str);border-radius:9px;padding:11px 13px;outline:none;transition:border-color .15s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--ocre)}
.msg{font-size:.86rem;padding:10px 12px;border-radius:8px;margin-top:6px}
.msg.err{background:rgba(178,58,72,.1);color:var(--err);border:1px solid rgba(178,58,72,.25)}
.msg.ok{background:rgba(46,125,91,.1);color:var(--ok);border:1px solid rgba(46,125,91,.25)}

/* ---------- Workspace ---------- */
.workspace{display:grid;grid-template-columns:380px 1fr;gap:0;min-height:calc(100vh - 62px)}
.panel{padding:24px 22px;overflow-y:auto}
.panel.left{border-right:1px solid var(--line);background:var(--surface)}
.panel h2{font-family:var(--f-display);font-weight:800;font-size:1.15rem;color:var(--nuit);margin-bottom:4px}
.panel .hint{color:var(--text-mut);font-size:.85rem;margin-bottom:20px}

/* rooms editor */
.rooms{display:flex;flex-direction:column;gap:8px;margin:6px 0 12px}
.room-row{display:grid;grid-template-columns:1fr 84px 34px;gap:8px;align-items:center}
.room-row input{padding:9px 11px;font-size:.9rem}
.room-row .del{border:1px solid var(--line-str);background:transparent;border-radius:8px;height:38px;cursor:pointer;color:var(--text-mut);font-size:1rem}
.room-row .del:hover{border-color:var(--err);color:var(--err)}
.addrow{font-family:var(--f-mono);font-size:.8rem;color:var(--ocre-d);background:none;border:1px dashed var(--line-str);
  border-radius:8px;padding:9px;width:100%;cursor:pointer}
.addrow:hover{border-color:var(--ocre)}

/* ---------- Results ---------- */
.tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line)}
.tab{font-family:var(--f-display);font-weight:700;font-size:.88rem;color:var(--text-mut);background:none;border:0;
  padding:10px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab.on{color:var(--nuit);border-bottom-color:var(--ocre)}
.tabpane{display:none}
.tabpane.on{display:block}
.placeholder{display:grid;place-items:center;height:60vh;color:var(--text-mut);text-align:center}
.placeholder .logo{width:64px;height:64px;opacity:.5;margin-bottom:18px}

.planbox{background:var(--surface-2);border:1px solid var(--line-str);border-radius:var(--r);padding:16px;overflow:auto}
.plan-svg{width:100%;height:auto;background:#fff;border-radius:8px}
.plan-svg .wall{fill:rgba(74,122,155,.08);stroke:var(--marine);stroke-width:2}
.plan-svg .rlabel{font-family:var(--f-mono);font-size:9px;fill:var(--nuit)}
.plan-svg .rarea{font-family:var(--f-mono);font-size:7.5px;fill:var(--text-mut)}

.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-top:16px}
.metric{background:var(--surface);border:1px solid var(--line-str);border-radius:10px;padding:14px}
.metric .k{font-family:var(--f-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mut)}
.metric .v{font-family:var(--f-display);font-weight:800;font-size:1.35rem;color:var(--nuit);margin-top:4px}
.metric .v small{font-size:.8rem;font-weight:400;color:var(--text-mut)}

/* score gauge */
.score-head{display:flex;align-items:center;gap:20px;background:var(--surface);border:1px solid var(--line-str);border-radius:var(--r);padding:20px;margin-bottom:16px}
.gauge{--p:0;width:96px;height:96px;border-radius:50%;flex:0 0 auto;
  background:conic-gradient(var(--ocre) calc(var(--p)*1%),rgba(28,46,66,.10) 0);display:grid;place-items:center}
.gauge .inner{width:72px;height:72px;border-radius:50%;background:var(--surface);display:grid;place-items:center;
  font-family:var(--f-display);font-weight:800;font-size:1.4rem;color:var(--nuit)}
.niveau{font-family:var(--f-display);font-weight:800;font-size:1.3rem;color:var(--nuit)}
.bars{display:flex;flex-direction:column;gap:10px}
.bar-row{display:grid;grid-template-columns:160px 1fr 48px;gap:10px;align-items:center;font-size:.85rem}
.bar-track{height:8px;background:rgba(28,46,66,.1);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:var(--bleu-cad);border-radius:6px}
.reco{margin-top:14px}
.reco li{margin:6px 0 6px 18px;color:var(--text-mut);font-size:.9rem}

.dpgf{width:100%;border-collapse:collapse;margin-top:10px;font-size:.86rem}
.dpgf th{text-align:left;font-family:var(--f-mono);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--text-mut);border-bottom:1px solid var(--line-str);padding:8px 6px}
.dpgf td{padding:8px 6px;border-bottom:1px solid var(--line)}
.dpgf td.num{text-align:right;font-family:var(--f-mono)}

.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;
  display:inline-block;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:880px){
  .workspace{grid-template-columns:1fr}
  .panel.left{border-right:0;border-bottom:1px solid var(--line)}
}
