/* ══════════════════════════════════════════════════════════════
   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);

  --amber-dim: #fef3c7;
  --amber-bg: #fffbeb;
  --amber-dark: #92400e;
}

/* ─── 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:unset;max-height:90vh}
.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:1.5rem 2rem;display:flex;flex-direction:column;overflow-y:auto;max-height:90vh}
.auth-tabs{display:flex;gap:.5rem;margin-bottom:.8rem;border-bottom:2px solid var(--border-2);padding-bottom:.4rem}
.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.15rem;font-weight:700;margin-bottom:.15rem;color:var(--txt)}
.auth-form-sub{color:var(--txt-3);font-size:.82rem;margin-bottom:.8rem}
.auth-sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.35rem;margin-top:.2rem}
.auth-sc{padding:.3rem .2rem;text-align:center;border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:var(--tr);font-size:.7rem;color:var(--txt-2);background:var(--bg-1)}
.auth-sc span{display:block;font-size:1rem;margin-bottom:.1rem}
.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:.8rem;color:var(--txt-3);font-size:.78rem}
.auth-demo a{color:var(--primary);font-weight:600;cursor:pointer}
.auth-demo a:hover{text-decoration:underline}

/* ─── FORMULAIRES ────────────────────────────────────────────── */
.f-group{margin-bottom:.55rem}
.f-label{display:block;font-size:.78rem;font-weight:600;color:var(--txt-2);margin-bottom:.2rem}
.f-input,.f-select{width:100%;padding:.42rem .6rem;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg-1);color:var(--txt);font-size:.85rem;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:.5rem}
.f-hint{font-size:.72rem;color:var(--txt-3);margin-top:.15rem}
.f-err{color:var(--rose);font-size:.75rem;margin-top:.25rem;padding:.3rem .5rem;background:var(--rose-dim);border-radius:var(--r-sm);display:none}
.f-err.show{display:block}

/* ─── BOUTONS ────────────────────────────────────────────────── */
.btn-auth{width:100%;padding:.55rem 1.2rem;background:linear-gradient(135deg,var(--c-400),var(--c-500));color:#fff;font-weight:600;font-size:.9rem;border-radius:var(--r-sm);transition:var(--tr);box-shadow:0 2px 8px rgba(29,185,122,.25);border:none;cursor:pointer;margin-top:.2rem}
.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:240px;background:linear-gradient(180deg,var(--c-600),#053d26);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;height:100dvh;height:-webkit-fill-available;z-index:50;transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;overscroll-behavior-x:none;padding-bottom:.25rem;will-change:transform;transform:translateX(0);touch-action:pan-y pinch-zoom}
.sidebar::-webkit-scrollbar{width:2px}
.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}

.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:45;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;pointer-events:none;touch-action:none;-webkit-tap-highlight-color:transparent}
.sidebar-backdrop.active{opacity:1;visibility:visible;pointer-events:auto}

.sb-top{padding:.4rem .75rem .25rem;flex:1}
.brand{display:flex;align-items:center;gap:.5rem;padding:.3rem .2rem;margin-bottom:.5rem;cursor:pointer;transition:var(--tr);border-radius:var(--r-sm)}
.brand:hover{background:rgba(255,255,255,.06)}
.brand-ico{width:26px;height:26px;flex-shrink:0}
.brand-name{font-size:.95rem;font-weight:700;color:#fff}
.brand-tag{font-size:.62rem;color:var(--c-200);display:block;margin-top:0}

.nav-sec{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--c-200);opacity:.7;padding:.25rem .75rem .1rem}
nav{padding:0 .4rem .25rem}
.ni{display:flex;align-items:center;gap:.4rem;padding:.28rem .65rem;border-radius:var(--r-sm);color:var(--c-100);font-size:.78rem;cursor:pointer;transition:var(--tr);margin-bottom:.04rem;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:.65rem;background:rgba(255,255,255,.1);padding:.08rem .3rem;border-radius:8px;color:#fff;font-weight:600;flex-shrink:0;align-self:center;line-height:1}
.ni-badge{font-size:.6rem;padding:.08rem .3rem;border-radius:4px;font-weight:700;margin-left:.3rem;flex-shrink:0;align-self:center;line-height:1}
.ni-badge.ai{background:linear-gradient(135deg,var(--c-300),var(--c-400));color:#fff}

.sb-foot{padding:.35rem .75rem .25rem;border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:51;pointer-events:auto}
.sb-top{position:relative;z-index:51;pointer-events:auto}
.yr-box{margin-bottom:.3rem;position:relative;z-index:52;pointer-events:auto}
.yr-label{font-size:.65rem;color:var(--c-200);opacity:.8;display:block;margin-bottom:.15rem}
.yr-row{display:flex;gap:.4rem}
.yr-sel{flex:1;padding:.3rem .5rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);color:#fff;font-size:.78rem;outline:none;cursor:pointer;touch-action:manipulation;min-height:32px;position:relative;z-index:53}
.yr-sel option{background:var(--c-600);color:#fff}
.ico-btn{position:relative;z-index:53;pointer-events:auto;touch-action:manipulation}

.user-tile{display:flex;align-items:center;gap:.45rem;padding:.3rem .4rem;border-radius:var(--r-sm);cursor:pointer;transition:var(--tr);margin-bottom:.2rem;position:relative;z-index:52;pointer-events:auto;touch-action:manipulation}
.user-tile:hover{background:rgba(255,255,255,.08)}
.user-tile:active{background:rgba(255,255,255,.12)}
.user-av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--c-400),var(--c-300));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}
.user-nm{font-size:.78rem;font-weight:600;color:#fff;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-rl{font-size:.68rem;color:var(--c-200);opacity:.8;display:block}

.logout-btn{width:100%;padding:.35rem;display:flex;align-items:center;justify-content:center;gap:.35rem;background:rgba(255,255,255,.06);color:var(--c-100);font-size:.72rem;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);transition:var(--tr);cursor:pointer;position:relative;z-index:52;pointer-events:auto;touch-action:manipulation;min-height:32px}
.logout-btn:hover{background:rgba(220,38,38,.15);color:#ff9e9e;border-color:rgba(220,38,38,.3)}
.logout-btn:active{background:rgba(220,38,38,.25);transform:scale(.98)}

/* ─── CONTENT WRAPPER ────────────────────────────────────────── */
.cw{flex:1;margin-left:240px;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}

/* ══ LISTE ISO (projets, produits, audit trail) ══════════════════ */
.iso-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  padding: .25rem 0;
  min-height: 60px;
}
.iso-empty {
  padding: 2rem 1rem;
  text-align: center;
  color: var(--txt-3);
  font-size: .85rem;
}

