:root{--sidebar-bg: #16213a;--sidebar-bg-2: #1e2a45;--sidebar-fg: #c7d2e4;--sidebar-fg-muted: #8696b3;--sidebar-active: #497ee4;--brand: #497ee4;--brand-dark: #3d69be;--content-bg: #eef2f7;--ink: #1e2a45;--line: #e2e8f0;--muted: #64748b;--danger: #b42318;--sidebar-w: 256px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:"Source Sans 3",Segoe UI,Tahoma,Arial,sans-serif;background:var(--content-bg);color:var(--ink)}a{color:var(--brand)}.admin-shell{display:flex;min-height:100vh}.admin-main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}.admin-content{flex:1 1 auto;padding:1.25rem 1.5rem}.admin-sidebar{flex:0 0 var(--sidebar-w);width:var(--sidebar-w);background:var(--sidebar-bg);color:var(--sidebar-fg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.admin-brand{display:flex;align-items:center;gap:.6rem;padding:1rem 1.1rem;font-weight:800;font-size:1.15rem;color:#fff;background:var(--sidebar-bg-2);border-bottom:1px solid rgba(255,255,255,.06)}.admin-brand img{height:30px}.admin-nav{padding:.5rem .5rem 2rem}.admin-nav-group-label{text-transform:uppercase;font-size:.7rem;letter-spacing:.06em;color:var(--sidebar-fg-muted);padding:.9rem .8rem .35rem}.admin-nav-link,.admin-nav-toggle{display:flex;align-items:center;gap:.65rem;width:100%;padding:.55rem .8rem;margin:.1rem 0;border:none;background:none;color:var(--sidebar-fg);text-decoration:none;border-radius:8px;font-size:.92rem;font-weight:600;cursor:pointer;text-align:left}.admin-nav-link:hover,.admin-nav-toggle:hover{background:#ffffff0f;color:#fff}.admin-nav-link.active{background:var(--sidebar-active);color:#fff}.admin-nav-link .ico,.admin-nav-toggle .ico{width:1.1rem;text-align:center;font-style:normal;opacity:.9}.admin-nav-toggle .chev{margin-left:auto;transition:transform .15s}.admin-nav-toggle.open .chev{transform:rotate(90deg)}.admin-nav-children{margin-left:.6rem;padding-left:.4rem;border-left:1px solid rgba(255,255,255,.08)}.admin-nav-children .admin-nav-link{font-size:.86rem;font-weight:500}.admin-topbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-bottom:1px solid var(--line);padding:.6rem 1.5rem;position:sticky;top:0;z-index:20}.admin-topbar .page-title{font-size:1.15rem;font-weight:800;color:var(--ink);margin:0}.admin-user{display:flex;align-items:center;gap:.8rem;position:relative}.admin-user .who{text-align:right;line-height:1.1}.admin-user .who .name{font-weight:700}.admin-user .who .role{font-size:.78rem;color:var(--muted)}.admin-user .avatar{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700}.admin-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;min-width:180px;border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px #0f172a1f;padding:.35rem;z-index:30}.admin-menu a,.admin-menu button{display:block;width:100%;text-align:left;padding:.5rem .7rem;border:none;background:none;color:var(--ink);text-decoration:none;border-radius:7px;font-size:.9rem;cursor:pointer}.admin-menu a:hover,.admin-menu button:hover{background:var(--content-bg)}.admin-menu .danger{color:var(--danger)}.hamburger{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--ink)}.card{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 4px 16px #0f172a0d;overflow:hidden}.card+.card{margin-top:1rem}.card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.9rem 1.1rem;border-bottom:1px solid var(--line);font-weight:700;color:var(--ink)}.card-body{padding:1.1rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.25rem}.kpi{border-radius:12px;padding:1rem 1.1rem;color:#fff;box-shadow:0 4px 16px #0f172a14;display:flex;flex-direction:column;gap:.25rem}.kpi .kpi-value{font-size:1.9rem;font-weight:800;line-height:1}.kpi .kpi-label{font-size:.85rem;opacity:.92}.kpi.blue{background:linear-gradient(135deg,#4a7bdc,#3d69be)}.kpi.cyan{background:linear-gradient(135deg,#17a2b8,#1391a5)}.kpi.green{background:linear-gradient(135deg,#28a745,#20913b)}.kpi.amber{background:linear-gradient(135deg,#f0ad4e,#e0972f)}.kpi.purple{background:linear-gradient(135deg,#7c5cdc,#6a49c4)}.kpi.slate{background:linear-gradient(135deg,#475569,#334155)}.table-wrap{overflow-x:auto}table.data-table{width:100%;border-collapse:collapse}table.data-table thead th{background:#f8fafc;text-align:left;font-size:.82rem;color:#475569;padding:.65rem 1rem;border-bottom:1px solid var(--line);white-space:nowrap}table.data-table tbody td{padding:.65rem 1rem;border-bottom:1px solid #eef2f7;color:var(--ink);vertical-align:middle}table.data-table tbody tr:last-child td{border-bottom:none}table.data-table tbody tr:hover{background:#f9fbff}.badge{display:inline-block;padding:.22rem .6rem;border-radius:999px;font-size:.76rem;font-weight:700}.badge.success{background:#dcfce7;color:#166534}.badge.secondary{background:#e2e8f0;color:#475569}.badge.warning{background:#fef3c7;color:#92400e}.badge.danger{background:#fee2e2;color:#991b1b}.badge.info{background:#dbeafe;color:#1e40af}.btn{display:inline-flex;align-items:center;gap:.4rem;border:1px solid transparent;border-radius:8px;padding:.45rem .9rem;font-size:.88rem;font-weight:700;cursor:pointer;text-decoration:none;line-height:1.2}.btn:disabled{opacity:.6;cursor:default}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover:not(:disabled){background:var(--brand-dark)}.btn-secondary{background:#fff;color:var(--ink);border-color:var(--line)}.btn-secondary:hover:not(:disabled){background:var(--content-bg)}.btn-danger{background:#fff;color:var(--danger);border-color:#fca5a5}.btn-danger:hover:not(:disabled){background:#fef2f2}.btn-danger-solid{background:var(--danger);color:#fff}.btn-sm{padding:.3rem .6rem;font-size:.8rem}.btn-row{display:flex;gap:.4rem;flex-wrap:wrap}.filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.filter-field{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--muted);font-weight:600}.filter-field select,.filter-field input{border:1px solid var(--line);border-radius:8px;padding:.45rem .6rem;font-size:.9rem;color:var(--ink);background:#fff;min-width:160px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field label{font-size:.85rem;font-weight:700;color:var(--ink)}.form-field input,.form-field select,.form-field textarea{border:1px solid var(--line);border-radius:8px;padding:.5rem .65rem;font-size:.92rem;color:var(--ink);background:#fff;width:100%}.form-field .hint{font-size:.78rem;color:var(--muted)}.form-actions{display:flex;gap:.6rem;margin-top:1.1rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:grid;place-items:center;z-index:100;padding:1rem}.modal{background:#fff;border-radius:14px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0f172a4d}.modal.wide{max-width:880px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.2rem;border-bottom:1px solid var(--line);font-weight:800}.modal-body{padding:1.2rem}.modal-footer{display:flex;justify-content:flex-end;gap:.6rem;padding:1rem 1.2rem;border-top:1px solid var(--line)}.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--muted)}.pager{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.8rem 1.1rem;border-top:1px solid var(--line);font-size:.88rem;color:var(--muted)}.pager .pages{display:flex;gap:.3rem}.pager button{border:1px solid var(--line);background:#fff;border-radius:7px;padding:.3rem .65rem;cursor:pointer;font-weight:600}.pager button.active{background:var(--brand);color:#fff;border-color:var(--brand)}.pager button:disabled{opacity:.5;cursor:default}.state-muted{padding:1.5rem;color:var(--muted);text-align:center}.state-danger{padding:1.25rem;color:var(--danger)}.alert{border-radius:10px;padding:.7rem .9rem;font-size:.9rem;margin-bottom:.9rem}.alert.success{background:#dcfce7;color:#166534}.alert.danger{background:#fee2e2;color:#991b1b}.alert.info{background:#dbeafe;color:#1e40af}.progress{height:8px;background:var(--line);border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;background:var(--brand);transition:width .3s}.section-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.section-head h2{margin:0;font-size:1.4rem;font-weight:800}.breadcrumb{font-size:.82rem;color:var(--muted);margin-bottom:.5rem}.nav-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.nav-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem;text-decoration:none;color:var(--ink);display:flex;flex-direction:column;gap:.4rem;box-shadow:0 4px 16px #0f172a0d}.nav-card:hover{border-color:var(--brand)}.nav-card .ico{font-size:1.5rem}.nav-card .t{font-weight:800}.nav-card .d{font-size:.85rem;color:var(--muted)}.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#16213a,#1e2a45);padding:1rem}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;width:100%;max-width:400px;padding:2rem}.login-card .brand{text-align:center;font-size:1.5rem;font-weight:800;color:var(--ink);margin-bottom:.25rem}.login-card .sub{text-align:center;color:var(--muted);margin-bottom:1.5rem;font-size:.9rem}@media(max-width:900px){.admin-sidebar{position:fixed;z-index:50;transform:translate(-100%);transition:transform .2s}.admin-sidebar.open{transform:translate(0)}.hamburger{display:block}.admin-content{padding:1rem}}
