@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@500;600;700;800&display=swap);:root{--bg:#f6f8fa;--surface:#fff;--surface2:#f6f8fa;--surface3:#eef1f5;--border:#e2e8f0;--border2:#cbd5e1;--border3:#94a3b8;--accent:#635bff;--accent-h:#4f46e5;--accent-s:#7c75ff;--accent-dim:#635bff14;--accent-dim2:#635bff0a;--text:#0f172a;--text2:#475569;--text3:#94a3b8;--green:#059669;--green-h:#10b981;--green-dim:#05966914;--yellow:#d97706;--yellow-h:#f59e0b;--yellow-dim:#d9770614;--red:#dc2626;--red-h:#ef4444;--red-dim:#dc262614;--blue:#2563eb;--blue-h:#3b82f6;--blue-dim:#2563eb14;--r:8px;--r-lg:12px;--r-xl:16px;--shadow-sm:0 1px 3px #00000014,0 1px 2px #0000000a;--shadow:0 4px 12px #00000014,0 1px 3px #0000000d;--shadow-lg:0 12px 40px #0000001a,0 4px 12px #0000000f}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f6f8fa;background:var(--bg);color:#0f172a;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.5}.app-shell,body{min-height:100vh}.app-shell,.sidebar{display:flex}.sidebar{background:#fff;background:var(--surface);border-right:1px solid #e2e8f0;border-right:1px solid var(--border);bottom:0;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);flex-direction:column;left:0;position:fixed;top:0;width:232px;z-index:200}.sidebar-brand{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:.55rem;padding:1.25rem 1.1rem 1.1rem}.sidebar-brand:before{color:#635bff;color:var(--accent);content:"◈";font-size:1.3rem;line-height:1}.sidebar-brand-text{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:700;letter-spacing:-.02em}.sidebar-brand-text span{color:#94a3b8;color:var(--text3);font-size:.8rem;font-weight:500;margin-left:2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:1px;overflow-y:auto;padding:.85rem .65rem}.nav-section{color:#94a3b8;color:var(--text3);font-size:.62rem;font-weight:600;letter-spacing:.1em;padding:.85rem .75rem .3rem;text-transform:uppercase}.nav-item{align-items:center;background:none;border:1px solid #0000;border-radius:8px;border-radius:var(--r);color:#475569;color:var(--text2);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.65rem;padding:.55rem .75rem;text-align:left;text-decoration:none;transition:all .12s ease;width:100%}.nav-item:hover{background:#f6f8fa;background:var(--surface2);color:#0f172a;color:var(--text)}.nav-item.active{background:#635bff14;background:var(--accent-dim);border-color:#635bff26;color:#635bff;color:var(--accent);font-weight:600}.nav-icon{flex-shrink:0;font-size:.95rem;text-align:center;width:18px}.sidebar-footer{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);padding:.85rem}.user-chip{align-items:center;background:#f6f8fa;background:var(--surface2);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;border-radius:var(--r);display:flex;gap:.6rem;padding:.55rem .7rem;transition:border-color .12s}.user-chip:hover{border-color:#cbd5e1;border-color:var(--border2)}.user-avatar{align-items:center;background:linear-gradient(135deg,#635bff,#4f46e5);background:linear-gradient(135deg,var(--accent),var(--accent-h));border-radius:7px;color:#fff;display:flex;flex-shrink:0;font-family:Space Grotesk,sans-serif;font-size:.7rem;font-weight:700;height:30px;justify-content:center;width:30px}.user-info{flex:1 1;min-width:0}.user-name{color:#0f172a;color:var(--text);font-size:.8rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{font-size:.67rem;margin-top:1px}.btn-logout-icon,.user-role{color:#94a3b8;color:var(--text3)}.btn-logout-icon{background:none;border:none;border-radius:5px;cursor:pointer;font-size:.9rem;line-height:1;padding:3px 5px;transition:all .12s}.btn-logout-icon:hover{background:#dc262614;background:var(--red-dim);color:#dc2626;color:var(--red)}.btn-signout{align-items:center;background:none;border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);color:#475569;color:var(--text2);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:.825rem;font-weight:500;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;text-align:left;transition:all .12s;width:100%}.btn-signout:hover{background:#dc262614;background:var(--red-dim);border-color:#dc26264d;color:#dc2626;color:var(--red)}.page-content{background:#f6f8fa;background:var(--bg);display:flex;flex:1 1;flex-direction:column;margin-left:232px;min-height:100vh}.page-header{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.75rem 2rem 1.5rem}.page-title{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1.35rem;font-weight:700;letter-spacing:-.02em}.page-sub{color:#94a3b8;color:var(--text3);font-size:.825rem;margin-top:2px}.page-body{flex:1 1;padding:1.75rem 2rem 2.5rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));margin-bottom:1.75rem}.stat-card{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--r-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);padding:1.25rem 1.25rem 1.1rem;transition:all .15s ease}.stat-card:hover{border-color:#cbd5e1;border-color:var(--border2);box-shadow:0 4px 12px #00000014,0 1px 3px #0000000d;box-shadow:var(--shadow);transform:translateY(-1px)}.stat-card-icon{display:block;font-size:1.25rem;line-height:1;margin-bottom:.85rem}.stat-card-val{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1.65rem;font-weight:700;letter-spacing:-.03em;line-height:1;margin-bottom:5px}.stat-card-lbl{color:#94a3b8;color:var(--text3);font-size:.75rem;font-weight:500}.stat-card.accent .stat-card-val{color:#635bff;color:var(--accent)}.stat-card.green .stat-card-val{color:#059669;color:var(--green)}.stat-card.yellow .stat-card-val{color:#d97706;color:var(--yellow)}.stat-card.red .stat-card-val{color:#dc2626;color:var(--red)}.stat-card.blue .stat-card-val{color:#2563eb;color:var(--blue)}.stat-card.accent{border-top:3px solid #635bff;border-top:3px solid var(--accent)}.stat-card.green{border-top:3px solid #10b981;border-top:3px solid var(--green-h)}.stat-card.yellow{border-top:3px solid #f59e0b;border-top:3px solid var(--yellow-h)}.stat-card.red{border-top:3px solid #ef4444;border-top:3px solid var(--red-h)}.stat-card.blue{border-top:3px solid #3b82f6;border-top:3px solid var(--blue-h)}.toolbar{gap:.75rem;justify-content:space-between;margin-bottom:1.1rem}.toolbar,.toolbar-left{align-items:center;display:flex;flex-wrap:wrap}.toolbar-left{flex:1 1;gap:.6rem}.toolbar-right{align-items:center;display:flex;gap:.6rem}.search-box{position:relative}.search-box input{background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#0f172a;color:var(--text);font-family:Inter,sans-serif;font-size:.85rem;outline:none;padding:.55rem .85rem .55rem 2.1rem;transition:all .15s;width:240px}.search-box input::placeholder{color:#94a3b8;color:var(--text3)}.search-box input:focus{border-color:#635bff;border-color:var(--accent);box-shadow:0 0 0 3px #635bff14;box-shadow:0 0 0 3px var(--accent-dim)}.search-box:before{color:#94a3b8;color:var(--text3);content:"⌕";font-size:1rem;left:.65rem;line-height:1;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.filter-select{background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#475569;color:var(--text2);cursor:pointer;font-family:Inter,sans-serif;font-size:.85rem;outline:none;padding:.55rem .85rem;transition:all .15s}.filter-select:focus{border-color:#635bff;border-color:var(--accent);box-shadow:0 0 0 3px #635bff14;box-shadow:0 0 0 3px var(--accent-dim);color:#0f172a;color:var(--text)}.btn-primary{align-items:center;background:#635bff;background:var(--accent);border:none;border-radius:8px;border-radius:var(--r);box-shadow:0 1px 3px #635bff4d,0 1px 2px #0000001a;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;gap:.35rem;padding:.55rem 1.1rem;transition:all .15s ease;white-space:nowrap}.btn-primary:hover{background:#4f46e5;background:var(--accent-h);box-shadow:0 4px 12px #635bff59;transform:translateY(-1px)}.btn-primary:active{box-shadow:none;transform:translateY(0)}.btn-ghost{align-items:center;background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#475569;color:var(--text2);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;gap:.35rem;padding:.55rem 1rem;transition:all .12s}.btn-ghost:hover{background:#f6f8fa;background:var(--surface2);border-color:#94a3b8;border-color:var(--border3);color:#0f172a;color:var(--text)}.btn-sm{border-radius:6px;font-size:.775rem;padding:.3rem .6rem}.btn-edit{background:#635bff14;background:var(--accent-dim);border:1px solid #635bff33;border-radius:6px;color:#635bff;color:var(--accent);cursor:pointer;font-family:Inter,sans-serif;font-size:.775rem;font-weight:500;padding:.28rem .65rem;transition:all .12s}.btn-edit:hover{background:#635bff24;border-color:#635bff;border-color:var(--accent)}.btn-del{background:#dc262614;background:var(--red-dim);border:1px solid #dc262633;border-radius:6px;color:#dc2626;color:var(--red);cursor:pointer;font-family:Inter,sans-serif;font-size:.775rem;font-weight:500;padding:.28rem .65rem;transition:all .12s}.btn-del:hover{background:#dc262624;border-color:#dc2626;border-color:var(--red)}.btn-renew{background:#05966914;background:var(--green-dim);border:1px solid #05966933;border-radius:6px;color:#059669;color:var(--green);cursor:pointer;font-family:Inter,sans-serif;font-size:.775rem;font-weight:500;padding:.28rem .65rem;transition:all .12s}.btn-renew:hover{background:#05966924;border-color:#059669;border-color:var(--green)}.btn-save{align-items:center;background:#635bff;background:var(--accent);border:none;border-radius:8px;border-radius:var(--r);box-shadow:0 1px 3px #635bff4d;color:#fff;cursor:pointer;display:flex;flex:2 1;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;justify-content:center;min-height:40px;padding:.65rem 1.4rem;transition:all .15s}.btn-save:hover:not(:disabled){background:#4f46e5;background:var(--accent-h);box-shadow:0 4px 12px #635bff59;transform:translateY(-1px)}.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-cancel{background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);color:#475569;color:var(--text2);cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;padding:.65rem 1.2rem;transition:all .12s}.btn-cancel:hover{background:#f6f8fa;background:var(--surface2);border-color:#94a3b8;border-color:var(--border3);color:#0f172a;color:var(--text)}.btn-danger{background:#dc2626;background:var(--red);border:none;border-radius:8px;border-radius:var(--r);box-shadow:0 1px 3px #dc26264d;color:#fff;cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;padding:.65rem 1.4rem;transition:all .15s}.btn-danger:hover{background:#ef4444;background:var(--red-h);box-shadow:0 4px 12px #dc26264d}.table-wrap{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--r-lg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{background:#f6f8fa;background:var(--surface2);color:#94a3b8;color:var(--text3);font-size:.7rem;font-weight:600;letter-spacing:.08em;padding:.7rem 1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table td,.data-table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border)}.data-table td{color:#0f172a;color:var(--text);font-size:.85rem;padding:.85rem 1rem;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:#f8fafc}.td-actions{align-items:center;display:flex;gap:.35rem}.badge{align-items:center;border-radius:5px;display:inline-flex;font-family:Inter,sans-serif;font-size:.7rem;font-weight:600;gap:3px;letter-spacing:.01em;padding:2px 8px}.badge-green{background:#05966914;background:var(--green-dim);border:1px solid #05966933;color:#059669;color:var(--green)}.badge-red{background:#dc262614;background:var(--red-dim);border:1px solid #dc262633;color:#dc2626;color:var(--red)}.badge-yellow{background:#d9770614;background:var(--yellow-dim);border:1px solid #d9770633;color:#d97706;color:var(--yellow)}.badge-blue{background:#2563eb14;background:var(--blue-dim);border:1px solid #2563eb33;color:#2563eb;color:var(--blue)}.badge-gray{background:#eef1f5;background:var(--surface3);border:1px solid #cbd5e1;border:1px solid var(--border2);color:#475569;color:var(--text2)}.badge-purple{background:#635bff14;background:var(--accent-dim);border:1px solid #635bff33;color:#635bff;color:var(--accent)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a73;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.modal{animation:modalIn .18s ease;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--r-xl);box-shadow:0 12px 40px #0000001a,0 4px 12px #0000000f;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;padding:0;width:100%}.modal-sm{max-width:420px}.modal-md{max-width:520px}.modal-lg{max-width:640px}.modal-xl{max-width:860px}@keyframes modalIn{0%{opacity:0;transform:scale(.97) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-head{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.25rem 1.5rem 1rem}.modal-head h2{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:700}.modal-close{background:#f6f8fa;background:var(--surface2);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;color:#475569;color:var(--text2);cursor:pointer;font-size:.8rem;line-height:1.4;padding:4px 8px;transition:all .12s}.modal-close:hover{background:#eef1f5;background:var(--surface3);border-color:#cbd5e1;border-color:var(--border2);color:#0f172a;color:var(--text)}.modal-body{padding:1.35rem 1.5rem}.modal-foot{background:#f6f8fa;background:var(--surface2);border-radius:0 0 16px 16px;border-radius:0 0 var(--r-xl) var(--r-xl);border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;gap:.6rem;padding:1rem 1.5rem 1.25rem}.form-grid{grid-gap:1rem;display:grid;gap:1rem}.form-row-2{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{color:#475569;color:var(--text2);font-size:.75rem;font-weight:600;letter-spacing:.01em}.form-input,.form-select,.form-textarea{background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);box-shadow:0 1px 2px #0000000a;color:#0f172a;color:var(--text);font-family:Inter,sans-serif;font-size:.875rem;outline:none;padding:.6rem .85rem;transition:all .15s;width:100%}.form-input::placeholder,.form-textarea::placeholder{color:#94a3b8;color:var(--text3)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#635bff;border-color:var(--accent);box-shadow:0 0 0 3px #635bff14;box-shadow:0 0 0 3px var(--accent-dim)}.form-textarea{min-height:80px;resize:vertical}.form-select option{background:#fff;background:var(--surface);color:#0f172a;color:var(--text)}.form-error{background:#dc262614;background:var(--red-dim);border:1px solid #dc262640;border-radius:8px;border-radius:var(--r);color:#dc2626;color:var(--red);font-size:.825rem;margin-bottom:.85rem;padding:.6rem .85rem}.form-check{align-items:center;color:#475569;color:var(--text2);cursor:pointer;display:flex;font-size:.875rem;gap:.55rem;padding:.25rem 0}.form-check input[type=checkbox]{accent-color:#635bff;accent-color:var(--accent);cursor:pointer;height:15px;width:15px}.period-pills{display:flex;flex-wrap:wrap;gap:.4rem}.period-pill{background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:6px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#475569;color:var(--text2);cursor:pointer;font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;padding:.38rem .85rem;transition:all .12s}.period-pill.selected,.period-pill:hover{background:#635bff14;background:var(--accent-dim);border-color:#635bff;border-color:var(--accent);color:#635bff;color:var(--accent)}.period-pill.selected{font-weight:600}.empty-state{padding:4rem 2rem;text-align:center}.empty-icon{display:block;font-size:2.25rem;margin-bottom:.85rem}.empty-state h3{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1rem;font-weight:600;margin-bottom:.4rem}.empty-state p{color:#94a3b8;color:var(--text3);font-size:.85rem;margin-bottom:1.25rem}.loader-wrap{align-items:center;display:flex;justify-content:center;padding:4rem}.spinner{animation:spin .7s linear infinite;border:2.5px solid #cbd5e1;border-top-color:#635bff;border:2.5px solid var(--border2);border-radius:50%;border-top-color:var(--accent);height:26px;width:26px}@keyframes spin{to{transform:rotate(1turn)}}.toast{animation:toastIn .22s ease;background:#0f172a;background:var(--text);border-radius:50px;bottom:1.75rem;box-shadow:0 12px 40px #0000001a,0 4px 12px #0000000f;box-shadow:var(--shadow-lg);color:#fff;font-size:.85rem;font-weight:500;left:50%;padding:.6rem 1.35rem;position:fixed;transform:translateX(-50%);white-space:nowrap;z-index:9999}@keyframes toastIn{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.auth-wrap{align-items:center;background:#f6f8fa;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:2rem}.auth-card{animation:modalIn .25s ease;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--r-xl);box-shadow:0 12px 40px #0000001a,0 4px 12px #0000000f;box-shadow:var(--shadow-lg);max-width:400px;padding:2.5rem 2.25rem;width:100%}.auth-logo{display:block;font-size:2rem;margin-bottom:1rem;text-align:center}.auth-title{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.3rem;text-align:center}.auth-sub{color:#94a3b8;color:var(--text3);font-size:.85rem;margin-bottom:2rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-switch{color:#94a3b8;color:var(--text3);font-size:.85rem;margin-top:1.5rem;text-align:center}.auth-switch a{color:#635bff;color:var(--accent);font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.confirm-card{animation:modalIn .18s ease;background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--r-xl);box-shadow:0 12px 40px #0000001a,0 4px 12px #0000000f;box-shadow:var(--shadow-lg);max-width:380px;padding:2rem 1.75rem;text-align:center;width:100%}.confirm-card h3{color:#0f172a;color:var(--text);font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:.6rem}.confirm-card p{color:#475569;color:var(--text2);font-size:.85rem;line-height:1.6;margin-bottom:1.5rem}.spinner-sm{animation:spin .7s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#f6f8fa;background:var(--surface2)}::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--border2);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--border3)}.mobile-menu-btn{background:#fff;background:var(--surface);border:1px solid #cbd5e1;border:1px solid var(--border2);border-radius:8px;border-radius:var(--r);box-shadow:0 4px 12px #00000014,0 1px 3px #0000000d;box-shadow:var(--shadow);cursor:pointer;display:none;font-size:1.1rem;left:1rem;line-height:1;padding:.5rem .65rem;position:fixed;top:1rem;z-index:300}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;display:none;inset:0;position:fixed;z-index:199}@media (max-width:768px){.mobile-menu-btn,.sidebar-overlay.open{display:block}.sidebar{transform:translateX(-100%);transition:transform .25s ease;z-index:250}.sidebar.open{box-shadow:4px 0 24px #0003;transform:translateX(0)}.page-content{margin-left:0}.page-header{padding:3.5rem 1rem 1rem}.page-body{padding:1rem 1rem 2rem}.stats-grid{gap:.65rem;grid-template-columns:repeat(2,1fr)}.form-row-2{grid-template-columns:1fr}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{min-width:600px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:16px 16px 0 0;border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:92vh;max-width:100%!important}.search-box input{width:100%}.toolbar{align-items:stretch}.toolbar,.toolbar-left{flex-direction:column}.period-pills{gap:.35rem}.period-pill{font-size:.75rem;padding:.35rem .7rem}.page-title{font-size:1.15rem}.btn-primary{font-size:.82rem;padding:.55rem .9rem}}@media (max-width:480px){.stats-grid{gap:.5rem;grid-template-columns:1fr 1fr}.stat-card{padding:.9rem}.stat-card-val{font-size:1.35rem}.page-header{gap:.65rem}}
/*# sourceMappingURL=main.8d0b608a.css.map*/