/* ══════════════════════════════════════════════════════════════
   Carboneum v5.1 — style.css
   Rampe Vert Carbone : #F0FDF8 → #BBFADE → #86EFBB → #3DD68C → #1DB97A → #0F8F5A → #065C39
   ══════════════════════════════════════════════════════════════ */

/* ─── CSS VARIABLES : Rampe Vert Carbone ───────────────────── */
:root {
  /* Ramp Vert Carbone (7 nuances) */
  --c-50:  #F0FDF8;
  --c-100: #BBFADE;
  --c-200: #86EFBB;
  --c-300: #3DD68C;
  --c-400: #1DB97A;  /* Primaire */
  --c-500: #0F8F5A;  /* Hover / Actif */
  --c-600: #065C39;  /* Sidebar / Header sombre */

  /* Alias sémantiques */
  --primary:     var(--c-400);
  --primary-dim: var(--c-300);
  --primary-dark:var(--c-500);
  --em:          var(--c-400);
  --em-dim:      var(--c-100);
  --sky:         var(--c-300);
  --amber:       #D97706;
  --rose:        #DC2626;
  --rose-dim:    rgba(220,38,38,0.12);
  --violet:      #7C3AED;
  --ai:          var(--c-300);
  --warn:        var(--amber);

  /* Surfaces */
  --bg:       #F4F9F6;
  --bg-1:     #FFFFFF;
  --bg-2:     var(--c-50);
  --bg-3:     rgba(29,185,122,0.04);
  --bg-4:     rgba(29,185,122,0.08);
  --bg-5:     rgba(6,92,57,0.10);
  --bg-dark:  var(--c-600);

  /* Texte */
  --txt:      #0F2E1F;
  --txt-2:    #2D6B4A;
  --txt-3:    #5A9E7A;
  --txt-inv:  #FFFFFF;

  /* Bordures */
  --border:   var(--c-200);
  --border-2: var(--c-100);

  /* Typo */
  --fh: 'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  --fm: 'JetBrains Mono','SF Mono','Fira Code',monospace;

  /* Ombres */
  --shadow-sm: 0 1px 2px rgba(6,92,57,0.06);
  --shadow:    0 2px 8px rgba(6,92,57,0.08);
  --shadow-lg: 0 8px 24px rgba(6,92,57,0.12);

  /* Rayons */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 20px;

  /* Transitions */
  --tr: all .2s cubic-bezier(.4,0,.2,1);
}

/* ─── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fh);background:var(--bg);color:var(--txt);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:var(--primary);text-decoration:none;transition:var(--tr)}a:hover{color:var(--primary-dark)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
ul,ol{list-style:none}
img{max-width:100%;display:block}

/* ─── UTILITAIRES ────────────────────────────────────────────── */
.hidden{display:none!important}
.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}
.text-center{text-align:center}.w-full{width:100%}
.mh{max-height:60vh;overflow-y:auto}

/* ─── SPLASH SCREEN ──────────────────────────────────────────── */
#splash{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
#splash.out{opacity:0;visibility:hidden}
.sp-inner{text-align:center;padding:2rem}
.sp-logo{width:72px;height:72px;margin:0 auto 1.5rem;animation:sp-pulse 2s ease-in-out infinite}
@keyframes sp-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.sp-title{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--c-400),var(--c-300));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.4rem}
.sp-sub{color:var(--txt-3);font-size:.95rem;margin-bottom:2rem}
.sp-bar{width:200px;height:4px;background:var(--bg-5);border-radius:2px;margin:0 auto 1rem;overflow:hidden}
.sp-prog{height:100%;width:0%;background:linear-gradient(90deg,var(--c-400),var(--c-300));border-radius:2px;transition:width .4s ease}
.sp-status{color:var(--txt-3);font-size:.82rem}

