:root{
    --waf-dark:#0f172a;
    --waf-dark-2:#111827;
    --waf-blue:#2563eb;
    --waf-blue-2:#1d4ed8;
    --waf-gold:#f5c542;
    --waf-bg:#eef2f7;
    --waf-card:#ffffff;
    --waf-border:#e2e8f0;
    --waf-text:#0f172a;
    --waf-muted:#64748b;
    --waf-danger:#dc2626;
    --waf-success:#16a34a;
}
*{box-sizing:border-box}
html,body{min-height:100%}
body{margin:0;background:var(--waf-bg);color:var(--waf-text);font-family:Arial,Helvetica,sans-serif;font-size:13px}
a{text-decoration:none}
.app-layout{display:flex;min-height:100vh;width:100%}
.app-sidebar{position:fixed;top:0;left:0;bottom:0;width:248px;background:linear-gradient(180deg,var(--waf-dark),var(--waf-dark-2));color:#e5e7eb;z-index:50;box-shadow:8px 0 25px rgba(15,23,42,.14);overflow-y:auto}
.app-main{margin-left:248px;width:calc(100% - 248px);min-height:100vh;padding:22px;background:linear-gradient(180deg,#f8fafc,var(--waf-bg));overflow-x:hidden}
.brand-box{display:flex;align-items:center;gap:12px;padding:20px 14px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--waf-gold),#fff3b0);color:#111827;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 20px rgba(245,197,66,.22)}
.brand-title{font-size:20px;line-height:1;margin:0;color:#fff;font-weight:800}.brand-subtitle{font-size:11px;color:#94a3b8;margin-top:5px}.user-box{margin:14px 12px;padding:13px;border-radius:14px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08)}.user-name{font-size:13px;color:#fff;font-weight:800}.user-role{font-size:11px;color:#94a3b8;margin-top:4px}.sidebar-section-title{padding:12px 14px 7px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.sidebar-nav{padding:0 10px 18px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:11px 11px;margin-bottom:6px;border-radius:11px;color:#e5e7eb;font-weight:700;transition:.18s ease}.sidebar-link:hover{background:rgba(255,255,255,.08);color:#fff}.sidebar-link.active{background:linear-gradient(135deg,var(--waf-blue),var(--waf-blue-2));color:#fff;box-shadow:0 10px 18px rgba(37,99,235,.28)}.sidebar-icon{width:18px;text-align:center}.sidebar-separator{height:1px;background:rgba(255,255,255,.08);margin:12px 0}.mobile-menu-btn{display:none;margin-bottom:14px;border:0;border-radius:10px;background:var(--waf-dark);color:#fff;padding:9px 12px;font-weight:800}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.page-title{font-size:24px;font-weight:900;margin:0;color:#0f172a}.page-subtitle{margin:5px 0 0;color:var(--waf-muted);font-size:13px}.page-actions{display:flex;gap:9px;flex-wrap:wrap}.btn{border-radius:10px;font-weight:700;font-size:13px}.dashboard-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px;margin-bottom:18px}.kpi-card,.dashboard-card,.content-card{background:var(--waf-card);border:1px solid var(--waf-border);border-radius:18px;box-shadow:0 10px 24px rgba(15,23,42,.06)}.kpi-card{padding:16px;min-height:128px;display:flex;flex-direction:column;justify-content:space-between}.kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--waf-muted);font-weight:900}.kpi-value{font-size:25px;line-height:1.05;color:#0f172a;font-weight:900}.kpi-card small{font-size:11px;color:var(--waf-muted)}.kpi-card-gold{background:linear-gradient(135deg,#fff8de,#fff);border-color:#f7df85}.kpi-card-finance{background:linear-gradient(135deg,#e8f2ff,#fff);border-color:#b9d8ff}.dashboard-card{padding:18px}.card-title-row{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:15px}.card-title-row h2{font-size:16px;font-weight:900;margin:0}.card-title-row span,.card-title-row a{font-size:12px;color:var(--waf-muted)}.chart-line{margin-bottom:14px}.chart-info,.finance-item{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:6px}.chart-info strong,.finance-item strong{font-size:13px}.chart-info span,.finance-item small{font-size:12px;color:var(--waf-muted)}.slim-progress{height:8px;background:#edf2f7;border-radius:999px}.slim-progress .progress-bar{background:var(--waf-blue);border-radius:999px}.finance-item{padding:12px 0;border-bottom:1px solid #edf2f7;margin-bottom:0}.finance-item:last-child{border-bottom:0}.finance-item span{font-weight:900}.table{font-size:13px}.table th{font-size:11px;color:var(--waf-muted);text-transform:uppercase;letter-spacing:.04em;background:#f8fafc}.table td,.table th{vertical-align:middle;padding:.72rem}.auth-body{min-height:100vh;background:radial-gradient(circle at 15% 20%,rgba(37,99,235,.22),transparent 30%),radial-gradient(circle at 85% 20%,rgba(245,197,66,.28),transparent 25%),linear-gradient(135deg,#0f172a,#111827 48%,#1e293b);display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:min(1040px,100%);display:grid;grid-template-columns:1.05fr .95fr;background:rgba(255,255,255,.96);border-radius:28px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.5)}.auth-hero{padding:42px;background:linear-gradient(160deg,#0f172a,#172554);color:#fff;position:relative;overflow:hidden}.auth-hero:after{content:"";position:absolute;right:-80px;bottom:-80px;width:220px;height:220px;border-radius:50%;background:rgba(245,197,66,.22)}.auth-logo{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,var(--waf-gold),#fff3b0);display:flex;align-items:center;justify-content:center;color:#111827;font-weight:900;font-size:18px;margin-bottom:22px}.auth-hero h1{font-size:34px;font-weight:900;margin:0 0 10px}.auth-hero p{color:#cbd5e1;margin:0;font-size:14px;max-width:420px}.auth-features{display:grid;gap:12px;margin-top:34px;position:relative;z-index:1}.auth-feature{padding:13px 14px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.09);font-weight:700}.auth-form-wrap{padding:42px}.auth-form-wrap h2{font-size:26px;font-weight:900;margin:0 0 6px}.auth-form-wrap .muted{color:var(--waf-muted);margin-bottom:24px}.form-label{font-weight:800;font-size:12px}.form-control,.form-select{border-radius:12px;border-color:#cbd5e1;padding:10px 12px;font-size:13px}.form-control:focus,.form-select:focus{box-shadow:0 0 0 .2rem rgba(37,99,235,.15);border-color:#2563eb}.auth-submit{width:100%;padding:12px;border-radius:13px;font-weight:900}.auth-footer{font-size:11px;color:var(--waf-muted);margin-top:16px;text-align:center}.alert{border-radius:14px}.card{border-radius:16px;border-color:var(--waf-border);box-shadow:0 8px 20px rgba(15,23,42,.04)}
@media(max-width:1200px){.dashboard-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.app-sidebar{width:230px}.app-main{margin-left:230px;width:calc(100% - 230px)}}
@media(max-width:900px){.app-sidebar{transform:translateX(-102%);transition:.22s ease;width:260px}.app-main{margin-left:0;width:100%;padding:16px}.mobile-menu-btn{display:inline-flex}.sidebar-open .app-sidebar{transform:translateX(0)}.auth-card{grid-template-columns:1fr}.auth-hero{display:none}}
@media(max-width:768px){.page-header{flex-direction:column}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-form-wrap{padding:28px}}
@media(max-width:520px){.dashboard-grid{grid-template-columns:1fr}.page-title{font-size:21px}}

/* Choix zone / contrat après connexion */
.contract-body{
    min-height:100vh;
    background:radial-gradient(circle at 15% 20%,rgba(37,99,235,.22),transparent 28%),radial-gradient(circle at 85% 15%,rgba(245,197,66,.25),transparent 24%),linear-gradient(135deg,#0f172a,#111827 48%,#1e293b);
    padding:24px;
}
.contract-shell{width:min(1120px,100%);margin:0 auto;color:#0f172a}
.contract-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;color:#fff}
.contract-brand{display:flex;align-items:center;gap:12px}.contract-brand h1{font-size:24px;font-weight:900;margin:0}.contract-brand span{font-size:12px;color:#cbd5e1}
.contract-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.contract-panel{background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.5);border-radius:24px;box-shadow:0 25px 70px rgba(0,0,0,.28);padding:28px}.contract-info-panel{background:linear-gradient(160deg,#ffffff,#eef6ff)}.panel-badge{display:inline-flex;padding:7px 10px;border-radius:999px;background:#dcfce7;color:#166534;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px}.contract-panel h2,.contract-panel h3{font-weight:900;margin:0 0 10px}.contract-panel p{color:#64748b;line-height:1.55}.contract-mini-list{display:grid;gap:12px;margin-top:26px}.contract-mini-list div{display:flex;align-items:center;gap:12px;padding:13px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;font-weight:800}.contract-mini-list span{width:28px;height:28px;border-radius:10px;background:#2563eb;color:#fff;display:inline-flex;align-items:center;justify-content:center}.contract-preview{border:1px dashed #93c5fd;background:#eff6ff;border-radius:16px;padding:13px;margin-top:8px}.contract-preview strong{display:block;color:#1e3a8a;margin-bottom:5px}.contract-preview span{font-size:12px;color:#334155;line-height:1.5}.contract-context-box{margin:0 12px 12px;padding:12px;border-radius:14px;background:rgba(245,197,66,.12);border:1px solid rgba(245,197,66,.25)}.contract-context-box .context-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#facc15;font-weight:900;margin-bottom:5px}.contract-context-box .context-zone{font-size:15px;font-weight:900;color:#fff;line-height:1.1}.contract-context-box .context-contract{font-size:11px;color:#cbd5e1;margin-top:5px;word-break:break-word}.contract-context-box a{display:inline-flex;margin-top:8px;font-size:11px;font-weight:900;color:#fef3c7}.context-warning{background:rgba(220,38,38,.12);border-color:rgba(220,38,38,.28)}.context-warning .context-label{color:#fecaca}
@media(max-width:800px){.contract-grid{grid-template-columns:1fr}.contract-body{padding:14px}.contract-panel{padding:20px}.contract-topbar{align-items:flex-start;flex-direction:column}}
