:root{--bg: #F4F7FB;--surface: #FFFFFF;--surface2: #F0F4FA;--surface3: #E8EDF5;--border: rgba(13,35,71,.08);--border2: rgba(13,35,71,.14);--accent: #2563A8;--accent2: #1A9E6E;--accent3: #E07B39;--accent4: #C0392B;--gold: #B07D1A;--text: #0D2347;--text2: #6B7FA0;--text3: #A0AABA;--navy: #0D2347;--r: 12px;--rs: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--navy);border-right:none;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100}.sidebar-logo{padding:20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.logo-icon{width:36px;height:36px;background:#2563a8;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-text{font-size:14px;line-height:1.2;color:#fff;font-weight:600}.logo-text span{display:block;font-size:10px;color:#fff6;letter-spacing:1px;text-transform:uppercase;font-weight:400}.sidebar-nav{padding:14px 12px;flex:1;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-label{font-size:10px;font-weight:600;letter-spacing:2px;color:#ffffff40;text-transform:uppercase;padding:0 8px;margin-bottom:6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--rs);cursor:pointer;color:#ffffff8c;font-size:13px;font-weight:500;margin-bottom:2px;text-decoration:none;transition:all .15s}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#2563a859;color:#fff}.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.7}.nav-item.active svg{opacity:1}.nav-badge{margin-left:auto;color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}.nav-badge.blue{background:#2563a8}.nav-badge.green{background:var(--accent2)}.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.08)}.user-card{display:flex;align-items:center;gap:10px;padding:10px;background:#ffffff12;border-radius:var(--rs)}.user-avatar{width:32px;height:32px;background:#2563a8;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.user-name{font-size:12px;font-weight:600;color:#fff}.user-role{font-size:10px;color:#fff6}.main{margin-left:240px;flex:1;display:flex;flex-direction:column}.topbar{padding:14px 28px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface);position:sticky;top:0;z-index:50}.topbar h1{font-size:17px;font-weight:700;color:var(--navy)}.topbar p{font-size:12px;color:var(--text2);margin-top:2px}.topbar-right{display:flex;align-items:center;gap:10px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--rs);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:DM Sans,sans-serif}.btn svg{width:14px;height:14px}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:#162f5c;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:#c0392b14;color:var(--accent4);border:1px solid rgba(192,57,43,.15)}.btn-success{background:#1a9e6e14;color:var(--accent2);border:1px solid rgba(26,158,110,.15)}.btn-sm{padding:6px 11px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.content{padding:22px 28px;flex:1}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;position:relative;overflow:hidden;transition:transform .2s;box-shadow:0 1px 4px #0d23470f}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0d23471a}.stat-card:before{content:none}.stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.stat-icon svg{width:18px;height:18px}.stat-value{font-size:26px;font-weight:700;font-family:DM Mono,monospace;color:var(--navy)}.stat-label{font-size:12px;color:var(--text2);margin-top:3px}.stat-change{font-size:11px;margin-top:6px}.up{color:var(--accent2)}.down{color:var(--accent4)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:14px;box-shadow:0 1px 4px #0d23470d}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-title{font-size:13px;font-weight:700;color:var(--navy)}.card-sub{font-size:11px;color:var(--text2);margin-top:2px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:0 1px 4px #0d23470d}.table-toolbar{padding:14px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);flex-wrap:wrap;background:var(--surface)}.search-box{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--rs);padding:7px 12px;flex:1;min-width:180px;max-width:280px}.search-box svg{width:14px;height:14px;color:var(--text3);flex-shrink:0}.search-box input{background:none;border:none;outline:none;color:var(--text);font-size:13px;font-family:DM Sans,sans-serif;width:100%}.search-box input::placeholder{color:var(--text3)}.filter-sel{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--rs);padding:7px 10px;color:var(--text2);font-size:12px;font-family:DM Sans,sans-serif;outline:none;cursor:pointer}.filter-sel option{background:var(--surface)}table{width:100%;border-collapse:collapse}thead tr{background:var(--surface2)}th{padding:10px 14px;text-align:left;font-size:11px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text2);white-space:nowrap;border-bottom:1px solid var(--border)}td{padding:12px 14px;font-size:13px;color:var(--text2);border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--surface2)}.td-name{color:var(--navy)!important;font-weight:600}.td-id{font-family:DM Mono,monospace;font-size:11px;color:var(--accent)!important}.td-num{font-family:DM Mono,monospace}.td-trunc{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}.badge:before{content:"";width:5px;height:5px;border-radius:50%}.badge-active{background:#1a9e6e1a;color:#1a9e6e}.badge-active:before{background:#1a9e6e}.badge-pending{background:#b07d1a1a;color:var(--gold)}.badge-pending:before{background:var(--gold)}.badge-deferred{background:#e07b391a;color:var(--accent3)}.badge-deferred:before{background:var(--accent3)}.badge-completed{background:#2563a81a;color:var(--accent)}.badge-completed:before{background:var(--accent)}.badge-inactive{background:#a0aaba1f;color:var(--text2)}.badge-inactive:before{background:var(--text2)}.badge-cat-found{background:#1a9e6e1a;color:#1a9e6e;font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}.badge-cat-ai{background:#2563a81a;color:var(--accent);font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600}.pay-method{display:inline-flex;align-items:center;gap:5px;font-size:12px}.pay-method svg{width:13px;height:13px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface2)}.pag-info{font-size:12px;color:var(--text2)}.empty{text-align:center;padding:50px 20px}.empty svg{width:38px;height:38px;opacity:.2;margin-bottom:12px;color:var(--navy)}.empty h3{font-size:14px;color:var(--text2);margin-bottom:6px}.empty p{font-size:12px;color:var(--text3)}.prog-bars{display:flex;flex-direction:column;gap:9px}.prog-bar-item{display:flex;flex-direction:column;gap:3px}.prog-bar-row{display:flex;justify-content:space-between;font-size:11px}.prog-bar-row span:first-child{color:var(--text);max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prog-bar-row span:last-child{color:var(--text2)}.prog-track{height:5px;background:var(--surface3);border-radius:3px;overflow:hidden}.prog-fill{height:100%;border-radius:3px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d234766;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:14px;width:780px;max-width:96vw;max-height:92vh;overflow-y:auto;box-shadow:0 8px 48px #0d23472e}.modal-head{padding:20px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:10}.modal-head h2{font-size:16px;font-weight:700;color:var(--navy)}.modal-close{background:var(--surface2);border:none;color:var(--text2);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--surface3);color:var(--text)}.modal-body{padding:20px 22px}.modal-foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:var(--surface)}.form-section{margin-bottom:22px}.form-sec-title{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:flex;align-items:center;gap:8px}.form-sec-title:after{content:"";flex:1;height:1px;background:var(--border)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-full{grid-column:1 / -1}.field{display:flex;flex-direction:column;gap:5px}.field label{font-size:11px;font-weight:600;color:var(--text2)}.field label .req{color:var(--accent4);margin-left:2px}.field input,.field select,.field textarea{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--rs);padding:9px 11px;color:var(--text);font-size:13px;font-family:DM Sans,sans-serif;outline:none;transition:border-color .15s;width:100%}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563a814}.field select option{background:var(--surface)}.field textarea{resize:vertical;min-height:68px}.field input::placeholder{color:var(--text3)}.tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--rs);padding:4px;margin-bottom:20px;width:fit-content;border:1px solid var(--border)}.tab{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text2);transition:all .15s}.tab.active{background:var(--surface);color:var(--navy);box-shadow:0 1px 4px #0d23471a;font-weight:600}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:40px;width:400px;max-width:95vw;box-shadow:0 4px 24px #0d23471a}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-card h1{font-size:22px;font-weight:700;margin-bottom:6px;color:var(--navy)}.login-card p{font-size:13px;color:var(--text2);margin-bottom:28px}.login-err{background:#c0392b12;border:1px solid rgba(192,57,43,.15);color:var(--accent4);padding:10px 14px;border-radius:var(--rs);font-size:13px;margin-bottom:16px}.toast-wrap{position:fixed;bottom:22px;right:22px;z-index:999;display:flex;flex-direction:column;gap:8px}.toast{background:var(--navy);border:1px solid rgba(255,255,255,.1);border-radius:var(--r);padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:0 8px 32px #0d234733;max-width:320px;animation:slideUp .3s ease}.toast svg{width:16px;height:16px;flex-shrink:0}.toast span{font-size:13px;color:#fff}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.bi-panel{background:var(--surface2);border-radius:var(--rs);padding:24px;text-align:center;border:1px dashed var(--border2)}.bi-panel svg{width:36px;height:36px;opacity:.25;margin-bottom:10px;color:var(--navy)}.bi-panel h3{font-size:14px;font-weight:600;margin-bottom:6px;color:var(--navy)}.bi-panel p{font-size:12px;color:var(--text2);max-width:400px;margin:0 auto 14px}.dash-grid{display:grid;grid-template-columns:1fr 300px;gap:14px}@media (max-width: 900px){.sidebar{width:60px}.logo-text,.nav-item span,.user-name,.user-role,.nav-label,.nav-badge{display:none}.sidebar-logo{justify-content:center;padding:14px}.logo-icon{margin:0}.nav-item{justify-content:center;padding:10px}.user-card{justify-content:center;padding:8px}.user-avatar{margin:0}.main{margin-left:60px}.stats-grid{grid-template-columns:1fr 1fr}.dash-grid,.form-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap;gap:8px}.topbar-right,.table-toolbar{flex-wrap:wrap}.search-box{min-width:100%}.modal{width:95vw;margin:10px}}@media (max-width: 600px){.sidebar{width:0;overflow:hidden;position:fixed;z-index:100}.main{margin-left:0}.content{padding:14px 16px}.stats-grid{grid-template-columns:1fr;gap:10px}.stat-value{font-size:22px}.dash-grid,.form-grid{grid-template-columns:1fr}.form-full{grid-column:1}.topbar{padding:12px 16px;flex-wrap:wrap;gap:8px}.topbar h1{font-size:15px}.topbar-right{width:100%;justify-content:flex-end}.table-toolbar{padding:10px 12px;flex-wrap:wrap;gap:8px}.search-box{min-width:100%;max-width:100%}.modal{width:100vw;max-height:95vh;border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0;right:0;margin:0}.overlay{align-items:flex-end}.modal-body,.modal-head{padding:14px 16px}.modal-foot{padding:12px 16px}.tabs{width:100%}.tab{flex:1;text-align:center;font-size:12px;padding:6px 8px}th,td{padding:8px 10px;font-size:12px}.stat-card,.card{padding:14px}.btn{padding:7px 12px;font-size:12px}.btn-sm{padding:5px 9px;font-size:11px}.pagination{flex-direction:column;gap:6px;align-items:flex-start}}.mobile-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--navy)}@media (max-width: 600px){.mobile-menu-btn{display:flex;align-items:center}.sidebar.open{width:240px}}.field input.error,.field select.error,.field textarea.error{border-color:var(--accent4)!important}.field-error{font-size:11px;color:var(--accent4);margin-top:4px;display:flex;align-items:center;gap:4px}
