*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F0F3F6;--panel:#FFFFFF;--card:#F7F9FB;--sb:#0F1219;--sb2:#181D28;
  --lum-blue:#6FA8C8;--lum-blue2:#4A82A0;--lum-blue3:#2A5870;
  --lum-blue-light:rgba(111,168,200,0.12);--lum-blue-mid:rgba(111,168,200,0.25);
  --ink:#1A1F2C;--mid:#6B7A8D;--soft:#A8B4C0;
  --border:rgba(111,168,200,0.18);--border2:rgba(111,168,200,0.32);
  --green:#27C97A;--green2:rgba(39,201,122,0.1);
  --amber:#E8A020;--amber2:rgba(232,160,32,0.1);
  --red:#E05858;--red2:rgba(224,88,88,0.1);
  --purple:#8A72F0;
  --f:'Barlow',sans-serif;--fc:'Barlow Condensed',sans-serif;--fp:'Playfair Display',serif;
}
/* ===== DARK MODE ===== */
html[data-theme="dark"]{
  --bg:#0E1117;--panel:#161B26;--card:#1C2333;
  --ink:#DDE3EE;--mid:#7A8699;--soft:#3E4A5C;
  --border:rgba(111,168,200,0.12);--border2:rgba(111,168,200,0.22);
  --lum-blue-light:rgba(111,168,200,0.09);--lum-blue-mid:rgba(111,168,200,0.18);
  --green2:rgba(39,201,122,0.09);--amber2:rgba(232,160,32,0.09);--red2:rgba(224,88,88,0.09);
}
/* Éléments de base */
html[data-theme="dark"] body{background:var(--bg);color:var(--ink);}
html[data-theme="dark"] .tb{background:var(--panel);border-color:var(--border);}
html[data-theme="dark"] .main{background:var(--bg);}
html[data-theme="dark"] .card{background:var(--panel);border-color:var(--border);}
html[data-theme="dark"] .kpi{background:var(--panel);}
html[data-theme="dark"] .lrow{background:var(--panel);}
html[data-theme="dark"] .llist{background:var(--border);}
/* Formulaires */
html[data-theme="dark"] input:not([type="range"]),
html[data-theme="dark"] textarea,
html[data-theme="dark"] select{background:var(--card)!important;color:var(--ink)!important;border-color:var(--border)!important;}
html[data-theme="dark"] .finp,html[data-theme="dark"] .oi,html[data-theme="dark"] .ci,html[data-theme="dark"] .ji,html[data-theme="dark"] .login-input{background:var(--card)!important;color:var(--ink)!important;border-color:var(--border)!important;}
/* Boutons ghost */
html[data-theme="dark"] .btn-ghost{background:var(--card);color:var(--mid);border-color:var(--border);}
html[data-theme="dark"] .btn-ghost:hover{color:var(--ink);}
/* Modals et overlays */
html[data-theme="dark"] .modal-content{background:var(--panel);border-color:var(--border);}
html[data-theme="dark"] .modal-overlay,.html[data-theme="dark"] #modal-overlay{background:rgba(0,0,0,0.75)!important;}
/* Rows et listes */
html[data-theme="dark"] .devis-row,html[data-theme="dark"] .ftrow{background:var(--panel);}
html[data-theme="dark"] .client-tab-pane{background:var(--bg);}
html[data-theme="dark"] .client-tab{background:var(--card);color:var(--mid);border-color:var(--border);}
html[data-theme="dark"] .client-tab.on{background:var(--panel);color:var(--ink);}
/* Chat */
html[data-theme="dark"] .bub{background:var(--card);color:var(--ink);}
html[data-theme="dark"] .msg.u .bub{background:var(--lum-blue);color:#fff;}
html[data-theme="dark"] .chat-list{background:var(--panel);}
/* Notif dropdown */
html[data-theme="dark"] #notif-dropdown{background:var(--panel);border-color:var(--border);}
/* User chip */
html[data-theme="dark"] .user-chip{background:var(--card);border-color:var(--border);}
html[data-theme="dark"] .un{color:var(--ink);}
/* Plan pill */
html[data-theme="dark"] .plan-pill{background:var(--lum-blue-light);}
/* Topbar logo */
html[data-theme="dark"] .iv-main{color:var(--ink);}
/* Score bar background */
html[data-theme="dark"] .st{background:var(--card);}
/* Formations cards */
html[data-theme="dark"] .fc{background:var(--panel);border-color:var(--border);}
/* Table rows */
html[data-theme="dark"] tr{background:var(--panel);}
html[data-theme="dark"] th{background:var(--card);color:var(--mid);}
html[data-theme="dark"] td{border-color:var(--border);}

html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--ink);font-family:var(--f);font-size:13px;}

