:root{--bg:#f0f4f8;--surface:#fff;--surface-alt:#f1f5f9;--border:#e2e8f0;--text:#0f172a;--muted:#64748b;--primary:#2563eb;--primary-light:#dbeafe;--success:#059669;--success-bg:#ecfdf5;--warning:#d97706;--warning-bg:#fffbeb;--danger:#dc2626;--danger-bg:#fef2f2;--radius:14px;--shadow:0 1px 3px rgba(0,0,0,.04),0 4px 24px rgba(0,0,0,.06);--shadow-lg:0 8px 40px rgba(0,0,0,.12);--font:"DM Sans",sans-serif}.dark{--bg:#0f172a;--surface:#1e293b;--surface-alt:#334155;--border:#334155;--text:#f1f5f9;--muted:#94a3b8;--primary-light:#1e3a5f}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}@keyframes countUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text);display:flex;min-height:100vh;overflow-x:hidden;font-size:12px}body:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(circle at 20% 20%,rgba(37,99,235,.03) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(124,58,237,.03) 0%,transparent 50%);pointer-events:none}.sidebar{width:250px;background:linear-gradient(180deg,#0f172a,#1a1f3a,#0f172a);color:#94a3b8;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-brand{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:10px}.sidebar-brand .logo{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),#7c3aed);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;font-size:16px}.sidebar-brand span{font-weight:800;font-size:14px;color:#fff;letter-spacing:-.02em}.nav-section{padding:20px 12px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#ffffff40;font-weight:700}.nav-group{padding:12px 20px 4px;font-size:11px;font-weight:800;color:#ffffff80;letter-spacing:-.01em}.nav-sub-section{padding:12px 12px 4px 28px;font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:#fff3;font-weight:700}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 14px;margin:2px 8px;cursor:pointer;border-radius:10px;border-left:3px solid transparent;transition:all .25s ease;font-size:12px;font-weight:500}.nav-item.nav-sub{padding-left:36px}.nav-item:hover{background:#ffffff0f;color:#e2e8f0}.nav-item.active{color:#fff;background:#2563eb1f;border-left-color:var(--primary);font-weight:700;box-shadow:inset 3px 0 16px #2563eb26}.nav-item .icon{font-size:17px;width:22px;text-align:center}.sidebar-footer{margin-top:auto;padding:16px 20px;border-top:1px solid rgba(255,255,255,.06);font-size:11px;color:#fff3}.main{margin-left:250px;flex:1;display:flex;flex-direction:column;min-height:100vh}.header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:#ffffffbf;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--border);transition:background .3s}.dark .header{background:#0f172acc}.header h1{font-size:16px;font-weight:800;letter-spacing:-.02em;display:flex;align-items:center;gap:10px}.header h1 span{font-size:11px;font-weight:500;color:var(--muted);background:var(--surface-alt);padding:2px 8px;border-radius:20px}.header-actions{display:flex;align-items:center;gap:10px}.btn{padding:6px 14px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px;font-family:var(--font)}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.btn-primary{background:linear-gradient(135deg,var(--primary),#4f46e5);color:#fff;border-color:transparent}.btn-primary:hover{box-shadow:0 4px 20px #2563eb59}.section{margin:0 24px 24px;animation:fadeInUp .6s ease both}.section:nth-child(2){animation-delay:.05s}.section:nth-child(3){animation-delay:.1s}.section:nth-child(4){animation-delay:.15s}.section-title{font-size:14px;font-weight:800;margin-bottom:10px;display:flex;align-items:center;gap:12px;letter-spacing:-.01em}.section-title .badge{font-size:10px;font-weight:600;padding:3px 10px;border-radius:20px;background:linear-gradient(135deg,var(--primary-light),rgba(124,58,237,.08));color:var(--primary)}.grid{display:grid;gap:12px}.grid-5{grid-template-columns:repeat(5,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.kpi-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;position:relative;overflow:hidden;transition:all .3s ease}.kpi-tile:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),#7c3aed);border-radius:var(--radius) var(--radius) 0 0;transition:height .3s}.kpi-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.kpi-tile:hover:before{height:5px}.kpi-tile.accent-green:before{background:linear-gradient(90deg,var(--success),#34d399)}.kpi-tile.accent-red:before{background:linear-gradient(90deg,var(--danger),#f87171)}.kpi-tile.accent-orange:before{background:linear-gradient(90deg,var(--warning),#fbbf24)}.kpi-label{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700;margin-bottom:4px}.kpi-value{font-size:28px;font-weight:900;line-height:1;animation:countUp .6s ease both;letter-spacing:-.03em}.kpi-value.text-red{color:var(--danger)}.kpi-value.text-green{color:var(--success)}.kpi-value.text-orange{color:var(--warning)}.kpi-value.text-blue{color:var(--primary)}.kpi-sub{font-size:10px;color:var(--muted);margin-top:4px;font-weight:500}.kpi-delta{font-size:10px;font-weight:700;margin-top:4px;display:inline-flex;align-items:center;gap:4px;padding:1px 6px;border-radius:6px}.kpi-delta.up{color:var(--success);background:var(--success-bg)}.kpi-delta.down{color:var(--danger);background:var(--danger-bg)}.kpi-cols{display:flex;gap:24px;align-items:flex-start;margin-top:12px}.kpi-col1{flex:1;text-align:center}.kpi-col2{flex:1;text-align:center;border-left:1px solid var(--border);padding-left:20px}.alert-sub{font-size:10px;opacity:.7;margin-top:4px;line-height:1.3}.alert-tile{padding:14px 12px;border-radius:var(--radius);text-align:center;transition:all .3s ease;cursor:pointer;overflow:hidden}.alert-tile:hover{transform:translateY(-3px)}.alert-tile.green{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0}.alert-tile.red{background:linear-gradient(135deg,#fef2f2,#fecaca);border:1px solid #fca5a5;animation:pulse 2.5s ease infinite}.alert-tile.orange{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d}.alert-tile .alert-val{font-size:30px;font-weight:900;letter-spacing:-.03em}.alert-tile .alert-label{font-size:10px;font-weight:600;color:var(--muted);margin-top:4px}.alert-tile .alert-status{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin-top:6px}.alert-tile.green .alert-val,.alert-tile.green .alert-status{color:var(--success)}.alert-tile.red .alert-val,.alert-tile.red .alert-status{color:var(--danger)}.alert-tile.orange .alert-val,.alert-tile.orange .alert-status{color:var(--warning)}.chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden;transition:box-shadow .3s}.chart-wrap:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--success),#7c3aed);border-radius:var(--radius) var(--radius) 0 0}.chart-wrap:hover{box-shadow:var(--shadow-lg)}canvas{max-height:200px}.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}table{width:100%;border-collapse:collapse;font-size:11px}th{position:sticky;top:0;background:var(--surface);text-transform:uppercase;font-size:10px;letter-spacing:.06em;font-weight:700;color:var(--muted);padding:10px 12px;border-bottom:2px solid var(--border);text-align:left;white-space:nowrap}td{padding:8px 12px;border-bottom:1px solid var(--border);transition:background .15s}tr:nth-child(2n){background:var(--surface-alt)}tr:hover td{background:#2563eb08}.dark tr:hover td{background:#2563eb14}.vision-badges{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;font-size:10px;font-weight:700}.vision-badges .vb{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:6px}.vision-badges .vb.vb-red{color:var(--danger);background:var(--danger-bg)}.vision-badges .vb.vb-orange{color:var(--warning);background:var(--warning-bg)}.vision-badges .vb.vb-green{color:var(--success);background:var(--success-bg)}.vision-status{margin-top:8px;font-size:10px;font-weight:700;display:inline-flex;align-items:center;gap:4px}.vision-status.vs-green{color:var(--success)}.vision-status.vs-orange{color:var(--warning)}.vision-status.vs-red{color:var(--danger)}.tab-content{display:none}.tab-content.active{display:block}.toast{position:fixed;bottom:24px;right:24px;padding:14px 24px;border-radius:12px;color:#fff;font-size:13px;font-weight:600;z-index:999;animation:slideIn .4s ease;box-shadow:0 8px 32px #0003}.toast.success{background:linear-gradient(135deg,var(--success),#34d399)}.toast.error{background:linear-gradient(135deg,var(--danger),#f87171)}.error-banner{display:none;margin:0 24px 16px;padding:14px 20px;background:var(--danger-bg);border:1px solid #fca5a5;border-radius:var(--radius);color:var(--danger);font-size:13px;font-weight:600;animation:fadeInUp .4s ease}.drawer-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(4px);z-index:200;display:none;opacity:0;transition:opacity .3s}.drawer-overlay.open{display:block;opacity:1}.drawer{position:fixed;top:0;right:0;width:520px;max-width:90vw;height:100vh;background:var(--surface);z-index:201;transform:translate(100%);transition:transform .35s ease;overflow-y:auto;box-shadow:-8px 0 40px #00000026}.drawer.open{transform:translate(0)}.drawer-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--surface);z-index:1}.drawer-header h2{font-size:16px;font-weight:800}.drawer-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--muted);padding:4px 8px;border-radius:8px;transition:all .2s}.drawer-close:hover{background:var(--surface-alt);color:var(--text)}.drawer-body{padding:24px}.drawer-body table{font-size:12.5px}.drawer-body td,.drawer-body th{padding:8px 12px}.synthese-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}.synthese-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center;transition:all .3s}.synthese-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.synthese-card .val{font-size:22px;font-weight:900}.synthese-card .lbl{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;margin-top:4px}.staffing-table{width:100%;border-collapse:collapse;font-size:12px}.staffing-table th{position:sticky;top:0;background:var(--surface);border-bottom:2px solid var(--border);padding:8px 6px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.staffing-table td{padding:5px 6px;border-bottom:1px solid var(--border)}.staffing-comm-row{background:var(--surface)}.staffing-comm-row:hover{background:var(--primary);color:#fff}.staffing-comm-row:hover td{color:#fff}.staffing-res-row:hover{background:#6366f10d}.staffing-total-row{background:var(--surface);border-top:2px solid var(--primary)}.staffing-total-row td{padding:8px 6px}a{color:#3b82f6;text-decoration:none}a:visited{color:#3b82f6}a:hover{color:#60a5fa;text-decoration:underline;opacity:.9}.dash-switcher{display:flex;flex-direction:column;gap:4px;padding:12px 12px 8px;border-bottom:1px solid rgba(255,255,255,.06)}.dash-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:11px;font-weight:700;color:#ffffff80;transition:all .25s ease;border:1px solid transparent}.dash-btn:hover{background:#ffffff0f;color:#e2e8f0}.dash-btn.active-star{background:#2563eb26;color:#60a5fa;border-color:#2563eb4d}.dash-btn.active-internal{background:#10b98126;color:#34d399;border-color:#10b9814d}.dash-btn.active-staffing{background:#a855f726;color:#c084fc;border-color:#a855f74d}.dash-btn .dash-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dash-dot.dot-star{background:#3b82f6}.dash-dot.dot-internal{background:#10b981}.dash-dot.dot-staffing{background:#a855f7}.dash-group{display:none}.dash-group.active{display:block}.dashboard-star .nav-item.active{background:#2563eb1f;border-left-color:#3b82f6;box-shadow:inset 3px 0 16px #2563eb26}.dashboard-internal .nav-item.active{background:#10b9811f;border-left-color:#10b981;box-shadow:inset 3px 0 16px #10b98126}.dashboard-staffing .nav-item.active{background:#a855f71f;border-left-color:#a855f7;box-shadow:inset 3px 0 16px #a855f726}.header-star h1 span{background:#2563eb1a;color:#3b82f6}.header-internal h1 span{background:#10b9811a;color:#10b981}.header-staffing h1 span{background:#a855f71a;color:#a855f7}@media(max-width:1200px){.grid-5,.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.sidebar{width:60px}.sidebar span,.nav-section,.sidebar-footer,.sidebar-brand span{display:none}.main{margin-left:60px}.nav-item{justify-content:center;padding:12px;margin:2px 4px}.header{padding:12px 16px}.section{margin:0 16px 24px}}@media(max-width:768px){.grid-5,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.drawer{width:100vw}}.user-badge-wrap{display:flex;align-items:center;gap:10px}.user-badge-name{font-size:.88em;font-weight:600;color:#ffffffe6;white-space:nowrap}.user-badge-logout{padding:4px 11px;border:1px solid rgba(255,255,255,.35);border-radius:6px;background:transparent;color:#fffc;font-size:.8em;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}.user-badge-logout:hover{background:#ffffff26;color:#fff}#login-overlay{position:fixed;inset:0;z-index:9999}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100%;background:linear-gradient(135deg,#1a252f,#2c3e50 60%,#34495e);padding:24px;box-sizing:border-box}.login-screen .login-card{background:#fff;border-radius:18px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 24px 64px #00000073}.login-screen .login-brand{text-align:center;margin-bottom:32px}.login-screen .login-brand .login-brand-logo{font-size:2.4em;line-height:1;margin-bottom:10px}.login-screen .login-brand h1{font-size:1.5em;font-weight:800;color:#2c3e50;margin:0 0 4px;letter-spacing:-.01em}.login-screen .login-brand h1 span{color:#3498db}.login-screen .login-brand p{color:#7f8c8d;font-size:.88em;margin:0}.login-screen .login-step-title{font-size:1.05em;font-weight:700;color:#2c3e50;margin:0 0 6px}.login-screen .login-step-desc{font-size:.86em;color:#7f8c8d;margin:0 0 18px;line-height:1.5}.login-screen .login-input{display:block;width:100%;padding:10px 14px;border:1.5px solid #dee2e6;border-radius:8px;font-size:1em;font-family:inherit;box-sizing:border-box;outline:none;transition:border-color .15s,box-shadow .15s;margin-bottom:4px}.login-screen .login-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db24}.login-screen .login-input.login-otp-input{font-size:1.7em;letter-spacing:.3em;text-align:center;font-weight:700;text-transform:uppercase;padding:12px 14px}.login-screen .login-btn-primary{display:block;width:100%;padding:11px;border:none;border-radius:8px;background:#2c3e50;color:#fff;font-size:1em;font-weight:700;font-family:inherit;cursor:pointer;margin-top:14px;transition:background .15s,transform .1s}.login-screen .login-btn-primary:hover:not(:disabled){background:#233140;transform:translateY(-1px)}.login-screen .login-btn-primary:disabled{opacity:.6;cursor:default;transform:none}.login-screen .login-btn-secondary{display:block;width:100%;padding:9px;border:1.5px solid #dee2e6;border-radius:8px;background:transparent;color:#7f8c8d;font-size:.88em;font-weight:600;font-family:inherit;cursor:pointer;margin-top:8px;transition:all .15s}.login-screen .login-btn-secondary:hover:not(:disabled){border-color:#adb5bd;color:#2c3e50}.login-screen .login-btn-secondary:disabled{opacity:.6;cursor:default}.login-screen .login-email-hint{background:#f0f4f8;border-radius:8px;padding:9px 14px;font-size:.87em;color:#495057;margin-bottom:18px}.login-screen .login-email-hint strong{color:#2c3e50}.login-screen .login-error{background:#fdeaea;color:#c0392b;border-radius:8px;padding:10px 14px;font-size:.87em;margin-top:12px;line-height:1.4}.login-screen .login-success{background:#eafaf1;color:#27ae60;border-radius:8px;padding:10px 14px;font-size:.87em;margin-top:8px}.login-screen .login-server-panel{margin-top:24px;border-top:1px solid #e9ecef;padding-top:12px}.login-screen .login-server-toggle{background:none;border:none;color:#adb5bd;font-size:.8em;cursor:pointer;padding:0;font-family:inherit;transition:color .15s}.login-screen .login-server-toggle:hover{color:#6c757d}.login-screen .login-server-toggle.open{color:#495057}.login-screen .login-server-form{margin-top:12px;display:flex;flex-direction:column;gap:8px}.login-screen .login-server-form.hidden{display:none}.login-screen .login-server-label{font-size:.82em;color:#6c757d;font-weight:600}.login-screen .login-server-input{font-size:.85em}.login-screen .login-server-save{width:auto;align-self:flex-start;padding:6px 14px}.login-screen .login-server-status{font-size:.8em;color:#27ae60;min-height:1.2em}.pyramide-dirty-banner{background:#fef3c7;border:1.5px solid #f59e0b;border-radius:5px;color:#92400e;font-size:.82em;font-weight:600;padding:3px 10px;align-self:center;white-space:nowrap;animation:dirty-pulse 2.5s ease-in-out infinite}.pyramide-dirty-banner.hidden{display:none}@keyframes dirty-pulse{0%,to{border-color:#f59e0b}50%{border-color:#ef4444}}