/* ── Carte projet (ISO 14064-2) ─────────────────────────────── */
.project-card {
  background: var(--bg-1);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  padding: 1rem;
  transition: var(--tr);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.project-card:hover {
  border-color: var(--c-200);
  box-shadow: var(--shadow-sm);
}
.project-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.project-name {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--txt);
}
.project-type {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.6rem;
  border-radius: 40px;
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--bg-3);
  color: var(--primary);
  border: 1px solid var(--c-200);
}
.project-type.reduction {
  background: rgba(29,185,122,0.12);
  color: var(--c-500);
}
.project-type.removal {
  background: rgba(14,165,233,0.12);
  color: #0f8f5a;
}
.project-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: 0.8rem;
  color: var(--txt-2);
  background: var(--bg-2);
  padding: 0.6rem;
  border-radius: var(--r-sm);
}
.project-metric {
  display: flex;
  align-items: baseline;
  gap: 0.3rem;
}
.project-metric strong {
  font-weight: 600;
  color: var(--txt);
}
.project-meta {
  font-size: 0.75rem;
  color: var(--txt-3);
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  border-top: 1px solid var(--border-2);
  padding-top: 0.6rem;
  margin-top: 0.2rem;
}
.project-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  border-top: 1px solid var(--border-2);
  padding-top: 0.6rem;
  margin-top: 0.2rem;
}
.project-additionality {
  font-size: 0.7rem;
  color: var(--amber);
  background: rgba(217,119,6,0.08);
  padding: 0.2rem 0.5rem;
  border-radius: 12px;
  display: inline-block;
}
.project-monitoring {
  font-size: 0.7rem;
  color: var(--sky);
}

/* ── Carte produit (ISO 14067) ─────────────────────────────── */
.product-card {
  background: var(--bg-1);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  padding: 1rem;
  transition: var(--tr);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.product-card:hover {
  border-color: var(--c-200);
  box-shadow: var(--shadow-sm);
}
.product-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.product-name {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--txt);
}
.product-fu {
  font-family: var(--fm);
  font-size: 0.8rem;
  color: var(--primary);
  background: var(--bg-3);
  padding: 0.2rem 0.5rem;
  border-radius: 16px;
}
.product-pcf {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--em);
  font-family: var(--fm);
}
.product-pcf small {
  font-size: 0.7rem;
  font-weight: normal;
  color: var(--txt-3);
}
.product-details {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  font-size: 0.75rem;
  color: var(--txt-2);
  background: var(--bg-2);
  padding: 0.5rem 0.7rem;
  border-radius: var(--r-sm);
}
.product-detail {
  display: flex;
  gap: 0.3rem;
  align-items: baseline;
}
.product-detail strong {
  font-weight: 600;
}
.product-uncertainty {
  color: var(--amber);
}
.product-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.2rem;
}
.iso-requirements-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.8rem;
  margin-top: 0.5rem;
}
.iso-req-item {
  background: var(--bg-2);
  border-radius: var(--r-sm);
  padding: 0.7rem;
  border-left: 3px solid var(--primary);
}
.iso-req-item strong {
  display: block;
  font-size: 0.85rem;
  margin-bottom: 0.3rem;
}
.iso-req-item p {
  font-size: 0.75rem;
  color: var(--txt-3);
  line-height: 1.4;
}

