@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap";._page_rf3qp_2{display:flex;height:100vh;background:linear-gradient(160deg,#0d1f42,#1a2f5e 55%,#bf0d3e 130%)}._left_rf3qp_8{flex:1;display:flex;flex-direction:column;justify-content:center;padding:60px 80px;position:relative;overflow:hidden}._circles_rf3qp_18{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}._circles_rf3qp_18 span{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.07)}._circles_rf3qp_18 span:nth-child(1){width:400px;height:400px;top:-100px;left:-100px}._circles_rf3qp_18 span:nth-child(2){width:600px;height:600px;top:-200px;left:-200px}._circles_rf3qp_18 span:nth-child(3){width:300px;height:300px;bottom:-80px;right:80px}._brand_rf3qp_28{display:flex;align-items:center;gap:14px;margin-bottom:52px}._brandIcon_rf3qp_29{width:50px;height:50px;background:#ffffff24;border:1px solid rgba(255,255,255,.22);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px}._brandName_rf3qp_37{color:#fff;font-size:19px;font-weight:700}._brandSub_rf3qp_38{color:#ffffff8c;font-size:11px;margin-top:2px}._heroTitle_rf3qp_40{font-size:clamp(30px,4vw,50px);font-weight:700;color:#fff;line-height:1.15;letter-spacing:-.03em;margin-bottom:18px}._heroTitle_rf3qp_40 span{color:#bf0d3e}._heroSub_rf3qp_50{font-size:15px;color:#ffffff9e;line-height:1.65;max-width:440px;margin-bottom:44px}._features_rf3qp_58{display:flex;flex-direction:column;gap:12px}._feature_rf3qp_58{display:flex;align-items:center;gap:14px;color:#ffffffb8;font-size:14px}._featureDot_rf3qp_60{width:34px;height:34px;flex-shrink:0;background:#ffffff1a;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:15px}._right_rf3qp_69{width:460px;background:#fff;display:flex;flex-direction:column;justify-content:center;padding:60px 52px}._formTitle_rf3qp_78{font-size:26px;font-weight:700;color:var(--ink);letter-spacing:-.03em;margin-bottom:5px}._formSub_rf3qp_79{font-size:14px;color:var(--stone);margin-bottom:32px}._form_rf3qp_78{display:flex;flex-direction:column;gap:0}._group_rf3qp_83{margin-bottom:16px}._label_rf3qp_84{display:block;font-size:11px;font-weight:600;color:var(--slate);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}._input_rf3qp_91{width:100%;padding:12px 15px;border:1.5px solid var(--pebble);border-radius:var(--r);font-family:DM Sans,sans-serif;font-size:14px;color:var(--ink);background:var(--paper);transition:all .2s;outline:none}._input_rf3qp_91:focus{border-color:var(--leaf);background:#fff;box-shadow:0 0 0 4px #1a2f5e1a}._errorBox_rf3qp_102{background:#ffebee;color:#c62828;border:1px solid #FFCDD2;border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:12px}._formRow_rf3qp_109{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}._remember_rf3qp_110{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--stone);cursor:pointer}._remember_rf3qp_110 input{accent-color:var(--leaf)}._forgot_rf3qp_112{font-size:13px;color:var(--mint);font-weight:500}._btnPrimary_rf3qp_114{width:100%;padding:13px;background:#bf0d3e;color:#fff;border:none;border-radius:var(--r);font-size:15px;font-weight:600;transition:all .2s}._btnPrimary_rf3qp_114:hover:not(:disabled){background:#9c0a32;transform:translateY(-1px);box-shadow:0 4px 16px #bf0d3e59}._btnPrimary_rf3qp_114:disabled{opacity:.65;cursor:not-allowed}._divider_rf3qp_124{display:flex;align-items:center;gap:12px;margin:22px 0}._divider_rf3qp_124 span{flex:1;height:1px;background:var(--pebble)}._divider_rf3qp_124 p{font-size:12px;color:var(--stone)}._btnSSO_rf3qp_128{width:100%;padding:12px;background:var(--paper);color:var(--slate);border:1.5px solid var(--pebble);border-radius:var(--r);font-size:14px;font-weight:500;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}._btnSSO_rf3qp_128:hover{border-color:var(--leaf);background:var(--foam)}._footer_rf3qp_140{margin-top:28px;font-size:11px;color:var(--stone);text-align:center;line-height:1.6}.cp-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d1f4273;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;animation:cp-fade-in .12s ease both}@keyframes cp-fade-in{0%{opacity:0}to{opacity:1}}.cp-panel{width:100%;max-width:580px;background:#fff;border-radius:14px;box-shadow:0 0 0 1px #0d1f4214,0 8px 32px #0d1f422e,0 2px 8px #0d1f421a;overflow:hidden;display:flex;flex-direction:column;max-height:72vh;animation:cp-slide-up .15s cubic-bezier(.16,1,.3,1) both}@keyframes cp-slide-up{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.cp-search-row{display:flex;align-items:center;gap:10px;padding:0 16px;height:54px;border-bottom:1px solid #e8eaf0;flex-shrink:0}.cp-search-icon{font-size:16px;flex-shrink:0;opacity:.5}.cp-input{flex:1;border:none;outline:none;font-size:15px;font-family:inherit;color:#0d1f42;background:transparent;caret-color:#1a2f5e}.cp-input::placeholder{color:#9ca3b8}.cp-clear{border:none;background:none;cursor:pointer;color:#9ca3b8;font-size:12px;padding:4px 6px;border-radius:4px;line-height:1;transition:color .1s,background .1s}.cp-clear:hover{color:#0d1f42;background:#f0f2f7}.cp-esc-hint{font-size:10px;font-family:inherit;background:#f0f2f7;color:#9ca3b8;border:1px solid #dde0ea;border-radius:4px;padding:2px 6px;flex-shrink:0}.cp-body{overflow-y:auto;padding:6px 0;flex:1}.cp-body::-webkit-scrollbar{width:4px}.cp-body::-webkit-scrollbar-thumb{background:#dde0ea;border-radius:2px}.cp-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#9ca3b8;padding:8px 16px 4px}.cp-item{display:flex;align-items:center;gap:10px;padding:9px 16px;cursor:pointer;transition:background .08s;border-radius:0;position:relative}.cp-item:hover,.cp-item--active{background:#f5f7fc}.cp-item--active{background:#eef1f9}.cp-item-icon{font-size:16px;flex-shrink:0;width:22px;text-align:center}.cp-item-label{font-size:14px;color:#0d1f42;font-weight:500;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cp-item-hint{font-size:12px;color:#9ca3b8;flex-shrink:0}.cp-item-cat{font-size:11px;color:#b0b6c8;background:#f0f2f7;border-radius:4px;padding:2px 7px;flex-shrink:0;display:none}.cp-item--active .cp-item-cat{display:block}.cp-item-enter{font-size:12px;font-family:inherit;background:#1a2f5e;color:#fff;border:none;border-radius:4px;padding:2px 7px;flex-shrink:0;margin-left:4px}.cp-empty-hint{text-align:center;padding:32px 24px;color:#9ca3b8;font-size:13px;line-height:1.7}.cp-empty-icon{font-size:28px;margin-bottom:8px;opacity:.5}.cp-empty-sub{font-size:12px;color:#b8bece;margin-top:4px}.cp-footer{display:flex;align-items:center;gap:14px;padding:8px 16px;border-top:1px solid #e8eaf0;background:#fafbfd;flex-shrink:0;font-size:11px;color:#9ca3b8}.cp-footer kbd{font-size:10px;font-family:inherit;background:#f0f2f7;color:#6b7491;border:1px solid #dde0ea;border-radius:4px;padding:1px 5px;margin-right:3px}@media (max-width: 620px){.cp-backdrop{padding-top:0;align-items:flex-end}.cp-panel{border-radius:14px 14px 0 0;max-height:85vh}}:root{--sidebar-w: 230px;--sidebar-mini-w: 56px;--topbar-h: 56px;--transition: .22s cubic-bezier(.4,0,.2,1);--sb-bg: #1a2354;--sb-accent: #22c89b;--sb-accent-tint: #22c89b1a;--sb-text: rgba(255,255,255,.65);--sb-text-dim: rgba(255,255,255,.4);--sb-border: rgba(255,255,255,.07)}*,*:before,*:after{box-sizing:border-box}#appShell{display:flex;height:100dvh;overflow:hidden;background:var(--paper, #f5f7fa)}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);height:100dvh;display:flex;flex-direction:column;background:var(--sb-bg);color:#fff;overflow:hidden;transition:width var(--transition),min-width var(--transition);z-index:300;flex-shrink:0;font-family:DM Sans,Inter,sans-serif}.sidebar--mini{width:var(--sidebar-mini-w);min-width:var(--sidebar-mini-w)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px;flex-shrink:0;border-bottom:1px solid var(--sb-border)}.sidebar-logo-wrap{display:flex;align-items:center;gap:10px;overflow:hidden;min-width:0}.sidebar-logo-icon{width:36px;height:36px;background:var(--sb-accent);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.sidebar-logo-img{width:22px;height:22px;object-fit:contain}.sidebar-logo-name{font-size:13px;font-weight:700;color:#fff;line-height:1.2;white-space:nowrap}.sidebar-logo-sub{font-size:10px;color:var(--sb-text-dim);white-space:nowrap}.sidebar-toggle-btn{background:#ffffff14;border:none;color:#ffffffb3;width:26px;height:26px;border-radius:7px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.sidebar-toggle-btn:hover{background:#ffffff29}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 0 12px;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section{margin-top:4px}.nav-section-title{display:flex;align-items:center;justify-content:space-between;padding:10px 16px 4px;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sb-text-dim);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.nav-section-title:hover{color:#fff9}.nav-chevron{font-size:11px;color:#ffffff4d;transition:transform .2s;flex-shrink:0}.nav-chevron.open{transform:rotate(90deg)}.nav-section-body{display:flex;flex-direction:column;overflow:hidden;max-height:2000px;transition:max-height .25s ease}.nav-section-body--closed{max-height:0}.nav-section-divider{height:1px;background:var(--sb-border);margin:10px 10px 6px}.nav-item{display:flex;align-items:center;gap:9px;padding:8px 14px 8px 16px;font-size:12.5px;font-weight:500;color:var(--sb-text);text-decoration:none;cursor:pointer;transition:background .12s,color .12s,transform .12s;white-space:nowrap;overflow:hidden;border-radius:0;min-height:36px}.nav-item:hover{background:#ffffff0f;color:#ffffffe6;transform:translate(2px)}.nav-item.active{background:var(--sb-accent-tint);color:var(--sb-accent);border-radius:8px;margin:1px 8px;padding:8px;font-weight:600}.nav-item.active:hover{transform:none}.nav-item--mini{justify-content:center;padding:9px 0;margin:1px 6px;gap:0}.nav-item--mini.active{margin:1px 6px;padding:9px 0}.nav-item-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center;line-height:1}.nav-item-label{overflow:hidden;text-overflow:ellipsis}.sidebar-user{display:flex;align-items:center;gap:9px;padding:8px 14px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--sb-accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#0d1f2d;flex-shrink:0}.sidebar-user-info{min-width:0;overflow:hidden}.sidebar-user-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:10px;color:var(--sb-text-dim);white-space:nowrap}.sidebar-footer{border-top:1px solid var(--sb-border);padding:10px 0;flex-shrink:0}.sidebar-footer-item{display:flex;align-items:center;gap:9px;padding:8px 14px 8px 16px;font-size:12px;color:var(--sb-text-dim);cursor:pointer;transition:color .12s,background .12s;white-space:nowrap}.sidebar-footer-item:hover{color:#fff;background:#ffffff0f}.sidebar-footer-item--mini{justify-content:center;padding:9px 0;gap:0}.main{flex:1;min-width:0;display:flex;flex-direction:column;height:100dvh;overflow:hidden}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:12px;padding:0 20px;background:#fff;border-bottom:1px solid var(--sand, #e8ecf0);flex-shrink:0;z-index:200}.topbar-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.topbar-brand-logo{font-size:14px;font-weight:800;color:var(--sb-bg)}.topbar-breadcrumb{flex:1;font-size:13px;color:var(--stone, #7a8ca0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;min-width:0}.breadcrumb{display:flex;align-items:center;gap:6px;min-width:0;overflow:hidden}.breadcrumb-crumb{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--stone, #7a8ca0);white-space:nowrap;transition:color .15s}.breadcrumb-home{cursor:pointer;width:26px;height:26px;border-radius:8px;background:var(--paper, #f5f7fa);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.breadcrumb-home:hover{background:var(--sb-accent);color:#06231c}.breadcrumb-home-icon{font-size:13px;line-height:1}.breadcrumb-sep{color:var(--sand, #dbe2ea);font-size:12px;flex-shrink:0}.breadcrumb-module{font-weight:600}.breadcrumb-current{font-weight:800;color:var(--sb-bg);overflow:hidden;text-overflow:ellipsis}.breadcrumb-current-icon{font-size:13px;flex-shrink:0}.breadcrumb-crumb.is-current{color:var(--sb-bg)}.topbar-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.topbar-search{display:flex;align-items:center;gap:8px;padding:7px 14px;background:var(--paper, #f5f7fa);border:1.5px solid var(--sand, #e8ecf0);border-radius:10px;font-size:12px;color:var(--stone, #7a8ca0);cursor:pointer;transition:border-color .15s;white-space:nowrap}.topbar-search:hover{border-color:var(--sb-accent)}.topbar-search-kbd{font-size:10px;padding:1px 5px;background:var(--sand, #e8ecf0);border-radius:4px;font-family:monospace}.topbar-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--paper, #f5f7fa);cursor:pointer;font-size:16px;transition:background .15s}.topbar-btn:hover{background:var(--sand, #e8ecf0)}.topbar-notif-dot{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:#ef4444;border:2px solid #fff}.btn-new{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:10px;font-size:12px;font-weight:700;color:#fff;cursor:pointer;white-space:nowrap;transition:opacity .15s;font-family:DM Sans,sans-serif;background:var(--sb-bg)}.btn-new:hover{opacity:.88}.topbar-hamburger{display:none;flex-direction:column;justify-content:space-between;width:36px;height:36px;padding:9px 8px;background:var(--paper, #f5f7fa);border:1.5px solid var(--sand, #e8ecf0);border-radius:9px;cursor:pointer;flex-shrink:0}.topbar-hamburger span{display:block;width:100%;height:2px;background:var(--sb-bg);border-radius:2px;transition:all .22s}.content{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px 28px}.page-anim{animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.mobile-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f2880;z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 1024px){.content{padding:18px 20px}.topbar-search,.btn-new span{display:none}.btn-new{padding:8px 10px;font-size:14px}.topbar-breadcrumb{display:none}#appShell:not(.mobile-nav-open) .sidebar{width:var(--sidebar-mini-w);min-width:var(--sidebar-mini-w)}#appShell:not(.mobile-nav-open) .sidebar .sidebar-logo-name,#appShell:not(.mobile-nav-open) .sidebar .sidebar-logo-sub,#appShell:not(.mobile-nav-open) .sidebar .sidebar-user,#appShell:not(.mobile-nav-open) .sidebar .nav-section-title,#appShell:not(.mobile-nav-open) .sidebar .sidebar-footer-item>span:last-child{display:none}#appShell:not(.mobile-nav-open) .sidebar .nav-item{justify-content:center;padding:9px 0;margin:1px 6px;gap:0}#appShell:not(.mobile-nav-open) .sidebar .nav-section-divider{display:block}#appShell:not(.mobile-nav-open) .sidebar .nav-section-body--closed{max-height:2000px}#appShell:not(.mobile-nav-open) .sidebar .sidebar-footer-item{justify-content:center;padding:9px 0}}@media (max-width: 767px){.topbar-hamburger{display:flex}.sidebar{position:fixed;left:-280px;top:0;height:100dvh;width:272px!important;min-width:272px!important;transition:left var(--transition),width var(--transition);box-shadow:none}.sidebar--mobile-open{left:0;box-shadow:4px 0 32px #0a0f284d}.mobile-overlay{display:block}.main{width:100%}.content{padding:14px 14px 80px}.topbar{padding:0 12px;gap:8px}.topbar-search,.topbar-breadcrumb{display:none}.topbar-brand-logo{font-size:13px}.btn-new{font-size:14px;padding:8px 10px}.sidebar--mobile-open .sidebar-logo-name,.sidebar--mobile-open .sidebar-logo-sub,.sidebar--mobile-open .sidebar-user,.sidebar--mobile-open .nav-section-title,.sidebar--mobile-open .sidebar-footer-item>span:last-child{display:flex!important}.sidebar--mobile-open .nav-item{justify-content:flex-start!important;padding:8px 14px 8px 16px!important;margin:1px 2px!important;gap:9px!important}.sidebar--mobile-open .nav-item.active{margin:1px 8px!important;padding:8px!important}.sidebar--mobile-open .sidebar-footer-item{justify-content:flex-start!important;padding:8px 14px 8px 16px!important}.sidebar--mobile-open .nav-section-body--closed{max-height:0}table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.sidebar-toggle-btn{display:none}}@media (max-width: 767px){[class*=-kpi-grid],[class*=kpi-grid]{grid-template-columns:1fr 1fr!important;gap:10px!important}[class*=-cards],[class*=cards-grid]{grid-template-columns:1fr!important}[class*=-stats],[class*=-filters],[class*=filters]{flex-wrap:wrap;gap:8px}[class*=-filters] input,[class*=-filters] select{min-width:0;flex:1 1 140px}[class*=-actions]{flex-wrap:wrap;gap:6px}table{min-width:600px}.proj-list-table{min-width:640px}}@media (min-width: 768px) and (max-width: 1024px){[class*=-kpi-grid],[class*=kpi-grid]{grid-template-columns:repeat(3,1fr)!important}[class*=-filters],[class*=filters]{flex-wrap:wrap;gap:8px}}.content::-webkit-scrollbar{width:5px}.content::-webkit-scrollbar-thumb{background:var(--sand, #e8ecf0);border-radius:3px}.content::-webkit-scrollbar-track{background:transparent}:root{--forest: #1a2f5e;--leaf: #1e3a75;--mint: #2a4d96;--sage: #7a98cc;--mist: #c8d7ee;--foam: #e8eef8;--paper: #f5f7fa;--white: #ffffff;--ink: #0d1f42;--slate: #2c3e6b;--stone: #6b7491;--pebble: #c5cad8;--sand: #eef0f5;--gold: #bf0d3e;--amber: #e8924a;--coral: #bf0d3e;--red: #bf0d3e;--red2: #9c0a32;--navy: #0d1f42;--shadow: rgba(13,31,66,.08);--shadow-md: rgba(13,31,66,.14);--shadow-lg: rgba(13,31,66,.25);--r: 10px;--r-lg: 16px;--r-xl: 22px}html,body,#root{height:100%;font-family:DM Sans,sans-serif;background:var(--paper);color:var(--ink)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--pebble);border-radius:3px}a{color:inherit;text-decoration:none}button{font-family:DM Sans,sans-serif;cursor:pointer}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px}.status-badge:before{content:"";width:6px;height:6px;border-radius:50%}.status-approved{background:#e8f5e9;color:#2e7d32}.status-approved:before{background:#4caf50}.status-pending{background:#fff8e1;color:#f57f17}.status-pending:before{background:var(--gold)}.status-draft{background:var(--sand);color:var(--stone)}.status-draft:before{background:var(--pebble)}.status-rejected{background:#ffebee;color:#c62828}.status-rejected:before{background:var(--coral)}.badge-pending{background:#fff3e0;color:var(--amber);font-size:10px;font-weight:700;padding:3px 9px;border-radius:6px}.badge-rejected{background:#ffebee;color:var(--coral);font-size:10px;font-weight:700;padding:3px 9px;border-radius:6px}.badge-approved{background:#e8f5e9;color:#2e7d32;font-size:10px;font-weight:700;padding:3px 9px;border-radius:6px}.badge-draft{background:var(--sand);color:var(--stone);font-size:10px;font-weight:700;padding:3px 9px;border-radius:6px}.btn-primary{padding:10px 22px;background:#bf0d3e;color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#9c0a32;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{padding:10px 22px;background:var(--paper);color:var(--slate);border:1.5px solid var(--pebble);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.btn-secondary:hover{border-color:var(--leaf);color:var(--leaf)}.btn-submit{padding:10px 22px;background:#1a2f5e;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-submit:hover{background:var(--leaf)}.btn-new{display:flex;align-items:center;gap:8px;padding:8px 18px;background:#1a2f5e;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-new:hover{background:#bf0d3e}.card{background:#fff;border:1px solid var(--sand);border-radius:var(--r-lg);overflow:hidden}.card-header{padding:16px 22px;border-bottom:1px solid var(--sand);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:14px;font-weight:700;color:var(--ink)}.card-action{font-size:12px;color:var(--mint);font-weight:500;cursor:pointer}.card-body{padding:16px 22px}.page-header{margin-bottom:28px;display:flex;align-items:flex-start;justify-content:space-between}.page-title{font-size:26px;font-weight:700;letter-spacing:-.03em;color:var(--ink)}.page-subtitle{font-size:14px;color:var(--stone);margin-top:3px}.page-header-actions{display:flex;gap:10px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:#fff;border:1px solid var(--sand);border-radius:var(--r-lg);padding:20px 22px;position:relative;overflow:hidden;transition:all .2s}.kpi-card:hover{box-shadow:0 6px 24px var(--shadow-md);transform:translateY(-2px)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.kpi-card.green:before{background:linear-gradient(90deg,var(--leaf),var(--sage))}.kpi-card.gold:before{background:linear-gradient(90deg,var(--gold),var(--amber))}.kpi-card.blue:before{background:linear-gradient(90deg,#2196f3,#42a5f5)}.kpi-card.coral:before{background:linear-gradient(90deg,var(--coral),var(--amber))}.kpi-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--stone);margin-bottom:10px}.kpi-value{font-size:32px;font-weight:700;color:var(--ink);letter-spacing:-.03em;line-height:1}.kpi-sub{font-size:12px;color:var(--stone);margin-top:8px;display:flex;align-items:center;gap:5px}.kpi-icon{position:absolute;right:18px;top:18px;font-size:28px;opacity:.12}.filter-bar{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filter-select{padding:8px 14px;background:#fff;border:1.5px solid var(--pebble);border-radius:8px;font-family:DM Sans,sans-serif;font-size:13px;color:var(--slate);cursor:pointer;outline:none;transition:all .15s}.filter-select:focus,.filter-select:hover{border-color:var(--leaf)}.input-group{margin-bottom:18px}.input-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--stone);margin-bottom:7px}.input-field{width:100%;padding:11px 14px;border:1.5px solid var(--pebble);border-radius:8px;font-family:DM Sans,sans-serif;font-size:14px;color:var(--ink);background:var(--paper);transition:all .2s;outline:none}.input-field:focus{border-color:var(--leaf);background:#fff;box-shadow:0 0 0 3px #1a2f5e1f}select.input-field{cursor:pointer}textarea.input-field{resize:vertical;min-height:80px}.input-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.indicators-table{background:#fff;border:1px solid var(--sand);border-radius:var(--r-lg);overflow:hidden}.table-head{display:grid;grid-template-columns:2fr 140px 1fr 1fr 1fr 1fr 100px;padding:12px 20px;border-bottom:2px solid var(--sand)}.th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--stone)}.table-row{display:grid;grid-template-columns:2fr 140px 1fr 1fr 1fr 1fr 100px;padding:14px 20px;border-bottom:1px solid var(--sand);align-items:center;cursor:pointer;transition:background .15s}.table-row:last-child{border-bottom:none}.table-row:hover{background:var(--paper)}.td{font-size:13px;color:var(--slate)}.td-name{color:var(--ink);font-weight:500}.td-code{font-family:DM Mono,monospace;font-size:11px;color:var(--stone);margin-top:2px}.row-actions{display:flex;gap:6px;justify-content:flex-end}.row-btn{width:30px;height:30px;background:var(--paper);border:1px solid var(--pebble);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:all .15s}.row-btn:hover{border-color:var(--leaf);background:var(--foam)}.progress-list{display:flex;flex-direction:column;gap:16px}.progress-header{display:flex;justify-content:space-between;margin-bottom:7px}.progress-name{font-size:13px;color:var(--ink);font-weight:500}.progress-pct{font-size:13px;font-weight:700}.progress-bar{height:8px;background:var(--sand);border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width 1.5s cubic-bezier(.4,0,.2,1)}.activity-list{display:flex;flex-direction:column}.activity-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--sand)}.activity-item:last-child{border-bottom:none}.activity-dot{width:32px;height:32px;flex-shrink:0;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px}.activity-text{font-size:13px;color:var(--slate);line-height:1.5}.activity-text b{color:var(--ink)}.activity-time{font-size:11px;color:var(--stone);margin-top:2px}.project-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.project-card{background:#fff;border:1px solid var(--sand);border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:all .2s}.project-card:hover{box-shadow:0 6px 24px var(--shadow-md);transform:translateY(-2px)}.project-card-top{height:8px}.project-card-body{padding:18px 20px}.project-card-name{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:4px}.project-card-donor{font-size:12px;color:var(--stone);margin-bottom:14px}.project-card-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:14px}.project-stat{text-align:center}.project-stat-val{font-size:18px;font-weight:700;color:var(--ink)}.project-stat-label{font-size:10px;color:var(--stone);margin-top:1px}.project-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--sand)}.project-date{font-size:11px;color:var(--stone)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d1f1780;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center}.modal{background:#fff;border-radius:var(--r-xl);width:580px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:0 24px 64px #00000040;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:24px 28px 20px;border-bottom:1px solid var(--sand);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.02em}.modal-close{width:32px;height:32px;background:var(--paper);border:1px solid var(--pebble);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;color:var(--stone);transition:all .15s}.modal-close:hover{background:var(--coral);color:#fff;border-color:var(--coral)}.modal-body{padding:24px 28px}.modal-footer{padding:16px 28px 24px;display:flex;gap:10px;justify-content:flex-end}.pending-list{display:flex;flex-direction:column;gap:10px}.pending-item{background:var(--paper);border:1px solid var(--sand);border-radius:var(--r);padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s}.pending-item:hover{border-color:var(--leaf);background:var(--foam)}.pending-name{font-size:13px;font-weight:500;color:var(--ink);flex:1}.pending-meta{font-size:11px;color:var(--stone)}.users-table{background:#fff;border:1px solid var(--sand);border-radius:var(--r-lg);overflow:hidden}.users-head{display:grid;grid-template-columns:2.5fr 1.5fr 1fr 1fr 90px;padding:12px 20px;border-bottom:2px solid var(--sand);background:var(--paper)}.users-row{display:grid;grid-template-columns:2.5fr 1.5fr 1fr 1fr 90px;padding:13px 20px;border-bottom:1px solid var(--sand);align-items:center;transition:background .15s;cursor:pointer}.users-row:last-child{border-bottom:none}.users-row:hover{background:var(--paper)}.user-avatar-sm{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.role-chip{font-size:11px;font-weight:600;padding:3px 10px;border-radius:6px}.role-admin{background:#fce4ec;color:#c62828}.role-meal_manager{background:#e8f5e9;color:#2e7d32}.role-agent{background:#e3f2fd;color:#1565c0}.role-coordinator{background:#fff8e1;color:#e65100}.role-partner{background:#f3e5f5;color:#7b1fa2}.role-reader{background:var(--sand);color:var(--stone)}.reports-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.report-card{background:#fff;border:1px solid var(--sand);border-radius:var(--r-lg);padding:20px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:12px}.report-card:hover{border-color:var(--leaf);box-shadow:0 4px 20px var(--shadow-md);transform:translateY(-2px)}.report-card-icon{font-size:28px}.report-card-title{font-size:14px;font-weight:700;color:var(--ink)}.report-card-desc{font-size:12px;color:var(--stone);line-height:1.5}.report-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid var(--sand);margin-top:auto}.report-card-date{font-size:11px;color:var(--stone)}.report-card-btn{padding:5px 14px;background:var(--paper);border:1px solid var(--pebble);border-radius:6px;font-size:11px;font-weight:600;color:var(--slate);cursor:pointer;transition:all .15s}.report-card-btn:hover{background:var(--forest);color:#fff;border-color:var(--forest)}.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:16px}.dash-col{display:flex;flex-direction:column;gap:16px}.mini-chart{display:flex;align-items:flex-end;gap:6px;height:80px;padding-top:8px}.mini-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}.mini-bar{width:100%;border-radius:4px 4px 0 0;background:var(--leaf);opacity:.7;transition:opacity .2s;min-height:4px}.mini-bar:hover{opacity:1}.mini-label{font-size:10px;color:var(--stone)}.lf-node{display:flex;align-items:flex-start;gap:10px;background:#fff;border:1.5px solid var(--sand);border-radius:var(--r);padding:11px 13px;transition:all .2s;position:relative;margin-bottom:5px}.lf-node:hover{border-color:var(--sage);box-shadow:0 2px 10px var(--shadow)}.lf-node-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:4px}.lf-node-level{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}.lf-node-label{font-size:13px;color:var(--ink);line-height:1.4}.lf-node-meta{font-size:11px;color:var(--stone);margin-top:3px}.form-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--stone);padding-bottom:10px;border-bottom:1px solid var(--sand);margin-bottom:16px;margin-top:8px}@keyframes pageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-anim{animation:pageIn .3s ease}.mono{font-family:DM Mono,monospace}.empty-state{text-align:center;padding:48px 24px;color:var(--stone);font-size:13px}.empty-state-icon{font-size:48px;margin-bottom:12px}.empty-state-title{font-size:16px;font-weight:600;color:var(--ink);margin-bottom:6px}:root{--navy: #1a2f5e;--navy-dark: #132248;--navy-soft: #2c4a8a;--red: #bf0d3e;--red-soft: #e8194a;--ink: #0a0f1e;--ink-2: #1e293b;--ink-3: #334155;--ink-4: #64748b;--ink-5: #94a3b8;--ink-6: #cbd5e1;--surf: #ffffff;--surf-2: #f8fafc;--surf-3: #f1f5f9;--surf-4: #e8eef8;--bdr: #e2e8f0;--bdr-2: #cbd5e1;--status-active: #16A34A;--status-closed: #1D4ED8;--status-suspended: #EA580C;--status-cancelled: #DC2626;--status-planning: #6B7280;--sector-sante: #bf0d3e;--sector-education: #1565C0;--sector-protection: #607D8B;--sector-genre: #AD1457;--sector-nutrition: #FF9800;--sector-dev: #2E7D32;--sector-inclusion: #7B1FA2;--sector-cohesion: #009688;--taux-high: #059669;--taux-med: #D97706;--taux-low: #EA580C;--taux-none: #DC2626;--success: #16A34A;--warning: #D97706;--error: #DC2626;--info: #0891B2;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", "Fira Code", "Cascadia Code", "Consolas", monospace;--text-h1: 22px;--text-h2: 15px;--text-h3: 13px;--text-body: 13px;--text-meta: 11px;--text-micro: 10px;--text-mono: 12px;--page-px: 28px;--page-py: 24px;--gap-card: 16px;--gap-inner: 12px;--pad-card: 20px 22px;--pad-sm: 12px 14px;--r-card: 12px;--r-badge: 20px;--r-rect: 6px;--r-input: 8px;--r-sm: 5px;--shadow-sm: 0 1px 3px rgba(10,15,30,.06), 0 2px 8px rgba(10,15,30,.04);--shadow-md: 0 2px 8px rgba(10,15,30,.08), 0 4px 16px rgba(10,15,30,.06);--shadow-lg: 0 8px 32px rgba(10,15,30,.12);--shadow-xl: 0 16px 48px rgba(10,15,30,.16);--ease: cubic-bezier(.4,0,.2,1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .35s;--sidebar-w: 220px;--sidebar-bg: #0d1f42;--topbar-h: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);color:var(--ink-3);background:var(--surf-2);line-height:1.5}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;min-height:100vh;grid-template-areas:"sidebar topbar" "sidebar main"}.app-sidebar{grid-area:sidebar;background:var(--sidebar-bg);color:#fff;display:flex;flex-direction:column;overflow:hidden;position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;z-index:100}.app-topbar{grid-area:topbar;position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--topbar-h);background:var(--surf);border-bottom:1px solid var(--bdr);display:flex;align-items:center;padding:0 var(--page-px);z-index:90;box-shadow:var(--shadow-sm)}.app-main{grid-area:main;margin-left:var(--sidebar-w);margin-top:var(--topbar-h);padding:var(--page-py) var(--page-px);min-height:calc(100vh - var(--topbar-h))}.text-h1{font-size:var(--text-h1);font-weight:800;color:var(--ink);letter-spacing:-.03em;line-height:1.2}.text-h2{font-size:var(--text-h2);font-weight:700;color:var(--ink);letter-spacing:-.01em}.text-h3{font-size:var(--text-h3);font-weight:700;color:var(--ink-2)}.text-body{font-size:var(--text-body);color:var(--ink-3)}.text-meta{font-size:var(--text-meta);color:var(--ink-4)}.text-micro{font-size:var(--text-micro);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-5)}.text-mono{font-family:var(--font-mono);font-size:var(--text-mono);font-variant-numeric:tabular-nums}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{font-size:var(--text-h1);font-weight:800;color:var(--ink);letter-spacing:-.03em;line-height:1.1;display:flex;align-items:center;gap:10px}.page-subtitle{font-size:var(--text-meta);color:var(--ink-4);margin-top:4px;font-weight:500}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:var(--text-micro);color:var(--ink-5);margin-bottom:12px}.breadcrumb a{color:var(--navy);text-decoration:none;font-weight:600}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:var(--ink-6)}.breadcrumb-current{color:var(--ink-3);font-weight:600}.card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-card);box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-base) var(--ease);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-header{padding:14px 20px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surf-2)}.card-title{font-size:var(--text-h3);font-weight:700;color:var(--ink);display:flex;align-items:center;gap:8px}.card-body{padding:var(--pad-card)}.kpi-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r-card);padding:16px 18px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-base) var(--ease),transform var(--dur-base) var(--ease)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-stripe{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r-card) var(--r-card) 0 0}.kpi-icon{font-size:18px;margin-bottom:8px;display:block}.kpi-value{font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.1;font-variant-numeric:tabular-nums}.kpi-label{font-size:var(--text-micro);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);margin-top:5px}.kpi-sub{font-size:var(--text-meta);color:var(--ink-5);margin-top:3px}.kpi-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap-card);margin-bottom:24px}.kpi-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--gap-card);margin-bottom:24px}.kpi-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap-card);margin-bottom:24px}@media (max-width:1100px){.kpi-grid-4,.kpi-grid-5{grid-template-columns:repeat(2,1fr)}}@media (max-width:700px){.kpi-grid-4,.kpi-grid-5,.kpi-grid-3{grid-template-columns:repeat(2,1fr)}}.tabs{display:flex;gap:2px;border-bottom:2px solid var(--bdr);margin-bottom:20px}.tab{padding:10px 18px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:var(--font-body);font-size:var(--text-body);font-weight:700;color:var(--ink-4);cursor:pointer;transition:all var(--dur-fast) var(--ease);display:flex;align-items:center;gap:6px;border-radius:var(--r-rect) var(--r-rect) 0 0}.tab:hover{color:var(--ink);background:var(--surf-3)}.tab.active{color:var(--navy);border-bottom-color:var(--navy)}.tab-count{background:var(--surf-3);color:var(--ink-4);font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;transition:all var(--dur-fast)}.tab.active .tab-count{background:#eef2ff;color:var(--navy)}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-body)}.data-table thead th{padding:10px 14px;background:var(--surf-2);border-bottom:2px solid var(--bdr);font-size:var(--text-micro);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-4);white-space:nowrap;text-align:left}.data-table thead th.right{text-align:right}.data-table thead th.center{text-align:center}.data-table tbody tr{border-bottom:1px solid var(--bdr);transition:background var(--dur-fast) var(--ease)}.data-table tbody tr:hover{background:#f8faff}.data-table tbody tr:last-child{border-bottom:none}.data-table td{padding:12px 14px;color:var(--ink-3);vertical-align:middle}.data-table td.right{text-align:right}.data-table td.center{text-align:center}.data-table td.mono{font-family:var(--font-mono);font-size:11.5px}.data-table tfoot td{padding:11px 14px;font-weight:700;background:#eef2ff;color:var(--navy);border-top:2px solid var(--navy)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:var(--r-badge);font-size:11px;font-weight:700;white-space:nowrap}.badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.badge-active{background:#dcfce7;color:#16a34a}.badge-closed{background:#dbeafe;color:#1d4ed8}.badge-suspended{background:#ffedd5;color:#ea580c}.badge-cancelled{background:#fee2e2;color:#dc2626}.badge-planning{background:#f1f5f9;color:#475569}.badge-draft{background:#f1f5f9;color:#64748b}.badge-pending{background:#fef3c7;color:#92400e}.badge-approved{background:#dcfce7;color:#16a34a}.code-badge{font-family:var(--font-mono);font-size:10.5px;background:#eef2ff;color:var(--navy);padding:2px 8px;border-radius:var(--r-sm);border:1px solid #C7D7FA;white-space:nowrap}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--r-input);font-family:var(--font-body);font-size:var(--text-body);font-weight:700;cursor:pointer;border:none;transition:all var(--dur-fast) var(--ease);white-space:nowrap;text-decoration:none}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy-dark);box-shadow:0 4px 12px #1a2f5e4d}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#a00030}.btn-ghost{background:transparent;color:var(--ink-4);border:1.5px solid var(--bdr)}.btn-ghost:hover{background:var(--surf-3);color:var(--ink);border-color:var(--bdr-2)}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.btn-sm{padding:5px 10px;font-size:11px;border-radius:var(--r-rect)}.btn-lg{padding:12px 24px;font-size:14px}.btn-icon{width:32px;height:32px;padding:0;border-radius:var(--r-rect);border:1.5px solid var(--bdr);background:var(--surf);color:var(--ink-4);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--dur-fast) var(--ease)}.btn-icon:hover{background:var(--surf-3);border-color:var(--navy);color:var(--navy)}.btn-icon.danger:hover{background:#fef2f2;border-color:#fecaca;color:var(--error)}.btn-new{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;background:var(--navy);color:#fff;border:none;border-radius:var(--r-input);font-family:var(--font-body);font-size:var(--text-body);font-weight:700;cursor:pointer;transition:all var(--dur-fast) var(--ease)}.btn-new:hover{background:var(--navy-dark);box-shadow:0 4px 12px #1a2f5e4d;transform:translateY(-1px)}.form-label{display:block;font-size:var(--text-micro);font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-4);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--bdr);border-radius:var(--r-input);font-family:var(--font-body);font-size:var(--text-body);color:var(--ink);background:var(--surf);outline:none;transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1a2f5e1a}.form-input::placeholder{color:var(--ink-5)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%2364748b' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form-textarea{resize:vertical;min-height:80px}.form-row{margin-bottom:16px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.search-wrap{position:relative}.search-input{padding:8px 12px 8px 34px;border:1.5px solid var(--bdr);border-radius:var(--r-input);font-family:var(--font-body);font-size:var(--text-body);color:var(--ink);background:var(--surf-2);outline:none;width:220px;transition:all var(--dur-fast) var(--ease)}.search-input:focus{border-color:var(--navy);background:var(--surf);box-shadow:0 0 0 3px #1a2f5e1a}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-5);font-size:13px;pointer-events:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0f1e80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--surf);border-radius:16px;box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;overflow:hidden;animation:modal-in var(--dur-base) var(--ease) both}.modal-lg{max-width:760px}.modal-sm{max-width:420px}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:none}}.modal-head{padding:20px 24px 16px;border-bottom:1px solid var(--bdr);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-title{font-size:16px;font-weight:700;color:var(--ink)}.modal-sub{font-size:11px;color:var(--ink-4);margin-top:3px}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-foot{padding:14px 24px;border-top:1px solid var(--bdr);display:flex;justify-content:flex-end;gap:8px}.progress{width:100%;height:6px;background:var(--surf-3);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .5s var(--ease)}.progress-sm{height:4px}.progress-lg{height:10px;border-radius:5px}.taux-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-badge);font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}.taux-high{background:#dcfce7;color:#15803d}.taux-med{background:#fef3c7;color:#92400e}.taux-low{background:#ffedd5;color:#9a3412}.taux-none{background:#fee2e2;color:#991b1b}.empty-state{text-align:center;padding:48px 24px;color:var(--ink-4)}.empty-state-icon{font-size:40px;margin-bottom:12px}.empty-state-title{font-size:15px;font-weight:700;color:var(--ink-3);margin-bottom:6px}.empty-state-sub{font-size:13px;color:var(--ink-4)}.loading-state{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--ink-4);font-size:13px}.spinner{width:20px;height:20px;border:2.5px solid var(--bdr);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-section{background:var(--surf-2);border:1px solid var(--bdr);border-radius:10px;padding:16px;margin-bottom:14px}.form-section-title{font-size:var(--text-micro);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);margin-bottom:12px;display:flex;align-items:center;gap:6px}@keyframes page-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-anim{animation:page-in var(--dur-slow) var(--ease) both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:50ms}.stagger>*:nth-child(3){animation-delay:.1s}.stagger>*:nth-child(4){animation-delay:.15s}.stagger>*:nth-child(5){animation-delay:.2s}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 20px;border-bottom:1px solid var(--bdr);background:var(--surf)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.w-full{width:100%}.text-right{text-align:right}.text-center{text-align:center}.font-700{font-weight:700}.font-800{font-weight:800}.color-navy{color:var(--navy)}.color-success{color:var(--success)}.color-error{color:var(--error)}.color-warning{color:var(--warning)}.color-muted{color:var(--ink-4)}@media (max-width: 768px){:root{--sidebar-w: 0px;--page-px: 16px;--page-py: 16px}.app-main{margin-left:0}.app-topbar{left:0}.form-grid-2,.form-grid-3{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}}