/* ─── AUTH SCREEN ────────────────────────────────────────────── */
#auth-screen{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;min-height:100vh}
.auth-bg{position:absolute;inset:0;background:linear-gradient(160deg,var(--c-600) 0%,var(--c-500) 50%,var(--c-400) 100%);opacity:.95}
.auth-wrap{position:relative;z-index:1;display:grid;grid-template-columns:1fr 420px;max-width:1100px;width:92%;background:var(--bg-1);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);overflow:hidden;min-height:560px}
.auth-hero{padding:3rem 2.5rem;background:linear-gradient(160deg,var(--c-600),var(--c-500));color:#fff;display:flex;flex-direction:column;justify-content:center}
.auth-hero-logo{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}
.auth-hero-brand{font-size:1.4rem;font-weight:700}
.auth-hero-pitch h2{font-size:1.6rem;font-weight:700;margin-bottom:1rem;line-height:1.3}
.auth-hero-pitch p{color:var(--c-100);font-size:.95rem;line-height:1.6;margin-bottom:2rem}
.auth-hero-feats{display:grid;gap:1rem}
.auth-feat{display:flex;align-items:center;gap:.75rem;font-size:.9rem}
.auth-feat-ico{width:36px;height:36px;background:rgba(255,255,255,.12);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.auth-panel{padding:2.5rem 2rem;display:flex;flex-direction:column}
.auth-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-2);padding-bottom:.5rem}
.auth-tab{padding:.5rem 1rem;font-size:.9rem;font-weight:600;color:var(--txt-3);border-radius:var(--r-sm);transition:var(--tr);cursor:pointer;background:none;border:none}
.auth-tab:hover{color:var(--primary)}
.auth-tab.active{color:var(--primary);background:var(--bg-3)}
.auth-form{flex:1;display:flex;flex-direction:column}
.auth-form-title{font-size:1.3rem;font-weight:700;margin-bottom:.3rem;color:var(--txt)}
.auth-form-sub{color:var(--txt-3);font-size:.88rem;margin-bottom:1.5rem}
.auth-sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;margin-top:.3rem}
.auth-sc{padding:.5rem .3rem;text-align:center;border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:var(--tr);font-size:.78rem;color:var(--txt-2);background:var(--bg-1)}
.auth-sc span{display:block;font-size:1.3rem;margin-bottom:.2rem}
.auth-sc:hover{border-color:var(--c-300);background:var(--c-50)}
.auth-sc.active{border-color:var(--primary);background:var(--bg-3);color:var(--primary);font-weight:600}
.auth-demo{text-align:center;margin-top:auto;padding-top:1.5rem;color:var(--txt-3);font-size:.85rem}
.auth-demo a{color:var(--primary);font-weight:600;cursor:pointer}
.auth-demo a:hover{text-decoration:underline}

/* ─── FORMULAIRES ────────────────────────────────────────────── */
.f-group{margin-bottom:1rem}
.f-label{display:block;font-size:.82rem;font-weight:600;color:var(--txt-2);margin-bottom:.35rem}
.f-input,.f-select{width:100%;padding:.55rem .75rem;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg-1);color:var(--txt);font-size:.88rem;transition:var(--tr);outline:none}
.f-input:focus,.f-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(29,185,122,.15)}
.f-input::placeholder{color:var(--txt-3);opacity:.6}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.f-hint{font-size:.78rem;color:var(--txt-3);margin-top:.25rem}
.f-err{color:var(--rose);font-size:.82rem;margin-top:.4rem;padding:.4rem .6rem;background:var(--rose-dim);border-radius:var(--r-sm);display:none}
.f-err.show{display:block}

/* ─── BOUTONS ────────────────────────────────────────────────── */
.btn-auth{width:100%;padding:.7rem 1.2rem;background:linear-gradient(135deg,var(--c-400),var(--c-500));color:#fff;font-weight:600;font-size:.95rem;border-radius:var(--r-sm);transition:var(--tr);box-shadow:0 2px 8px rgba(29,185,122,.25);border:none;cursor:pointer}
.btn-auth:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(29,185,122,.35)}
.btn-auth:disabled{opacity:.6;cursor:not-allowed;transform:none}

