*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0b0f19;--bg2:#121829;--bg3:#1a2236;--bg4:#1f2a42;--input:#0d1424;
  --gold:#f0b429;--gold2:#c4931d;--blue:#3b82f6;--cyan:#22d3ee;--red:#ef4444;--green:#22c55e;--orange:#f97316;--purple:#a855f7;
  --t1:#e8ecf4;--t2:#8b95a8;--t3:#4b5568;--border:#1e293b;
}
html{font-size:15px}
body{font-family:'Exo 2',sans-serif;background:var(--bg);color:var(--t1);min-height:100vh}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--t3);border-radius:3px}
a{color:var(--gold);text-decoration:none}

/* UTILS */
.mono{font-family:'JetBrains Mono',monospace}
.badge{display:inline-block;padding:0.12rem 0.5rem;border-radius:5px;font-size:0.67rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.b-green{background:rgba(34,197,94,.15);color:var(--green)}.b-red{background:rgba(239,68,68,.15);color:var(--red)}.b-blue{background:rgba(59,130,246,.15);color:var(--blue)}.b-gold{background:rgba(240,180,41,.15);color:var(--gold)}.b-purple{background:rgba(168,85,247,.15);color:var(--purple)}.b-orange{background:rgba(249,115,22,.15);color:var(--orange)}.b-cyan{background:rgba(34,211,238,.15);color:var(--cyan)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.1rem;border:none;border-radius:8px;font-family:'Rajdhani',sans-serif;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .15s;text-transform:uppercase;letter-spacing:.3px}
.btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#0a0e17}.btn-blue{background:var(--blue);color:#fff}.btn-red{background:var(--red);color:#fff}.btn-green{background:var(--green);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--t2)}.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm{padding:.3rem .7rem;font-size:.76rem}
.card{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:1.1rem;margin-bottom:.8rem;transition:border-color .2s}
.card:hover{border-color:rgba(240,180,41,.15)}
.card-t{font-family:'Rajdhani',sans-serif;font-weight:600;font-size:.93rem;margin-bottom:.6rem;display:flex;align-items:center;gap:.4rem}
input,select,textarea{width:100%;padding:.55rem .75rem;background:var(--input);border:1px solid var(--border);border-radius:7px;color:var(--t1);font-family:'Exo 2',sans-serif;font-size:.88rem;transition:border-color .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(240,180,41,.12)}
select option{background:var(--bg2)}
textarea{resize:vertical;min-height:55px}
label{display:block;font-size:.7rem;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:1px;margin-bottom:.35rem}
.fg{margin-bottom:.85rem}
.row{display:flex;gap:.7rem}.row>*{flex:1}
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:.67rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:1px;padding:.5rem .6rem;border-bottom:1px solid var(--border)}
td{padding:.5rem .6rem;font-size:.83rem;border-bottom:1px solid rgba(30,41,59,.5);vertical-align:middle}
tr:hover td{background:rgba(240,180,41,.02)}

/* AUTH */
#auth{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;align-items:center;justify-content:center;background-image:radial-gradient(ellipse at 30% 50%,rgba(240,180,41,.05) 0%,transparent 60%)}
#auth.hide{display:none}
.auth-box{width:92%;max-width:400px;animation:slideUp .5s ease}
@keyframes slideUp{from{opacity:0;transform:translateY(25px)}to{opacity:1;transform:translateY(0)}}
.auth-logo{text-align:center;margin-bottom:2rem}
.auth-logo h1{font-family:'Rajdhani',sans-serif;font-size:2rem;font-weight:700;color:var(--gold);letter-spacing:3px;text-transform:uppercase}
.auth-logo p{color:var(--t2);font-size:.82rem;letter-spacing:1px;margin-top:.2rem}
.auth-card{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:1.8rem}
.auth-card .btn-gold{width:100%;padding:.75rem;font-size:1rem;margin-top:.3rem}

