@import url('https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@100;200;300;400;600;700&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300&display=swap');

/* ── RESET & BASE ── */
*{box-sizing:border-box;margin:0;padding:0;}
::selection{background:var(--tx);color:#fff;}
::-moz-selection{background:var(--tx);color:#fff;}
body{font-family:'DM Sans',sans-serif;background:#ffffff;overflow:hidden;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}

/* ══ DESIGN TOKENS — Swiss Editorial ══
   Palette : blanc pur / gris pierre / noir graphite
   Accents  : un seul doré discret, status en gris fonctionnel
*/
:root{
  /* ── Typographic scale ── */
  --fs-xs:9px;  /* labels, meta, badges */
  --fs-sm:10px; /* secondary info */
  --fs-md:11px; /* nav, body small */
  --fs-base:12px; /* body principal */
  --fs-lg:14px; /* sous-titres */
  --fs-xl:20px; /* titres */
  --fs-2xl:28px;/* KPI */
  /* ── Spacing scale (4px grid) ── */
  --sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;
  --sp-5:20px;--sp-6:24px;--sp-7:28px;--sp-8:32px;
  /* ── Border-radius ── */
  --r-sm:2px;--r-md:4px;--r-lg:8px;--rdb:#ffcdd2;--bg:#fafaf8;--card:#ffffff;--warm:#f5f5f2;--glt:#eeeeec;--glt2:#e8e8e6;--bd:#dedede;--bd2:#c4c4c2;--bd3:#e8e8e6;--tx:#080808;--tx2:#282828;--mu:#868686;--mu2:#b2b2b2;--dark:#0a0a0a;--dark2:#141414;--dark3:#1e1e1e;--gold:#0a0a0a;--gold2:#444444;--gn:#1a5c35;--gnl:#edf5f0;--gna:#1e6b3e;--rd:#b03030;--rdl:#fdf0f0;--bl:#1a3a6c;--bll:#eef2fa;--pur:#4a2a7a;
  --ivory:#fdf8f0;--shadow-md:0 2px 8px rgba(0,0,0,.08);--shadow-lg:0 4px 20px rgba(0,0,0,.12);--purl:#f3effe;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:2px;transition:background .2s;}
::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.32);}

/* ── APP SHELL : encadrement discret, coins droits comme un document imprimé ── */
#ap{width:100%;height:100vh;height:100dvh;min-height:0;max-height:none;display:flex;overflow:hidden;border-radius:2px;border:1px solid var(--bd);position:relative;box-shadow:0 4px 24px rgba(0,0,0,.1),0 1px 4px rgba(0,0,0,.06);
  /* Optimisation repaint : force composition GPU pour éviter le flash blanc
     visible lors des re-renders complets (wizards PV/RV, navigation sidebar).
     Le navigateur conserve le calque pendant le swap du contenu au lieu de
     tout dé-paint puis re-paint. */
  transform:translateZ(0);
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}

/* ── AVATARS ── */
.av{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:2px;font-size:9px;font-weight:600;letter-spacing:.02em;flex-shrink:0;}
.av-sm{width:17px;height:17px;font-size:9px;border-radius:1px;}

/* ── SEARCH HINTS ── */
.ksearch-hint{font-size:9px;color:var(--mu);display:flex;align-items:center;gap:4px;margin-top:3px;}
.ksearch-kbd{background:var(--dark2);border:1px solid var(--dark3);border-radius:2px;padding:1px 4px;font-size:9px;color:var(--mu);}

/* ── SAVE INDICATOR ── */
.save-dot{width:5px;height:5px;border-radius:50%;background:#3d9060;display:inline-block;margin-right:5px;transition:background .3s;}
.save-dot.saving{background:#888888;}
.save-dot.error{background:#b03030;}

/* ══════════════════════════════════════════════════════ SIDEBAR ══
   Inspiré de la colonne gauche Maeve : texte sur fond très sombre,
   hiérarchie par opacité et espacement, aucune décoration superflue
*/
.sb{width:210px;min-width:210px;background:var(--dark);display:flex;flex-direction:column;height:100%;overflow:hidden;border-right:1px solid rgba(255,255,255,.04);}

/* Entête : nom agence aéré comme un masthead */
.sbh{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06);}
.LE{font-family:'Josefin Sans',sans-serif;font-size:11px;font-weight:100;color:rgba(255,255,255,.85);letter-spacing:.38em;text-transform:uppercase;}
.LB{display:none;}
.LA{display:none;}
.LC{display:none;}

/* Rôle actif : ligne discrète encadrée */
.rp{margin:10px 12px 0;padding:5px 10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:1px;display:flex;justify-content:space-between;align-items:center;font-size:10px;color:rgba(255,255,255,.45);}

/* Sync */
.sy{display:flex;align-items:center;gap:5px;padding:7px 14px 3px;font-size:9px;color:rgba(255,255,255,.2);font-family:'DM Sans',sans-serif;letter-spacing:.08em;}
.sdot{width:4px;height:4px;border-radius:50%;background:#3d9060;animation:pulse 3s infinite;flex-shrink:0;}
@keyframes notifSlide{from{opacity:0;transform:translateY(8px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

/* Nav section label : très discret, comme une note marginale */
.nav-section{padding:14px 16px 4px;font-family:'DM Sans',sans-serif;font-size:8px;font-weight:500;letter-spacing:.2em;color:rgba(255,255,255,.28);text-transform:uppercase;}

/* Items de nav : juste du texte, accent par une ligne gauche fine */
.ni{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;font-size:11px;font-weight:400;color:rgba(255,255,255,.72);border-left:2px solid transparent;transition:color .12s,background .1s,border-color .12s;letter-spacing:.02em;overflow:hidden;}
.ni:hover{color:#ffffff;background:rgba(255,255,255,.05);}
.ni.act{color:#ffffff;border-left-color:rgba(255,255,255,.6);background:rgba(255,255,255,.06);font-weight:500;}

/* Badges nav : minimalistes, texte seul encadré */
.nbdg{background:rgba(255,255,255,.08);color:rgba(255,255,255,.45);border:none;border-radius:1px;font-size:9px;font-weight:400;padding:1px 6px;margin-left:auto;letter-spacing:.04em;}
.nbdg-pur{background:transparent;color:#9878c8;border:1px solid rgba(74,40,120,.4);border-radius:1px;font-size:9px;font-weight:500;padding:1px 5px;margin-left:auto;}

.sb-bot{margin-top:auto;padding:10px 12px;border-top:1px solid rgba(255,255,255,.06);}

/* ══════════════════════════════════════════════════ MAIN CONTENT ══ */
.mn{flex:1;overflow:hidden;display:flex;flex-direction:column;background:var(--bg);}

/* Top bar : bande fine, titre aéré tracé comme un titre de section éditoriale */
.tbr{padding:16px 28px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--card);}
.tbt{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;color:var(--tx);letter-spacing:.3em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:420px;}
.tbs{font-family:'DM Sans',sans-serif;font-size:10px;color:var(--mu2);margin-top:3px;letter-spacing:.02em;font-weight:400;}

/* Zone de contenu */
.ct{flex:1;overflow-y:auto;padding:24px 28px;scroll-behavior:smooth;}

/* ══════════════════════════════════════════════════ KPI GRID ══
   Cards : blanches, sans border-radius prononcé, ligne gauche fine
   comme des encadrés typographiques.
*/
.mg{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-bottom:20px;}
.mc{
  background:var(--card);
  border:1px solid var(--bd);
  border-radius:2px;
  padding:18px 18px 16px 20px;
  border-left:3px solid var(--bd2);
  position:relative;
  transition:border-left-color .2s;
}
/* ══ DARK MODE ══════════════════════════════════════════════ */
[data-theme=dark]{
  --bg:#0f0f0f;--card:#1a1a1a;--warm:#141414;
  --bd:#2a2a2a;--bd2:#333;--bd3:#222;
  --tx:#e8e2d8;--tx2:#c8bfb0;--mu:#888;--mu2:#666;
  --dark:#000;--dark2:#111;--dark3:#0a0a0a;
  --gold:#c8a84b;--gold2:#b89838;
  --gn:#2d6a4f;--gnl:#0d2b1e;--gna:#52b788;
  --rd:#c0392b;--rdl:#2d1010;--rdb:#5a1515;
  --bl:#4a90d9;--bll:#0d1f35;
  --pur:#7c5cbf;--purl:#1a1030;
  --glt:#0d2b1e;--glt2:#1a3d2b;
  --ivory:#1a1a1a;--shadow-md:0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 4px 20px rgba(0,0,0,.6);
}
[data-theme=dark] .proj-card{background:var(--card);border-color:var(--bd2);}
[data-theme=dark] .inp,[data-theme=dark] .sel,[data-theme=dark] .txa{background:#1e1e1e;color:var(--tx);border-color:var(--bd2);}
[data-theme=dark] .modal-overlay{background:rgba(0,0,0,.8);}
[data-theme=dark] .modal{background:#1a1a1a;border:1px solid var(--bd2);}
[data-theme=dark] .tbl .tr.hd{background:var(--warm);color:var(--mu);}
[data-theme=dark] .tr{border-bottom-color:var(--bd2);}
[data-theme=dark] .tr:hover{background:#1e1e1e;}
[data-theme=dark] table{color:var(--tx);}
[data-theme=dark] a{color:var(--bl);}

.mc:hover{border-left-color:#111111;}
.mc.g{border-left-color:var(--gna);}
.mc.r{border-left-color:var(--rd);}
.mc.b{border-left-color:var(--bl);}
.mc.p{border-left-color:var(--pur);}

/* Valeurs KPI : grands chiffres ultra-légers */
.mv{font-family:'DM Sans',sans-serif;font-size:26px;font-weight:100;color:var(--tx);line-height:1;letter-spacing:-.01em;}
.ml{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;letter-spacing:.12em;color:var(--mu);text-transform:uppercase;margin-top:6px;}
.ms{font-size:10px;color:var(--mu2);margin-top:3px;}

/* ══════════════════════════════════════════════════════ TABLES ══
   Lignes fines, zéro radius, header sobre comme un tableau typographique
*/
.tbl{background:var(--card);border:1px solid var(--bd);border-radius:1px;overflow:hidden;overflow-x:auto;margin-bottom:14px;}
.tr{display:grid;align-items:center;padding:10px 16px;border-bottom:1px solid var(--bd3);gap:8px;font-size:11px;line-height:1.4;transition:background .08s;min-width:0;}
.tr:last-child{border-bottom:none;}
.tr:not(.hd):hover{background:var(--glt);}
.tr.hd{background:var(--warm);font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;letter-spacing:.12em;color:var(--mu);text-transform:uppercase;padding:9px 16px;border-bottom:1px solid var(--bd);}

/* ══════════════════════════════════════════════ PHASE BADGES ══
   Style : texte seul, fond très doux, coins quasi-droits
*/
.pb{font-size:9px;font-weight:500;padding:3px 10px;border-radius:1px;display:inline-block;letter-spacing:.08em;text-transform:uppercase;}
.pESQ{background:#ededed;color:#505050;}
.pAPS{background:#eaeaf2;color:#484070;}
.pAPD{background:#f0ece0;color:#706030;}
.pPRO{background:#e4eef6;color:#204468;}
.pACT{background:#ece8f2;color:#482870;}
.pDET{background:#e4f0ea;color:#1c5030;}
.pAOR{background:#d8eee2;color:#0a4828;}
.pVISA{background:#f0ece0;color:#987020;}
.pPC{background:#f0e4e4;color:#781818;}

/* ══════════════════════════════════════════════ PROGRESS BAR ══ */
.pbar{height:2px;background:var(--bd);border-radius:0;overflow:hidden;margin-top:8px;}
.pfill{height:100%;background:var(--tx);border-radius:0;transition:width .5s cubic-bezier(.16,1,.3,1);}

/* ══════════════════════════════════════════════════ TAB ROW ══ */
.tabrow{display:flex;border-bottom:1px solid var(--bd);flex-shrink:0;padding:0 28px;background:var(--card);overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:0;}
.tabt{padding:11px 16px;background:none;border:none;font-size:11px;color:var(--mu);font-family:'DM Sans',sans-serif;font-weight:400;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;display:flex;align-items:center;gap:5px;letter-spacing:.02em;transition:color .12s;}
.tabt:hover{color:var(--tx2);}
.tabt.act{color:var(--tx);border-bottom-color:var(--tx);font-weight:500;}

/* ══════════════════════════════════════════════════════ BUTTONS ══
   Inspiré Brinkk : peu de padding, bords nets, transitions discrètes
*/
.bp{padding:9px 20px;background:var(--tx);color:#ffffff;border:1px solid var(--tx);border-radius:2px;font-size:11px;font-family:'DM Sans',sans-serif;cursor:pointer;font-weight:500;letter-spacing:.04em;transition:opacity .15s;box-shadow:0 1px 3px rgba(0,0,0,.12);}
.bp:hover{opacity:.82;box-shadow:0 2px 8px rgba(0,0,0,.12);}
.bs{padding:8px 18px;background:transparent;color:var(--tx2);border:1px solid var(--bd2);border-radius:2px;font-size:11px;font-family:'DM Sans',sans-serif;cursor:pointer;letter-spacing:.02em;transition:border-color .15s,color .15s;}
.bs:hover{border-color:var(--tx);color:var(--tx);}
.ba{padding:8px 13px;background:var(--tx);color:#ffffff;border:none;border-radius:2px;font-size:10px;cursor:pointer;font-family:'DM Sans',sans-serif;font-weight:400;letter-spacing:.03em;transition:opacity .15s;}
.ba:hover{opacity:.82;box-shadow:0 1px 4px rgba(0,0,0,.1);}
.bprint{padding:8px 12px;background:var(--bl);color:#fff;border:none;border-radius:1px;font-size:10px;cursor:pointer;font-family:'DM Sans',sans-serif;}
.bpur{padding:8px 12px;background:var(--pur);color:#fff;border:none;border-radius:1px;font-size:10px;cursor:pointer;font-family:'DM Sans',sans-serif;}
.bd2{padding:5px 12px;background:transparent;color:var(--rd);border:1px solid rgba(150,48,48,.2);border-radius:1px;font-size:10px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .15s;}
.bd2:hover{background:var(--rdl);}
.bg2{padding:5px 12px;background:transparent;color:var(--gn);border:1px solid rgba(46,102,68,.2);border-radius:1px;font-size:10px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:background .15s;}
.bg2:hover{background:var(--gnl);}

/* ══════════════════════════════════════════════════════ FORMS ══ */
.fld{margin-bottom:18px;}
.fld label{display:block;font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;letter-spacing:.14em;color:var(--mu);text-transform:uppercase;margin-bottom:6px;}
.inp,.sel,.txa{width:100%;padding:9px 12px;background:#fff;border:1px solid var(--bd);border-radius:2px;font-size:12px;color:var(--tx);font-family:'DM Sans',sans-serif;transition:border-color .15s,box-shadow .15s;outline:none;}
.inp:focus,.sel:focus,.txa:focus{border-color:var(--tx);box-shadow:0 0 0 2px rgba(8,8,8,.08);outline:none;}
.inp:hover:not(:focus),.sel:hover:not(:focus){border-color:var(--bd2);}
.inp::placeholder,.txa::placeholder{color:var(--mu2);font-style:italic;}
.sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888886' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;}
.txa{height:58px;resize:vertical;}
.inp-gold{background:#f7f7f7;border-color:#111111;}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px 14px;}
.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:0 10px;}

/* ══════════════════════════════════════════════════════ MODALS ══
   Fenêtre document : bords nets, fond blanc, header quasi-noir
*/
.mlay{position:absolute;inset:0;background:rgba(8,8,8,.4);display:flex;align-items:center;justify-content:center;z-index:50;backdrop-filter:blur(3px);}
.mbox{background:var(--card);border-radius:2px;overflow:hidden;max-height:94%;width:640px;display:flex;flex-direction:column;box-shadow:0 24px 64px rgba(0,0,0,.16),0 0 0 1px rgba(0,0,0,.08);}
.mhd{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;background:var(--dark);}
.mtt{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:100;color:#ffffff;letter-spacing:.32em;text-transform:uppercase;}
.mbd{padding:24px 28px;overflow-y:auto;flex:1;min-height:0;}
.mft{display:flex;justify-content:flex-end;gap:8px;padding-top:13px;margin-top:10px;border-top:1px solid var(--bd);}

/* ─────────────────────────────────────────────────── PROJECT CARDS ── */
.proj-card{background:var(--card);border:1px solid var(--bd);border-radius:2px;overflow:hidden;margin-bottom:8px;transition:border-color .15s,box-shadow .15s;}
.proj-card:hover{border-color:var(--bd2);box-shadow:0 2px 10px rgba(0,0,0,.06);}
.proj-card-hd{padding:12px 15px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;}
.proj-card-hd:hover{background:var(--glt);}
.proj-card-body{border-top:1px solid var(--bd);padding:14px 15px;}

/* ────────────────────────────────────────────────── PIPELINE CARDS ── */
.pcard{background:var(--card);border:1px solid var(--bd);border-radius:1px;overflow:hidden;margin-bottom:8px;border-left:2px solid var(--pur);}
.pcard.won{border-left-color:var(--gn);}.pcard.lost{border-left-color:var(--rd);}
.pcard-hd{padding:11px 15px;display:flex;align-items:flex-start;justify-content:space-between;}

/* ─────────────────────────────────────────────────────── PAY SLIPS ── */
.slip{background:var(--card);border:1px solid var(--bd);border-radius:1px;overflow:hidden;margin-bottom:14px;}
.slip-hd{background:var(--dark);padding:12px 16px;display:flex;justify-content:space-between;align-items:flex-start;color:#ffffff;}
.slip-tbl{width:100%;border-collapse:collapse;font-size:11px;}
.slip-tbl th{background:var(--warm);padding:7px 14px;text-align:left;font-size:9px;font-weight:500;letter-spacing:.14em;color:var(--mu);text-transform:uppercase;border-bottom:1px solid var(--bd);}
.slip-tbl td{padding:7px 14px;border-bottom:1px solid var(--bd3);color:var(--tx);}
.slip-tbl td.r{text-align:right;font-weight:500;}
.slip-tbl td.neg{text-align:right;font-weight:500;color:var(--rd);}

/* ────────────────────────────────────────────────────── FEE CARDS ── */
.fcard{background:var(--card);border:1px solid var(--bd);border-radius:2px;overflow:hidden;margin-bottom:14px;transition:border-color .15s,box-shadow .15s;}
.fcard:hover{border-color:var(--bd2);box-shadow:0 2px 12px rgba(0,0,0,.06);}
.fcard-hd{padding:11px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--bd3);}
.fcard-code{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:200;color:var(--tx);letter-spacing:.15em;}

/* ──────────────────────────────────────────────────── MESSAGES ── */
.msg-wrap{position:relative;margin-bottom:8px;}
.msg-wrap:hover .msg-actions{opacity:1;}
.msg-actions{position:absolute;top:6px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .15s;}
.msg-del{background:#fff;border:1px solid var(--bd);border-radius:1px;padding:2px 7px;font-size:10px;color:var(--rd);cursor:pointer;}
.msg{padding:10px 13px;border-radius:1px;line-height:1.6;}
.msg-col{background:#f5f5f5;border-left:2px solid #111111;}
.msg-dir{background:var(--gnl);border-left:2px solid var(--gna);}
.msg-cli{background:var(--bll);border-left:2px solid var(--bl);}
.msg-text{font-size:12px;color:var(--tx2);padding-right:60px;}
.msg-meta{font-size:9px;color:var(--mu2);margin-top:4px;}

/* ──────────────────────────────────────────────────── MISC ── */
.ndot{width:6px;height:6px;border-radius:50%;background:var(--rd);display:inline-block;margin-left:5px;vertical-align:middle;}
.ea{width:100%;padding:9px 12px;background:#fff;border:1px solid var(--bd);border-radius:2px;font-size:12px;color:var(--tx);font-family:'DM Sans',sans-serif;outline:none;transition:border-color .15s,box-shadow .15s;resize:none;height:56px;margin-top:6px;}
.ea:focus{border-color:var(--tx);box-shadow:0 0 0 3px rgba(8,8,8,.07);outline:none;}
.ea::placeholder{color:var(--mu2);font-style:italic;}
.dr{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--mu);background:var(--warm);border:1px solid var(--bd);border-radius:1px;padding:3px 9px;}

/* Notifications */
.notif{position:fixed;bottom:28px;right:28px;z-index:9999;padding:12px 18px 12px 16px;border-radius:2px;font-size:11px;font-weight:400;letter-spacing:.01em;background:#0a0a0a;color:#fff;box-shadow:0 8px 32px rgba(0,0,0,.2),0 1px 0 rgba(255,255,255,.04) inset;animation:notifSlide .28s cubic-bezier(.16,1,.3,1);max-width:380px;cursor:pointer;display:flex;align-items:center;gap:10px;border-left:3px solid rgba(255,255,255,.12);}
.notif.w{background:#300808;}.notif.ok{background:#082010;}.notif.pur{background:#1c0838;}

/* Section headers */
.sct{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--bd3);}
.scl{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:600;color:var(--mu);letter-spacing:.12em;text-transform:uppercase;}

/* Financial rows */
.fr{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--bd3);font-size:12px;}
.fr:last-child{border-bottom:none;}

/* Login screen */
.lsc{display:flex;height:100%;width:100%;}
.lll{width:240px;min-width:240px;background:var(--dark);display:flex;flex-direction:column;justify-content:center;padding:34px 28px;color:#ffffff;}
.lrt{flex:1;display:flex;align-items:center;justify-content:center;background:var(--warm);}

/* Print overlay */
#pov{position:absolute;inset:0;background:rgba(0,0,0,.7);z-index:100;display:none;align-items:center;justify-content:center;}
#pov.show{display:flex;}

/* ─────────────────────────────────────────────────── FINITIONS ── */
.fin-header{padding:14px 22px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--card);}
.fin-rooms-bar{display:flex;gap:6px;padding:10px 22px 9px;border-bottom:1px solid var(--bd);flex-wrap:wrap;background:var(--card);flex-shrink:0;align-items:center;}
.r-chip{padding:5px 14px;background:transparent;border:1px solid var(--bd);border-radius:2px;font-size:10px;font-weight:400;color:var(--mu);cursor:pointer;transition:border-color .12s,color .12s,background .12s;letter-spacing:.04em;}
.r-chip:hover{border-color:var(--bd2);color:var(--tx2);}
.r-chip.act{background:var(--tx);color:#fff;border-color:var(--tx);}
.fin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(228px,1fr));gap:8px;padding:14px 22px;overflow-y:auto;flex:1;}
.fin-card{background:var(--card);border:1px solid var(--bd);border-radius:1px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s;}
.fin-card:hover{border-color:var(--bd2);box-shadow:0 2px 8px rgba(0,0,0,.07);}
.fin-photo{height:80px;background:var(--warm);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.fin-body{padding:11px;flex:1;display:flex;flex-direction:column;gap:5px;}
.fin-lot-row{display:flex;justify-content:space-between;align-items:center;}
.fin-lot{font-size:9px;color:var(--mu);font-weight:500;letter-spacing:.12em;text-transform:uppercase;}
.fin-name{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:200;color:var(--tx);letter-spacing:.12em;text-transform:uppercase;line-height:1.35;}
.fin-ref{font-size:10px;color:var(--mu);font-style:italic;}
.fin-data{display:grid;grid-template-columns:1fr 1fr;gap:2px 8px;font-size:10px;color:var(--tx2);}
.fin-notes{font-size:10px;color:var(--mu);font-style:italic;background:var(--warm);padding:6px 8px;border-radius:0;line-height:1.55;}
.fin-cmts{display:flex;flex-direction:column;gap:3px;margin-top:3px;}
.fin-cmt{display:flex;gap:5px;font-size:10px;padding:4px 7px;border-radius:1px;}
.fin-cmt.client{background:#f5f5f5;border-left:1px solid #888888;}
.fin-cmt.arch{background:#f0f7f3;border-left:1px solid #6a9a78;}
.fin-cmt.dir{background:var(--bll);border-left:1px solid var(--bl);}
.fin-cmt-a{font-weight:600;color:var(--tx2);min-width:50px;font-size:9px;}
.fin-cmt-t{color:var(--tx2);flex:1;}
.fin-cmt-ts{font-size:9px;color:var(--mu2);}
.fin-actions{display:flex;gap:4px;margin-top:auto;padding-top:6px;border-top:1px solid var(--bd3);flex-wrap:wrap;}
.fin-cmt-inp{display:flex;gap:5px;margin-top:3px;}
.fin-cmt-inp input{flex:1;padding:5px 8px;border:1px solid var(--bd);border-radius:1px;font-size:10px;font-family:'DM Sans',sans-serif;color:var(--tx);}
.fin-cmt-inp input:focus{outline:none;border-color:var(--tx);}

/* Status badges */
.sbadge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:1px;font-size:9px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;}
.sbadge.pending{background:#f2f2f2;color:#505050;}
.sbadge.validated{background:var(--gnl);color:var(--gn);}
.sbadge.refused{background:var(--rdl);color:var(--rd);}
.sbadge.modified{background:var(--purl);color:var(--pur);}

/* ─────────────────────────────────────────── CLIENT VIEW ── */
.cli-sb{width:210px;min-width:210px;background:var(--dark);display:flex;flex-direction:column;height:100%;overflow:hidden;}
.cli-proj{padding:12px 12px 8px;border-bottom:1px solid rgba(255,255,255,.05);}
.cli-room{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;cursor:pointer;font-size:11px;color:#888888;border-left:1px solid transparent;transition:color .12s,background .12s;}
.cli-room:hover{color:#ffffff;background:rgba(255,255,255,.05);}
.cli-room.act{color:#ffffff;border-left-color:#ffffff;background:rgba(255,255,255,.06);}
.no-fin{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--mu);}

/* ─────────────────────────────────────── PROJECT DETAIL VIEW ── */
.pv-header{padding:14px 22px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--card);}
.pv-back{background:none;border:none;color:var(--mu);font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:4px;transition:color .12s;}
.pv-back:hover{color:var(--tx);}
.pv-title{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:100;color:var(--tx);letter-spacing:.3em;text-transform:uppercase;}
.pv-meta{font-size:10px;color:var(--mu);margin-top:2px;}
.fin-locked{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--mu);text-align:center;}

.av{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;flex-shrink:0;overflow:hidden;border:2px solid rgba(0,0,0,.06);}.av img{width:100%;height:100%;object-fit:cover;border-radius:50%;}.av-sm{width:22px;height:22px;font-size:9px;border-radius:50%;border:1.5px solid rgba(0,0,0,.06);}.av-lg{width:52px;height:52px;font-size:16px;border-radius:50%;border:2px solid rgba(0,0,0,.06);}.pb{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;padding:3px 7px;border-radius:0;letter-spacing:.08em;display:inline-block;}.mv{font-family:'DM Sans',sans-serif;font-size:26px;font-weight:100;letter-spacing:.02em;color:var(--tx);}.ml{font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--mu);margin-top:4px;}.mg{display:grid;gap:1px;margin-bottom:20px;background:var(--bd);}.mc{background:var(--card);padding:20px 20px 16px;position:relative;}.nbdg{background:#0a0a0a;color:#fff;font-size:9px;min-width:16px;height:16px;border-radius:0;padding:0 4px;display:inline-flex;align-items:center;justify-content:center;margin-left:6px;font-weight:600;font-family:'DM Sans',sans-serif;}.nbdg-pur{background:var(--pur);color:#fff;font-size:9px;min-width:16px;height:16px;border-radius:0;padding:0 4px;display:inline-flex;align-items:center;justify-content:center;margin-left:6px;font-weight:600;}
.cli-app{display:flex;flex-direction:column;height:100%;background:#fafafa;overflow:hidden;}.cli-topnav{display:flex;align-items:center;background:#0a0a0a;height:48px;padding:0 28px;flex-shrink:0;overflow-x:auto;}.cli-topnav-brand{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-right:20px;white-space:nowrap;flex-shrink:0;}.cli-topnav-proj{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:100;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-right:auto;white-space:nowrap;}.cli-nav-item{padding:0 14px;height:48px;display:flex;align-items:center;font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2px solid transparent;transition:all .12s;white-space:nowrap;flex-shrink:0;}.cli-nav-item:hover{color:rgba(255,255,255,.8);}.cli-nav-item.act{color:#fff;border-bottom-color:#fff;}.cli-main{flex:1;overflow-y:auto;scroll-behavior:smooth;}.cli-hero{position:relative;min-height:55vh;background:#0a0a0a;display:flex;align-items:flex-end;overflow:hidden;}.cli-hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0a0a0a 0%,#1a1a1a 60%,#0f0f0f 100%);}.cli-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:48px 48px;}.cli-hero-content{position:relative;z-index:2;padding:36px 48px;width:100%;}.cli-hero-label{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:10px;}.cli-hero-title{font-family:'DM Sans',sans-serif;font-size:clamp(26px,4vw,52px);font-weight:100;letter-spacing:.15em;text-transform:uppercase;color:#fff;line-height:1.1;margin-bottom:6px;}.cli-hero-client{font-size:11px;color:rgba(255,255,255,.45);letter-spacing:.06em;font-family:'DM Sans',sans-serif;}.cli-hero-stats{display:flex;gap:28px;margin-top:20px;flex-wrap:wrap;}.cli-hero-stat{border-left:1px solid rgba(255,255,255,.12);padding-left:14px;}.cli-hero-stat-val{font-family:'DM Sans',sans-serif;font-size:18px;font-weight:100;color:#fff;}.cli-hero-stat-lbl{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-top:3px;}.cli-phases{padding:32px 48px;background:#fff;border-bottom:1px solid #ececec;}.cli-phases-title{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.35em;text-transform:uppercase;color:#888;margin-bottom:22px;}.cli-timeline{display:flex;align-items:flex-start;gap:0;position:relative;}.cli-timeline::before{content:'';position:absolute;top:14px;left:0;right:0;height:1px;background:#e8e8e8;z-index:0;}.cli-phase-node{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;}.cli-phase-dot{width:28px;height:28px;border-radius:50%;border:2px solid #e0e0e0;background:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:7px;}.cli-phase-dot.done{background:#0a0a0a;border-color:#ffffff;}.cli-phase-dot.active{background:#fff;border-color:#0a0a0a;box-shadow:0 0 0 4px rgba(10,10,10,.07);}.cli-phase-code{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:500;letter-spacing:.08em;text-align:center;color:#0a0a0a;}.cli-phase-code.future{color:#bbb;}.cli-phase-name{font-family:'DM Sans',sans-serif;font-size:9px;text-align:center;color:#999;margin-top:3px;max-width:58px;line-height:1.3;}.cli-phase-name.active{color:#0a0a0a;font-weight:600;}.cli-rooms-section{padding:32px 48px;background:#fafafa;}.cli-section-header{display:flex;align-items:center;gap:16px;margin-bottom:22px;}.cli-section-title{font-family:'DM Sans',sans-serif;font-size:9px;font-weight:700;letter-spacing:.35em;text-transform:uppercase;color:#888;white-space:nowrap;}.cli-section-line{flex:1;height:1px;background:#e8e8e8;}.cli-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;background:#e8e8e8;}.cli-room-card{background:#fff;padding:22px;cursor:pointer;transition:background .15s;}.cli-room-card:hover,.cli-room-card.act{background:#0a0a0a;}.cli-room-card.act .cli-room-name,.cli-room-card.act .cli-room-surface,.cli-room-card.act .cli-room-status{color:rgba(255,255,255,.7);}.cli-room-card.act .cli-room-fill{background:#fff;}.cli-room-card.act .cli-room-progress{background:rgba(255,255,255,.12);}.cli-room-name{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:300;letter-spacing:.12em;text-transform:uppercase;color:#0a0a0a;margin-bottom:4px;}.cli-room-surface{font-size:9px;color:#888;font-family:'DM Sans',sans-serif;margin-bottom:11px;}.cli-room-progress{height:2px;background:#f0f0f0;margin-bottom:7px;}.cli-room-fill{height:100%;background:#0a0a0a;transition:width .4s;}.cli-room-status{font-size:9px;color:#888;font-family:'DM Sans',sans-serif;letter-spacing:.08em;}.cli-room-detail{padding:0 48px 48px;background:#fff;}.cli-room-detail-header{padding:28px 0 20px;border-bottom:1px solid #f0f0f0;margin-bottom:28px;display:flex;align-items:flex-end;justify-content:space-between;}.cli-room-detail-name{font-family:'DM Sans',sans-serif;font-size:clamp(20px,3vw,34px);font-weight:100;letter-spacing:.2em;text-transform:uppercase;color:#0a0a0a;}.cli-fin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1px;background:#f0f0f0;}.cli-fin-card{background:#fff;overflow:hidden;}.cli-fin-card:hover{box-shadow:0 3px 20px rgba(0,0,0,.07);}.cli-fin-photo{width:100%;height:170px;object-fit:cover;display:block;}.cli-fin-photo-placeholder{width:100%;height:130px;background:#f5f5f3;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #f0f0f0;}.cli-fin-body{padding:14px 16px;}.cli-fin-lot{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:#888;margin-bottom:5px;}.cli-fin-name{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;letter-spacing:.06em;color:#0a0a0a;margin-bottom:3px;}.cli-fin-type{font-size:10px;color:#888;margin-bottom:6px;}.cli-fin-meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;}.cli-fin-tag{font-family:'DM Sans',sans-serif;font-size:9px;padding:2px 7px;background:#f5f5f3;color:#666;letter-spacing:.05em;}.cli-fin-tag.ref{background:#0a0a0a;color:#fff;}.cli-fin-actions{display:flex;gap:1px;background:#f0f0f0;margin-top:10px;}.cli-fin-btn{flex:1;padding:9px 4px;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:all .12s;background:#fff;color:#aaa;}.cli-fin-btn:hover{background:#f5f5f3;color:#444;}.cli-fin-btn.active-approve{background:#0a0a0a;color:#fff;}.cli-fin-btn.active-revise{background:#fff8e8;color:#856404;}.cli-fin-status{padding:5px 10px;font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:.12em;text-transform:uppercase;text-align:center;margin-top:1px;}.cli-fin-status.validated{background:#f0f7f2;color:#1a5e35;}.cli-fin-status.pending{background:#fafafa;color:#aaa;}.cli-fin-status.refused{background:#fff8e8;color:#856404;}.cli-comment-area{padding:0 16px 12px;}.cli-comment-input{width:100%;border:1px solid #ebebea;padding:7px 9px;font-family:'DM Sans',sans-serif;font-size:10px;resize:none;background:#fafafa;outline:none;transition:border-color .15s;}.cli-comment-input:focus{border-color:#0a0a0a;background:#fff;}.cli-comment{padding:5px 0;border-top:1px solid #f5f5f3;}.cli-comment-author{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:#aaa;}.cli-comment-text{font-size:10px;color:#444;margin-top:2px;line-height:1.5;}.cli-content-section{padding:32px 48px;border-bottom:1px solid #f0f0f0;}.cli-progress-bar{height:2px;background:#f0f0f0;}.cli-progress-fill{height:100%;background:#0a0a0a;transition:width .6s ease;}.cli-page-break{page-break-after:always;}@media print{.cli-topnav,.cli-no-print{display:none!important;}.cli-main{overflow:visible!important;height:auto!important;}.cli-app{height:auto!important;overflow:visible!important;}@page{margin:15mm 18mm;size:A4 portrait;}}

@media print{.sb-no-print{display:none!important;}@page{size:A4 landscape;margin:0;}}

.cli-fin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1px;background:var(--bd3);}

/* ── Finitions — nouvelle UI intuitive ── */
.fin2-layout{display:flex;flex-direction:column;min-height:100%;}
.fin2-rooms{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;padding:16px 20px;background:#fff;border-bottom:1px solid var(--bd);flex-shrink:0;}
.fin2-room-card{position:relative;background:var(--card);border:1px solid var(--bd);border-radius:4px;padding:12px 10px 10px;cursor:pointer;transition:all .18s;text-align:center;min-height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;}
.fin2-room-card:hover{border-color:var(--bd2);background:var(--warm);transform:none;box-shadow:0 2px 8px rgba(0,0,0,.07);}
.fin2-room-sel{outline:2px solid var(--bl)!important;background:var(--bll)!important;}.fin2-room-card.act{border-color:var(--gold);background:#fffbf0;box-shadow:0 4px 20px rgba(212,175,55,.18);}
.fin2-room-card .fin2-room-icon{font-size:20px;line-height:1;margin-bottom:4px;}
.fin2-room-card .fin2-room-name{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;letter-spacing:0;text-transform:uppercase;color:var(--tx);line-height:1.2;}
.fin2-room-card .fin2-room-stats{font-size:9px;color:var(--mu);}
.fin2-room-card .fin2-room-cost{font-size:10px;font-weight:600;color:var(--gna);}
.fin2-add-room{border:1px dashed var(--bd2);border-radius:4px;padding:12px 10px;cursor:pointer;transition:all .15s;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:90px;color:var(--mu);}
.fin2-add-room:hover{border-color:var(--bd2);color:var(--tx2);background:var(--glt);}
.fin2-body{flex:1;display:flex;min-height:0;}
.fin2-lots{width:220px;flex-shrink:0;border-right:1px solid var(--bd);background:#fafafa;}
.fin2-lot-tile{margin:6px 8px;border-radius:4px;cursor:pointer;transition:all .12s;overflow:hidden;border:1px solid transparent;}
.fin2-lot-item{padding:7px 10px;border-bottom:1px solid var(--bd2);cursor:pointer;transition:background .1s;font-size:10px;color:var(--tx);}
.fin2-lot-tile:hover{transform:translateY(-1px);}
.fin2-lot-tile.act{border-color:var(--tx);background:var(--warm);}
.fin2-lot-inner{padding:11px 14px;display:flex;align-items:center;gap:9px;}
.fin2-lot-icon{font-size:20px;width:34px;text-align:center;flex-shrink:0;}
.fin2-lot-label{font-size:11px;font-weight:600;color:var(--tx);line-height:1.2;}
.fin2-lot-sub{font-size:9px;color:var(--mu);}
.fin2-lot-add{margin:6px 8px;border:1px dashed var(--bd);border-radius:4px;padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:7px;color:var(--mu);transition:all .12s;}
.fin2-lot-add:hover{border-color:var(--tx);color:var(--tx);background:var(--warm);}
.fin2-content{flex:1;background:#fff;}
.fin2-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--mu);padding:32px;}
.fin2-guide-step{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:var(--warm);border-radius:8px;border-left:3px solid var(--gold);}

/* ══ RESPONSIVE MOBILE ══════════════════════════════════════ */
@media (max-width: 768px){
  .sb-toggle{display:flex!important;}
  /* Layout principal */
  .sb{
    position:fixed;left:0;top:0;bottom:0;z-index:200;
    transform:translateX(-100%);transition:transform .25s ease;
    width:260px!important;min-width:260px!important;
  }
  .sb.open{transform:translateX(0);}
  .mn{width:100vw!important;padding-top:56px;}
  /* Overlay sidebar mobile */
  .sb-overlay{display:block!important;}
  /* Header barre */
  .tbr{padding:10px 14px 8px!important;flex-wrap:wrap;gap:8px;}
  .tbt{font-size:10px!important;}
  /* Contenu */
  .ct{padding:12px 14px!important;}
  /* Grilles */
  .g2,.g3,.g4{grid-template-columns:1fr!important;}
  /* Tables */

  /* Tabs */
  .tabrow{overflow-x:auto;flex-wrap:nowrap!important;-webkit-overflow-scrolling:touch;}
  .tabt{white-space:nowrap;padding:8px 10px!important;font-size:9px!important;}
  /* Modal */
  .modal{width:96vw!important;max-width:96vw!important;margin:2vh auto!important;max-height:94vh!important;}
  .mbd{padding:12px 14px!important;}
  /* DQE / Finitions */
  .fin2-wrap{flex-direction:column!important;}
  .fin2-lots{width:100%!important;border-right:none!important;border-bottom:1px solid var(--bd)!important;max-height:200px;}
  /* Boutons mobile */
  .bp,.bs,.ba{font-size:10px!important;padding:6px 10px!important;}
  /* KPI grids */
  [style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important;}
  [style*="grid-template-columns:repeat(3"]{grid-template-columns:repeat(2,1fr)!important;}
  /* Sidebar bouton toggle */
  .sb-toggle{display:flex!important;}
  /* Projets cards */
  .proj-card [style*="display:flex;gap:5px"]{flex-wrap:wrap!important;}
}
@media (max-width: 480px){
  .sb{width:100vw!important;min-width:100vw!important;}
  .ct{padding:8px 10px!important;}
  [style*="grid-template-columns:repeat(2"]{grid-template-columns:1fr!important;}
  .tbt{font-size:9px!important;letter-spacing:.1em!important;}
}
/* Overlay sidebar */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;}
/* Toggle sidebar button */
.sb-toggle{display:none;position:fixed;top:10px;left:10px;z-index:300;align-items:center;justify-content:center;width:40px;height:40px;background:var(--dark);border:1px solid rgba(255,255,255,.15);border-radius:6px;cursor:pointer;color:rgba(255,255,255,.85);box-shadow:0 2px 8px rgba(0,0,0,.3);transition:opacity .15s;}
html{scroll-behavior:smooth;}
*:focus-visible{outline:2px solid var(--bl);outline-offset:2px;}

.sc-ov{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:9500;display:flex;align-items:center;justify-content:center;animation:scfi .12s ease;}
@keyframes scfi{from{opacity:0}to{opacity:1}}
.sc-box{background:var(--card);border:1px solid var(--bd);border-radius:6px;padding:24px 26px;max-width:380px;width:calc(100% - 32px);box-shadow:0 20px 60px rgba(0,0,0,.2);animation:scup .14s ease;}
@keyframes scup{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.sc-title{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--tx);margin-bottom:8px;}
.sc-msg{font-size:12px;color:var(--mu);line-height:1.55;margin-bottom:20px;white-space:pre-line;}
.sc-row{display:flex;gap:8px;justify-content:flex-end;}
.sc-n{padding:7px 16px;background:transparent;color:var(--tx2);border:1px solid var(--bd2);border-radius:2px;font-size:11px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:border-color .12s,color .12s;}
.sc-n:hover{border-color:var(--tx);color:var(--tx);}
.sc-y{padding:7px 16px;color:#fff;border:none;border-radius:2px;font-size:11px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;transition:opacity .12s;}
.sc-y:hover{opacity:.83;}
.sc-y.d{background:var(--rd);} .sc-y.n{background:var(--tx);} .sc-y.g{background:var(--gna);}

/* ══ UI v136 ══════════════════════════════════════════════════════ */
body{background:#f0ede8;}
#ap{height:100vh;height:100dvh;margin:0;border:none;box-shadow:0 4px 24px rgba(0,0,0,.12);}
.sb{width:215px;min-width:215px;}
.sbh{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.07);}
.LE{font-weight:200;color:rgba(255,255,255,.9);letter-spacing:.42em;}
.rp{margin:10px 12px 0;padding:6px 10px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);font-size:9px;color:rgba(255,255,255,.5);letter-spacing:.06em;}
.nav-section{padding:16px 16px 5px;font-size:8px;font-weight:600;letter-spacing:.22em;color:rgba(255,255,255,.38);}
.ni{padding:10px 16px;font-size:11px;color:rgba(255,255,255,.68);transition:color .15s,background .12s,border-color .15s;white-space:nowrap;overflow:hidden;}
.ni:hover{color:#fff;background:rgba(255,255,255,.06);}
.ni.act{color:#fff;border-left-color:rgba(255,255,255,.75);background:rgba(255,255,255,.08);font-weight:500;}
.nbdg{background:rgba(255,255,255,.12);color:rgba(255,255,255,.6);border-radius:2px;font-size:8px;font-weight:700;padding:2px 6px;min-width:18px;text-align:center;margin-left:auto;}
.nbdg-pur{background:transparent;color:#b090e8;border:1px solid rgba(120,80,200,.4);border-radius:2px;font-size:8px;font-weight:700;padding:2px 6px;margin-left:auto;}
.sb-bot{padding:12px;border-top:1px solid rgba(255,255,255,.07);}
.sy{padding:6px 14px 2px;font-size:9px;color:rgba(255,255,255,.22);letter-spacing:.06em;}
.tbr{padding:14px 28px 13px;min-height:56px;}
.tbt{font-size:12px;font-weight:300;letter-spacing:.28em;}
.tbs{font-size:10px;color:var(--mu);letter-spacing:.03em;}
.tabrow{padding:0 24px;scrollbar-width:none;}
.tabrow::-webkit-scrollbar{display:none;}
.tabt{padding:12px 14px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;}
.tabt:hover{color:var(--tx);}
.tabt.act{color:var(--tx);border-bottom-color:var(--tx);font-weight:600;}
.bp{padding:8px 18px;font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;border-radius:1px;}
.bs{padding:8px 18px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;border-radius:1px;}
.ba{padding:8px 12px;font-size:9px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;border-radius:1px;transition:opacity .15s;}
.bprint{padding:8px 12px;font-size:9px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border-radius:1px;transition:opacity .15s;}
.bpur{padding:8px 12px;font-size:9px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border-radius:1px;transition:opacity .15s;}
.bprint:hover,.bpur:hover,.ba:hover{opacity:.82;}
.mc{padding:20px 18px 16px 20px;border-radius:1px;transition:border-left-color .2s,box-shadow .2s;}
.mc:hover{box-shadow:0 2px 12px rgba(0,0,0,.07);}
.mc.g:hover{box-shadow:0 2px 16px rgba(26,92,53,.12);}
.mc.b:hover{box-shadow:0 2px 16px rgba(26,58,108,.12);}
.mc.r:hover{box-shadow:0 2px 16px rgba(176,48,48,.10);}
.mc.p:hover{box-shadow:0 2px 16px rgba(74,42,122,.10);}
.mv{font-size:28px;font-weight:100;letter-spacing:-.02em;line-height:1;}
.ml{font-size:9px;font-weight:600;letter-spacing:.14em;margin-top:7px;}
.ms{font-size:9px;margin-top:4px;line-height:1.4;}
.tbl{margin-bottom:16px;}
.tr{padding:11px 16px;transition:background .1s;}
.tr.hd{font-size:9px;font-weight:600;letter-spacing:.14em;}
.fld label{font-size:9px;font-weight:600;letter-spacing:.16em;margin-bottom:7px;}
.inp,.sel,.txa{border-radius:1px;}
.pb{font-size:8px;font-weight:700;padding:3px 9px;letter-spacing:.1em;}
.sbadge{padding:3px 8px;font-size:8px;font-weight:700;letter-spacing:.1em;}
.sbadge.pending{background:var(--warm);color:var(--mu);}
.scl{font-size:9px;font-weight:700;letter-spacing:.16em;}
.proj-card:hover{border-color:var(--bd2);box-shadow:0 3px 14px rgba(0,0,0,.08);}
.proj-card-hd{padding:13px 16px;}
.pcard{border-left-width:3px;transition:box-shadow .15s;}
.pcard:hover{box-shadow:0 2px 10px rgba(0,0,0,.07);}
.pcard-hd{padding:13px 15px;gap:10px;}
.fcard:hover{border-color:var(--bd2);box-shadow:0 2px 12px rgba(0,0,0,.06);}
.fcard-hd{padding:12px 16px;}
.fcard-code{font-size:13px;font-weight:300;letter-spacing:.1em;}
.mlay{background:rgba(8,8,8,.48);backdrop-filter:blur(4px);}
.mbox{max-height:92%;width:660px;box-shadow:0 28px 72px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.07);}
.mhd{padding:15px 24px;}
.mtt{font-size:9px;font-weight:400;color:rgba(255,255,255,.85);letter-spacing:.3em;}
.mbd::-webkit-scrollbar{width:3px;}
.mbd::-webkit-scrollbar-thumb{background:rgba(0,0,0,.12);border-radius:2px;}
.sc-box{border-radius:2px;box-shadow:0 24px 64px rgba(0,0,0,.22),0 0 0 1px rgba(0,0,0,.04);}
.sc-title{font-size:11px;font-weight:500;letter-spacing:.1em;}
.notif{bottom:24px;right:24px;padding:13px 18px 13px 16px;max-width:400px;box-shadow:0 12px 40px rgba(0,0,0,.25);border-left:3px solid rgba(255,255,255,.15);}
.pbar{height:3px;}
.msg-col{background:#f6f6f6;border-left:2px solid rgba(8,8,8,.3);}
.fin-header{padding:12px 22px 11px;}
.fin-rooms-bar{gap:5px;padding:9px 22px 8px;scrollbar-width:none;overflow-x:auto;}
.fin-rooms-bar::-webkit-scrollbar{display:none;}
.fin-name{font-weight:300;letter-spacing:.08em;line-height:1.4;}
.r-chip{padding:6px 14px;border-radius:1px;letter-spacing:.05em;}
.r-chip.act{font-weight:500;}
.slip-hd{padding:14px 18px;}
.dr{font-size:9px;padding:3px 8px;letter-spacing:.02em;display:inline-flex;}
.pv-title{font-size:12px;font-weight:300;letter-spacing:.28em;}
.fin2-room-card .fin2-room-name{font-size:10px;letter-spacing:.04em;}
.cli-nav-item{padding:0 16px;letter-spacing:.12em;transition:all .15s;}
.cli-hero-title{font-size:clamp(24px,3.5vw,48px);letter-spacing:.18em;}
::-webkit-scrollbar{width:3px;height:3px;}
::-webkit-scrollbar-thumb{background:rgba(0,0,0,.15);border-radius:2px;}
@keyframes fadeInUp{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:translateY(0);}}
.proj-card,.fcard{animation:fadeInUp .18s ease both;}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 32px;text-align:center;color:var(--mu);gap:10px;}
.empty-state-icon{font-size:32px;opacity:.35;margin-bottom:4px;}
.empty-state-title{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--mu);}
.empty-state-sub{font-size:10px;color:var(--mu2);max-width:280px;line-height:1.6;}
[data-theme=dark] .mc:hover{box-shadow:0 2px 12px rgba(0,0,0,.4);}
[data-theme=dark] .proj-card:hover{box-shadow:0 3px 14px rgba(0,0,0,.3);}
[data-theme=dark] .mlay{background:rgba(0,0,0,.7);}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}
input[type=number]{-moz-appearance:textfield;}
*:focus-visible{outline:2px solid var(--bl);outline-offset:2px;}
/* ── Login page mobile ───────────────────────────────────── */
@media (max-width: 600px){
  /* Masquer le left sidebar de login sur mobile */
  #login-left{display:none!important;}
  #login-right{width:100vw!important;min-height:100dvh!important;min-height:100vh!important;}
}
/* ── Mobile responsive amélioré ─────────────────────────────── */
@media (max-width: 768px){
  #ap{border-radius:0!important;border:none!important;box-shadow:none!important;height:100dvh!important;height:100vh!important;}
  .mbox{width:96vw!important;max-width:96vw!important;max-height:90dvh!important;max-height:90vh!important;}
  .tbr{padding:10px 14px 8px 60px!important;}
  .proj-card,.pcard,.fcard{animation:none;}
  .g2{gap:10px!important;}
  .mv{font-size:22px!important;}
  .fld label{font-size:8px!important;}
  .scl{font-size:8px!important;}
}
@media (max-width: 480px){
  .tbr{padding:8px 10px 8px 56px!important;}
  .tbt{letter-spacing:.12em!important;}
  .mbox{width:100vw!important;max-width:100vw!important;border-radius:0!important;max-height:100dvh!important;max-height:100vh!important;}
  .ct{padding:8px!important;}
}
/* ══ WIZARD PANEL (PV & RV) ════════════════════════════════════
   Overlay pleine page sur desktop, bottom-sheet sur mobile
═══════════════════════════════════════════════════════════════*/
.wiz-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:400;display:flex;align-items:center;justify-content:center;animation:wiz-fade-in .18s ease;}
.wiz-panel{position:relative;background:var(--card);width:100%;max-width:720px;max-height:92vh;overflow-y:auto;border-radius:3px;box-shadow:0 8px 32px rgba(0,0,0,.18);display:flex;flex-direction:column;animation:wiz-slide-up .22s cubic-bezier(.16,1,.3,1);}.wiz-panel.no-anim{animation:none;}
.wiz-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 13px;border-bottom:1px solid var(--bd);flex-shrink:0;background:var(--warm);position:sticky;top:0;z-index:2;}
.wiz-panel-title{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:300;letter-spacing:.3em;text-transform:uppercase;color:var(--tx);}
.wiz-panel-sub{font-family:'DM Sans',sans-serif;font-size:9px;color:var(--mu);margin-top:2px;letter-spacing:.04em;}
.wiz-panel-close{background:none;border:none;cursor:pointer;color:var(--mu);font-size:22px;line-height:1;padding:0 4px;transition:color .1s;}
.wiz-panel-close:hover{color:var(--tx);}
.wiz-panel-body{flex:1;padding:20px;}
.wiz-panel-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--bd);flex-shrink:0;background:var(--card);position:sticky;bottom:0;z-index:2;}
@keyframes wiz-fade-in{from{opacity:0}to{opacity:1}}
@keyframes wiz-slide-up{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}
@media(max-width:640px){
  .wiz-backdrop{align-items:flex-end;}
  .wiz-panel{max-width:100%;max-height:92vh;border-radius:12px 12px 0 0;animation:wiz-mobile-up .25s cubic-bezier(.16,1,.3,1);}
  .wiz-panel-body{padding:14px;}
}
@keyframes wiz-mobile-up{from{transform:translateY(100%)}to{transform:translateY(0)}}

/* ═══════════════════════════════════════════════════════
   MOBILE RESPONSIVE — ajouts uniquement, rien n'est cassé
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px){

  /* ── DQE table — scroll horizontal natif ── */
  [data-dqe-lot]{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  [data-row]{min-width:580px;}

  /* ── DQE toolbar — scroll horizontal ── */
  .dqe-toolbar-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
  .dqe-toolbar-wrap::-webkit-scrollbar{display:none;}

  /* ── Lots zone DQE — scroll horizontal chips ── */
  [data-dqe-lots]{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;padding-bottom:4px;}

  /* ── CCTP page — sidebar collapse en mobile ── */
  .cctp-sidebar{display:none!important;}
  .cctp-preview{flex:1!important;}

  /* ── Tabs DQE — scroll ── */
  [data-dqe-tabs]{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap!important;scrollbar-width:none;}
  [data-dqe-tabs]::-webkit-scrollbar{display:none;}

  /* ── Wizard PV/RV — footer boutons wrap ── */
  .wiz-panel-footer{flex-wrap:wrap;gap:6px;}
  .wiz-panel-footer > div{flex-wrap:wrap;gap:6px;}

  /* ── Modaux — plein écran sur petit mobile ── */
  .modal{width:100vw!important;max-width:100vw!important;margin:0!important;max-height:100vh!important;border-radius:0!important;}

  /* ── Portail prestataire/fournisseur — KPI grids ── */
  [style*="grid-template-columns:repeat(auto-fill,minmax(110"]{grid-template-columns:repeat(2,1fr)!important;}

  /* ── Listes OS/PV/RV — colonnes réduites ── */
  .tbl [style*="grid-template-columns:70px"]{min-width:480px;}
  .tbl [style*="grid-template-columns:60px"]{min-width:420px;}

  /* ── Boutons actions projet — wrap ── */
  .proj-card [style*="display:flex;align-items:center;gap:8"]{flex-wrap:wrap!important;}

  /* ── Champs formulaire — 100% width ── */
  .g2 .fld,.g3 .fld{min-width:0;}

  /* ── Section title (sct) ── */
  .sct{flex-wrap:wrap;gap:8px;}

  /* ── Header wizard CCTP sidebar lot — masquer sur mobile ── */
  [data-cctp-sidebar]{width:100%!important;border-right:none!important;border-bottom:1px solid var(--bd)!important;max-height:120px;overflow-x:auto;overflow-y:hidden;display:flex!important;flex-direction:row!important;flex-wrap:nowrap;}
  [data-cctp-sidebar] > div{flex-shrink:0;min-width:100px;}

  /* ── Page CCTP — layout colonne sur mobile ── */
  [data-cctp-page]{flex-direction:column!important;}

  /* ── Recap DQE — tableau scroll ── */
  [data-dqe-recap]{overflow-x:auto;}
  [data-dqe-recap] table{min-width:500px;}
}

@media (max-width: 480px){
  /* ── Toolbar DQE — icônes seulement, texte masqué ── */
  .dqe-tool-label{display:none!important;}

  /* ── Actions PV wizard step4 — empiler ── */
  [data-pv-action-row]{flex-wrap:wrap!important;gap:4px!important;}
  [data-pv-action-row] .inp{flex:1 1 100%!important;}

  /* ── Checklist RV — boutons statuts compacts ── */
  [data-check-statuts]{gap:2px!important;}
  [data-check-statuts] button{padding:1px 4px!important;font-size:8px!important;}

  /* ── Cover page du document CCTP/DQE — padding réduit ── */
  .cover{padding:32px 24px!important;}

  /* ── Modal body padding ── */
  .mbd{padding:10px 12px!important;}

  /* ── Formulaires — labels plus petits ── */
  .fld label{font-size:9px!important;}
  .inp,.txa,.sel{font-size:11px!important;} /* 11px minimum sur iOS pour pas de zoom */
}

/* ═══════════════════════════════════════════════════════
   MOBILE TERRAIN — checklist, photos, accordéons
   ═══════════════════════════════════════════════════════ */
@media (max-width: 768px){

  /* ── Boutons checklist RV — zones tactiles agrandies ── */
  [data-check-statuts] button,
  [data-rv-check] button {
    padding:6px 12px!important;
    font-size:10px!important;
    min-height:36px!important;
    min-width:44px!important;
  }

  /* ── Headers accordéon lots RV — plus hauts pour le doigt ── */
  [data-rv-lot-header] {
    min-height:52px!important;
    padding:12px 14px!important;
  }

  /* ── Bouton ajouter photo — plus grand ── */
  [data-photo-add] label,
  label[data-photo-btn] {
    padding:10px 16px!important;
    font-size:11px!important;
    min-height:44px!important;
  }

  /* ── Boutons statut présence PV — tactiles ── */
  [data-presence-btns] button {
    padding:6px 12px!important;
    font-size:10px!important;
    min-height:36px!important;
  }

  /* ── Actions entreprises RV — empiler sur mobile ── */
  [data-ent-actions] {
    flex-direction:column!important;
    gap:6px!important;
  }

  /* ── Bouton OS sur actions PV — visible ── */
  [data-pv-os-btn] {
    min-height:36px!important;
    padding:6px 10px!important;
  }

  /* ── Grille photos RV/PV — 1 colonne sur mobile ── */
  [data-photo-grid] {
    grid-template-columns:1fr!important;
  }

  /* ── Inputs texte RV/PV — taille lecture confortable ── */
  [data-rv-obs], [data-rv-act],
  textarea.txa {
    font-size:14px!important;
    min-height:56px!important;
  }

  /* ── Stepper wizard — compact ── */
  .wiz-panel-header {
    padding:10px 14px!important;
  }
  .wiz-panel-header .wiz-panel-title {
    font-size:12px!important;
  }

  /* ── Indicateur autosave — bien visible ── */
  #wiz-autosave-ts {
    font-size:10px!important;
    padding:3px 8px!important;
    background:var(--gnl)!important;
    border-radius:2px!important;
    color:var(--gna)!important;
  }
}

@media (max-width: 480px){
  /* ── Checklist — pleine largeur ── */
  [data-check-statuts] {
    width:100%!important;
    justify-content:space-between!important;
  }
  [data-check-statuts] button {
    flex:1!important;
  }

  /* ── Accordéon lot nom — taille lisible ── */
  [data-rv-lot-header] [data-lot-nom] {
    font-size:12px!important;
    font-weight:700!important;
  }

  /* ── Wizard stepper labels — masquer sur très petit ── */
  .wiz-panel-header [data-step-label] {
    display:none!important;
  }

  /* ── Photo grid — pleine largeur ── */
  [data-photo-grid] img {
    height:180px!important;
    object-fit:cover!important;
  }
}