.btn-p{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:var(--bg-3);color:var(--primary);font-size:.82rem;font-weight:600;border-radius:var(--r-sm);border:1.5px solid var(--c-200);transition:var(--tr);cursor:pointer}
.btn-p:hover{background:var(--bg-4);border-color:var(--primary)}

.btn-ai{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem 1rem;background:linear-gradient(135deg,var(--c-400),var(--c-500));color:#fff;font-size:.85rem;font-weight:600;border-radius:var(--r-sm);transition:var(--tr);box-shadow:0 2px 8px rgba(29,185,122,.2);border:none;cursor:pointer}
.btn-ai:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(29,185,122,.3)}

.btn-sm{display:inline-flex;align-items:center;gap:.3rem;padding:.32rem .65rem;background:var(--bg-2);color:var(--txt-2);font-size:.78rem;font-weight:500;border-radius:var(--r-sm);border:1px solid var(--border-2);transition:var(--tr);cursor:pointer}
.btn-sm:hover{background:var(--bg-3);border-color:var(--c-200)}

.btn-edit{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:transparent;color:var(--txt-3);transition:var(--tr);cursor:pointer;border:none}
.btn-edit:hover{background:var(--bg-3);color:var(--primary)}

.btn-del{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:transparent;color:var(--rose);transition:var(--tr);cursor:pointer;border:none}
.btn-del:hover{background:var(--rose-dim)}

.btn-cl{padding:.5rem 1rem;background:var(--bg-2);color:var(--txt-2);font-size:.85rem;font-weight:500;border-radius:var(--r-sm);border:1.5px solid var(--border);transition:var(--tr);cursor:pointer}
.btn-cl:hover{background:var(--bg-3)}

.btn-ok{padding:.5rem 1rem;background:linear-gradient(135deg,var(--c-400),var(--c-500));color:#fff;font-size:.85rem;font-weight:600;border-radius:var(--r-sm);transition:var(--tr);box-shadow:0 2px 6px rgba(29,185,122,.2);border:none;cursor:pointer}
.btn-ok:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(29,185,122,.3)}

.ico-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:var(--bg-2);color:var(--txt-2);border:1px solid var(--border-2);transition:var(--tr);cursor:pointer}
.ico-btn:hover{background:var(--bg-3);color:var(--primary)}

/* ─── APP LAYOUT ─────────────────────────────────────────────── */
#app{display:flex;min-height:100vh}