/* ── Vérification & signature (ISO 14064-3) ───────────────── */
.verification-panel {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.assurance-computed-card, .hash-card {
  background: var(--bg-2);
  border-radius: var(--r-md);
  padding: 1rem;
}
.assurance-value {
  font-size: 1.3rem;
  font-weight: 700;
  font-family: var(--fm);
}
.assurance-value.reasonable { color: var(--em); }
.assurance-value.limited    { color: var(--amber); }
.assurance-value.none       { color: var(--rose); }
.assurance-note {
  font-size: 0.75rem;
  color: var(--txt-3);
  margin-top: 0.3rem;
}
.hash-display {
  font-family: var(--fm);
  font-size: 0.75rem;
  background: var(--bg-1);
  padding: 0.5rem;
  border-radius: var(--r-sm);
  word-break: break-all;
  border: 1px solid var(--border-2);
}
.hash-status {
  font-size: 0.7rem;
  margin-top: 0.3rem;
}
.hash-status.modified { color: var(--rose); }
.hash-status.unchanged { color: var(--em); }
.verification-form {
  background: var(--bg-1);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  padding: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.form-row .form-group {
  flex: 1;
  min-width: 180px;
}
.verification-form label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--txt-2);
  display: block;
  margin-bottom: 0.2rem;
}
.verification-form input, 
.verification-form select, 
.verification-form textarea {
  width: 100%;
  padding: 0.45rem 0.6rem;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-1);
  font-size: 0.85rem;
}
.verification-form textarea {
  resize: vertical;
}
.audit-trail {
  margin-top: 1rem;
}
.audit-item {
  background: var(--bg-2);
  border-radius: var(--r-sm);
  padding: 0.7rem;
  margin-bottom: 0.5rem;
  border-left: 3px solid var(--primary);
}
.audit-date {
  font-size: 0.7rem;
  color: var(--txt-3);
  margin-bottom: 0.2rem;
}
.audit-detail {
  font-size: 0.8rem;
  color: var(--txt-2);
}
.audit-justification {
  font-size: 0.75rem;
  color: var(--txt-3);
  margin-top: 0.3rem;
  font-style: italic;
}
#save-verification-btn {
  background: var(--primary);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: var(--r-sm);
  font-weight: 600;
  cursor: pointer;
  transition: var(--tr);
}
#save-verification-btn:hover {
  background: var(--primary-dark);
  transform: translateY(-1px);
}

/* ─── 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}

/* ─── 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}

/* ─── AMÉLIORATIONS : ADEME · TRANSPORT · UTILISATEURS ──────── */
.sec#sec-ademe .card,
.sec#sec-admin-transport .card,
.sec#sec-admin-users .card {
  overflow: visible;
}

.toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border-2);
}
.toolbar-left {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.toolbar-right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}

.filter-group {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  background: var(--bg-2);
  padding: 0.2rem 0.5rem;
  border-radius: var(--r-sm);
  border: 1px solid var(--border-2);
}
.filter-group .pill {
  margin: 0;
  background: transparent;
  border: none;
  padding: 0.25rem 0.6rem;
}
.filter-group .pill.active {
  background: var(--bg-3);
  color: var(--primary);
  border-radius: var(--r-sm);
}
.filter-group .pill:not(.active):hover {
  background: var(--bg-3);
}

.search-input {
  width: 240px;
  padding: 0.4rem 0.7rem;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-1);
  font-size: 0.8rem;
  transition: var(--tr);
}
.search-input:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 2px rgba(29,185,122,0.1);
}

.btn-ademe-primary {
  background: var(--primary);
  color: white;
  border: none;
}
.btn-ademe-primary:hover {
  background: var(--primary-dark);
  transform: translateY(-1px);
}
.btn-ademe-secondary {
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1.5px solid var(--border-2);
}
.btn-ademe-secondary:hover {
  background: var(--bg-3);
  border-color: var(--c-200);
  color: var(--primary);
}
.btn-export {
  background: var(--bg-1);
  color: var(--txt-2);
  border: 1.5px solid var(--border-2);
}
.btn-export:hover {
  background: var(--bg-2);
  border-color: var(--primary);
  color: var(--primary);
}
.btn-import {
  background: var(--bg-1);
  color: var(--sky);
  border: 1.5px solid var(--border-2);
}
.btn-import:hover {
  background: var(--bg-3);
  border-color: var(--sky);
}
.btn-filter-toggle {
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1px solid var(--border-2);
}
.btn-filter-toggle.active {
  background: var(--primary-dim);
  color: var(--primary-dark);
  border-color: var(--primary);
}

.ademe-dt,
.transport-dt {
  width: 100%;
  font-size: 0.85rem;
  border-collapse: collapse;
}
.ademe-dt th,
.transport-dt th {
  text-align: left;
  padding: 0.7rem 0.8rem;
  background: var(--bg-2);
  font-weight: 600;
  color: var(--txt-2);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border-bottom: 2px solid var(--border);
}
.ademe-dt td,
.transport-dt td {
  padding: 0.6rem 0.8rem;
  border-bottom: 1px solid var(--border-2);
  vertical-align: middle;
  color: var(--txt);
}
.ademe-dt tr:hover td,
.transport-dt tr:hover td {
  background: var(--bg-3);
}
.ademe-dt .ademe-nom {
  font-weight: 600;
}
.ademe-dt .ademe-cat,
.transport-dt .transport-mode {
  font-size: 0.75rem;
  color: var(--txt-3);
}
.ademe-dt .ademe-fe,
.transport-dt .transport-fe {
  font-family: var(--fm);
  font-weight: 600;
  color: var(--primary);
  text-align: right;
}
.ademe-dt .btn-del,
.transport-dt .btn-del {
  opacity: 0.6;
  transition: opacity 0.2s;
}
.ademe-dt .btn-del:hover,
.transport-dt .btn-del:hover {
  opacity: 1;
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 1rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--border-2);
}
.pagination button {
  min-width: 80px;
}
.pagination span {
  font-size: 0.8rem;
  color: var(--txt-3);
}

