@import "https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;600;700;800&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@500&display=swap";@import "https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&display=swap";:root{--brand-primary:#fdb42a;--brand-primary-dark:#c88a00;--brand-secondary:#7f5600;--surface-bg:#f8f9fc;--surface-base:#fff;--surface-card:#fff;--surface-card-hover:#fcfcfd;--surface-elevated:#fff;--surface-border:#00000014;--surface-border-focus:#fdb42a80;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--text-brand:#c88a00;--status-success:#22c55e;--status-warning:#f59e0b;--status-error:#ef4444;--status-info:#3b82f6;--font-display:"Hanken Grotesk", sans-serif;--font-body:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--sidebar-width:260px;--topbar-height:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px}body.dark-mode{--surface-bg:#0b0f19;--surface-base:#111827;--surface-card:#111827;--surface-card-hover:#1f2937;--surface-elevated:#1f2937;--surface-border:#ffffff1a;--surface-border-focus:#fdb42a80;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-muted:#6b7280;--text-brand:#fdb42a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--surface-bg);color:var(--text-primary);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:var(--font-body);border:none;outline:none}.material-symbols-outlined{text-transform:none;letter-spacing:normal;word-wrap:normal;white-space:nowrap;font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;vertical-align:middle;direction:ltr;font-family:Material Symbols Outlined;font-size:24px;font-style:normal;font-weight:400;line-height:1;display:inline-block}.material-symbols-outlined.filled{font-variation-settings:"FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface-base)}::-webkit-scrollbar-thumb{background:var(--surface-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.portal-shell{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--topbar-height) 1fr;min-height:100vh;display:grid}.portal-main{min-height:calc(100vh - var(--topbar-height));grid-area:2/2;padding:28px 32px;overflow-y:auto}@media (width<=900px){.portal-shell{grid-template-columns:1fr}.portal-main{grid-column:1;padding:20px 16px}}.portal-card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:24px;transition:background .2s,border-color .2s}.portal-card:hover{background:var(--surface-card-hover)}.stat-card{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);cursor:default;flex-direction:column;gap:8px;padding:20px 24px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;display:flex}.stat-card:hover{border-color:#fdb42a66;transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.stat-label{letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);font-size:12px;font-weight:600}.stat-value{font-family:var(--font-display);color:var(--text-primary);font-size:32px;font-weight:800;line-height:1}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:8px;display:flex}.gradient-text{background:linear-gradient(135deg,#fdb42a,#ffda85);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.btn{border-radius:var(--radius-md);font-family:var(--font-body);cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-brand{background:linear-gradient(135deg, var(--brand-primary), #e6a010);color:#1a0e00;box-shadow:0 4px 14px #fdb42a40}.btn-brand:hover{transform:translateY(-1px);box-shadow:0 6px 20px #fdb42a59}.btn-brand:active{transform:scale(.97)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--surface-border);background:0 0}.btn-ghost:hover{background:var(--surface-elevated);color:var(--text-primary);border-color:#00000026}.btn-danger{color:var(--status-error);background:#ef44441f;border:1px solid #ef444433}.btn-danger:hover{background:#ef444433}.btn-sm{padding:7px 14px;font-size:13px}.portal-table{border-collapse:collapse;width:100%}.portal-table thead tr{border-bottom:1px solid var(--surface-border)}.portal-table th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);padding:12px 16px;font-size:11px;font-weight:700}.portal-table td{color:var(--text-secondary);border-bottom:1px solid #0000000a;padding:14px 16px;font-size:14px}.portal-table tbody tr:hover td{background:#00000005}.portal-table tbody tr:last-child td{border-bottom:none}.badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-admin{color:#fdb42a;background:#fdb42a26}.badge-blue{color:#60a5fa;background:#3b82f626}.badge-purple{color:#a855f7;background:#a855f726}.badge-orange{color:#fb923c;background:#f9731626}.badge-green{color:#4ade80;background:#22c55e26}.badge-pink{color:#f472b6;background:#ec489926}.badge-red{color:#f87171;background:#ef444426}.badge-teal{color:#2dd4bf;background:#14b8a626}.badge-yellow{color:#facc15;background:#eab30826}.badge-indigo{color:#818cf8;background:#6366f126}.badge-cyan{color:#22d3ee;background:#06b6d426}.badge-emerald{color:#34d399;background:#10b98126}.badge-slate{color:#94a3b8;background:#64748b26}.badge-rose{color:#fb7185;background:#f43f5e26}.portal-input{background:var(--surface-base);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-family:var(--font-body);color:var(--text-primary);outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s}.portal-input:focus{border-color:var(--surface-border-focus);box-shadow:0 0 0 3px #fdb42a14}.portal-input::placeholder{color:var(--text-muted)}.portal-select{background:var(--surface-base);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-family:var(--font-body);color:var(--text-primary);cursor:pointer;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .2s}.portal-select:focus{border-color:var(--surface-border-focus)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-box{background:var(--surface-card);border:1px solid var(--surface-border);border-radius:var(--radius-xl);width:100%;max-width:480px;padding:28px;animation:.25s cubic-bezier(.34,1.56,.64,1) slideUp}.modal-title{font-family:var(--font-display);margin-bottom:20px;font-size:20px;font-weight:700}.modal-footer{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.form-group{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.form-label{color:var(--text-secondary);font-size:13px;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.page-title{font-family:var(--font-display);color:var(--text-primary);font-size:24px;font-weight:800}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:14px}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.grid-5{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;display:grid}@media (width<=1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.spinner{border:2px solid #0000001a;border-top-color:var(--brand-primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-md);align-items:center;gap:10px;min-width:260px;max-width:360px;padding:12px 18px;font-size:14px;font-weight:500;animation:.3s cubic-bezier(.34,1.56,.64,1) toastIn;display:flex;box-shadow:0 8px 24px #0006}.toast-success{color:#4ade80;background:#22c55e26;border:1px solid #22c55e4d}.toast-error{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.toast-info{color:#60a5fa;background:#3b82f626;border:1px solid #3b82f64d}@keyframes toastIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.divider{background:var(--surface-border);height:1px;margin:20px 0}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state .material-symbols-outlined{opacity:.4;font-size:48px}.empty-state p{font-size:14px}.sidebar{background:var(--surface-base);border-right:1px solid var(--surface-border);z-index:100;flex-direction:column;grid-area:1/1/3;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--surface-border);flex-shrink:0;align-items:center;gap:12px;padding:20px 20px 16px;display:flex}.sidebar-logo{object-fit:contain;background:#fdb42a1a;border-radius:8px;flex-shrink:0;width:36px;height:36px;padding:3px}.sidebar-brand-text{flex-direction:column;gap:1px;display:flex}.sidebar-brand-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;font-size:15px;font-weight:800;line-height:1}.sidebar-brand-sub{letter-spacing:.06em;text-transform:uppercase;color:var(--brand-primary);font-size:10px;font-weight:600}.sidebar-role-wrap{padding:12px 20px 8px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex;overflow-y:auto}.sidebar-link{color:var(--text-secondary);border-radius:10px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-link:hover{background:var(--surface-card);color:var(--text-primary)}.sidebar-link--active{color:var(--brand-primary);background:#fdb42a1f;font-weight:600}.sidebar-link--active .sidebar-link-icon{font-variation-settings:"FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24}.sidebar-link-icon{flex-shrink:0;font-size:20px}.sidebar-link-label{flex:1}.sidebar-footer{border-top:1px solid var(--surface-border);flex-shrink:0;align-items:center;gap:10px;padding:16px;display:flex}.sidebar-user{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--brand-primary), var(--brand-secondary));color:#1a0e00;width:34px;height:34px;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex}.sidebar-user-info{flex-direction:column;gap:1px;min-width:0;display:flex}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-logout-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;align-items:center;padding:6px;transition:color .2s,background .2s;display:flex}.sidebar-logout-btn:hover{color:var(--status-error);background:#ef44441a}.sidebar-logout-btn .material-symbols-outlined{font-size:20px}@media (width<=900px){.sidebar{display:none}}.core-login-root{min-height:100vh;font-family:var(--font-body);background:#050505;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.core-bg{z-index:0;background:radial-gradient(circle at 15%,#fdb42a14,#0000 25%),radial-gradient(circle at 85% 30%,#c88a000d,#0000 25%);position:absolute;inset:0}.core-grid{transform-origin:50%;z-index:1;background-image:linear-gradient(90deg,#ffffff05 1px,#0000 1px),linear-gradient(#ffffff05 1px,#0000 1px);background-size:40px 40px;animation:40s linear infinite gridMove;position:absolute;inset:-50%;transform:rotate(15deg)}@keyframes gridMove{0%{transform:rotate(15deg)translateY(0)}to{transform:rotate(15deg)translateY(-40px)}}.core-login-card{z-index:10;-webkit-backdrop-filter:blur(20px);background:#14141499;border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:440px;padding:48px 40px;animation:.8s cubic-bezier(.16,1,.3,1) cardEntrance;position:relative;box-shadow:0 24px 64px #0006}@keyframes cardEntrance{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.core-login-header{text-align:center;margin-bottom:36px}.core-login-logo{width:56px;height:56px;color:var(--brand-primary);background:#fdb42a1a;border:1px solid #fdb42a33;border-radius:16px;justify-content:center;align-items:center;margin:0 auto 16px;display:flex}.core-login-title{font-family:var(--font-display);color:#fff;letter-spacing:-.02em;margin-bottom:6px;font-size:28px;font-weight:800}.core-login-subtitle{color:#9ca3af;font-size:14px}.core-login-error{color:#f87171;background:#ef44441a;border:1px solid #ef444433;border-radius:12px;align-items:center;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:13px;font-weight:500;animation:.5s cubic-bezier(.36,.07,.19,.97) both shake;display:flex}@keyframes shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-4px)}40%,60%{transform:translate(4px)}}.core-input-group{margin-bottom:20px;position:relative}.core-input-label{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.core-input-wrapper{align-items:center;display:flex;position:relative}.core-input-icon{color:#6b7280;font-size:20px;transition:color .2s;position:absolute;left:14px}.core-input{width:100%;font-family:var(--font-body);color:#fff;background:#0006;border:1px solid #ffffff1a;border-radius:12px;outline:none;padding:14px 14px 14px 44px;font-size:15px;transition:all .2s}.core-input::placeholder{color:#4b5563}.core-input:focus{border-color:var(--brand-primary);background:#0009;box-shadow:0 0 0 3px #fdb42a26}.core-input:focus+.core-input-icon{color:var(--brand-primary)}.core-btn{background:var(--brand-primary);color:#1a0e00;width:100%;font-family:var(--font-body);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;margin-top:12px;padding:16px;font-size:15px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 8px 24px #fdb42a40}.core-btn:hover{background:#ffc04d;transform:translateY(-2px);box-shadow:0 12px 32px #fdb42a59}.core-btn:active{transform:scale(.98)}.core-btn:disabled{color:#9ca3af;cursor:not-allowed;box-shadow:none;background:#4b5563;transform:none}.core-spinner{border:2px solid #0003;border-top-color:#1a0e00;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}