/* ─── SIDEBAR ────────────────────────────────────────────────── */
.sidebar{width:260px;background:linear-gradient(180deg,var(--c-600),#053d26);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:50;transition:transform .3s ease;overflow-y:auto}
.sidebar::-webkit-scrollbar{width:4px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.sb-top{padding:1.25rem 1rem;flex:1}
.brand{display:flex;align-items:center;gap:.7rem;padding:.5rem .3rem;margin-bottom:1.5rem;cursor:pointer;transition:var(--tr);border-radius:var(--r-sm)}
.brand:hover{background:rgba(255,255,255,.06)}
.brand-ico{width:32px;height:32px;flex-shrink:0}
.brand-name{font-size:1.05rem;font-weight:700;color:#fff}
.brand-tag{font-size:.68rem;color:var(--c-200);display:block;margin-top:.1rem}

.nav-sec{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--c-200);opacity:.7;padding:.6rem 1rem .3rem}
nav{padding:0 .5rem .5rem}
.ni{display:flex;align-items:center;gap:.65rem;padding:.55rem .85rem;border-radius:var(--r-sm);color:var(--c-100);font-size:.85rem;cursor:pointer;transition:var(--tr);margin-bottom:.15rem;position:relative}
.ni:hover{background:rgba(255,255,255,.08);color:#fff}
.ni.active{background:rgba(29,185,122,.2);color:#fff;font-weight:600}
.ni i{flex-shrink:0;opacity:.8}
.ni-cnt{margin-left:auto;font-size:.72rem;background:rgba(255,255,255,.1);padding:.15rem .45rem;border-radius:10px;color:#fff;font-weight:600}
.ni-badge{font-size:.65rem;padding:.15rem .4rem;border-radius:4px;font-weight:700;margin-left:auto}
.ni-badge.ai{background:linear-gradient(135deg,var(--c-300),var(--c-400));color:#fff}

.sb-foot{padding:1rem;border-top:1px solid rgba(255,255,255,.08)}
.yr-box{margin-bottom:.75rem}
.yr-label{font-size:.7rem;color:var(--c-200);opacity:.8;display:block;margin-bottom:.3rem}
.yr-row{display:flex;gap:.4rem}
.yr-sel{flex:1;padding:.4rem .6rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);color:#fff;font-size:.82rem;outline:none;cursor:pointer}
.yr-sel option{background:var(--c-600);color:#fff}

.user-tile{display:flex;align-items:center;gap:.65rem;padding:.6rem;border-radius:var(--r-sm);cursor:pointer;transition:var(--tr);margin-bottom:.5rem}
.user-tile:hover{background:rgba(255,255,255,.08)}
.user-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--c-400),var(--c-300));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}
.user-nm{font-size:.82rem;font-weight:600;color:#fff;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-rl{font-size:.72rem;color:var(--c-200);opacity:.8;display:block}

.logout-btn{width:100%;padding:.5rem;display:flex;align-items:center;justify-content:center;gap:.4rem;background:rgba(255,255,255,.06);color:var(--c-100);font-size:.78rem;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);transition:var(--tr);cursor:pointer}
.logout-btn:hover{background:rgba(220,38,38,.15);color:#ff9e9e;border-color:rgba(220,38,38,.3)}

/* ─── CONTENT WRAPPER ────────────────────────────────────────── */
.cw{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh}

/* ─── TOPBAR ─────────────────────────────────────────────────── */
.topbar{height:56px;background:var(--bg-1);border-bottom:1px solid var(--border-2);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:40}
.hmbg{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--r-sm);background:transparent;color:var(--txt-2);cursor:pointer;border:none}
.hmbg:hover{background:var(--bg-2)}
.tb-ttl h1{font-size:1.05rem;font-weight:700;color:var(--txt)}
.tb-sub{font-size:.78rem;color:var(--txt-3)}
.tb-acts{display:flex;align-items:center;gap:.5rem}

.q-pill{display:flex;align-items:center;gap:.4rem;padding:.35rem .7rem;background:var(--bg-2);border-radius:20px;border:1px solid var(--border-2);font-size:.78rem;color:var(--txt-2)}
.q-dot{width:8px;height:8px;border-radius:50%;background:var(--em);animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.5}}

.act-btn-ai{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;background:linear-gradient(135deg,var(--c-400),var(--c-500));color:#fff;font-size:.82rem;font-weight:600;border-radius:var(--r-sm);transition:var(--tr);box-shadow:0 2px 8px rgba(29,185,122,.2);border:none;cursor:pointer}
.act-btn-ai:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(29,185,122,.3)}
.act-btn-ai i{flex-shrink:0}

.act-btn-p{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;background:var(--bg-1);color:var(--txt);font-size:.82rem;font-weight:500;border-radius:var(--r-sm);border:1.5px solid var(--border);transition:var(--tr);cursor:pointer}
.act-btn-p:hover{border-color:var(--primary);color:var(--primary)}

.exp-wrap{position:relative}
.exp-dd{position:absolute;right:0;top:calc(100% + 6px);background:var(--bg-1);border:1.5px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:.4rem;min-width:220px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:var(--tr);z-index:60}
.exp-dd.open{opacity:1;visibility:visible;transform:translateY(0)}
.exp-dd button{width:100%;display:flex;align-items:center;gap:.5rem;padding:.5rem .7rem;border-radius:var(--r-sm);font-size:.82rem;color:var(--txt);background:transparent;transition:var(--tr);cursor:pointer;border:none;text-align:left}
.exp-dd button:hover{background:var(--bg-3);color:var(--primary)}
.exp-dd hr{border:none;border-top:1px solid var(--border-2);margin:.3rem 0}

/* ─── MAIN CONTENT ───────────────────────────────────────────── */
.main{flex:1;padding:1.25rem 1.5rem 2rem;overflow-y:auto}

/* ─── SECTIONS ───────────────────────────────────────────────── */
.sec{display:none;animation:fadeIn .3s ease}
.sec.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─── CARDS ──────────────────────────────────────────────────── */
.card{background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);padding:1.25rem;margin-bottom:1rem;transition:var(--tr)}
.card:hover{box-shadow:var(--shadow)}

.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}
.ct{font-size:.95rem;font-weight:700;color:var(--txt)}
.cm{font-size:.78rem;color:var(--txt-3);font-weight:500}
.chw{position:relative}
.chw.sm{max-height:320px}

/* ─── GRIDS ────────────────────────────────────────────────── */
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}
.g2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}