.user-table {
  width: 100%;
  border-collapse: collapse;
}
.user-table th {
  text-align: left;
  padding: 0.7rem 0.8rem;
  background: var(--bg-2);
  font-weight: 600;
  color: var(--txt-2);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  border-bottom: 2px solid var(--border);
}
.user-table td {
  padding: 0.6rem 0.8rem;
  border-bottom: 1px solid var(--border-2);
  vertical-align: middle;
  color: var(--txt);
}
.user-table tr:hover td {
  background: var(--bg-3);
}
.user-role-badge {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  border-radius: 40px;
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--bg-3);
  color: var(--primary);
  border: 1px solid var(--c-200);
}
.user-role-badge.admin {
  background: rgba(220,38,38,0.12);
  color: var(--rose);
  border-color: rgba(220,38,38,0.3);
}
.user-role-badge.editor {
  background: rgba(217,119,6,0.12);
  color: var(--amber);
  border-color: rgba(217,119,6,0.3);
}
.user-role-badge.viewer {
  background: rgba(29,185,122,0.12);
  color: var(--primary);
  border-color: rgba(29,185,122,0.2);
}
.user-actions {
  display: flex;
  gap: 0.4rem;
}
.user-actions .btn-edit,
.user-actions .btn-del {
  width: 28px;
  height: 28px;
}

.empty-message {
  text-align: center;
  padding: 2rem;
  color: var(--txt-3);
  background: var(--bg-2);
  border-radius: var(--r-md);
  margin: 1rem 0;
}

/* ─── CORRECTION BOUTONS MODIFIER/SUPPRIMER DANS LES CARTES ISO ─── */
.project-card .btn-sm,
.product-card .btn-sm {
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1px solid var(--border-2);
  padding: 0.3rem 0.7rem;
  border-radius: var(--r-sm);
  font-size: 0.75rem;
  transition: var(--tr);
}
.project-card .btn-sm:hover,
.product-card .btn-sm:hover {
  background: var(--bg-3);
  border-color: var(--c-200);
  color: var(--primary);
}
.project-card .btn-del,
.product-card .btn-del {
  width: auto;
  height: auto;
  padding: 0.3rem 0.7rem;
  background: var(--bg-2);
  color: var(--rose);
  border: 1px solid var(--border-2);
  border-radius: var(--r-sm);
  font-size: 0.75rem;
  gap: 0.3rem;
}
.project-card .btn-del:hover,
.product-card .btn-del:hover {
  background: var(--rose-dim);
  border-color: var(--rose);
  color: var(--rose);
}
.project-actions,
.product-actions {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  margin-top: 0.5rem;
}


/* ══════════════════════════════════════════════════════════════
   STYLES MANQUANTS — Portefeuille de projets & Catalogue produits
   ══════════════════════════════════════════════════════════════ */

/* ─── En-tête de page ISO (projets, produits, vérification) ─── */
.iso-page-hd {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 1.25rem;
  padding: 1.25rem 1.5rem;
  background: linear-gradient(135deg, var(--bg-1), var(--bg-2));
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
}

.iso-page-hd-left {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  flex: 1;
  min-width: 0;
}

.iso-page-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.8rem;
  background: linear-gradient(135deg, var(--c-400), var(--c-500));
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  border-radius: var(--r-sm);
  letter-spacing: 0.03em;
  text-transform: uppercase;
  flex-shrink: 0;
  white-space: nowrap;
  box-shadow: 0 2px 6px rgba(29,185,122,0.2);
}

.iso-page-badge--teal {
  background: linear-gradient(135deg, #0ea5e9, #38bdf8);
  box-shadow: 0 2px 6px rgba(14,165,233,0.2);
}

.iso-page-badge--violet {
  background: linear-gradient(135deg, #7c3aed, #a78bfa);
  box-shadow: 0 2px 6px rgba(124,58,237,0.2);
}

.iso-page-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--txt);
  margin-bottom: 0.25rem;
  line-height: 1.3;
}

.iso-page-sub {
  font-size: 0.82rem;
  color: var(--txt-3);
  line-height: 1.5;
  max-width: 600px;
}

/* ─── Carte assurance calculée (ISO 14064-3) ───────────────── */
.iso-assurance-card {
  background: var(--bg-1);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  padding: 1rem;
  transition: var(--tr);
}

.iso-assurance-card:hover {
  box-shadow: var(--shadow);
  border-color: var(--c-200);
}

.iso-assurance-body {
  padding: 0.5rem 0;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.iso-assurance-body .value {
  font-family: var(--fm);
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
}

.iso-assurance-body .audit-date {
  font-size: 0.75rem;
  color: var(--txt-3);
  margin-top: 0.2rem;
}

/* ─── Formulaire vérification ISO 14064-3 ──────────────────── */
.iso-veri-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0.5rem 0;
}

.iso-veri-form .f-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.iso-veri-form .f-group {
  margin-bottom: 0;
}

/* ─── Spinner de chargement ISO ──────────────────────────────── */
.iso-spinner {
  width: 24px;
  height: 24px;
  border: 2.5px solid var(--border);
  border-top-color: var(--primary);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto;
}

/* ─── Badge ISO dans la navigation ───────────────────────────── */
.ni-badge.iso {
  background: linear-gradient(135deg, #7c3aed, #a78bfa);
  color: #fff;
  font-size: 0.6rem;
  padding: 0.15rem 0.4rem;
  border-radius: 4px;
  font-weight: 700;
}

/* ─── Élément AI dans la navigation ────────────────────────── */
.ni.ai-item {
  position: relative;
}

.ni.ai-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--c-300), var(--c-400));
  border-radius: var(--r-sm) 0 0 var(--r-sm);
  opacity: 0;
  transition: opacity 0.2s ease;
}