/* LOGIN */
.login-overlay{position:fixed;inset:0;background:linear-gradient(135deg,#0B0E14 0%,#131825 50%,#0F1219 100%);z-index:2000;display:flex;align-items:center;justify-content:center;}
.login-overlay.hidden{display:none;}
.login-box{background:var(--panel);width:420px;max-width:92%;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.4);}
.login-hd{background:linear-gradient(135deg,#0F1219 0%,#161B26 100%);padding:2.5rem 2rem 2rem;text-align:center;border-bottom:2px solid rgba(111,168,200,0.25);position:relative;}
.login-hd::before{content:'';position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;border:1px solid rgba(111,168,200,0.08);}
.login-hd::after{content:'';position:absolute;bottom:-30px;left:-30px;width:80px;height:80px;border-radius:50%;border:1px solid rgba(111,168,200,0.06);}
.login-logo{font-family:var(--fp);font-size:1.5rem;font-weight:700;color:#fff;letter-spacing:2px;}
.login-logo-img{width:90px;height:auto;margin-bottom:12px;display:block;margin-left:auto;margin-right:auto;}
.login-logo-light{display:none !important;}
.login-logo-dark{display:block !important;}
.login-sub{font-family:var(--fc);font-size:0.55rem;font-weight:600;color:var(--lum-blue);letter-spacing:4px;text-transform:uppercase;margin-top:6px;opacity:0.8;}
.login-body{padding:1.8rem 1.5rem;}
.login-field{margin-bottom:1.1rem;}
.login-label{font-family:var(--fc);font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--soft);margin-bottom:6px;}
.login-input{width:100%;background:var(--card);border:1px solid var(--border);color:var(--ink);padding:0.65rem 0.9rem;font-size:12px;font-family:var(--f);outline:none;border-radius:6px;transition:border-color 0.2s;}
.login-input:focus{border-color:var(--lum-blue);box-shadow:0 0 0 3px rgba(111,168,200,0.1);}
.login-btn{width:100%;padding:0.7rem;background:var(--lum-blue);color:#fff;border:none;font-family:var(--fc);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:6px;transition:all 0.2s;}
.login-btn:hover{background:var(--lum-blue2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(111,168,200,0.3);}
.login-roles{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:1rem;}
.login-role{padding:0.6rem;background:var(--card);border:1px solid var(--border);cursor:pointer;text-align:center;transition:all 0.15s;}
.login-role:hover{border-color:var(--lum-blue);background:var(--lum-blue-light);}
.login-role-icon{font-size:1.2rem;margin-bottom:4px;}
.login-role-name{font-family:var(--fc);font-size:10px;font-weight:700;color:var(--ink);}
.login-role-desc{font-size:8px;color:var(--mid);margin-top:2px;}
.login-demo{font-size:9px;color:var(--soft);text-align:center;margin-top:0.8rem;}

/* TOPBAR */
.tb{height:52px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1.2rem;flex-shrink:0;position:relative;overflow:hidden;}
.tb::after{content:'';position:absolute;bottom:0;left:0;width:100%;height:2px;background:linear-gradient(to right,var(--lum-blue),transparent 60%);}
.iv-logo{display:flex;align-items:center;gap:10px;cursor:pointer;}
.iv-sym{width:36px;height:22px;}
.tb-logo-img{height:28px;width:auto;object-fit:contain;flex-shrink:0;display:block;}
.tb-logo-dark{display:none;}
[data-theme="dark"] .tb-logo-dark{display:inline;}
[data-theme="dark"] .tb-logo-light{display:none;}
.iv-wordmark{display:flex;flex-direction:column;}
.iv-main{font-family:var(--fp);font-size:0.88rem;font-weight:700;color:var(--ink);letter-spacing:1.5px;line-height:1;}
.iv-sub{font-family:var(--fc);font-size:0.52rem;font-weight:600;color:var(--lum-blue2);letter-spacing:3px;text-transform:uppercase;}
.tb-crumb{display:flex;align-items:center;gap:6px;font-family:var(--fc);font-size:0.62rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--soft);}
.tb-crumb span{color:var(--lum-blue2);}
.tb-modes{display:flex;gap:1px;background:var(--bg);padding:2px;border:1px solid var(--border);}
.tm{padding:0.3rem 0.9rem;font-family:var(--fc);font-size:0.6rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border:none;background:transparent;color:var(--mid);transition:all 0.15s;}
.tm.on{background:var(--sb);color:#fff;}
.tb-r{display:flex;align-items:center;gap:8px;}
.plan-pill{font-family:var(--fc);font-size:0.58rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:3px 8px;background:var(--lum-blue-light);color:var(--lum-blue2);border:1px solid var(--lum-blue-mid);}
.notif-btn{width:28px;height:28px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;font-size:11px;}
.nb{position:absolute;top:5px;right:6px;width:5px;height:5px;background:var(--lum-blue);border-radius:50%;}
.user-chip{display:flex;align-items:center;gap:6px;background:var(--card);border:1px solid var(--border);padding:3px 8px 3px 4px;cursor:pointer;}
.ua{width:22px;height:22px;border-radius:50%;background:var(--sb);display:flex;align-items:center;justify-content:center;font-family:var(--fc);font-size:8px;font-weight:700;color:#fff;}
.un{font-family:var(--fc);font-size:9px;font-weight:600;color:var(--ink);}
.logout-btn{background:transparent;border:1px solid var(--border);color:var(--mid);font-size:9px;padding:3px 8px;cursor:pointer;font-family:var(--fc);font-weight:600;}
.logout-btn:hover{color:var(--red);border-color:var(--red);}

/* LAYOUT */
.wrap{display:flex;flex-direction:column;height:100vh;}
.body{display:grid;grid-template-columns:196px 1fr;flex:1;overflow:hidden;}

/* SIDEBAR */
.sb-rail{background:var(--sb);display:flex;flex-direction:column;overflow-y:auto;position:relative;}
.sb-section{font-family:var(--fc);font-size:0.58rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.22);padding:0.8rem 1rem 0.2rem;}
.sb-item{display:flex;align-items:center;gap:8px;padding:0.42rem 1rem;cursor:pointer;color:rgba(255,255,255,0.45);font-size:11px;border-left:2px solid transparent;transition:all 0.12s;}
.sb-item:hover{background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.75);}
.sb-item.on{background:var(--lum-blue-light);color:#fff;border-left-color:var(--lum-blue);}
.sb-item svg{width:12px;height:12px;opacity:0.5;flex-shrink:0;}
.sb-item.on svg{opacity:1;}
.sb-badge{margin-left:auto;font-size:8px;padding:1px 5px;font-weight:700;border-radius:2px;}
.bb{background:var(--lum-blue);color:#fff;}
.bg{background:var(--green);color:#fff;}
.ba{background:var(--amber);color:#fff;}
.br{background:var(--red);color:#fff;}
.bp{background:var(--purple);color:#fff;}
.sb-user{padding:0.8rem 1rem;border-top:1px solid rgba(255,255,255,0.08);display:flex;align-items:center;gap:8px;margin-top:auto;}
.sb-av{width:30px;height:30px;border-radius:50%;background:var(--lum-blue);display:flex;align-items:center;justify-content:center;font-family:var(--fc);font-size:9px;font-weight:700;color:#fff;flex-shrink:0;}
.sb-uname{font-family:var(--fc);font-size:10px;font-weight:700;color:#fff;}
.sb-urole{font-size:8.5px;color:rgba(255,255,255,0.35);}

/* MAIN */
.main{overflow-y:auto;padding:1.2rem;background:var(--bg);display:flex;flex-direction:column;gap:1rem;}
.view{display:none;}.view.on{display:flex;flex-direction:column;gap:1rem;}
#a-newsletter.on{height:100%;}

/* PRIMITIVES */
.ph{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;}
.ph-tag{font-family:var(--fc);font-size:0.58rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--lum-blue2);margin-bottom:3px;}
.ph-h{font-family:var(--fp);font-size:1.35rem;font-weight:700;color:var(--ink);line-height:1.1;}
.ph-s{font-size:10px;color:var(--mid);margin-top:3px;}
.ph-r{display:flex;gap:6px;align-items:flex-start;flex-shrink:0;}
.btn{padding:0.35rem 0.9rem;font-size:10px;font-weight:600;cursor:pointer;border:none;font-family:var(--fc);letter-spacing:0.5px;text-transform:uppercase;transition:all 0.15s;}
.btn-primary{background:var(--lum-blue);color:#fff;}.btn-primary:hover{background:var(--lum-blue2);}
.btn-dark{background:var(--sb);color:#fff;}.btn-dark:hover{background:var(--sb2);}
.btn-ghost{background:var(--panel);color:var(--mid);border:1px solid var(--border);}.btn-ghost:hover{color:var(--ink);}
.grid2{display:grid;grid-template-columns:1.5fr 1fr;gap:1rem;}
.grid22{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;}

/* KPI */
.krow{display:grid;gap:1px;background:var(--border);}
.k4{grid-template-columns:repeat(4,1fr);}.k5{grid-template-columns:repeat(5,1fr);}
.kpi{background:var(--panel);padding:0.85rem 1rem;position:relative;overflow:hidden;}
.kpi-deco{position:absolute;bottom:-12px;right:-12px;width:44px;height:44px;border-radius:50%;border:1.5px solid var(--border);pointer-events:none;}
.kpi-l{font-family:var(--fc);font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--soft);margin-bottom:4px;}
.kpi-v{font-family:var(--fp);font-size:1.25rem;font-weight:700;color:var(--ink);line-height:1;}
.kpi-d{font-size:9px;margin-top:3px;}.ku{color:var(--green);}.kd{color:var(--red);}

/* CARD */
.card{background:var(--panel);border:1px solid var(--border);padding:1rem;position:relative;overflow:hidden;}
.card-deco{position:absolute;top:-16px;right:-16px;width:52px;height:52px;border-radius:50%;background:var(--lum-blue-light);pointer-events:none;}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:0.7rem;}
.ct{font-family:var(--fc);font-size:10.5px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;color:var(--ink);}
.ca{font-size:9px;color:var(--lum-blue2);cursor:pointer;font-family:var(--fc);font-weight:600;letter-spacing:0.5px;text-transform:uppercase;}

/* Score ring */
.rw{position:relative;width:86px;height:86px;margin:0 auto 0.6rem;}.rw svg{width:100%;height:100%;}
.rc{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.rn{font-family:var(--fp);font-size:1.3rem;font-weight:700;line-height:1;}
.rl{font-size:7px;color:var(--soft);letter-spacing:1px;text-transform:uppercase;}
.sdim{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
.sl{font-size:9px;color:var(--mid);min-width:76px;font-weight:500;}
.st{flex:1;height:4px;background:var(--card);border-radius:2px;}.sf{height:100%;border-radius:2px;}
.sv{font-size:9px;font-weight:600;color:var(--ink);min-width:26px;text-align:right;}

/* Pills */
.pill{font-family:var(--fc);font-size:8px;padding:2px 7px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;}
.p-green{background:var(--green2);color:var(--green);border:1px solid rgba(39,201,122,0.2);}
.p-amber{background:var(--amber2);color:var(--amber);border:1px solid rgba(232,160,32,0.2);}
.p-blue{background:var(--lum-blue-light);color:var(--lum-blue2);border:1px solid var(--lum-blue-mid);}
.p-red{background:var(--red2);color:var(--red);border:1px solid rgba(224,88,88,0.2);}
.p-dark{background:var(--sb);color:#fff;}
.p-gray{background:rgba(136,136,136,0.1);color:#888;border:1px solid rgba(136,136,136,0.2);}
/* Plan badges in client list */
.plan-badge-lancement{background:var(--lum-blue-light);color:var(--lum-blue2);border:1px solid var(--lum-blue-mid);}
.plan-badge-acceleration{background:rgba(138,114,240,0.1);color:var(--purple);border:1px solid rgba(138,114,240,0.2);}
.plan-badge-domination{background:var(--amber2);color:var(--amber);border:1px solid rgba(232,160,32,0.2);}
/* Locked sidebar items */
.sb-locked{opacity:0.45;cursor:pointer !important;}
.sb-locked::after{content:'🔒';font-size:8px;margin-left:auto;opacity:0.7;}

/* LIST */
.llist{display:flex;flex-direction:column;gap:1px;background:var(--border);}
.lrow{background:var(--panel);padding:0.6rem 0.9rem;display:grid;align-items:center;gap:8px;cursor:pointer;transition:background 0.1s;}
.lrow:hover{background:var(--lum-blue-light);}
.lav{width:27px;height:27px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;}
.lname{font-size:11px;font-weight:500;color:var(--ink);}.lsub{font-size:10px;color:var(--mid);}
.lscore{font-family:var(--fp);font-size:11px;font-weight:700;}

/* KANBAN */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);}
.kcol{background:var(--panel);padding:0.75rem;}
.kcol-h{font-family:var(--fc);font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--soft);margin-bottom:0.6rem;padding-bottom:0.4rem;border-bottom:2px solid var(--bg);}
.kcard{background:var(--bg);padding:0.6rem;border-left:3px solid transparent;cursor:pointer;margin-bottom:4px;transition:all 0.1s;}
.kcard:hover{background:var(--lum-blue-light);}
.kcard.hot{border-left-color:var(--green);}.kcard.warm{border-left-color:var(--amber);}.kcard.cold{border-left-color:var(--lum-blue);}.kcard.done{border-left-color:var(--green);opacity:0.7;}
.kc-name{font-size:10px;font-weight:600;color:var(--ink);margin-bottom:1px;}.kc-sub{font-size:9px;color:var(--mid);}.kc-val{font-family:var(--fp);font-size:11px;font-weight:700;color:var(--lum-blue2);margin-top:3px;}.kc-notes{font-size:8px;color:var(--mid);margin-top:2px;font-style:italic;line-height:1.3;}.kcol.drag-over{background:var(--lum-blue-light);outline:2px dashed var(--lum-blue);}
.kcard[draggable="true"]{cursor:grab;}.kcard[draggable="true"]:active{cursor:grabbing;}
.file-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--card);border:1px solid var(--border);margin-bottom:1px;transition:background 0.1s;}
.file-item:hover{background:var(--lum-blue-light);}
.file-icon{font-size:1.2rem;flex-shrink:0;width:26px;text-align:center;}
.file-meta{flex:1;min-width:0;}
.file-name{font-size:10px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.file-sub{font-size:8px;color:var(--soft);margin-top:1px;}
.devis-row{display:grid;grid-template-columns:1fr auto auto auto;gap:8px;align-items:center;padding:8px 12px;background:var(--card);border:1px solid var(--border);margin-bottom:1px;}
.pipe-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin-bottom:8px;}
.pipe-stat{background:var(--panel);padding:10px 12px;text-align:center;}
.pipe-stat-v{font-family:var(--fp);font-size:1.1rem;font-weight:700;color:var(--ink);}
.pipe-stat-l{font-family:var(--fc);font-size:7px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--soft);margin-bottom:2px;}

/* AI CHAT */
.ai-wrap{display:flex;flex-direction:column;min-height:350px;}
.ai-hd{background:var(--sb);padding:0.8rem;display:flex;align-items:center;gap:10px;}
.ai-icon{width:32px;height:32px;background:var(--lum-blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;}
.ai-nm{font-family:var(--fc);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#fff;}
.ai-st{font-size:9px;color:var(--lum-blue);}
.ai-msgs{flex:1;max-height:240px;overflow-y:auto;background:var(--panel);border:1px solid var(--border);border-top:none;border-bottom:none;padding:0.8rem;display:flex;flex-direction:column;gap:8px;}
.msg{display:flex;gap:7px;}.msg.u{flex-direction:row-reverse;}
.bub{background:var(--card);padding:0.55rem 0.8rem;font-size:10px;color:var(--ink);line-height:1.65;max-width:88%;border:1px solid var(--border);}
.msg.u .bub{background:var(--lum-blue);color:#fff;border-color:transparent;}
.msm{width:22px;height:22px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;background:var(--lum-blue-light);margin-top:2px;}
.ai-qs{display:flex;flex-wrap:wrap;gap:4px;padding:0.6rem;background:var(--card);border:1px solid var(--border);border-bottom:none;}
.aq{padding:3px 8px;font-size:9px;background:var(--panel);border:1px solid var(--border);color:var(--mid);cursor:pointer;font-family:var(--fc);font-weight:600;transition:all 0.1s;}
.aq:hover{background:var(--lum-blue);color:#fff;border-color:var(--lum-blue);}
.ai-irow{display:flex;background:var(--panel);border:1px solid var(--border);}
.ai-inp{flex:1;background:transparent;border:none;color:var(--ink);padding:0.5rem 0.7rem;font-size:11px;font-family:var(--f);outline:none;}
.ai-snd{background:var(--sb);border:none;color:#fff;width:36px;cursor:pointer;font-size:12px;}.ai-snd:hover{background:var(--lum-blue2);}

/* SITE AGENT */
.site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;}
.site-card{background:var(--panel);border:1px solid var(--border);border-left:4px solid var(--lum-blue);padding:14px;cursor:pointer;transition:border-color 0.15s;}
.site-card:hover{border-left-color:var(--lum-blue2);box-shadow:0 2px 12px rgba(111,168,200,0.12);}
.site-agent-layout{display:grid;grid-template-columns:270px 1fr;height:calc(100vh - 160px);overflow:hidden;border:1px solid var(--border);}
.site-panel{overflow-y:auto;border-right:1px solid var(--border);background:var(--panel);}
.sp-tabs{display:flex;border-bottom:1px solid var(--border);}
.sp-tab{flex:1;padding:7px 4px;font-family:var(--fc);font-size:8px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;border:none;background:var(--card);color:var(--soft);cursor:pointer;border-right:1px solid var(--border);transition:all 0.1s;}
.sp-tab:last-child{border-right:none;}
.sp-tab.on{background:var(--panel);color:var(--lum-blue2);}
.sp-pane{display:none;padding:10px;}.sp-pane.on{display:block;}
.site-chat{display:flex;flex-direction:column;height:100%;background:var(--bg);}
.site-msgs{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:10px;}
.site-qs{display:flex;flex-wrap:wrap;gap:4px;padding:8px 10px;background:var(--panel);border-top:1px solid var(--border);}
.site-irow{display:flex;background:var(--panel);border-top:1px solid var(--border);}
.site-inp{flex:1;background:transparent;border:none;padding:0.65rem 1rem;font-size:11px;font-family:var(--f);color:var(--ink);outline:none;resize:none;min-height:44px;max-height:120px;}
.site-snd{background:var(--sb);border:none;color:#fff;width:44px;cursor:pointer;font-size:14px;flex-shrink:0;}.site-snd:hover{background:var(--lum-blue2);}
.code-block{background:#0F1219;border:1px solid rgba(111,168,200,0.25);padding:0.9rem 0.9rem 0.7rem;font-family:'Courier New',monospace;font-size:10px;color:#e0e8f0;line-height:1.6;overflow-x:auto;position:relative;margin:4px 0;}
.code-lang{font-family:var(--fc);font-size:7px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--lum-blue);position:absolute;top:6px;left:10px;}
.code-actions{position:absolute;top:4px;right:6px;display:flex;gap:3px;}
.code-btn{background:rgba(111,168,200,0.15);border:1px solid rgba(111,168,200,0.3);color:var(--lum-blue);font-size:8px;padding:2px 6px;cursor:pointer;font-family:var(--fc);font-weight:700;}
.code-btn:hover{background:var(--lum-blue);color:#fff;}
.snippet-item{background:var(--card);border:1px solid var(--border);border-left:3px solid var(--lum-blue);padding:8px 10px;margin-bottom:4px;}
.cred-row{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--card);border:1px solid var(--border);margin-bottom:2px;font-size:10px;}
.page-status-btn{font-size:8px;font-family:var(--fc);font-weight:700;padding:2px 7px;border:1px solid var(--border);background:var(--card);cursor:pointer;}
.page-status-btn.todo{color:var(--soft);}
.page-status-btn.wip{background:var(--amber2);border-color:var(--amber);color:var(--amber);}
.page-status-btn.done{background:var(--green2);border-color:var(--green);color:var(--green);}

/* FORMS */
.of{display:flex;flex-direction:column;gap:7px;}
.flab{font-family:var(--fc);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--soft);margin-bottom:2px;}
.finp{background:var(--panel);border:1px solid var(--border);color:var(--ink);padding:0.42rem 0.65rem;font-size:11px;font-family:var(--f);outline:none;width:100%;}
.finp:focus{border-color:var(--lum-blue);}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:7px;}
.opco-result{background:var(--green2);border:1px solid rgba(39,201,122,0.25);padding:1rem;margin-top:4px;}
.or-t{font-family:var(--fc);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:4px;}
.or-v{font-family:var(--fp);font-size:1.6rem;font-weight:700;color:var(--green);}
.or-d{font-size:9px;color:var(--mid);margin-top:4px;line-height:1.5;}

/* CHAT */
.chat-list{display:flex;flex-direction:column;gap:5px;max-height:185px;overflow-y:auto;margin-bottom:8px;}
.cmsg{display:flex;gap:7px;}
.cm-av{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;}
.cm-n{font-family:var(--fc);font-size:11px;font-weight:700;margin-bottom:1px;color:var(--ink);}.cm-t{font-size:11px;color:var(--mid);line-height:1.4;}.cm-ts{font-size:9px;color:var(--soft);}
.ci-row{display:flex;border:1px solid var(--border);}.ci{flex:1;background:var(--panel);border:none;color:var(--ink);padding:0.5rem 0.75rem;font-size:12px;font-family:var(--f);outline:none;}
.cs{background:var(--lum-blue);border:none;color:#fff;width:30px;cursor:pointer;font-size:11px;}
.stt-btn{background:transparent !important;color:var(--ink);width:32px;transition:all 0.2s ease;flex-shrink:0;}
.stt-btn:hover{background:var(--lum-blue-light) !important;}
@keyframes stt-pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.stt-recording{animation:stt-pulse 1s ease-in-out infinite;}

/* MODULE CARDS */
.mod-card{background:var(--panel);border:1px solid var(--border);padding:1rem;cursor:pointer;transition:all 0.12s;display:flex;flex-direction:column;gap:6px;}
.mod-card:hover{border-color:var(--lum-blue);background:var(--lum-blue-light);}
.mod-card-icon{font-size:1.4rem;}
.mod-card-name{font-family:var(--fc);font-size:10.5px;font-weight:700;color:var(--ink);}
.mod-card-type{font-size:9px;color:var(--mid);}
.mod-card-tags{display:flex;gap:4px;flex-wrap:wrap;}

/* FORMATIONS */
.fg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.fc{background:var(--panel);padding:1rem;cursor:pointer;transition:background 0.1s;position:relative;overflow:hidden;}.fc:hover{background:var(--lum-blue-light);}
.fc-deco{position:absolute;bottom:-10px;right:-10px;width:38px;height:38px;border-radius:50%;background:var(--bg);pointer-events:none;}
.ftag{font-family:var(--fc);font-size:7px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:2px 6px;margin-bottom:7px;display:inline-block;}
.f-opco{background:var(--lum-blue-light);color:var(--lum-blue2);border:1px solid var(--lum-blue-mid);}
.f-strat{background:var(--card);color:var(--ink);border:1px solid var(--border);}
.f-dig{background:var(--amber2);color:var(--amber);border:1px solid rgba(232,160,32,0.2);}
.f-mind{background:var(--green2);color:var(--green);border:1px solid rgba(39,201,122,0.2);}
.f-free{background:var(--purple);color:#fff;border:1px solid var(--purple);}
.fc-t{font-size:11px;font-weight:600;color:var(--ink);margin-bottom:3px;line-height:1.4;}.fc-m{font-size:9px;color:var(--mid);margin-bottom:6px;}
.fc-p{font-family:var(--fp);font-size:1rem;font-weight:700;color:var(--ink);}
.fc-bar{height:3px;background:var(--bg);margin-top:6px;border-radius:2px;}.fc-fill{height:100%;border-radius:2px;background:var(--lum-blue);}
.ftrow{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border);}.ftrow:last-child{border:none;}

/* MINDSET */
.ms-emoji{font-size:1.2rem;cursor:pointer;opacity:0.3;transition:all 0.15s;display:inline-block;margin-right:8px;}.ms-emoji.on{opacity:1;transform:scale(1.2);}
.eb-row{display:flex;gap:2px;}.eb{flex:1;height:16px;background:var(--card);border:1px solid var(--border);cursor:pointer;}.eb.on{background:var(--green);border-color:var(--green);}
.ji{background:var(--panel);border:1px solid var(--border);color:var(--ink);padding:0.6rem;font-size:10px;font-family:var(--f);outline:none;resize:none;width:100%;min-height:60px;}.ji:focus{border-color:var(--lum-blue);}

/* OFFRES IV */
.iv-offer{border:1px solid var(--border);background:var(--panel);position:relative;overflow:hidden;}
.iv-offer.featured{background:var(--sb);border-color:var(--sb);}
.iv-offer-top{padding:1.2rem;border-bottom:1px solid var(--border);}.iv-offer.featured .iv-offer-top{border-color:rgba(255,255,255,0.08);}
.iv-offer-tag{font-family:var(--fc);font-size:0.58rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--lum-blue2);margin-bottom:4px;}.iv-offer.featured .iv-offer-tag{color:var(--lum-blue);}
.iv-offer-name{font-family:var(--fp);font-size:1.2rem;font-weight:700;color:var(--ink);margin-bottom:3px;}.iv-offer.featured .iv-offer-name{color:#fff;}
.iv-offer-sub{font-size:10px;color:var(--mid);margin-bottom:0.8rem;}.iv-offer.featured .iv-offer-sub{color:rgba(255,255,255,0.5);}
.iv-offer-body{padding:1.2rem;}
.iv-item{font-size:10.5px;color:var(--ink);display:flex;align-items:flex-start;gap:7px;margin-bottom:6px;line-height:1.5;}
.iv-item::before{content:'\2192';color:var(--lum-blue);flex-shrink:0;font-weight:600;font-size:10px;margin-top:1px;}
.iv-offer.featured .iv-item{color:rgba(255,255,255,0.75);}.iv-offer.featured .iv-item::before{color:var(--lum-blue);}
.iv-price{font-family:var(--fp);font-size:1.5rem;font-weight:700;color:var(--ink);margin-bottom:2px;}.iv-offer.featured .iv-price{color:#fff;}
.iv-price-sub{font-size:9px;color:var(--mid);}.iv-offer.featured .iv-price-sub{color:rgba(255,255,255,0.45);}
.iv-cta{margin-top:0.8rem;width:100%;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(15,18,25,0.7);z-index:1000;display:none;align-items:center;justify-content:center;}.modal-overlay.show{display:flex;}
.modal-box{background:var(--panel);max-width:640px;width:92%;position:relative;overflow:hidden;}
.modal-hd{background:var(--sb);padding:1.4rem 1.6rem;position:relative;}.modal-hd::after{content:'';position:absolute;top:-20px;right:20px;width:60px;height:60px;border-radius:50%;border:1px solid rgba(111,168,200,0.15);}
.modal-close{position:absolute;top:0.8rem;right:0.8rem;background:transparent;border:none;color:rgba(255,255,255,0.4);cursor:pointer;font-size:1rem;}
.modal-tag{font-family:var(--fc);font-size:0.58rem;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--lum-blue);margin-bottom:4px;}
.modal-h{font-family:var(--fp);font-size:1.3rem;font-weight:700;color:#fff;}.modal-s{font-size:10px;color:rgba(255,255,255,0.45);margin-top:2px;}
.modal-body{padding:1.4rem 1.6rem;}.modal-foot{padding:0.8rem 1.6rem;background:var(--card);border-top:1px solid var(--border);font-size:9px;color:var(--soft);text-align:center;}

/* CLIENT FOLDER TABS */
.client-tabs{display:flex;gap:1px;background:var(--border);margin-bottom:1rem;}
.client-tab{flex:1;padding:0.5rem 1rem;text-align:center;background:var(--panel);font-family:var(--fc);font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--mid);cursor:pointer;border:none;border-bottom:2px solid transparent;transition:all 0.12s;}
.client-tab:hover{background:var(--lum-blue-light);color:var(--ink);}
.client-tab.on{background:var(--panel);color:var(--ink);border-bottom-color:var(--lum-blue);}
.client-tab-pane{display:none;}.client-tab-pane.on{display:block;}

/* TASKS TABLE */
.tasks-table{width:100%;border-collapse:collapse;}
.tasks-table th{background:var(--sb);color:rgba(255,255,255,0.5);font-family:var(--fc);font-size:8px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:0.5rem 0.7rem;text-align:left;border-bottom:1px solid var(--border);}
.tasks-table td{padding:0.55rem 0.7rem;font-size:10px;color:var(--ink);border-bottom:1px solid var(--border);background:var(--panel);vertical-align:middle;}
.tasks-table tr:hover td{background:var(--lum-blue-light);}
.p-purple{background:rgba(138,114,240,0.1);color:var(--purple);border:1px solid rgba(138,114,240,0.2);}
.p-red-strong{background:var(--red2);color:var(--red);border:1px solid rgba(224,88,88,0.2);}

/* NOTIFICATIONS DROPDOWN */
.notif-item{padding:0.7rem 0.9rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.1s;}
.notif-item:hover{background:var(--lum-blue-light);}
.notif-item.unread{border-left:3px solid var(--lum-blue);}
.notif-item-icon{font-size:12px;margin-right:4px;}
.notif-item-title{font-family:var(--fc);font-size:9px;font-weight:700;color:var(--ink);margin-bottom:2px;}
.notif-item-sub{font-size:9px;color:var(--mid);line-height:1.45;}
.notif-item-ts{font-size:8px;color:var(--soft);margin-top:2px;}

/* STUDIO */
.studio-toolbar{display:flex;gap:4px;padding:0.6rem;background:var(--sb);flex-wrap:wrap;}
.studio-tool{padding:5px 10px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);font-size:9px;font-family:var(--fc);font-weight:600;cursor:pointer;transition:all 0.12s;letter-spacing:0.5px;text-transform:uppercase;}
.studio-tool:hover,.studio-tool.on{background:var(--lum-blue);color:#fff;border-color:var(--lum-blue);}
.studio-canvas{background:#1a1a2e;min-height:300px;display:flex;align-items:center;justify-content:center;}
.studio-placeholder{text-align:center;color:rgba(255,255,255,0.3);}
.studio-placeholder div:first-child{font-size:2.5rem;margin-bottom:8px;}
.studio-placeholder div:nth-child(2){font-family:var(--fc);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;}
.studio-placeholder div:last-child{font-size:9px;margin-top:4px;}
.studio-sidebar{background:var(--panel);border:1px solid var(--border);padding:0.8rem;display:flex;flex-direction:column;gap:8px;}
.studio-panel{background:var(--card);padding:0.7rem;border:1px solid var(--border);}
.studio-panel-h{font-family:var(--fc);font-size:8px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--soft);margin-bottom:6px;}
.studio-slider{width:100%;margin:4px 0;accent-color:var(--lum-blue);}
.studio-tabs{display:flex;gap:1px;background:var(--border);margin-bottom:0.8rem;}
.studio-tab{flex:1;padding:0.5rem;text-align:center;background:var(--card);font-family:var(--fc);font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--mid);cursor:pointer;border:none;transition:all 0.12s;}
.studio-tab.on{background:var(--sb);color:#fff;}

/* SOCIAL */
.social-card{background:var(--panel);border:1px solid var(--border);padding:0.8rem;display:flex;align-items:center;gap:10px;transition:all 0.12s;}.social-card:hover{border-color:var(--lum-blue);}
.social-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.social-info{flex:1;}.social-name{font-family:var(--fc);font-size:10px;font-weight:700;color:var(--ink);}.social-status{font-size:9px;color:var(--mid);}
.social-connect-btn{padding:4px 10px;font-size:9px;font-family:var(--fc);font-weight:700;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;border:none;}
.connected{background:var(--green2);color:var(--green);border:1px solid rgba(39,201,122,0.3);}.not-connected{background:var(--lum-blue);color:#fff;}

/* CHARTS */
.chart-bars{display:flex;align-items:flex-end;gap:4px;height:100px;padding-top:10px;}
.chart-bar{flex:1;background:var(--lum-blue);border-radius:2px 2px 0 0;position:relative;min-width:12px;}.chart-bar:hover{background:var(--lum-blue2);}
.chart-bar-label{position:absolute;bottom:-16px;left:50%;transform:translateX(-50%);font-size:7px;color:var(--soft);white-space:nowrap;}
.chart-bar-val{position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:7px;font-weight:600;color:var(--ink);white-space:nowrap;}

/* CLIENT DETAIL */
.client-header{background:var(--sb);padding:1.2rem;display:flex;align-items:center;gap:1rem;position:relative;overflow:hidden;}
.client-avatar-lg{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--fc);font-size:16px;font-weight:700;color:#fff;flex-shrink:0;}
.client-name-lg{font-family:var(--fp);font-size:1.2rem;font-weight:700;color:#fff;}
.client-meta{font-size:10px;color:rgba(255,255,255,0.45);}
.client-actions{margin-left:auto;display:flex;gap:6px;}

/* ===== STRIPE PAYMENT ===== */
.stripe-btn{display:inline-flex;align-items:center;gap:6px;padding:0.45rem 1rem;background:linear-gradient(135deg,#635BFF,#7B73FF);color:#fff;border:none;font-family:var(--fc);font-size:10px;font-weight:700;letter-spacing:0.5px;text-transform:uppercase;cursor:pointer;transition:all 0.15s;border-radius:3px;}
.stripe-btn:hover{background:linear-gradient(135deg,#4B45D6,#635BFF);transform:translateY(-1px);box-shadow:0 4px 12px rgba(99,91,255,0.3);}
.stripe-btn svg{width:14px;height:14px;}
.stripe-badge{display:inline-flex;align-items:center;gap:4px;font-size:8px;color:var(--soft);font-family:var(--fc);font-weight:600;letter-spacing:0.5px;}
.stripe-badge svg{width:10px;height:10px;}

/* ===== RESPONSIVE MOBILE ===== */

/* Hamburger */
.hamburger{display:none;background:transparent;border:none;cursor:pointer;padding:6px;}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;transition:all 0.2s;border-radius:1px;}
.sb-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(15,18,25,0.6);z-index:99;}
.sb-overlay.show{display:block;}

@media(max-width:1024px){
  .body{grid-template-columns:180px 1fr;}
  .grid3{grid-template-columns:1fr 1fr;}
  .krow.k5{grid-template-columns:repeat(3,1fr);}
  .kanban{grid-template-columns:1fr 1fr;}
  .fg{grid-template-columns:1fr 1fr;}
  .tb-crumb{display:none;}
  .plan-pill{display:none;}
}
@media(max-width:900px){
  .body{grid-template-columns:160px 1fr;}
  .grid2,.grid22{grid-template-columns:1fr;}
  .krow.k4{grid-template-columns:1fr 1fr;}
  .krow.k5{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  /* Mobile: natural page scroll, width-constrained to prevent horizontal overflow */
  html,body{height:auto !important;overflow:visible !important;width:100% !important;max-width:100vw !important;-webkit-overflow-scrolling:touch;}
  .wrap{height:auto !important;min-height:100dvh;min-height:100vh;overflow:visible !important;width:100% !important;}

  /* Contain widths instead of using overflow:hidden */
  .main,.main *,.view.on,.view.on *{max-width:100vw;box-sizing:border-box;}
  .view.on{overflow:visible !important;height:auto !important;}

  /* Hamburger visible */
  .hamburger{display:flex;flex-direction:column;align-items:center;justify-content:center;}

  /* Topbar */
  .tb{padding:0 0.6rem;gap:6px;flex-wrap:nowrap;height:50px;overflow:hidden;max-width:100vw;position:relative;}
  .iv-logo{gap:6px;flex-shrink:0;}
  .iv-sym{width:26px;height:16px;}
  .tb-logo-img{height:20px;}
  .iv-main{font-size:0.7rem;}
  .iv-sub{font-size:0.4rem;letter-spacing:2px;}
  .tb-crumb{display:none;}
  .tb-modes{display:none !important;}
  .tb-r{gap:4px;flex-shrink:0;}
  .plan-pill{display:none;}
  .un{display:none;}
  .notif-btn{width:26px;height:26px;font-size:10px;}
  .logout-btn{font-size:8px;padding:3px 8px;display:flex;align-items:center;justify-content:center;background:var(--card) !important;border:1px solid var(--border) !important;color:var(--mid);font-family:var(--fc);font-weight:600;white-space:nowrap;}
  .user-chip{padding:2px 4px;}
  .ua{width:20px;height:20px;font-size:7px;}

  /* Mobile mode switcher */
  .mobile-modes{display:flex !important;gap:0;background:var(--bg);padding:0;border:none;margin:0;}
  .mobile-modes .tm{padding:0.45rem 0;flex:1;text-align:center;font-size:0.6rem;border-bottom:2px solid transparent;color:var(--soft);}
  .mobile-modes .tm.on{border-bottom-color:var(--lum-blue);background:var(--panel);color:var(--lum-blue2);font-weight:800;}

  /* Layout: single column — keep display:grid so JS can toggle display:none */
  .body{grid-template-columns:1fr !important;overflow:visible !important;flex:none !important;height:auto !important;width:100% !important;}

  /* Sidebar: slide-in drawer — starts below topbar */
  .sb-rail{position:fixed;top:50px;left:-270px;width:270px;height:calc(100vh - 50px);z-index:200;transition:left 0.3s cubic-bezier(0.25,0.8,0.25,1);overflow-y:auto;box-shadow:none;-webkit-overflow-scrolling:touch;pointer-events:auto;}
  .sb-rail.open{left:0;box-shadow:4px 0 24px rgba(0,0,0,0.3);}
  .sb-rail *{pointer-events:auto !important;}

  /* Main — no scroll trap, natural page flow */
  .main{padding:0.8rem;overflow:visible !important;height:auto !important;flex:none !important;width:100% !important;}

  /* Grid layouts - responsive on mobile */
  .grid2,.grid22,.grid3{grid-template-columns:1fr !important;}
  .krow.k4,.krow.k5{grid-template-columns:1fr 1fr !important;}
  .kanban{grid-template-columns:1fr !important;}
  .fg{grid-template-columns:1fr !important;}

  /* FORCE inline grids to 2 columns max to prevent overflow */
  [style*="grid-template-columns"]{grid-template-columns:1fr 1fr !important;}

  /* KPIs: compact on mobile */
  .kpi{padding:10px 12px !important;}
  .kpi-l{font-size:7px !important;}
  .kpi-v{font-size:1.1rem !important;}

  /* Calendar week: keep 7 cols but make it scrollable */
  [style*="repeat(7,1fr)"]{grid-template-columns:repeat(7,minmax(42px,1fr)) !important;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  /* Valeurs IV: keep 5 cols scrollable */
  [style*="repeat(5,1fr)"]{grid-template-columns:repeat(5,minmax(60px,1fr)) !important;overflow-x:auto;-webkit-overflow-scrolling:touch;}

  /* Re-allow list rows with proper layout */
  .lrow[style*="grid-template-columns"]{grid-template-columns:auto 1fr auto !important;}

  /* Hide decorative circles that cause overflow */
  .kpi-deco,.card-deco,.fc-deco{display:none !important;}

  /* Login */
  .login-box{width:94%;max-width:400px;}
  .login-roles{grid-template-columns:1fr 1fr;gap:4px;}
  .login-role{padding:0.5rem 0.4rem;}
  .login-role-icon{font-size:1rem;}
  .login-role-name{font-size:9px;}

  /* Page header */
  .ph{flex-direction:column;gap:0.5rem;}
  .ph-r{flex-wrap:wrap;width:100%;}
  .ph-r .btn{font-size:8px !important;padding:5px 8px !important;}
  .ph-h{font-size:1.1rem;}
  .ph-tag{font-size:0.5rem;}

  /* KPI cards */
  .kpi{padding:0.75rem 0.8rem;}
  .kpi-v{font-size:1rem;}
  .kpi-l{font-size:9px;letter-spacing:1.5px;}

  /* Cards */
  .card{padding:0.8rem;}
  .ct{font-size:10px;}

  /* AI Chat */
  .ai-wrap{min-height:280px;}
  .ai-msgs{max-height:220px;}
  .ai-qs{gap:3px;padding:0.5rem;}
  .aq{font-size:8px;padding:3px 6px;}
  .bub{font-size:10px;max-width:92%;}

  /* Studio */
  .studio-tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .studio-tab{font-size:8px;padding:0.4rem 0.5rem;white-space:nowrap;flex-shrink:0;}
  .studio-canvas{min-height:220px;}
  .studio-toolbar{gap:4px;padding:0.5rem;}
  .studio-tool{padding:5px 8px;font-size:8px;}
  #studio-video,#studio-photo{grid-template-columns:1fr !important;}
  .studio-sidebar{padding:0.6rem;}

  /* Social cards */
  .social-icon{width:32px;height:32px;font-size:14px;border-radius:6px;}
  .social-card{padding:0.7rem;gap:8px;}

  /* Client detail */
  .client-header{flex-direction:column;text-align:center;gap:0.6rem;padding:1rem;}
  .client-actions{margin-left:0;justify-content:center;flex-wrap:wrap;}
  .client-avatar-lg{width:44px;height:44px;font-size:15px;}
  .client-name-lg{font-size:1rem;}

  /* Offres IV */
  .iv-offer{margin-bottom:0;}
  .iv-offer-top{padding:1rem;}
  .iv-offer-body{padding:1rem;}
  .iv-offer-name{font-size:1rem;}
  .iv-price{font-size:1.2rem;}
  .iv-item{font-size:10px;margin-bottom:5px;}

  /* Inline grids already handled by global rule above */

  /* Modal */
  .modal-box{width:96%;max-width:100%;max-height:90vh;overflow-y:auto;}
  .modal-hd{padding:1rem;}
  .modal-body{padding:0.8rem;}
  .modal-h{font-size:1.05rem;}
  /* modal inline grids handled by global rule */

  /* Charts */
  .chart-bars{height:80px;}

  /* Calendly widget */
  .calendly-inline-widget{min-width:100% !important;height:550px !important;}

  /* Buttons */
  .btn{padding:0.35rem 0.7rem;font-size:9px;}
  .stripe-btn{padding:0.4rem 0.8rem;font-size:9px;}

  /* Lists - simplify on mobile */
  .lrow{padding:0.55rem 0.7rem;display:flex !important;flex-wrap:wrap;gap:6px;align-items:center;}
  .lrow .lav{flex-shrink:0;}
  .lrow > div:nth-child(2){flex:1;min-width:0;}
  .lrow .lname{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .lrow .lscore{font-size:10px;}
  .lrow .pill{font-size:7px;padding:1px 5px;}
  .lav{width:24px;height:24px;font-size:8px;}

  /* Forms */
  .fr2{grid-template-columns:1fr;}
  .of{gap:5px;}

  /* Score ring smaller on mobile */
  .rw{width:72px;height:72px;}

  /* Valeurs IV row (5 columns) */
  .krow.k5{grid-template-columns:1fr !important;}

  /* Quick actions — 2x2 grid on mobile */
  #home-quick-actions{grid-template-columns:repeat(2,1fr) !important;gap:4px !important;}
  #home-quick-actions button{padding:8px 4px !important;font-size:8px !important;}

  /* Marketplace services — 2 cols on mobile */
  #home-valider-banner{padding:10px 12px !important;}
  #home-valider-banner button{font-size:8px !important;padding:5px 10px !important;}

  /* Activity feed */
  #home-activity-feed div{font-size:9px;}

  /* Quick message */
  #home-quick-msg{font-size:9px !important;padding:6px 8px !important;}

  /* RDV section */
  [style*="padding:2rem"]{padding:1rem !important;}

  /* Stripe */
  .stripe-btn{width:100%;justify-content:center;padding:0.5rem;}

  /* Tasks table scroll */
  .tasks-table{font-size:9px;}
  .tasks-table th,.tasks-table td{padding:5px 6px;}
}

@media(max-width:400px){
  .login-roles{grid-template-columns:1fr;}
  .ph-h{font-size:0.95rem;}
  .kpi-v{font-size:1rem;}
  .iv-offer-name{font-size:0.9rem;}
  .iv-price{font-size:1rem;}
  .studio-tabs{gap:0;}
  #home-quick-actions{grid-template-columns:repeat(2,1fr) !important;}
}

/* ─── RESPONSIVE DASHBOARD AGENCE ─── */
@media(max-width:768px){
  /* KPI row : 2 cols on mobile instead of 4 */
  .krow.k4{grid-template-columns:repeat(2,1fr) !important;}
  .krow.k5{grid-template-columns:repeat(2,1fr) !important;}
  /* Force 4-col inline grid to 2 cols */
  [style*="repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr) !important;}
  /* Dashboard special: width-constrained */
  #a-dash,#a-lumos{overflow:visible !important;max-width:100%;width:100%;}
  /* Prevent any child from exceeding viewport */
  #a-dash *,#a-lumos *{max-width:100% !important;box-sizing:border-box;}
  /* Objectif MRR flex row → column on small screens */
  #a-dash [style*="justify-content:space-between"]{flex-wrap:wrap;gap:4px;}
  /* ftrow (tableau répartition) adapté */
  .ftrow{gap:4px;}
}

/* ─── PWA STANDALONE MODE (installed on home screen) ─── */
@media(display-mode:standalone){
  /* Push EVERYTHING below the iOS status bar / notch */
  .wrap{padding-top:env(safe-area-inset-top,20px) !important;padding-bottom:env(safe-area-inset-bottom,0px);}
  /* Sidebar: push below topbar + safe area */
  .sb-rail{top:calc(50px + env(safe-area-inset-top,20px)) !important;height:calc(100vh - 50px - env(safe-area-inset-top,20px)) !important;}
  /* Login overlays respect safe areas */
  .login-overlay{padding-top:env(safe-area-inset-top,20px);}
}

/* TOASTS */
#toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{display:flex;align-items:center;gap:8px;padding:0.7rem 1rem;background:var(--sb);border-left:3px solid var(--lum-blue);color:#fff;font-family:var(--fc);font-size:10px;font-weight:600;letter-spacing:0.5px;max-width:320px;box-shadow:0 4px 16px rgba(0,0,0,0.25);animation:toastIn 0.25s ease;pointer-events:all;}
.toast.success{border-left-color:var(--green);}
.toast.error{border-left-color:var(--red);}
.toast.warning{border-left-color:var(--amber);}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;transform:translateX(20px)}}

/* Skeleton */
.skeleton{background:linear-gradient(90deg,var(--card) 25%,var(--border) 50%,var(--card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:2px;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-line{height:10px;margin-bottom:6px;}.skeleton-line.lg{height:20px;}.skeleton-line.sm{height:8px;width:60%;}
.skeleton-card{background:var(--panel);border:1px solid var(--border);padding:1rem;}
/* Chantier 2 — CTA contextuel */
.cta-contextual{background:var(--lum-blue-light);border:1px solid var(--border);border-left:3px solid var(--lum-blue);padding:12px 16px;margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;animation:fadeUp .2s ease-out}
.cta-contextual .cta-msg{font-size:10px;color:var(--ink);flex:1;min-width:200px;line-height:1.5}
.cta-contextual .cta-btn{font-family:var(--fc);font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:6px 14px;background:var(--lum-blue);color:#fff;border:none;cursor:pointer;white-space:nowrap}
.cta-contextual .cta-btn:hover{opacity:.9}
.cta-opco-banner{background:linear-gradient(135deg,var(--amber2),rgba(232,160,32,0.05));border:1px solid rgba(232,160,32,0.2);border-left:3px solid var(--amber);padding:10px 14px;margin:8px 10px;font-size:9px;color:var(--amber);cursor:pointer}
.cta-opco-banner:hover{opacity:.9}

/* Chantier 3 — Floating Agent */
.fab-agent{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--lum-blue);color:#fff;border:none;cursor:pointer;z-index:900;box-shadow:0 4px 16px rgba(111,168,200,0.4);display:flex;align-items:center;justify-content:center;font-size:22px;transition:transform .15s,box-shadow .15s}
.fab-agent:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(111,168,200,0.5)}
.fab-agent:active{transform:scale(.95)}
.fab-agent .fab-badge{position:absolute;top:-2px;right:-2px;width:14px;height:14px;border-radius:50%;background:var(--amber);display:none;border:2px solid var(--bg)}
.agent-panel{position:fixed;top:0;right:-420px;width:400px;height:100vh;background:var(--panel);border-left:1px solid var(--border);z-index:950;transition:right .25s ease-out;display:flex;flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,0.15)}
.agent-panel.open{right:0}
.agent-panel .ap-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.agent-panel .ap-close{background:none;border:none;color:var(--mid);cursor:pointer;font-size:18px;padding:4px}
.agent-panel .ap-body{flex:1;overflow-y:auto;padding:0}
.agent-panel .ap-footer{border-top:1px solid var(--border);padding:10px 12px;display:flex;gap:6px}
.agent-panel .ap-footer input{flex:1;font-size:11px;padding:8px 10px;border:1px solid var(--border);background:var(--card);color:var(--ink);font-family:var(--ft)}
.agent-panel .ap-footer button{padding:8px 14px;background:var(--lum-blue);color:#fff;border:none;cursor:pointer;font-size:11px;font-weight:600}
.agent-panel .ap-chips{display:flex;flex-wrap:wrap;gap:4px;padding:8px 12px}
.agent-panel .ap-chip{font-size:9px;padding:4px 10px;background:var(--card);border:1px solid var(--border);color:var(--mid);cursor:pointer;font-family:var(--fc);font-weight:600}
.agent-panel .ap-chip:hover{border-color:var(--lum-blue);color:var(--lum-blue)}
@media(max-width:600px){.agent-panel{width:100%}}

/* Chantier 5 — Transitions & animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.view.on{animation:fadeUp .15s ease-out}
.card:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.06);transition:transform .15s,box-shadow .15s}
.btn:active{transform:scale(.98)}
.btn-loading{position:relative;color:transparent!important;pointer-events:none}
.btn-loading::after{content:'';position:absolute;width:14px;height:14px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin .5s linear infinite;top:50%;left:50%;margin:-7px 0 0 -7px}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-success{background:var(--green)!important;color:#fff!important;pointer-events:none}
.btn-success::before{content:'\\2713 '}

/* Chantier 6 — Onboarding checklist */
.ob-checklist{background:var(--panel);border:1px solid var(--border);border-left:3px solid var(--lum-blue);padding:14px 16px;margin-bottom:10px;animation:fadeUp .3s ease-out}
.ob-checklist .ob-title{font-family:var(--fc);font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--lum-blue2);margin-bottom:8px}
.ob-checklist .ob-progress{height:4px;background:var(--border);border-radius:2px;margin-bottom:10px}
.ob-checklist .ob-bar{height:4px;background:var(--lum-blue);border-radius:2px;transition:width .4s ease-out}
.ob-step{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border);cursor:pointer}
.ob-step:last-child{border-bottom:none}
.ob-step .ob-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;flex-shrink:0;transition:all .2s}
.ob-step.done .ob-check{background:var(--green);border-color:var(--green)}
.ob-step .ob-text{font-size:10px;color:var(--ink);flex:1}
.ob-step.done .ob-text{color:var(--mid);text-decoration:line-through}
.ob-step .ob-go{font-family:var(--fc);font-size:8px;font-weight:700;color:var(--lum-blue2);opacity:0;transition:opacity .15s}
.ob-step:hover .ob-go{opacity:1}

/* Chantier 7 — Empty states */
.empty-state{padding:3rem;text-align:center;background:var(--panel);border:1px solid var(--border)}
.empty-state .es-icon{font-size:2.5rem;margin-bottom:10px}
.empty-state .es-title{font-family:var(--fp);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:4px}
.empty-state .es-desc{font-size:10px;color:var(--mid);max-width:300px;margin:0 auto;line-height:1.6}
.empty-state .es-btn{margin-top:14px}

@media print{
  .sb-rail,.tb,.login-overlay,.modal-overlay,#toast-container,.ai-irow,.ai-qs,.btn,.ph-r{display:none!important;}
  .body{grid-template-columns:1fr!important;}
  .main{overflow:visible!important;padding:0!important;}
  .view{display:flex!important;}
  .view:not(.on){display:none!important;}
  html,body{overflow:visible!important;height:auto!important;}
  .wrap{height:auto!important;}
}