/* ─── KPIs ───────────────────────────────────────────────────── */
.kpi{background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);padding:1rem;position:relative;overflow:hidden;transition:var(--tr)}
.kpi::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--kc,var(--primary));border-radius:var(--r-md) 0 0 var(--r-md)}
.kpi:hover{box-shadow:var(--shadow)}
.kpi-l{font-size:.78rem;color:var(--txt-3);margin-bottom:.3rem;font-weight:500}
.kpi-v{font-family:var(--fm);font-size:1.6rem;font-weight:700;color:var(--kc,var(--txt));line-height:1.2}
.kpi-u{font-size:.75rem;color:var(--txt-3);margin-left:.2rem;font-weight:500}
.kpi-t{font-size:.72rem;color:var(--txt-3);margin-top:.2rem}

/* ─── TABLES ─────────────────────────────────────────────────── */
.tw{overflow-x:auto}
.dt{width:100%;border-collapse:collapse;font-size:.85rem}
.dt th{text-align:left;padding:.6rem .7rem;font-weight:600;color:var(--txt-2);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--border);white-space:nowrap;background:var(--bg-2)}
.dt td{padding:.55rem .7rem;border-bottom:1px solid var(--border-2);vertical-align:middle;color:var(--txt)}
.dt tr:hover td{background:var(--bg-3)}
.dt .num{font-family:var(--fm);font-weight:600;text-align:right}

/* ─── PROGRESS BARS ──────────────────────────────────────────── */
.pbar-row{display:flex;align-items:center;gap:.5rem}
.pbar{flex:1;height:6px;background:var(--bg-5);border-radius:3px;overflow:hidden;min-width:40px}
.pbar-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .5s ease}

/* ─── PILLS / TAGS ─────────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;padding:.25rem .6rem;background:var(--bg-2);border:1.5px solid var(--border-2);border-radius:20px;font-size:.75rem;color:var(--txt-2);cursor:pointer;transition:var(--tr);font-weight:500}
.pill:hover{border-color:var(--c-200)}
.pill.active{background:var(--bg-3);border-color:var(--primary);color:var(--primary);font-weight:600}
.pill-row{display:flex;flex-wrap:wrap;gap:.4rem;padding:.5rem 0;margin-bottom:.5rem}

/* ─── SCOPE CARDS ────────────────────────────────────────────── */
.cat-grp{margin-bottom:1rem}
.cat-hd{display:flex;align-items:center;justify-content:space-between;padding:.6rem .8rem;background:linear-gradient(90deg,var(--bg-3),transparent);border-radius:var(--r-sm);margin-bottom:.5rem;border-left:3px solid var(--primary)}
.cat-hd span:first-child{font-weight:600;color:var(--txt);font-size:.88rem}
.cat-tot{font-family:var(--fm);font-size:.85rem;font-weight:700;color:var(--primary)}

.itl{font-weight:600;color:var(--txt);font-size:.85rem}
.est-dot{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:10px;font-size:.7rem;font-weight:600}
.est-dot.y{background:rgba(29,185,122,.12);color:var(--c-500)}
.est-dot.n{background:rgba(138,160,168,.1);color:var(--txt-3)}