.ni.ai-item:hover::before,
.ni.ai-item.active::before {
  opacity: 1;
}

/* ─── Navigation admin-only ──────────────────────────────────── */
.nav-admin-only {
  display: none;
}

.nav-admin-only.visible {
  display: flex;
}

/* ─── Textarea global (f-textarea) ──────────────────────────── */
.f-textarea {
  width: 100%;
  padding: 0.45rem 0.6rem;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--bg-1);
  color: var(--txt);
  font-size: 0.85rem;
  transition: var(--tr);
  outline: none;
  resize: vertical;
  min-height: 60px;
  font-family: inherit;
}

.f-textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(29,185,122,0.15);
}

/* ══════════════════════════════════════════════════════════════
   CORRECTION BOUTONS EDIT/DELETE — Projets & Produits
   ══════════════════════════════════════════════════════════════ */

/* ─── Boutons dans les cartes projet v2 ──────────────────────── */
.project-card-v2 .project-actions-v2 {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  padding: 0.7rem 1.2rem 1rem;
  margin-top: auto;
}

.project-card-v2 .project-actions-v2 .btn-sm {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-sm);
  font-size: 0.8rem;
  font-weight: 500;
  transition: var(--tr);
  cursor: pointer;
  font-family: inherit;
  line-height: 1.4;
}

.project-card-v2 .project-actions-v2 .btn-sm:hover {
  background: var(--bg-3);
  border-color: var(--c-200);
  color: var(--primary);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.project-card-v2 .project-actions-v2 .btn-sm:active {
  transform: translateY(0);
}

.project-card-v2 .project-actions-v2 .btn-sm i,
.project-card-v2 .project-actions-v2 .btn-sm svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.project-card-v2 .project-actions-v2 .btn-del {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  background: var(--bg-2);
  color: var(--rose);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-sm);
  font-size: 0.8rem;
  font-weight: 500;
  transition: var(--tr);
  cursor: pointer;
  font-family: inherit;
  line-height: 1.4;
}

.project-card-v2 .project-actions-v2 .btn-del:hover {
  background: var(--rose-dim);
  border-color: var(--rose);
  color: var(--rose);
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(220,38,38,0.15);
}

.project-card-v2 .project-actions-v2 .btn-del:active {
  transform: translateY(0);
}

.project-card-v2 .project-actions-v2 .btn-del i,
.project-card-v2 .project-actions-v2 .btn-del svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* ─── Boutons dans les cartes produit v2 ───────────────────── */
.product-card-v2 .product-actions-v2 {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  padding: 0.6rem 1.2rem 1rem;
  margin-top: auto;
}

.product-card-v2 .product-actions-v2 .btn-sm {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-sm);
  font-size: 0.8rem;
  font-weight: 500;
  transition: var(--tr);
  cursor: pointer;
  font-family: inherit;
  line-height: 1.4;
}

.product-card-v2 .product-actions-v2 .btn-sm:hover {
  background: var(--bg-3);
  border-color: var(--c-200);
  color: var(--primary);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.product-card-v2 .product-actions-v2 .btn-sm:active {
  transform: translateY(0);
}

.product-card-v2 .product-actions-v2 .btn-sm i,
.product-card-v2 .product-actions-v2 .btn-sm svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.product-card-v2 .product-actions-v2 .btn-del {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  background: var(--bg-2);
  color: var(--rose);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-sm);
  font-size: 0.8rem;
  font-weight: 500;
  transition: var(--tr);
  cursor: pointer;
  font-family: inherit;
  line-height: 1.4;
}

.product-card-v2 .product-actions-v2 .btn-del:hover {
  background: var(--rose-dim);
  border-color: var(--rose);
  color: var(--rose);
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(220,38,38,0.15);
}

.product-card-v2 .product-actions-v2 .btn-del:active {
  transform: translateY(0);
}

.product-card-v2 .product-actions-v2 .btn-del i,
.product-card-v2 .product-actions-v2 .btn-del svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

