/* ============================================================
   ESPACE PRIVÉ INGEN INDUSTRIE — cockpit (style sombre, marque ambre)
   ============================================================ */
:root{
  --bg:#16181d; --sidebar:#101218; --panel:#1d2027; --panel-2:#23262e; --elev:#282c35;
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.15);
  --amber:#f5b14c; --amber-deep:#e8902b; --amber-rgb:245,177,76;
  --text:#eef0f4; --muted:#9aa0ab; --green:#3ecf6a; --red:#ff5f57; --blue:#3db4ff;
  --font-d:'Space Grotesk',system-ui,sans-serif; --font-b:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
[hidden]{display:none!important}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-b);-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-d);font-weight:700;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}

/* ---------- Connexion (écran premium) ---------- */
.auth{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow:hidden}
.auth-bg{position:absolute;inset:0;z-index:0}
.auth-bg video{width:100%;height:100%;object-fit:cover;opacity:.35}
.auth-bg-tint{position:absolute;inset:0;background:
  radial-gradient(55% 45% at 50% 38%,rgba(var(--amber-rgb),.12),transparent 70%),
  linear-gradient(180deg,rgba(16,18,24,.9),rgba(16,18,24,.82) 45%,rgba(16,18,24,.94))}
.auth-card{position:relative;z-index:1;width:min(400px,100%);text-align:center;border:1px solid var(--line-2);border-radius:1.4rem;
  background:rgba(29,32,39,.82);backdrop-filter:blur(18px);
  box-shadow:0 50px 120px -50px #000,0 0 80px -50px rgba(var(--amber-rgb),.4);padding:2.8rem 2.2rem 2rem;
  animation:authIn .6s cubic-bezier(.22,.61,.36,1)}
@keyframes authIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.auth-logo{height:2.6rem;width:auto;margin-bottom:1.6rem;filter:drop-shadow(0 0 26px rgba(var(--amber-rgb),.35))}
.auth-kicker{display:inline-block;color:var(--amber);font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:600;margin-bottom:.7rem}
.auth h1{font-size:1.7rem;margin:0 0 .4rem}
.auth-sub{color:var(--muted);font-size:.9rem;line-height:1.5;margin:0 auto 1.8rem;max-width:30ch}
#authForm{display:flex;flex-direction:column;gap:.8rem}
#authForm input{padding:.95rem 1.1rem;border-radius:.8rem;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);font-size:1rem;transition:border-color .2s,background .2s}
#authForm input::placeholder{color:var(--muted)}
#authForm input:focus{outline:none;border-color:var(--amber);background:rgba(255,255,255,.07)}
#authBtn{margin-top:.3rem;padding:.95rem;border:none;border-radius:.8rem;background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#0a0b0d;font-weight:700;font-size:1rem;letter-spacing:.01em;transition:transform .2s,box-shadow .2s}
#authBtn:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px rgba(var(--amber-rgb),.7)}
.auth-err{color:var(--red);font-size:.85rem;min-height:1rem;margin:.4rem 0 0}
.auth-foot{margin-top:1.8rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.06);color:var(--muted);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}
/* champs labellisés + options */
.afield{display:flex;flex-direction:column;gap:.35rem;text-align:left}
.afield>span{font-size:.74rem;color:var(--muted);letter-spacing:.02em}
.pw-wrap{position:relative;display:flex}
.pw-wrap input{flex:1;padding-right:4.6rem}
.pw-eye{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--muted);font-size:.78rem;cursor:pointer;padding:.3rem .4rem}
.pw-eye:hover{color:var(--amber)}
.auth-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;font-size:.82rem;margin-top:-.1rem}
.remember{display:flex;align-items:center;gap:.45rem;color:var(--muted);cursor:pointer}
.remember input{accent-color:var(--amber);width:auto}
.auth-link{color:var(--amber);text-decoration:none;font-size:.82rem}
.auth-link:hover{text-decoration:underline}
/* mot de passe oublié */
.forgot-box{text-align:left}
.forgot-box h2{font-size:1.15rem;margin:0 0 .8rem}
.forgot-box p{color:var(--muted);font-size:.88rem;line-height:1.55;margin:.5rem 0}
.forgot-box strong{color:var(--text)}
.forgot-cmd{display:block;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:.5rem;padding:.6rem .7rem;font-family:ui-monospace,monospace;font-size:.78rem;color:var(--amber);margin:.6rem 0 1rem;word-break:break-all}