.bio-row{opacity:.7}
.bio-tag{display:inline-block;padding:.15rem .4rem;background:var(--c-100);color:var(--c-500);border-radius:4px;font-size:.68rem;font-weight:600;margin-left:.4rem}

/* ─── ACTION CARDS ───────────────────────────────────────────── */
.ac-list{display:flex;flex-direction:column;gap:.6rem}
.ac-card{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);transition:var(--tr)}
.ac-card:hover{box-shadow:var(--shadow-sm);border-color:var(--c-200)}
.ac-card.done{opacity:.6;background:var(--bg-2)}
.ac-scope-tag{display:inline-flex;align-items:center;padding:.25rem .5rem;background:var(--bg-3);color:var(--primary);border-radius:4px;font-size:.72rem;font-weight:700;flex-shrink:0}
.ac-title{font-weight:600;color:var(--txt);font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-meta{font-size:.75rem;color:var(--txt-3);margin-top:.15rem}
.ac-pot{font-family:var(--fm);font-size:.85rem;font-weight:700;color:var(--em);flex-shrink:0;white-space:nowrap}
.sdot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sdot.planned{background:var(--txt-3)}
.sdot.in_progress{background:var(--amber)}
.sdot.completed{background:var(--em)}
.ie-sel{padding:.25rem .4rem;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg-1);font-size:.78rem;color:var(--txt);outline:none;cursor:pointer}

/* ─── REMOVAL CARDS ──────────────────────────────────────────── */
.removals-list{display:flex;flex-direction:column;gap:.6rem}
.removal-card{padding:.8rem 1rem;background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);transition:var(--tr)}
.removal-card:hover{box-shadow:var(--shadow-sm);border-color:var(--c-200)}

/* ─── AI SECTIONS ────────────────────────────────────────────── */
.ai-hero{display:flex;align-items:flex-start;gap:1.25rem;padding:1.5rem;background:linear-gradient(135deg,var(--bg-3),rgba(29,185,122,.06));border:1.5px solid var(--c-200);border-radius:var(--r-md);margin-bottom:1.25rem}
.ai-hero-ico{font-size:2.2rem;flex-shrink:0;line-height:1}
.ai-hero h2{font-size:1.1rem;font-weight:700;color:var(--txt);margin-bottom:.4rem}
.ai-hero p{color:var(--txt-2);font-size:.88rem;line-height:1.5;max-width:600px}
.ai-actions-row{display:flex;gap:.5rem;margin-top:.9rem;flex-wrap:wrap}
.ai-card .ch{margin-bottom:.75rem}

/* ─── ANOMALIES / RECOMMENDATIONS ────────────────────────────── */
.anomaly-item{display:flex;gap:.75rem;padding:.8rem 1rem;background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);margin-bottom:.5rem;transition:var(--tr)}
.anomaly-item:hover{border-color:var(--c-200);box-shadow:var(--shadow-sm)}
.anomaly-item.high{border-left:3px solid var(--rose)}
.anomaly-item.medium{border-left:3px solid var(--amber)}
.anomaly-item.low{border-left:3px solid var(--txt-3)}
.anomaly-sev{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;flex-shrink:0;height:fit-content}
.anomaly-sev.high{background:var(--rose-dim);color:var(--rose)}
.anomaly-sev.medium{background:rgba(217,119,6,.1);color:var(--amber)}
.anomaly-sev.low{background:rgba(138,160,168,.1);color:var(--txt-3)}
.anomaly-msg{font-size:.85rem;color:var(--txt);line-height:1.4}
.anomaly-sug{font-size:.78rem;color:var(--txt-2);margin-top:.3rem;padding:.4rem .6rem;background:var(--bg-3);border-radius:var(--r-sm);border-left:2px solid var(--primary)}

.rec-card{display:flex;gap:.85rem;padding:.9rem 1rem;background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);margin-bottom:.5rem;transition:var(--tr)}
.rec-card:hover{box-shadow:var(--shadow-sm);border-color:var(--c-200)}
.rec-title{font-weight:600;color:var(--txt);font-size:.88rem;margin-bottom:.25rem}
.rec-detail{font-size:.8rem;color:var(--txt-2);line-height:1.4}
.rec-meta{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}
.rec-meta-tag{font-size:.72rem;padding:.2rem .45rem;background:var(--bg-2);border-radius:4px;color:var(--txt-3);border:1px solid var(--border-2)}