/* ─── Responsive boutons ───────────────────────────────────── */
@media (max-width: 768px) {
  .project-card-v2 .project-actions-v2,
  .product-card-v2 .product-actions-v2 {
    justify-content: stretch;
    padding: 0.6rem 1rem 0.8rem;
  }

  .project-card-v2 .project-actions-v2 .btn-sm,
  .project-card-v2 .project-actions-v2 .btn-del,
  .product-card-v2 .product-actions-v2 .btn-sm,
  .product-card-v2 .product-actions-v2 .btn-del {
    flex: 1;
    justify-content: center;
    padding: 0.5rem 0.6rem;
    font-size: 0.85rem;
  }

  .iso-page-hd {
    flex-direction: column;
    padding: 1rem;
    gap: 0.75rem;
  }

  .iso-page-hd-left {
    flex-direction: column;
    gap: 0.5rem;
  }

  .iso-page-badge {
    align-self: flex-start;
  }

  .iso-page-title {
    font-size: 1.1rem;
  }

  .iso-veri-form .f-row {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  .iso-assurance-card {
    padding: 0.75rem;
  }
}
/* ─── 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(-105%);width:260px;touch-action:pan-y pinch-zoom}
  .sidebar.open{transform:translateX(0);box-shadow:4px 0 24px rgba(0,0,0,.3)}
  .sidebar.open .sb-foot,.sidebar.open .sb-top{pointer-events:auto}
  .cw{margin-left:0}
  .hmbg{display:inline-flex;width:44px;height:44px;-webkit-tap-highlight-color:rgba(29,185,122,.2)}
  .hmbg:active{background:var(--bg-3);transform:scale(.95)}
  .g4,.g2,.synth-grid{grid-template-columns:1fr}
  .auth-wrap{grid-template-columns:1fr;max-width:420px}
  .auth-hero{display:none}
  .topbar{padding:0 .75rem;height:56px}
  .tb-ttl h1{font-size:.95rem}
  .tb-sub{display:none}
  .bl{display:none}
  .main{padding:1rem}
  .ai-hero{flex-direction:column;gap:.75rem}
  body.sidebar-open{overflow:hidden;position:fixed;width:100%;touch-action:none}
  .cw.sidebar-open{filter:blur(1px);transition:filter .3s ease}

  .sidebar .sb-top{padding:.3rem .6rem .15rem}
  .sidebar .brand{padding:.25rem .2rem;min-height:36px}
  .sidebar .brand-ico{width:24px;height:24px}
  .sidebar .brand-name{font-size:.9rem}
  .sidebar .brand-tag{font-size:.6rem}
  .sidebar .nav-sec{padding:.2rem .6rem .1rem;font-size:.58rem;letter-spacing:.1em}
  .sidebar nav{padding:0 .3rem .15rem}
  .sidebar .ni{padding:.35rem .65rem;font-size:.8rem;min-height:36px;margin-bottom:.02rem;gap:.35rem}
  .sidebar .ni i{width:16px;height:16px}
  .sidebar .ni-cnt{font-size:.65rem;padding:.08rem .3rem;min-width:18px;text-align:center}
  .sidebar .ni-badge{font-size:.58rem;padding:.08rem .3rem}
  .sidebar .sb-foot{padding:.25rem .6rem .15rem}
  .sidebar .yr-box{margin-bottom:.2rem}
  .sidebar .yr-label{font-size:.6rem;margin-bottom:.1rem}
  .sidebar .yr-sel{padding:.3rem .45rem;font-size:.78rem;min-height:30px}
  .sidebar .ico-btn{width:28px;height:28px}
  .sidebar .user-tile{padding:.3rem .4rem;min-height:34px}
  .sidebar .user-av{width:28px;height:28px;font-size:.8rem}
  .sidebar .user-nm{font-size:.76rem}
  .sidebar .user-rl{font-size:.68rem}
  .sidebar .logout-btn{padding:.35rem;font-size:.72rem;min-height:32px}
  .sidebar::after{content:'';position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(90deg,transparent,rgba(0,0,0,.1));pointer-events:none;opacity:0;transition:opacity .3s}
  .sidebar.open::after{opacity:1}

  /* ISO responsive */
  .project-header, .product-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .project-metrics, .product-details {
    flex-direction: column;
    gap: 0.4rem;
  }
  .form-row {
    flex-direction: column;
    gap: 0.6rem;
  }
  .iso-requirements-grid {
    grid-template-columns: 1fr;
  }

  /* ADEME/Transport/Users responsive */
  .toolbar {
    flex-direction: column;
    align-items: stretch;
  }
  .toolbar-left, .toolbar-right {
    justify-content: space-between;
    width: 100%;
  }
  .search-input {
    width: 100%;
  }
  .filter-group {
    flex-wrap: wrap;
  }
  .ademe-dt, .transport-dt, .user-table {
    font-size: 0.75rem;
  }
  .ademe-dt th, .transport-dt th, .user-table th {
    padding: 0.4rem 0.5rem;
  }
  .ademe-dt td, .transport-dt td, .user-table td {
    padding: 0.4rem 0.5rem;
  }
  .pagination button {
    min-width: 60px;
    font-size: 0.7rem;
  }
}

/* ─── 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}
}

/* ══════════════════════════════════════════════════════════════
   AMÉLIORATIONS CATALOGUE PRODUITS & PORTEFEUILLE PROJETS
   ══════════════════════════════════════════════════════════════ */

/* ─── Grille de cartes ─────────────────────────────────────── */
.projects-grid,
.products-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 1rem;
  padding: 0.25rem 0;
  min-height: 60px;
}

@media (max-width: 768px) {
  .projects-grid,
  .products-grid {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
}

@media (min-width: 1400px) {
  .projects-grid,
  .products-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ─── Carte projet (ISO 14064-2) ───────────────────────────── */
.project-card-v2 {
  background: var(--bg-1);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  padding: 0;
  transition: var(--tr);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
}

.project-card-v2::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-400), var(--c-300));
  opacity: 0.7;
  transition: opacity 0.3s ease;
}

.project-card-v2:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--c-200);
  transform: translateY(-2px);
}

.project-card-v2:hover::before {
  opacity: 1;
}

.project-card-v2 .project-header-v2 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.2rem 0.6rem;
  flex-wrap: wrap;
}

.project-card-v2 .project-name-v2 {
  font-weight: 700;
  font-size: 1rem;
  color: var(--txt);
  line-height: 1.3;
  flex: 1;
  min-width: 0;
  word-break: break-word;
}

.project-card-v2 .project-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.7rem;
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 700;
  flex-shrink: 0;
  white-space: nowrap;
}

.project-card-v2 .project-type-badge.reduction {
  background: linear-gradient(135deg, rgba(29,185,122,0.12), rgba(61,214,140,0.08));
  color: var(--c-500);
  border: 1px solid rgba(29,185,122,0.25);
}

