*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d26;--surface2:#22262f;--border:#2a2d36;--brand:#3b82f6;--brand-dark:#2563eb;--brand-glow:#3b82f640;--text:#f1f3f8;--text2:#8b92a5;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--purple:#8b5cf6;--pink:#ec4899;--sidebar-w:240px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px}.layout{min-height:100vh;display:flex}.overlay{z-index:40;background:#00000080;position:fixed;inset:0}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:50;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 16px;display:flex}.logo{align-items:center;gap:10px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--brand), var(--purple));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;display:flex}.logo-text{font-size:15px;font-weight:700}.logo-sub{color:var(--text2);font-size:11px}.close-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px}.close-btn:hover{background:var(--surface2);color:var(--text)}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-item{color:var(--text2);border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--brand-glow);color:var(--brand);font-weight:600}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.admin-info{align-items:center;gap:10px;margin-bottom:12px;display:flex}.admin-avatar{background:var(--surface2);border:2px solid var(--brand);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.admin-email{font-size:13px;font-weight:600}.admin-role{color:var(--text2);font-size:11px}.logout-btn{border:1px solid var(--border);width:100%;color:var(--text2);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.logout-btn:hover{border-color:var(--danger);color:var(--danger);background:#ef44441a}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:30;align-items:center;gap:16px;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.menu-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px;display:none}.menu-btn:hover{background:var(--surface2)}.topbar-title{font-size:16px;font-weight:700}.topbar-right{margin-left:auto}.admin-badge{background:var(--brand);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.content{flex:1;padding:24px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-title{font-size:24px;font-weight:700}.page-sub{color:var(--text2);margin-top:4px;font-size:13px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:16px;padding:20px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:flex-start;gap:14px;padding:20px;display:flex}.stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-value{font-size:24px;font-weight:800}.stat-label{color:var(--text2);margin-top:2px;font-size:12px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text2);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;background:var(--surface2);padding:12px 16px;font-size:12px;font-weight:600}td{border-bottom:1px solid var(--border);padding:14px 16px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-admin{background:linear-gradient(135deg, var(--brand), var(--purple));color:#fff}.btn-admin:hover{opacity:.9}.btn-ghost{border:1px solid var(--border);color:var(--text2);background:0 0}.btn-ghost:hover{border-color:var(--text2);color:var(--text)}.btn-sm{border-radius:6px;padding:5px 10px;font-size:12px}.badge{border-radius:20px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{color:var(--success);background:#22c55e26}.badge-warning{color:var(--warning);background:#f59e0b26}.badge-danger{color:var(--danger);background:#ef444426}.badge-info{color:var(--brand);background:#3b82f626}.badge-purple{color:var(--purple);background:#8b5cf626}.badge-pink{color:var(--pink);background:#ec489926}.form-group{margin-bottom:16px}.form-label{margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.form-input:focus{border-color:var(--brand)}.form-input::placeholder{color:var(--text2)}textarea.form-input{resize:vertical;min-height:80px}.modal-backdrop{z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:560px;max-height:90vh;padding:28px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-close{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px}.modal-close:hover{background:var(--surface2)}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.avatar{background:var(--surface2);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.text-muted{color:var(--text2)}.text-sm{font-size:12px}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.font-mono{font-family:JetBrains Mono,monospace;font-size:13px}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.mb-2{margin-bottom:8px}.ml-auto{margin-left:auto}.loading{color:var(--text2);justify-content:center;align-items:center;gap:12px;padding:60px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--text2);padding:48px 24px}.empty-icon{opacity:.4;margin-bottom:12px;font-size:48px}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0}.menu-btn{display:flex}.card-grid{grid-template-columns:1fr 1fr}.topbar-title{font-size:14px}.content{padding:16px}}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:40px}.login-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-logo-icon{background:linear-gradient(135deg, var(--brand), var(--purple));color:#fff;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:800;display:flex}.login-title{text-align:center;font-size:22px;font-weight:800}.login-sub{color:var(--text2);text-align:center;margin-top:4px;font-size:13px}.login-error{border:1px solid var(--danger);color:var(--danger);background:#ef44441a;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.divider{align-items:center;gap:12px;margin:20px 0;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.divider span{color:var(--text2);font-size:12px;font-weight:600}.toast-stack{z-index:200;flex-direction:column;gap:10px;max-width:360px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--surface);border:1px solid var(--border);border-left-width:4px;border-radius:10px;align-items:flex-start;gap:10px;min-width:280px;padding:12px 14px;animation:.2s toast-in;display:flex;box-shadow:0 8px 24px #00000059}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--danger)}.toast-warning{border-left-color:var(--warning)}.toast-info{border-left-color:var(--brand)}.toast-title{font-size:13px;font-weight:600}.toast-desc{color:var(--text2);margin-top:2px;font-size:12px;line-height:1.5}.toast-close{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:2px}.toast-close:hover{background:var(--surface2);color:var(--text)}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.drawer-backdrop{z-index:90;background:#000000a6;position:fixed;inset:0}.drawer{background:var(--surface);border-left:1px solid var(--border);z-index:95;flex-direction:column;width:480px;max-width:95vw;animation:.25s drawer-in;display:flex;position:fixed;top:0;bottom:0;right:0}@keyframes drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.drawer-title{font-size:16px;font-weight:700}.drawer-body{flex:1;padding:20px;overflow-y:auto}.drawer-section{margin-bottom:24px}.drawer-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text2);margin-bottom:8px;font-size:11px;font-weight:700}.skeleton{background:linear-gradient(90deg, var(--surface2) 0%, var(--border) 50%, var(--surface2) 100%);background-size:200% 100%;border-radius:6px;animation:1.2s ease-in-out infinite skel}@keyframes skel{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-row{height:14px;margin-bottom:10px}.skeleton-card{border-radius:12px;height:120px;margin-bottom:12px}.detail-grid{grid-template-columns:1fr 1fr;gap:12px 16px;display:grid}.detail-row{flex-direction:column;gap:2px;display:flex}.detail-key{color:var(--text2);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.detail-val{word-break:break-word;font-size:13px;font-weight:600}.filter-chip{background:var(--brand-glow);color:var(--brand);border-radius:16px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.img-thumb{object-fit:contain;background:var(--bg);border:1px solid var(--border);cursor:zoom-in;border-radius:8px;width:100%;max-height:220px}.img-thumb-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toolbar-right{align-items:center;gap:8px;margin-left:auto;display:flex}.pagination{border-top:1px solid var(--border);color:var(--text2);justify-content:space-between;align-items:center;padding:12px 16px;font-size:12px;display:flex}.pagination-controls{align-items:center;gap:6px;display:flex}