/* ─── ESTIMATES ──────────────────────────────────────────────── */
.est-preview{display:flex;align-items:center;gap:.75rem;padding:.7rem .9rem;background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);margin-bottom:.4rem;transition:var(--tr)}
.est-preview:hover{border-color:var(--c-200)}
.est-confidence{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;flex-shrink:0}
.est-confidence.high{background:rgba(29,185,122,.12);color:var(--c-500)}
.est-confidence.medium{background:rgba(217,119,6,.1);color:var(--amber)}
.est-confidence.low{background:rgba(138,160,168,.1);color:var(--txt-3)}

/* ─── CSRD ───────────────────────────────────────────────────── */
.csrd-section{background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);margin-bottom:.6rem;overflow:hidden}
.csrd-sec-hd{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem;background:var(--bg-2);border-bottom:1.5px solid var(--border-2);font-weight:600;font-size:.88rem;color:var(--txt)}
.csrd-content{padding:.9rem 1rem;font-size:.85rem;color:var(--txt-2);line-height:1.6}
.csrd-compliance{font-size:.72rem;padding:.25rem .5rem;border-radius:4px;font-weight:600;flex-shrink:0}
.csrd-compliance.conforme{background:rgba(29,185,122,.12);color:var(--c-500)}
.csrd-compliance.partiel{background:rgba(217,119,6,.1);color:var(--amber)}
.csrd-compliance.à_compléter{background:rgba(138,160,168,.1);color:var(--txt-3)}

/* ─── VALIDATION / CHECKLIST ─────────────────────────────────── */
.ck-list{display:flex;flex-direction:column;gap:.4rem;margin-top:1rem}
.ck-item{display:flex;align-items:center;gap:.6rem;padding:.55rem .7rem;background:var(--bg-2);border-radius:var(--r-sm);transition:var(--tr)}
.ck-item:hover{background:var(--bg-3)}
.ck-ico{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}
.ck-ico.ok{background:rgba(29,185,122,.15);color:var(--c-500)}
.ck-ico.nok{background:rgba(138,160,168,.1);color:var(--txt-3)}
.prog-ring-row{display:flex;align-items:center;gap:1.25rem;padding:1rem 0}

/* ─── BENCHMARK ──────────────────────────────────────────────── */
.bm-hero{background:linear-gradient(135deg,var(--bg-3),rgba(29,185,122,.05));border:1.5px solid var(--c-200);border-radius:var(--r-md);padding:1.25rem;margin-bottom:1rem}
.bm-refs,.bm-targets{padding:.5rem}

/* ─── SYNTHESIS ──────────────────────────────────────────────── */
.synth-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1rem}
.synth-stat{background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);padding:.9rem;text-align:center;transition:var(--tr)}
.synth-stat:hover{box-shadow:var(--shadow-sm)}
.synth-v{font-family:var(--fm);font-size:1.4rem;font-weight:700;color:var(--primary);line-height:1.2}
.synth-l{font-size:.75rem;color:var(--txt-3);margin-top:.25rem}

/* ─── ADEME PICKER ───────────────────────────────────────────── */
.ap-srch{width:100%;padding:.55rem .9rem;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg-1);color:var(--txt);font-size:.88rem;outline:none;transition:var(--tr);margin-bottom:.5rem}
.ap-srch:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(29,185,122,.12)}
.ap-list{max-height:320px;overflow-y:auto}
.ap-item{display:flex;align-items:center;justify-content:space-between;padding:.55rem .7rem;border-radius:var(--r-sm);cursor:pointer;transition:var(--tr);border:1.5px solid transparent}
.ap-item:hover{background:var(--bg-3);border-color:var(--c-200)}
.ap-item div:first-child{flex:1;min-width:0}
.ap-cat{font-size:.72rem;color:var(--txt-3);margin-top:.15rem}
.ap-val{font-family:var(--fm);font-size:.8rem;font-weight:600;color:var(--primary);flex-shrink:0;margin-left:.5rem}