.project-card-v2 .project-type-badge.removal {
  background: linear-gradient(135deg, rgba(14,165,233,0.12), rgba(56,189,248,0.08));
  color: #0ea5e9;
  border: 1px solid rgba(14,165,233,0.25);
}

.project-card-v2 .project-metrics-v2 {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.6rem 1.2rem;
  background: var(--bg-2);
  margin: 0 0.8rem;
  border-radius: var(--r-sm);
}

.project-card-v2 .project-metric-v2 {
  display: flex;
  align-items: baseline;
  gap: 0.3rem;
  font-size: 0.8rem;
  color: var(--txt-2);
}

.project-card-v2 .project-metric-v2 strong {
  font-weight: 600;
  color: var(--txt);
}

.project-card-v2 .project-metric-v2 .metric-value {
  font-family: var(--fm);
  font-weight: 700;
  color: var(--primary);
}

.project-card-v2 .project-metric-v2 .metric-arrow {
  color: var(--txt-3);
  font-size: 0.75rem;
}

.project-card-v2 .project-meta-v2 {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem 1.2rem;
  font-size: 0.75rem;
  color: var(--txt-3);
  padding: 0.6rem 1.2rem 0.4rem;
  border-top: 1px solid var(--border-2);
  margin-top: 0.3rem;
}

.project-card-v2 .project-meta-item {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.project-card-v2 .project-meta-item i {
  width: 14px;
  height: 14px;
  opacity: 0.6;
}

.project-card-v2 .project-additionality-v2 {
  font-size: 0.72rem;
  color: var(--amber);
  background: rgba(217,119,6,0.06);
  padding: 0.35rem 0.7rem;
  border-radius: var(--r-sm);
  margin: 0.3rem 1.2rem;
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  line-height: 1.4;
}

.project-card-v2 .project-additionality-v2 i {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  margin-top: 0.1rem;
}

.project-card-v2 .project-additionality-v2 .add-text {
  flex: 1;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.project-card-v2 .project-actions-v2 {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  padding: 0.7rem 1.2rem 1rem;
  margin-top: auto;
}

.project-card-v2 .project-actions-v2 .btn-sm {
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1px solid var(--border-2);
  padding: 0.35rem 0.8rem;
  border-radius: var(--r-sm);
  font-size: 0.78rem;
  transition: var(--tr);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.project-card-v2 .project-actions-v2 .btn-sm:hover {
  background: var(--bg-3);
  border-color: var(--c-200);
  color: var(--primary);
}

.project-card-v2 .project-actions-v2 .btn-del {
  background: var(--bg-2);
  color: var(--rose);
  border: 1px solid var(--border-2);
  padding: 0.35rem 0.8rem;
  border-radius: var(--r-sm);
  font-size: 0.78rem;
  transition: var(--tr);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.project-card-v2 .project-actions-v2 .btn-del:hover {
  background: var(--rose-dim);
  border-color: var(--rose);
}

/* ─── Barre de progression projet ──────────────────────────── */
.project-progress-bar {
  width: 100%;
  height: 6px;
  background: var(--bg-5);
  border-radius: 3px;
  overflow: hidden;
  margin: 0.3rem 1.2rem 0.5rem;
  max-width: calc(100% - 2.4rem);
}

.project-progress-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s ease;
  background: linear-gradient(90deg, var(--c-400), var(--c-300));
}

.project-progress-fill.reduction {
  background: linear-gradient(90deg, var(--c-400), var(--c-300));
}

.project-progress-fill.removal {
  background: linear-gradient(90deg, #0ea5e9, #38bdf8);
}

/* ─── Carte produit (ISO 14067) ────────────────────────────── */
.product-card-v2 {
  background: var(--bg-1);
  border: 1.5px solid var(--border-2);
  border-radius: var(--r-md);
  padding: 0;
  transition: var(--tr);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
}

.product-card-v2::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--c-300), var(--c-400));
  opacity: 0.7;
  transition: opacity 0.3s ease;
}

.product-card-v2:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--c-200);
  transform: translateY(-2px);
}

.product-card-v2:hover::before {
  opacity: 1;
}

.product-card-v2 .product-header-v2 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.2rem 0.5rem;
  flex-wrap: wrap;
}

.product-card-v2 .product-name-v2 {
  font-weight: 700;
  font-size: 1rem;
  color: var(--txt);
  line-height: 1.3;
  flex: 1;
  min-width: 0;
  word-break: break-word;
}

.product-card-v2 .product-fu-badge {
  font-family: var(--fm);
  font-size: 0.72rem;
  color: var(--primary);
  background: linear-gradient(135deg, var(--bg-3), var(--bg-4));
  padding: 0.25rem 0.6rem;
  border-radius: 16px;
  border: 1px solid var(--c-200);
  flex-shrink: 0;
  white-space: nowrap;
}

.product-card-v2 .product-pcf-v2 {
  padding: 0.3rem 1.2rem 0.6rem;
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
}

.product-card-v2 .product-pcf-value {
  font-family: var(--fm);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--em);
  line-height: 1;
}

.product-card-v2 .product-pcf-unit {
  font-size: 0.78rem;
  color: var(--txt-3);
  font-weight: 500;
}

.product-card-v2 .product-details-v2 {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  font-size: 0.78rem;
  color: var(--txt-2);
  padding: 0.5rem 1.2rem;
  background: var(--bg-2);
  margin: 0 0.8rem;
  border-radius: var(--r-sm);
}

