/* ============================================================
   Espace CA — AirFrance Provence Aviation
   Design System v3 — Aligned with Platform Admin
   ============================================================ */
:root{--navy:#002157;--red:#E4002B;--green:#10b981;--orange:#f59e0b;--sky:#6CB4EE;--purple:#7C3AED}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Outfit',sans-serif;background:#f4f5f7;color:#1a2030;min-height:100vh}
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%)}
.login-box{background:#fff;padding:40px;border-radius:16px;width:100%;max-width:400px;box-shadow:0 8px 30px rgba(0,0,0,.08)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo img{max-width:240px;border-radius:10px}
.login-box h1{font-size:22px;color:var(--navy);margin-bottom:4px;text-align:center}
.login-box .subtitle{font-size:13px;color:#8b95a5;margin-bottom:24px;text-align:center}
.login-error{background:#fef2f2;color:#dc2626;padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px;border:1px solid #fecaca}
.ff{margin-bottom:14px}
.ff label{display:block;font-size:12px;font-weight:600;color:#5e6878;margin-bottom:5px}
.ff input,.ff select,.ff textarea{width:100%;padding:10px 14px;border:1.5px solid #e4e7ec;border-radius:8px;font-family:inherit;font-size:14px;outline:none;transition:border .2s}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,33,87,.08)}
.row{display:flex;gap:12px}.row>*{flex:1}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;font-family:inherit;transition:all .2s;text-decoration:none}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:#003380}
.btn-outline{background:#fff;color:var(--navy);border:1.5px solid #e4e7ec}.btn-outline:hover{border-color:var(--navy)}
.btn-sm{padding:6px 14px;font-size:12px}
.btn-success{background:var(--green);color:#fff}
.btn-danger-vote{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-danger-vote:hover{background:#dc2626;color:#fff}
.btn-neutral{background:#f2f4f7;color:#5e6878;border:1.5px solid #e4e7ec}.btn-neutral:hover{background:#e4e7ec}
.app{display:flex;min-height:100vh}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:240px;background:var(--navy);color:#fff;padding:24px 0;overflow-y:auto;z-index:50}
.sidebar-brand{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.sidebar-brand-title{font-weight:700;font-size:15px;color:#fff}
.sidebar-brand small{display:block;font-weight:400;font-size:11px;color:rgba(255,255,255,.4);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.sidebar-user{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06)}
.sidebar-user-name{font-size:14px;font-weight:600;color:#fff}
.sidebar-user-role{font-size:11px;color:rgba(255,255,255,.45)}
.sidebar-nav{padding:16px 12px}
.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;color:rgba(255,255,255,.6);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:2px;text-decoration:none}
.sidebar-link:hover{background:rgba(255,255,255,.06);color:#fff}
.sidebar-link.active{background:rgba(255,255,255,.1);color:#fff}
.sidebar-link span{font-size:18px;width:22px;text-align:center}
.sidebar-bottom{position:absolute;bottom:0;left:0;right:0;padding:16px 12px;border-top:1px solid rgba(255,255,255,.06)}
.main{margin-left:240px;padding:32px;flex:1;min-width:0}
.main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:12px}
.main-header h1{font-size:24px;color:var(--navy)}
.main-header p{font-size:13px;color:#8b95a5}
.card{background:#fff;border-radius:12px;border:1px solid #e4e7ec;padding:24px;margin-bottom:16px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-header h3{font-size:16px;color:var(--navy)}
.card-clickable{cursor:pointer;transition:all .2s;text-decoration:none;display:block;color:inherit}
.card-clickable:hover{border-color:var(--navy);box-shadow:0 4px 16px rgba(0,33,87,.06);transform:translateY(-2px)}
.card-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.card-icon-blue{background:rgba(0,33,87,.06);color:var(--navy)}
.card-icon-amber{background:rgba(245,158,11,.1);color:var(--orange)}
.card-icon-green{background:rgba(16,185,129,.1);color:var(--green)}
.card-title{font-size:15px;font-weight:600;color:#1a2030}
.card-meta{font-size:12px;color:#8b95a5}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;margin-bottom:24px}
.stat-card{background:#fff;border:1px solid #e4e7ec;border-radius:12px;padding:20px;text-align:center}
.stat-card .num{font-size:28px;font-weight:800;color:var(--navy)}
.stat-card .label{font-size:12px;color:#8b95a5;margin-top:2px}
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.tile{background:#fff;border:1px solid #e4e7ec;border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;transition:all .25s;text-decoration:none;display:block;color:inherit}
.tile:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.tile-icon{font-size:32px;margin-bottom:10px;display:block}
.tile-name{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:4px}
.tile-desc{font-size:12px;color:#8b95a5}
.badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700}
.badge-active{background:rgba(16,185,129,.1);color:var(--green)}
.badge-closed{background:rgba(239,68,68,.1);color:#dc2626}
.badge-upcoming{background:#f2f4f7;color:#8b95a5}
.badge-voted{background:rgba(16,185,129,.1);color:var(--green)}
.badge-required{background:rgba(245,158,11,.1);color:var(--orange)}
.badge-officialise{background:rgba(16,185,129,.08);color:var(--green)}
.badge-presentiel{background:rgba(0,33,87,.06);color:var(--navy)}
.badge-dematerialise{background:rgba(124,58,237,.08);color:var(--purple)}
.badge-cat-ca{background:rgba(0,33,87,.08);color:var(--navy)}
.badge-cat-bureau{background:rgba(124,58,237,.08);color:var(--purple)}
.badge-cat-ag{background:rgba(245,158,11,.1);color:var(--orange)}
.badge-cat-autre{background:rgba(16,185,129,.08);color:var(--green)}
.badge-next{position:absolute;top:-10px;right:16px;background:var(--navy);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:100px}
.position-relative{position:relative}
.date-block{padding:10px 16px;border-radius:10px;text-align:center;min-width:60px;flex-shrink:0}
.date-day{display:block;font-size:22px;font-weight:800;line-height:1}
.date-month{display:block;font-size:11px;font-weight:600;margin-top:2px;text-transform:uppercase}
.odj-point{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid #f2f4f7}
.odj-point:last-child{border:none}
.odj-number{background:var(--navy);color:#fff;min-width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:12px;font-weight:700;flex-shrink:0}
.content-block{white-space:pre-wrap;line-height:1.7;font-size:14px;color:#3d4654}
.vote-buttons{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0}
.btn-vote-lg{padding:14px 28px;font-size:15px;font-weight:700;border-radius:10px}
.result-bar-bg{height:8px;background:#f2f4f7;border-radius:4px;overflow:hidden}
.result-bar{height:100%;border-radius:4px;transition:width .5s}
.result-bar-pour{background:var(--green)}
.result-bar-contre{background:var(--red)}
.result-bar-abstention{background:var(--orange)}
.result-bar-other{background:var(--sky)}
.info-box{padding:16px;border-radius:10px;margin:12px 0;font-size:14px}
.info-box-green{background:rgba(16,185,129,.06);color:#065f46;border:1px solid rgba(16,185,129,.15)}
.info-box-blue{background:rgba(37,99,235,.05);color:#1e40af;border:1px solid rgba(37,99,235,.12)}
.info-box-amber{background:rgba(245,158,11,.06);color:#92400e;border:1px solid rgba(245,158,11,.15)}
.detail-section{padding:20px 0;border-top:1px solid #f2f4f7;margin-top:16px}
.detail-section h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.voter-detail{max-height:400px;overflow-y:auto}
.voter-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f2f4f7;font-size:13px}
.voter-row:last-child{border:none}
.vote-pour{color:var(--green);font-weight:600}
.vote-contre{color:var(--red);font-weight:600}
.vote-abstention{color:var(--orange);font-weight:600}
.vote-none{color:#ccc;font-style:italic}
.empty-state{text-align:center;padding:48px 24px;color:#8b95a5}
.empty-state-icon{font-size:40px;margin-bottom:12px}
.flash{padding:14px 20px;border-radius:10px;margin:0 0 16px;font-size:14px;position:relative;transition:opacity .3s}
.flash-success{background:rgba(16,185,129,.06);color:#065f46;border:1px solid rgba(16,185,129,.15)}
.flash-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}
.flash-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;cursor:pointer;color:inherit;opacity:.5}
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--navy);cursor:pointer;margin-bottom:20px;padding:6px 12px;border-radius:6px;background:rgba(0,33,87,.04);border:none;font-family:inherit;text-decoration:none}
.back-link:hover{background:rgba(0,33,87,.08)}
@media(max-width:768px){
  .sidebar{width:100%;position:relative;height:auto;padding:16px 0}
  .sidebar-bottom{position:relative}
  .main{margin-left:0;padding:20px}
  .stat-grid{grid-template-columns:1fr 1fr}
  .tiles{grid-template-columns:1fr 1fr}
  .row{flex-direction:column}
  .vote-buttons{flex-direction:column}
}