.ademe-dt .ademe-nom{font-weight:600;color:var(--txt);font-size:.82rem}
.ademe-dt .ademe-cat{font-size:.75rem;color:var(--txt-3)}
.ademe-dt .ademe-unit{font-size:.75rem;color:var(--txt-3)}
.ademe-dt .ademe-fe{font-weight:600;color:var(--primary)}

/* ─── TRANSPORT MODAL ────────────────────────────────────────── */
.tm-section{padding:.5rem 0}
.tm-section.hidden{display:none}

/* ─── AI LOADING ─────────────────────────────────────────────── */
.ai-loading{display:flex;align-items:center;gap:.75rem;padding:2rem;color:var(--txt-3);font-size:.9rem;justify-content:center}
.ai-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── EMPTY STATES ───────────────────────────────────────────── */
.em-st{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1rem;color:var(--txt-3);text-align:center}
.em-st i{opacity:.4;margin-bottom:.75rem}
.em-st p{font-size:.88rem}

/* ─── TOASTS ─────────────────────────────────────────────────── */
.tw-wrap{position:fixed;bottom:1.25rem;right:1.25rem;z-index:200;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.toast{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;background:var(--bg-1);border:1.5px solid var(--border-2);border-radius:var(--r-md);box-shadow:var(--shadow-lg);font-size:.85rem;color:var(--txt);transform:translateX(120%);transition:transform .35s cubic-bezier(.34,1.56,.64,1);pointer-events:auto;max-width:320px}
.toast.in{transform:translateX(0)}
.toast.s{border-left:3px solid var(--em)}
.toast.e{border-left:3px solid var(--rose)}
.toast.w{border-left:3px solid var(--amber)}
.toast.i{border-left:3px solid var(--sky)}

/* ─── MODAL ────────────────────────────────────────────────────── */
.mov{position:fixed;inset:0;z-index:150;background:rgba(6,92,57,.4);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
.mov.open{opacity:1;visibility:visible}
.mbox{background:var(--bg-1);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:92%;max-width:560px;max-height:85vh;display:flex;flex-direction:column;transform:scale(.95);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.mov.open .mbox{transform:scale(1)}
.mbox.wide{max-width:720px}
.mhd{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1.5px solid var(--border-2)}
.mttl{font-size:1rem;font-weight:700;color:var(--txt)}
.mcls{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);background:transparent;color:var(--txt-3);transition:var(--tr);cursor:pointer;border:none}
.mcls:hover{background:var(--bg-3);color:var(--rose)}
.mbd{padding:1.25rem;overflow-y:auto;flex:1}
.m-acts{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1.5px solid var(--border-2);margin-top:auto}

/* ─── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width:1024px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .synth-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .cw{margin-left:0}
  .hmbg{display:inline-flex}
  .g4,.g2,.synth-grid{grid-template-columns:1fr}
  .auth-wrap{grid-template-columns:1fr;max-width:420px}
  .auth-hero{display:none}
  .topbar{padding:0 1rem}
  .tb-sub{display:none}
  .bl{display:none}
  .main{padding:1rem}
  .ai-hero{flex-direction:column;gap:.75rem}
}

/* ─── SCROLLBAR ──────────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--c-200);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--c-300)}

/* ─── SELECTION ──────────────────────────────────────────────── */
::selection{background:rgba(29,185,122,.2);color:var(--c-600)}

/* ─── PRINT ──────────────────────────────────────────────────── */
@media print{
  .sidebar,.topbar,.hmbg,.tb-acts,.act-btn-ai,.act-btn-p,.exp-wrap,.logout-btn,.ni-badge{display:none!important}
  .cw{margin-left:0}
  .card{break-inside:avoid;border:1px solid #ddd}
  body{background:#fff;color:#000}
}