.product-card-v2 .product-detail-v2 {
  display: flex;
  align-items: center;
  gap: 0.3rem;
}

.product-card-v2 .product-detail-v2 strong {
  font-weight: 600;
  color: var(--txt);
}

.product-card-v2 .product-detail-v2 .detail-icon {
  width: 14px;
  height: 14px;
  opacity: 0.5;
  color: var(--primary);
}

.product-card-v2 .product-uncertainty-v2 {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.72rem;
  color: var(--amber);
  padding: 0.4rem 1.2rem 0.2rem;
}

.product-card-v2 .product-uncertainty-v2 i {
  width: 14px;
  height: 14px;
}

.product-card-v2 .product-contrib-v2 {
  font-size: 0.72rem;
  color: var(--txt-3);
  padding: 0.4rem 1.2rem;
  line-height: 1.5;
  border-top: 1px solid var(--border-2);
  margin-top: 0.3rem;
}

.product-card-v2 .product-contrib-v2 .contrib-label {
  font-weight: 600;
  color: var(--txt-2);
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-bottom: 0.2rem;
}

.product-card-v2 .product-contrib-v2 .contrib-label i {
  width: 14px;
  height: 14px;
  opacity: 0.6;
}

.product-card-v2 .product-contrib-v2 .contrib-text {
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  font-style: italic;
}

.product-card-v2 .product-actions-v2 {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  padding: 0.6rem 1.2rem 1rem;
  margin-top: auto;
}

.product-card-v2 .product-actions-v2 .btn-sm {
  background: var(--bg-2);
  color: var(--txt-2);
  border: 1px solid var(--border-2);
  padding: 0.35rem 0.8rem;
  border-radius: var(--r-sm);
  font-size: 0.78rem;
  transition: var(--tr);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.product-card-v2 .product-actions-v2 .btn-sm:hover {
  background: var(--bg-3);
  border-color: var(--c-200);
  color: var(--primary);
}

.product-card-v2 .product-actions-v2 .btn-del {
  background: var(--bg-2);
  color: var(--rose);
  border: 1px solid var(--border-2);
  padding: 0.35rem 0.8rem;
  border-radius: var(--r-sm);
  font-size: 0.78rem;
  transition: var(--tr);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  cursor: pointer;
}

.product-card-v2 .product-actions-v2 .btn-del:hover {
  background: var(--rose-dim);
  border-color: var(--rose);
}

/* ─── Indicateur de réduction ──────────────────────────────── */
.reduction-indicator {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 1.2rem;
  font-size: 0.8rem;
}

.reduction-indicator .ri-label {
  color: var(--txt-3);
  font-size: 0.72rem;
}

.reduction-indicator .ri-value {
  font-family: var(--fm);
  font-weight: 700;
  color: var(--em);
}

.reduction-indicator .ri-pct {
  font-family: var(--fm);
  font-weight: 600;
  font-size: 0.78rem;
  padding: 0.15rem 0.4rem;
  border-radius: 4px;
  background: rgba(29,185,122,0.1);
  color: var(--c-500);
}

.reduction-indicator .ri-pct.negative {
  background: rgba(220,38,38,0.1);
  color: var(--rose);
}

/* ─── Responsive ───────────────────────────────────────────── */
@media (max-width: 768px) {
  .project-card-v2 .project-header-v2,
  .product-card-v2 .product-header-v2 {
    flex-direction: column;
    align-items: flex-start;
  }

  .project-card-v2 .project-metrics-v2,
  .product-card-v2 .product-details-v2 {
    flex-direction: column;
    gap: 0.3rem;
  }

  .project-card-v2 .project-meta-v2,
  .product-card-v2 .product-details-v2 {
    gap: 0.4rem 0.8rem;
  }

  .project-card-v2 .project-actions-v2,
  .product-card-v2 .product-actions-v2 {
    justify-content: stretch;
  }

  .project-card-v2 .project-actions-v2 .btn-sm,
  .project-card-v2 .project-actions-v2 .btn-del,
  .product-card-v2 .product-actions-v2 .btn-sm,
  .product-card-v2 .product-actions-v2 .btn-del {
    flex: 1;
    justify-content: center;
  }
}

/* ══════════════════════════════════════════════════════════
   RBAC — Navigation conditionnelle
   .nav-admin-only masqué par défaut, révélé par RBAC.applyUI()
   ══════════════════════════════════════════════════════════ */
.nav-admin-only {
  display: none;
}

/* ══════════════════════════════════════════════════════════
   FIX — Boutons edit/delete cartes projet & produit v2
   Corrige le conflit avec .btn-del { width:28px; height:28px }
   ══════════════════════════════════════════════════════════ */
.project-card-v2 .project-actions-v2 .btn-del,
.product-card-v2  .product-actions-v2  .btn-del {
  width: auto !important;
  height: auto !important;
  border: 1.5px solid var(--border-2) !important;
  padding: .4rem .85rem !important;
  gap: .35rem !important;
  font-size: .8rem !important;
  font-weight: 500 !important;
  font-family: inherit !important;
  line-height: 1.4 !important;
  background: var(--bg-2) !important;
}
.project-card-v2 .project-actions-v2 .btn-del:hover,
.product-card-v2  .product-actions-v2  .btn-del:hover {
  background: rgba(220,38,38,.08) !important;
  border-color: var(--rose) !important;
}