/* ---------- App shell (sidebar + main) ---------- */
.app{min-height:100vh;display:flex}
.sidebar{width:244px;flex-shrink:0;height:100vh;position:sticky;top:0;overflow-y:auto;display:flex;flex-direction:column;
  padding:1.1rem .8rem;border-right:1px solid var(--line);background:var(--sidebar)}
.side-logo img{height:1.9rem;width:auto;margin:.3rem .6rem 1.5rem}
.side-group{margin-bottom:1.3rem}
.side-label{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);padding:0 .6rem;margin-bottom:.5rem}
.side-item{display:flex;align-items:center;gap:.7rem;width:100%;padding:.6rem .7rem;border-radius:.6rem;border:none;background:transparent;color:var(--muted);font-size:.9rem;text-align:left;cursor:pointer;transition:background .15s,color .15s}
.side-item svg{width:1.15rem;height:1.15rem;flex-shrink:0}
.side-item:hover{background:rgba(255,255,255,.04);color:var(--text)}
.side-item.active{background:rgba(var(--amber-rgb),.12);color:var(--amber)}
.side-companies{display:flex;flex-direction:column;gap:.15rem}
.co-ava{width:1.6rem;height:1.6rem;border-radius:.45rem;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:.58rem;background:rgba(255,255,255,.06);border:1px solid var(--line);flex-shrink:0}
.co-ava.all{color:var(--muted)}
.side-companies .tag{margin-left:auto;font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.side-bottom{margin-top:auto;margin-bottom:0}

/* ---------- Zone principale + topbar ---------- */
.main-wrap{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:1rem;padding:1rem clamp(1rem,2.5vw,2rem);border-bottom:1px solid var(--line);
  background:rgba(16,18,24,.88);backdrop-filter:blur(10px);position:sticky;top:0;z-index:6}
.topbar-title{flex:1;min-width:0}
.topbar-title .crumb{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.topbar-title h1{font-family:var(--font-d);font-size:1.25rem;margin:.05rem 0 0}
.topbar-actions{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.user-chip{font-size:.8rem;color:var(--text);padding:.32rem .7rem;border:1px solid var(--line);border-radius:999px}
.user-chip b{color:var(--amber);font-weight:600}
.side-toggle{display:none;background:transparent;border:1px solid var(--line);color:var(--text);border-radius:.5rem;font-size:1.1rem;padding:.2rem .6rem;cursor:pointer}
.save-state{font-size:.8rem;color:var(--muted)}
.save-state.dirty{color:var(--amber)}
.save-state.saved{color:var(--green)}
.btn{padding:.55rem 1.1rem;border-radius:.6rem;border:1px solid var(--line);background:transparent;color:var(--text);font-size:.85rem;font-weight:500;transition:.2s;cursor:pointer}
.btn-amber{background:linear-gradient(135deg,var(--amber),var(--amber-deep));color:#0a0b0d;border:none;font-weight:700}
.btn-amber:hover{transform:translateY(-1px);box-shadow:0 8px 24px -8px rgba(var(--amber-rgb),.6)}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber)}

/* ---------- Contenu ---------- */
.cock-main{padding:1.8rem clamp(1.2rem,3vw,2.6rem) 4rem;width:100%;flex:1;max-width:1600px;margin:0 auto}
.section-title{font-size:1.2rem;margin:0 0 1rem}
.page-head{margin-bottom:1.5rem}
.page-head h1{font-family:var(--font-d);font-size:1.7rem;margin:0}
.page-sub{color:var(--muted);font-size:.92rem;margin:.35rem 0 0}
.muted{color:var(--muted)}

/* note d'information */
.note{display:flex;gap:.8rem;align-items:flex-start;border:1px solid var(--line);border-radius:.8rem;background:rgba(var(--amber-rgb),.05);padding:.9rem 1.1rem;margin-bottom:1.4rem;color:var(--muted);font-size:.88rem;line-height:1.5}
.note-ico{flex-shrink:0;width:1.3rem;height:1.3rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(var(--amber-rgb),.18);color:var(--amber);font-family:var(--font-d);font-weight:700;font-size:.75rem}

/* panneaux (cartes titrées façon design) */
.panel{border:1px solid var(--line);border-radius:1rem;background:var(--panel);padding:1.3rem 1.4rem;margin-bottom:1.4rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}
.panel-head h2{font-size:1rem;margin:0}
.panel-head .muted{font-size:.82rem}

/* avatar initiales + statut */
.ava{width:2rem;height:2rem;border-radius:.5rem;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:.7rem;background:rgba(var(--amber-rgb),.16);color:var(--amber);vertical-align:middle;margin-right:.6rem;flex-shrink:0}
.cell-id{display:flex;align-items:center}
.status{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--green)}
.status .sdot{width:.5rem;height:.5rem;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}

/* rôle en pastille (select stylé) */
.role-sel{appearance:none;-webkit-appearance:none;border-radius:999px;padding:.3rem 1.6rem .3rem .8rem;font-size:.75rem;font-weight:600;cursor:pointer;
  background:rgba(var(--amber-rgb),.14) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M2 3l3 3 3-3' stroke='%23888e99' stroke-width='1.4' fill='none' stroke-linecap='round'/></svg>") no-repeat right .6rem center;
  color:var(--amber);border:1px solid rgba(var(--amber-rgb),.3);width:auto!important}
.role-sel.role-membre{background-color:rgba(255,255,255,.06);color:var(--text);border-color:var(--line)}
.role-sel option{background:var(--panel-2);color:var(--text)}

/* boutons d'action ligne */
.cell-actions{white-space:nowrap;text-align:right}
.act-btn{background:transparent;border:1px solid var(--line);color:var(--muted);font-size:.76rem;padding:.32rem .6rem;border-radius:.5rem;margin-left:.35rem;transition:.15s}
.act-btn:hover{border-color:var(--amber);color:var(--amber)}
.act-del:hover{border-color:var(--red);color:#ff8a84}
.act-btn[disabled]{opacity:.3;cursor:not-allowed}

/* formulaire labellisé */
.form-grid{display:flex;gap:.9rem;flex-wrap:wrap;align-items:flex-end}
.form-grid .field{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:160px}
.form-grid .field span{font-size:.72rem;color:var(--muted);letter-spacing:.03em}
.form-grid input,.form-grid select{padding:.7rem .9rem;border-radius:.6rem;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);font-size:.9rem}
.form-grid input:focus,.form-grid select:focus{outline:none;border-color:var(--amber)}
.form-grid select option{background:var(--panel-2)}
.form-note{color:var(--muted);font-size:.78rem;margin:.9rem 0 0}

/* cartes KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.6rem}
.kpi{border:1px solid var(--line);border-radius:.9rem;padding:1.2rem 1.3rem;background:var(--panel)}
.kpi .label{font-size:.78rem;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.kpi .val{font-family:var(--font-d);font-weight:700;font-size:1.7rem;margin-top:.35rem}
.kpi .val.amber{color:var(--amber)} .kpi .val.green{color:var(--green)} .kpi .val.red{color:var(--red)}

/* cartes sociétés (overview) */
.co-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.co-card{border:1px solid var(--line);border-radius:.9rem;padding:1.3rem;background:var(--panel)}
.co-card h3{margin:0 0 .2rem;font-size:1.1rem}
.co-card .co-meta{color:var(--muted);font-size:.82rem;margin-bottom:1rem}
.co-card .co-row{display:flex;justify-content:space-between;font-size:.9rem;padding:.35rem 0;border-top:1px solid rgba(255,255,255,.05)}
.co-card .co-row span:last-child{font-family:var(--font-d);font-weight:600}
.num-inline{width:8rem;text-align:right;background:transparent;border:1px solid transparent;border-radius:.4rem;color:var(--text);font-family:var(--font-d);font-weight:600;font-size:.9rem;padding:.25rem .4rem}
.num-inline:hover{border-color:rgba(255,255,255,.12)}
.num-inline:focus{outline:none;border-color:var(--amber);background:rgba(255,255,255,.05)}

/* tableaux / listes éditables */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.data-table{width:100%;border-collapse:collapse;font-size:.9rem}
.data-table th{text-align:left;color:var(--muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;padding:.6rem .6rem;border-bottom:1px solid var(--line)}
.data-table td{padding:.45rem .6rem;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}
.data-table tr.done td{opacity:.5}
.data-table input,.data-table select{width:100%;background:transparent;border:1px solid transparent;border-radius:.4rem;color:var(--text);padding:.35rem .4rem;font-size:.9rem}
.data-table input:hover,.data-table select:hover{border-color:rgba(255,255,255,.1)}
.data-table input:focus,.data-table select:focus{outline:none;border-color:var(--amber);background:rgba(255,255,255,.04)}
.data-table input[type=date]{color-scheme:dark}
.data-table select option{background:var(--panel-2)}
.cell-num input{text-align:right}
.row-del{background:transparent;border:none;color:var(--muted);font-size:1.1rem;line-height:1;padding:.2rem .4rem;border-radius:.4rem}
.row-del:hover{color:var(--red);background:rgba(255,95,87,.1)}
.add-btn{padding:.55rem 1rem;border-radius:.6rem;border:1px dashed var(--line);background:transparent;color:var(--amber);font-size:.85rem}
.add-btn:hover{border-color:var(--amber);background:rgba(var(--amber-rgb),.06)}

/* badges échéances */
.pill{display:inline-block;padding:.2rem .6rem;border-radius:999px;font-size:.72rem;font-weight:600}
.pill.late{background:rgba(255,95,87,.15);color:#ff8a84}
.pill.soon{background:rgba(245,177,76,.15);color:var(--amber)}
.pill.ok{background:rgba(54,178,74,.15);color:#5fd17a}
.pill.done{background:rgba(255,255,255,.08);color:var(--muted)}

.notes-area{width:100%;min-height:50vh;background:var(--panel);border:1px solid var(--line);border-radius:1rem;color:var(--text);padding:1.2rem;font-size:.95rem;line-height:1.6;resize:vertical}
.notes-area:focus{outline:none;border-color:var(--amber)}

/* module Accès */
.user-add{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.user-add input,.user-add select{padding:.7rem .9rem;border-radius:.6rem;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text);font-size:.9rem}
.user-add input:focus,.user-add select:focus{outline:none;border-color:var(--amber)}
.user-add select option{background:var(--panel-2)}
.row-del[disabled]{opacity:.25;cursor:not-allowed}

/* ---------- Responsive : sidebar repliable ---------- */
@media (max-width:860px){
  .side-toggle{display:inline-block}
  .sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 50px rgba(0,0,0,.7)}
  .sidebar.open{transform:none}
  .data-table{font-size:.82rem}
}

/* ============================================================
   Design moderne / épuré / légèrement futuriste (IA · SaaS)
   ============================================================ */
body{background:radial-gradient(1000px 540px at 84% -14%, rgba(var(--amber-rgb),.07), transparent 62%), var(--bg)}

/* sidebar : libellés + item actif (barre ambre + glow) */
.side-label{font-weight:600;opacity:.8;margin-top:.4rem}
.side-item{border-radius:.7rem;font-weight:450}
.side-item.active{background:linear-gradient(90deg,rgba(var(--amber-rgb),.15),rgba(var(--amber-rgb),.03));color:var(--amber)}
.side-item.active::before{content:"";position:absolute;left:0;top:.4rem;bottom:.4rem;width:3px;border-radius:0 3px 3px 0;background:var(--amber);box-shadow:0 0 12px rgba(var(--amber-rgb),.7)}
.soon{margin-left:auto;font-size:.56rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:999px;padding:.1rem .42rem;white-space:nowrap}
.side-item.active .soon{color:var(--amber);border-color:rgba(var(--amber-rgb),.4)}

/* titres de page */
.page-head h1{font-size:1.85rem;letter-spacing:-.02em}

/* panneaux : profondeur subtile */
.panel{background:linear-gradient(180deg,rgba(255,255,255,.022),transparent),var(--panel);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03),0 22px 50px -42px rgba(0,0,0,.85);border-radius:1rem}
.panel-head h2{font-size:1.02rem;letter-spacing:-.01em}

/* KPI modernes */
.kpi{background:linear-gradient(180deg,rgba(255,255,255,.022),transparent),var(--panel);transition:transform .25s,box-shadow .25s,border-color .25s}
.kpi:hover{transform:translateY(-3px);border-color:rgba(var(--amber-rgb),.35);box-shadow:0 26px 54px -38px rgba(0,0,0,.9)}
.kpi .val{font-size:1.85rem}

/* tableaux : lignes qui réagissent */
.data-table tbody tr{transition:background .15s}
.data-table tbody tr:hover{background:rgba(255,255,255,.025)}

/* cartes sociétés */
.co-card{background:linear-gradient(180deg,rgba(255,255,255,.022),transparent),var(--panel)}

/* module "bientôt" */
.soon-panel{border:1px dashed var(--line-2);border-radius:1rem;padding:2.6rem 2rem;background:rgba(255,255,255,.015);max-width:640px}
.soon-badge{display:inline-block;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);background:rgba(var(--amber-rgb),.12);border:1px solid rgba(var(--amber-rgb),.3);border-radius:999px;padding:.3rem .8rem;margin-bottom:1.1rem}
.soon-panel h2{font-family:var(--font-d);font-size:1.45rem;margin:0 0 .7rem}
.soon-panel p{color:var(--muted);line-height:1.65;margin:.5rem 0;max-width:54ch}

/* alertes */
.alert-row{display:flex;align-items:center;gap:1rem;padding:.7rem .2rem;border-top:1px solid var(--line)}
.alert-row:first-of-type{border-top:none}
.alert-lbl{flex:1;min-width:0;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.alert-date{color:var(--muted);font-size:.85rem;white-space:nowrap}

/* boutons : focus accessible */
.btn:focus-visible,.side-item:focus-visible,.add-btn:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

/* ============================================================
   Direction "salle de contrôle / labo" — moderne, épuré, ambre HUD
   ============================================================ */
/* grille HUD très discrète en fond du contenu */
.main-wrap{position:relative}
.main-wrap::before{content:"";position:fixed;inset:0 0 0 244px;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.014) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.014) 1px,transparent 1px);
  background-size:44px 44px;mask-image:radial-gradient(120% 80% at 70% 0%,#000,transparent 75%)}
.topbar,.cock-main{position:relative;z-index:1}

/* en-tête de page : libellé ambre type "console" + filet */
.page-head{padding-bottom:1rem;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:.15rem}
.page-head h1{display:flex;align-items:center;gap:.6rem}
.page-head h1::before{content:"";width:.55rem;height:.55rem;border-radius:1px;background:var(--amber);box-shadow:0 0 10px rgba(var(--amber-rgb),.8);transform:rotate(45deg)}

/* panneaux : liseré ambre discret au survol */
.panel{transition:border-color .25s,box-shadow .25s}
.panel:hover{border-color:rgba(var(--amber-rgb),.18)}
.panel-head h2{position:relative;padding-left:.75rem}
.panel-head h2::before{content:"";position:absolute;left:0;top:.15em;bottom:.15em;width:2px;border-radius:2px;background:var(--amber);opacity:.85}

/* KPI : label "instrument" + valeur en display */
.kpi{position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--amber),transparent 70%);opacity:.5}
.kpi .label{font-size:.68rem;letter-spacing:.12em}
.kpi .val{font-family:var(--font-d)}