/* LAYOUT */
.app{display:none;min-height:100vh}
.app.on{display:flex}
.side{width:240px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s}
.side-head{padding:1rem 1.1rem;border-bottom:1px solid var(--border)}
.side-head h2{font-family:'Rajdhani',sans-serif;font-size:1.05rem;font-weight:700;color:var(--gold);letter-spacing:2px;text-transform:uppercase}
.side-user{padding:.8rem 1.1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.6rem}
.av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--orange));display:flex;align-items:center;justify-content:center;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:.8rem;color:#0a0e17;flex-shrink:0}
.side-name{font-weight:600;font-size:.85rem}.side-role{font-size:.66rem;color:var(--t2);text-transform:uppercase;letter-spacing:.5px}
.side-nav{flex:1;overflow-y:auto;padding:.5rem 0}
.nav-sec{padding:.5rem 1.1rem .15rem;font-size:.6rem;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px}
.nav-i{display:flex;align-items:center;gap:.55rem;padding:.45rem 1.1rem;cursor:pointer;color:var(--t2);font-size:.82rem;font-weight:500;transition:all .12s;border-left:3px solid transparent}
.nav-i:hover{background:rgba(240,180,41,.05);color:var(--t1)}
.nav-i.on{background:rgba(240,180,41,.08);color:var(--gold);border-left-color:var(--gold)}
.nav-i .ico{font-size:.95rem;width:20px;text-align:center}
.nav-i .nbadge{margin-left:auto;background:var(--red);color:#fff;font-size:.58rem;font-weight:700;padding:.06rem .38rem;border-radius:10px}
.side-lock{margin:.3rem 1.1rem;padding:.55rem .8rem;background:rgba(240,180,41,.06);border:1px dashed rgba(240,180,41,.2);border-radius:8px;font-size:.75rem;color:var(--t2);text-align:center;cursor:default}
.side-foot{padding:.7rem 1.1rem;border-top:1px solid var(--border)}
.side-foot .btn{width:100%;font-size:.76rem}
.main{margin-left:240px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.top{height:50px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.3rem;gap:.8rem;position:sticky;top:0;z-index:50}
.burger{display:none;background:none;border:none;color:var(--t1);font-size:1.3rem;cursor:pointer}
.top-title{font-family:'Rajdhani',sans-serif;font-weight:600;font-size:1rem}
.top-r{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pul 2s infinite}
@keyframes pul{0%,100%{opacity:1}50%{opacity:.4}}
.content{flex:1;padding:1.2rem;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:90}.overlay.on{display:block}

/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:300;animation:fadeIn .15s}
.modal{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:1.4rem;width:92%;max-width:480px;max-height:82vh;overflow-y:auto;animation:dropIn .2s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.modal-t{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:1.05rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.modal-acts{display:flex;gap:.4rem;margin-top:1rem;justify-content:flex-end}

/* STAT */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.7rem;margin-bottom:1rem}
.stat{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:.9rem 1rem}
.stat-l{font-size:.66rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:1px}
.stat-v{font-family:'Rajdhani',sans-serif;font-size:1.6rem;font-weight:700;margin-top:.1rem}
.stat-s{font-size:.7rem;color:var(--t2)}

/* TOAST */
.toast{position:fixed;bottom:1rem;right:1rem;background:var(--bg3);border:1px solid var(--green);color:var(--t1);padding:.65rem 1rem;border-radius:8px;font-size:.82rem;z-index:9999;animation:toastIn .3s ease,toastOut .3s ease 3s forwards;display:flex;align-items:center;gap:.4rem;max-width:400px}
.toast-err{border-color:var(--red);background:rgba(239,68,68,.12)}.toast-warn{border-color:var(--orange);background:rgba(249,115,22,.12)}
@keyframes toastIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{to{opacity:0;transform:translateY(20px)}}

/* HEALTH */
.health-profile{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.health-row{display:flex;justify-content:space-between;padding:.45rem .7rem;background:var(--input);border-radius:6px;font-size:.83rem}
.health-row span:first-child{color:var(--t2)}
.timeline-item{position:relative;padding-left:1.5rem;padding-bottom:1rem;border-left:2px solid var(--border)}
.timeline-item:last-child{border-left-color:transparent;padding-bottom:0}
.timeline-item::before{content:'';position:absolute;left:-5px;top:.3rem;width:8px;height:8px;border-radius:50%;background:var(--gold)}
.timeline-date{font-size:.7rem;color:var(--t3);margin-bottom:.15rem}
.timeline-text{font-size:.84rem}

/* VOTE LOCK */
.vote-locked{opacity:.5;pointer-events:none;position:relative}
.vote-locked::after{content:'✓ Vous avez voté';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg3);border:1px solid var(--green);color:var(--green);padding:.4rem 1rem;border-radius:6px;font-size:.82rem;font-weight:600}

/* AUTH TABS */
.auth-tabs{display:flex;margin-bottom:0;border-radius:10px 10px 0 0;overflow:hidden;border:1px solid var(--border);border-bottom:none}
.auth-tab{flex:1;padding:.65rem;text-align:center;font-family:'Rajdhani',sans-serif;font-weight:600;font-size:.88rem;cursor:pointer;background:var(--bg2);color:var(--t3);transition:all .15s}
.auth-tab.on{background:var(--bg3);color:var(--gold)}
.auth-tab:hover:not(.on){color:var(--t2)}
.auth-card{border-radius:0 0 12px 12px!important}
.auth-subtabs{display:flex;margin-bottom:1rem;background:var(--input);border-radius:8px;padding:3px}
.auth-subtab{flex:1;padding:.5rem;text-align:center;font-size:.82rem;font-weight:600;cursor:pointer;border-radius:6px;color:var(--t3);transition:all .15s}
.auth-subtab.on{background:var(--bg3);color:var(--gold);box-shadow:0 2px 8px rgba(0,0,0,.2)}

/* GOV PANEL */
.gov-side{width:240px;background:linear-gradient(180deg,#1a0a0a 0%,#121829 30%);border-right:1px solid rgba(239,68,68,.2)}
.gov-side .side-head{border-bottom-color:rgba(239,68,68,.15)}
.gov-side .side-head h2{color:var(--red)}
.gov-side .nav-i.on{color:var(--red);border-left-color:var(--red);background:rgba(239,68,68,.08)}
.gov-side .nav-i:hover{background:rgba(239,68,68,.05)}
.gov-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:5px;font-size:.65rem;font-weight:700;background:rgba(239,68,68,.12);color:var(--red);text-transform:uppercase;letter-spacing:.5px}
.gov-warn{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:8px;padding:.7rem .9rem;margin-bottom:.8rem;font-size:.82rem;color:var(--red)}
.vault-item{display:flex;align-items:center;gap:.7rem;padding:.65rem .8rem;background:var(--input);border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;transition:border-color .15s}
.vault-item:hover{border-color:rgba(239,68,68,.3)}
.vault-icon{font-size:1.3rem}
.vault-info{flex:1}
.vault-name{font-weight:600;font-size:.88rem}
.vault-meta{font-size:.72rem;color:var(--t3)}
.defcon-grid{display:flex;gap:.4rem;margin:1rem 0}
.defcon-btn{flex:1;padding:.7rem;text-align:center;border-radius:7px;font-family:'Rajdhani',sans-serif;font-weight:700;font-size:.85rem;cursor:pointer;border:2px solid transparent;transition:all .15s}
.defcon-btn:hover{transform:scale(1.03)}
.defcon-btn.sel{border-color:#fff;box-shadow:0 0 15px rgba(255,255,255,.2)}
.dc5{background:var(--green);color:#052e16}.dc4{background:var(--blue);color:#0c1a3d}.dc3{background:var(--gold);color:#3d2e00}.dc2{background:var(--orange);color:#3d1c00}.dc1{background:var(--red);color:#3d0a0a}

/* WORK */
.work-locked{text-align:center;padding:3rem 1rem}
.work-locked .emoji{font-size:3rem;margin-bottom:.8rem}

/* RESPONSIVE */
@media(max-width:768px){
  .side{transform:translateX(-100%)}.side.open{transform:translateX(0)}
  .main{margin-left:0!important}.burger{display:block}
  .row{flex-direction:column}.stats{grid-template-columns:1fr 1fr}
  .health-profile{grid-template-columns:1fr}
}
@media(max-width:480px){.stats{grid-template-columns:1fr}}