/* tableau de bord pleine largeur */
.dash-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:1.2rem;align-items:start}
.dash-grid .panel{margin:0}
.dash-grid + .section-title{margin-top:1.8rem}
@media (max-width:980px){ .dash-grid{grid-template-columns:1fr} }

/* listes "data" : interlignes + chiffres alignés */
.co-row{align-items:center}
.mini-list .co-row:first-child{border-top:none}

/* ============================================================
   Modules complets : fiche société · conformité · organigramme
   ============================================================ */

/* champ "check" (case à cocher alignée) */
.field.check{flex-direction:row;align-items:center;justify-content:space-between;gap:.6rem}
.field.check input{width:1.1rem;height:1.1rem;accent-color:var(--amber)}

/* fiche société */
.fiche-head{display:flex;align-items:center;gap:.9rem;margin:.2rem 0 1rem}
.fiche-name{font-family:var(--font-d);font-weight:700;font-size:1.15rem}
.fiche-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.fiche-tab{padding:.5rem .9rem;border:1px solid var(--line);border-radius:.7rem;background:var(--panel-2);color:var(--muted);font-size:.85rem;font-weight:600}
.fiche-tab:hover{color:var(--text);border-color:var(--line-2)}
.fiche-tab.active{color:#0a0b0d;background:linear-gradient(135deg,var(--amber),var(--amber-deep));border-color:transparent}
.co-pick{cursor:default}

/* conformité */
.conf-row{display:grid;grid-template-columns:9.5rem 1fr 9rem 1.6rem;gap:.6rem;align-items:center;padding:.5rem 0;border-top:1px solid var(--line)}
.conf-row:first-of-type{border-top:none}
.conf-item{font-size:.9rem;display:flex;flex-direction:column;gap:.15rem}
.conf-cat{font-size:.68rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.conf-row.fait .conf-item{opacity:.65}
.conf-row.fait .conf-item:first-child{text-decoration:line-through}
.conf-sel,.conf-date{padding:.4rem .5rem;border:1px solid var(--line);border-radius:.55rem;background:var(--panel-2);color:var(--text);font-size:.8rem}
.conf-sel.s-fait{color:var(--green);border-color:rgba(62,207,106,.4)}
.conf-sel.s-na{color:var(--muted)}
.score{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--muted);font-weight:600}
.score-bar{width:90px;height:6px;border-radius:4px;background:rgba(255,255,255,.08);overflow:hidden}
.score-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--amber),var(--green))}

/* badge auto */
.tag.auto{background:rgba(var(--amber-rgb),.14);color:var(--amber);border-color:rgba(var(--amber-rgb),.3);margin-left:.4rem}

/* organigramme */
.org-chart{display:flex;flex-direction:column;align-items:center;gap:0;padding:.6rem 0 .2rem}
.org-top{display:flex;justify-content:center}
.org-bar{width:2px;height:1.3rem;background:var(--line-2)}
.org-row{display:flex;gap:1.2rem;flex-wrap:wrap;justify-content:center;position:relative;padding-top:1.3rem}
.org-branch{position:relative}
.org-branch::before{content:"";position:absolute;top:-1.3rem;left:50%;width:2px;height:1.3rem;background:var(--line-2)}
.org-row::before{content:"";position:absolute;top:0;left:10%;right:10%;height:2px;background:var(--line-2)}
.org-row .org-branch:only-child::before{left:50%}
.org-node{display:flex;align-items:center;gap:.7rem;border:1px solid var(--line);border-radius:.9rem;background:var(--panel-2);padding:.7rem .9rem;min-width:11rem}
.org-node.root{border-color:rgba(var(--amber-rgb),.45);box-shadow:0 0 30px -16px rgba(var(--amber-rgb),.7)}
.org-name{font-family:var(--font-d);font-weight:700;font-size:.92rem}
.org-sub{font-size:.72rem;color:var(--muted)}
.org-pct{font-size:.72rem;color:var(--amber);font-weight:700;margin-top:.15rem}
@media (max-width:640px){ .org-row::before{display:none} .org-branch::before{display:none} .conf-row{grid-template-columns:8rem 1fr;grid-auto-rows:auto} .conf-date{grid-column:1/-1} }

/* ============================================================
   DA « Verre & supernova » — cockpit (inspirée de la page login)
   ============================================================ */
.app{position:relative;z-index:0;background:transparent}
.app-bg{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.app-bg video{width:100%;height:100%;object-fit:cover;opacity:.16;filter:saturate(1.1)}
.app-bg-tint{position:absolute;inset:0;background:
  radial-gradient(58% 48% at 80% 6%,rgba(var(--amber-rgb),.11),transparent 62%),
  radial-gradient(48% 42% at 6% 102%,rgba(61,180,255,.055),transparent 60%),
  linear-gradient(180deg,rgba(16,18,24,.87),rgba(16,18,24,.93) 50%,rgba(16,18,24,.96))}

/* Sidebar = rail flottant en verre dépoli */
.sidebar{position:sticky;top:.9rem;height:calc(100vh - 1.8rem);margin:.9rem 0 .9rem .9rem;padding:1.1rem .8rem;
  border:1px solid var(--line-2);border-radius:1.15rem;
  background:linear-gradient(180deg,rgba(40,44,53,.55),rgba(16,18,24,.6));
  -webkit-backdrop-filter:blur(18px) saturate(1.1);backdrop-filter:blur(18px) saturate(1.1);
  box-shadow:0 40px 90px -50px #000,0 0 60px -45px rgba(var(--amber-rgb),.45)}
.side-logo img{filter:drop-shadow(0 0 18px rgba(var(--amber-rgb),.3))}

/* Topbar = barre de verre collante */
.topbar{position:sticky;top:0;z-index:6;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(29,32,39,.74),rgba(29,32,39,.5));
  -webkit-backdrop-filter:blur(16px) saturate(1.1);backdrop-filter:blur(16px) saturate(1.1)}

/* Panneaux / KPI / cartes : verre dépoli + halo ambre */
.panel,.kpi,.co-card{
  background:linear-gradient(180deg,rgba(255,255,255,.045),transparent 55%),rgba(29,32,39,.55);
  -webkit-backdrop-filter:blur(15px) saturate(1.08);backdrop-filter:blur(15px) saturate(1.08);
  border:1px solid var(--line-2);box-shadow:0 30px 60px -46px #000}
.panel:hover{border-color:rgba(var(--amber-rgb),.28);box-shadow:0 30px 60px -42px #000,0 0 42px -30px rgba(var(--amber-rgb),.42)}
.kpi{transition:transform .25s,box-shadow .25s,border-color .25s}
.kpi:hover{transform:translateY(-3px);border-color:rgba(var(--amber-rgb),.4);box-shadow:0 26px 50px -34px #000,0 0 48px -26px rgba(var(--amber-rgb),.55)}
.kpi::after{height:2px;background:linear-gradient(90deg,var(--amber),transparent 72%);opacity:.75}

/* Verre sur les éléments d'interface */
.user-chip{background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.btn{background:rgba(255,255,255,.04);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.btn-amber{-webkit-backdrop-filter:none;backdrop-filter:none}
.fiche-tab{background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}
.org-node{background:rgba(29,32,39,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}

/* la supernova porte l'ambiance : on retire l'ancienne grille HUD */
.main-wrap::before{display:none}

/* entrée douce du contenu (comme la carte de login) */
.cock-main{animation:cockIn .5s cubic-bezier(.22,.61,.36,1)}
@keyframes cockIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

@media (max-width:980px){
  .sidebar{margin:0;border-radius:0;height:100vh;top:0}
}

/* ============================================================
   DA « CINÉMATIQUE » — univers du site + login appliqué au cockpit
   (scopée à .app : la page login #auth n'est pas affectée)
   ============================================================ */
.app{
  --bg:#07080a; --panel:rgba(245,177,76,.04); --panel-2:#15120c;
  --line:rgba(245,177,76,.18); --line-2:rgba(245,177,76,.34);
  --text:#f4ede2; --muted:#9a948a; --green:#7ed99f; --red:#ff7a72; --hair:rgba(244,237,226,.10);
  background:#07080a;color:var(--text)
}
.app-bg video{opacity:.40;filter:none}
.app-bg-tint{background:
  radial-gradient(circle at 50% 26%,transparent 22%,rgba(7,8,10,.5) 68%,rgba(7,8,10,.9) 100%),
  radial-gradient(58% 46% at 82% 4%,rgba(245,177,76,.10),transparent 56%),
  linear-gradient(180deg,rgba(7,8,10,.5),rgba(7,8,10,.8))}

/* sidebar verre ambré */
.sidebar{border:1px solid rgba(245,177,76,.16);
  background:linear-gradient(180deg,rgba(245,177,76,.06),rgba(7,8,10,.5));
  box-shadow:0 40px 90px -55px #000,0 0 70px -50px rgba(245,177,76,.4)}
.side-item.active{background:linear-gradient(90deg,rgba(245,177,76,.16),transparent)}
.side-companies .tag{color:var(--muted)}

/* topbar verre */
.topbar{border-bottom:1px solid var(--hair);
  background:linear-gradient(180deg,rgba(7,8,10,.78),rgba(7,8,10,.42))}
.topbar-title .crumb{color:var(--amber);letter-spacing:.24em}
.user-chip{background:rgba(245,177,76,.06);border-color:rgba(245,177,76,.2)}

/* boutons pilule (DA site) */
.btn{border-radius:999px;border:1px solid rgba(245,177,76,.22);background:rgba(245,177,76,.06)}
.btn:hover{border-color:var(--amber);transform:translateY(-1px)}
.btn-amber{background:var(--amber);color:#1a1206;border:none}
.add-btn{border-radius:999px;border:1px solid rgba(245,177,76,.3)}
.add-btn:hover{background:rgba(245,177,76,.08);border-color:var(--amber)}

/* en-tête de page : eyebrow ambré + filet net */
.page-head{border-bottom:1px solid var(--hair);gap:.2rem}
.page-head .eyebrow{display:inline-block;color:var(--amber);font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;font-weight:500;margin-bottom:.45rem}
.page-head h1::before{display:none}
.page-head h1{font-size:1.9rem}

/* panneaux verre ambré (toutes les pages) */
.panel,.co-card,.kpi{
  background:rgba(245,177,76,.035);border:1px solid rgba(245,177,76,.18);border-radius:1.1rem;
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 30px 60px -52px #000}
.panel:hover,.co-card:hover{border-color:var(--amber);background:rgba(245,177,76,.06);box-shadow:0 30px 60px -46px #000,0 0 40px -30px rgba(245,177,76,.35)}
.kpi::after{display:none}
.note{background:rgba(245,177,76,.05);border-color:rgba(245,177,76,.18)}
.soon-panel{border-color:rgba(245,177,76,.25);background:rgba(245,177,76,.02)}

/* ---- Hero du tableau de bord ---- */
.dhero{padding:.4rem 0 2.2rem;border-bottom:1px solid var(--hair);animation:cockIn .5s cubic-bezier(.22,.61,.36,1)}
.dhero .eyebrow{display:inline-block;color:var(--amber);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;margin-bottom:1rem}
.dhero-num{font-family:var(--font-d);font-weight:600;font-size:clamp(3rem,8vw,5.6rem);line-height:.9;letter-spacing:-.02em;text-shadow:0 0 60px rgba(245,177,76,.16)}
.dhero-num .e{color:var(--muted);font-weight:400;font-size:.36em}
.dhero-sub{display:flex;align-items:center;gap:1.3rem;flex-wrap:wrap;margin-top:1.2rem}
.dhero-delta{font-family:var(--font-d);font-weight:500;font-size:1.05rem;white-space:nowrap}
.dhero-lead{color:var(--text);opacity:.85;max-width:48ch;line-height:1.5}
.pos{color:#7ed99f}.neg{color:#ff7a72}
.dstats{display:flex;flex-wrap:wrap;margin-top:1.8rem}
.dstat{padding:.1rem 2rem;border-left:1px solid var(--hair)}
.dstat:first-child{padding-left:0;border-left:none}
.dstat .k{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.dstat .v{font-family:var(--font-d);font-weight:600;font-size:1.65rem;margin-top:.35rem}
.dstat .v.amber{color:var(--amber)}

/* sections du dashboard */
.dsec{display:flex;align-items:baseline;justify-content:space-between;margin:2.4rem 0 1.2rem}
.dsec h2{font-family:var(--font-d);font-weight:600;font-size:1.45rem;letter-spacing:-.01em;margin:0}
.dsec .eyebrow{color:var(--amber);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase}

/* cartes sociétés (cinématique, verre ambré, hover lift) */
.firmgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:1.2rem}
.firmc{position:relative;overflow:hidden;padding:1.5rem 1.6rem;border:1px solid rgba(245,177,76,.18);border-radius:1.1rem;
  background:rgba(245,177,76,.035);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .3s,border-color .3s,background .3s}
.firmc:hover{transform:translateY(-6px);border-color:var(--amber);background:rgba(245,177,76,.07)}
.firmc .acc{position:absolute;top:0;left:0;right:0;height:2px;opacity:.75}
.firmc .nm{font-family:var(--font-d);font-weight:600;font-size:1.16rem}
.firmc .role{color:var(--muted);font-size:.8rem;margin-top:.15rem;letter-spacing:.04em}
.firmc .trow{display:flex;align-items:center;justify-content:space-between;margin-top:.7rem;font-size:.86rem;color:var(--muted)}
.firmc .trow .num-inline{font-size:1.05rem;width:7rem}
.firmc .confb{margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--hair)}
.firmc .confb .lab{display:flex;justify-content:space-between;font-size:.74rem;color:var(--muted);margin-bottom:.4rem}
.firmc .confb .lab b{font-family:var(--font-d);color:var(--text)}
.firmc .confb .track{height:3px;background:rgba(244,237,226,.1);position:relative;border-radius:2px;overflow:hidden}
.firmc .confb .track i{position:absolute;inset:0 auto 0 0;background:var(--amber)}
.firmc .confb .track i.low{background:#ff7a72}
.firmc .nx{margin-top:.95rem;display:flex;justify-content:space-between;align-items:center;font-size:.82rem;gap:.6rem}
.firmc .nx .d{font-family:var(--font-d);color:var(--muted);white-space:nowrap}
.firmc .nx .d.late{color:#ff7a72}

/* panneau « à surveiller » */
.watchp{padding:0;overflow:hidden}
.evrow{display:grid;grid-template-columns:104px 1fr auto;gap:1.2rem;align-items:center;padding:1.1rem 1.6rem;border-top:1px solid var(--hair)}
.evrow:first-child{border-top:none}
.evrow:hover{background:rgba(245,177,76,.04)}
.evrow .when{font-family:var(--font-d);font-weight:600}
.evrow .evlbl{font-weight:500}
.evrow .evlbl small{display:block;color:var(--muted);font-size:.78rem;margin-top:.1rem}

@media(max-width:760px){.dstat{padding:.1rem 1.1rem}.evrow{grid-template-columns:80px 1fr}}
