@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.static{position:static}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.inline-flex{display:inline-flex}.border{border-style:var(--tw-border-style);border-width:1px}.capitalize{text-transform:capitalize}}:root{--bg:#f3f4f7;--bg-subtle:#ebedf2;--surface:#fff;--surface-elevated:#fff;--surface-hover:#f7f8fa;--ink:#0c1222;--ink-1:#0c1222;--ink-2:#4a5568;--muted:#8e99a4;--border:#e0e4eb;--border-strong:#c7cdd6;--accent:#0d9488;--accent-soft:#14b8a6;--accent-tint:#eefcfa;--accent-ink:#0b7a70;--accent-glow:#0d948824;--accent-rgb:13, 148, 136;--success:#16a34a;--danger:#dc2626;--warning:#d97706;--card-shadow:0 1px 3px #0c12220a, 0 1px 2px #0c122208;--card-shadow-hover:0 4px 12px #0c122212, 0 10px 24px #0c12220a;--overlay:#0c12228c;--glass-bg:#ffffffb3;--glass-border:#0000000f;--sidebar-bg:#0c1222;--sidebar-bg-gradient:linear-gradient(174deg, #0e1526 0%, #0a0f1c 40%, #0c1222 100%);--sidebar-surface:#1a2236;--sidebar-text:#b8c2ce;--sidebar-muted:#5a6779;--sidebar-border:#ffffff0f;--sidebar-active-bg:#0d948824;--sidebar-active-border:#14b8a6;--sidebar-hover-bg:#ffffff0a}html.dark{--bg:#020617;--bg-subtle:#0c1222;--surface:#0e1526;--surface-elevated:#1a2236;--surface-hover:#1a2236;--ink:#f0f2f5;--ink-1:#f0f2f5;--ink-2:#8e99a4;--muted:#5a6779;--border:#1a2236;--border-strong:#2a3448;--accent:#14b8a6;--accent-soft:#2dd4bf;--accent-tint:#14b8a61f;--accent-ink:#2dd4bf;--accent-glow:#14b8a629;--glass-bg:#0e1526b3;--glass-border:#ffffff0f;--card-shadow:0 2px 6px #0000004d, 0 6px 16px #0003;--card-shadow-hover:0 6px 16px #00000059, 0 16px 36px #00000040;--overlay:#000000b8;--sidebar-bg:#020617;--sidebar-bg-gradient:linear-gradient(174deg, #020617 0%, #0c1222 50%, #020617 100%);--sidebar-surface:#0c1222;--sidebar-text:#8e99a4;--sidebar-muted:#4a5568}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Manrope,system-ui,-apple-system,sans-serif;line-height:1.55}::selection{color:var(--ink);background:#0d948833}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--sidebar-bg-gradient);border-right:1px solid var(--sidebar-border);z-index:40;flex-direction:column;width:240px;height:100vh;transition:width .25s cubic-bezier(.22,.61,.36,1);display:flex;position:fixed;top:0;left:0}.sidebar:before{content:"";pointer-events:none;background:linear-gradient(#0d94880f,#0000);height:120px;position:absolute;top:0;left:0;right:0}.sidebar-collapsed{width:64px}.sidebar-header{border-bottom:1px solid var(--sidebar-border);justify-content:space-between;align-items:center;padding:18px 16px;display:flex;position:relative}.sidebar-logo-block{flex-direction:column;gap:1px;display:flex}.sidebar-logo{color:#fff;letter-spacing:-.03em;-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#14b8a6,#0d9488);-webkit-background-clip:text;background-clip:text;font-size:1.05rem;font-weight:800;line-height:1.2}.sidebar-logo-by{color:var(--sidebar-muted);letter-spacing:.06em;opacity:.55;font-size:.6rem;font-weight:500;transition:opacity .2s}.sidebar-logo-block:hover .sidebar-logo-by{opacity:.85}.sidebar-toggle{color:var(--sidebar-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px;transition:all .15s}.sidebar-toggle:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text)}.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:14px 16px}.sidebar-user-name{color:var(--sidebar-text);font-size:.83rem;font-weight:600}.sidebar-user-role{color:var(--sidebar-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:500}.sidebar-logout{color:var(--sidebar-muted);cursor:pointer;background:0 0;border:none;margin-top:8px;padding:4px 0;font-family:inherit;font-size:.8rem;transition:color .15s}.sidebar-logout:hover{color:#f87171}.nav-item{color:var(--sidebar-text);cursor:pointer;border-left:3px solid #0000;border-radius:9px;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:.855rem;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-item:hover{background:var(--sidebar-hover-bg);color:#e0e4eb}.nav-item-active{background:var(--sidebar-active-bg);color:var(--accent-soft);border-left-color:var(--sidebar-active-border);font-weight:700}.nav-item-active:after{content:"";background:var(--accent-soft);opacity:.5;border-radius:3px;width:3px;height:16px;position:absolute;top:50%;right:-8px;transform:translateY(-50%)}.nav-item-collapsed{justify-content:center;padding:10px}.nav-item-collapsed span,.nav-item-collapsed:after{display:none}.main-content{flex:1;min-height:100vh;margin-left:240px;transition:margin-left .25s cubic-bezier(.22,.61,.36,1)}.sidebar-collapsed~.main-content{margin-left:64px}.page{max-width:1440px;padding:28px 36px;animation:.3s ease-out page-enter}@keyframes page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:28px;display:flex}.page-title{color:var(--ink);letter-spacing:-.03em;font-size:1.55rem;font-weight:800;line-height:1.2}.glass-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--card-shadow);border-radius:14px;padding:20px;transition:box-shadow .25s,transform .25s}.glass-card:hover{box-shadow:var(--card-shadow-hover)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--card-shadow);border-radius:14px;padding:20px;transition:all .25s;position:relative;overflow:hidden}.kpi-card:before{content:"";background:linear-gradient(90deg,var(--accent),var(--accent-soft));opacity:0;height:3px;transition:opacity .25s;position:absolute;top:0;left:0;right:0}.kpi-card:hover:before{opacity:1}.kpi-card:hover{box-shadow:var(--card-shadow-hover);transform:translateY(-1px)}.kpi-icon{color:var(--accent);margin-bottom:8px}.kpi-label{color:var(--ink-2);text-transform:uppercase;letter-spacing:.03em;font-size:.82rem;font-weight:500}.kpi-value{color:var(--ink);letter-spacing:-.02em;margin-top:4px;font-size:1.75rem;font-weight:800}.btn{cursor:pointer;border:none;border-radius:9px;justify-content:center;align-items:center;gap:6px;padding:9px 18px;font-family:inherit;font-size:.855rem;font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(.22,.61,.36,1);display:inline-flex;position:relative}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-ink) 100%);color:#fff;box-shadow:0 2px 8px #0d948840}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #0d948859}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--surface);color:var(--ink);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-subtle);border-color:var(--border-strong)}.btn-danger{color:#fff;background:#dc2626;box-shadow:0 2px 8px #dc262633}.btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.btn-ghost{color:var(--ink-2);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-subtle)}.input-field,.form-input{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--ink);border-radius:9px;outline:none;margin-bottom:0;padding:10px 14px;font-family:inherit;font-size:.88rem;transition:border-color .2s,box-shadow .2s}.input-field+.input-field,.input-field:not(:last-child){margin-bottom:12px}.input-field:focus,.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input-field::placeholder,.form-input::placeholder{color:var(--muted)}select.input-field,select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238E99A4' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}textarea.input-field,textarea.form-input{resize:vertical;min-height:60px}.form-label{color:var(--ink-2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.badge{letter-spacing:.02em;text-transform:uppercase;border-radius:6px;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.badge-success{color:#15803d;background:#dcfce7}.badge-warning{color:#92400e;background:#fef3c7}.badge-danger{color:#991b1b;background:#fee2e2}.badge-info{color:#1e40af;background:#dbeafe}.badge-muted{background:var(--bg-subtle);color:var(--muted)}.data-table{border-collapse:collapse;width:100%;font-size:.86rem}.data-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--border);background:var(--bg-subtle);z-index:1;padding:10px 14px;font-size:.73rem;font-weight:600;position:sticky;top:0}.data-table td{color:var(--ink);border-bottom:1px solid var(--border);padding:11px 14px;transition:background .1s}.data-table tbody tr{transition:background .1s}.data-table tbody tr:hover td{background:var(--surface-hover)}.data-table tbody tr:last-child td{border-bottom:none}.data-table{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.spinner-center{justify-content:center;align-items:center;min-height:200px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--muted);padding:48px 24px}.empty-state-title{color:var(--ink-2);margin-bottom:4px;font-size:1rem;font-weight:600}.modal-overlay{background:var(--overlay);z-index:100;-webkit-backdrop-filter:blur(4px);justify-content:center;align-items:center;animation:.2s overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-content,.modal{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:90%;max-width:520px;max-height:90vh;padding:28px;animation:.25s cubic-bezier(.22,.61,.36,1) modal-enter;overflow-y:auto;box-shadow:0 24px 56px #0000002e,0 8px 16px #00000014}@keyframes modal-enter{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;display:flex}.modal-header h2,.modal-header h3{letter-spacing:-.02em;font-size:1.15rem;font-weight:700}.modal-title{letter-spacing:-.02em;margin-bottom:16px;font-size:1.15rem;font-weight:700}.toast{z-index:200;border-radius:12px;padding:12px 20px;font-size:.855rem;font-weight:600;animation:.3s cubic-bezier(.22,.61,.36,1) toast-in;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 28px #00000026}.toast-success{color:#fff;background:#16a34a}.toast-error{color:#fff;background:#dc2626}@keyframes toast-in{0%{opacity:0;transform:translateY(16px)}}.alert{border-radius:10px;padding:12px 16px;font-size:.855rem;font-weight:500}.alert-danger{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}.alert-success{color:#15803d;background:#dcfce7;border:1px solid #bbf7d0}.login-page{background:var(--sidebar-bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#0d948826,#0000 70%);width:600px;height:600px;position:absolute;top:-30%;right:-20%}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#0d948814,#0000 70%);width:400px;height:400px;position:absolute;bottom:-20%;left:-10%}.login-form{background:var(--surface);border:1px solid var(--border);z-index:1;border-radius:20px;width:380px;padding:40px 36px;animation:.5s cubic-bezier(.22,.61,.36,1) login-enter;position:relative;box-shadow:0 20px 60px #0003,0 4px 12px #0000001a}@keyframes login-enter{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.login-form .btn-primary{width:100%;margin-top:4px;padding:12px;font-size:.95rem}.login-logo-block{text-align:center;margin-bottom:4px}.login-title{-webkit-text-fill-color:transparent;text-align:center;letter-spacing:-.04em;background:linear-gradient(135deg,#14b8a6,#0d9488);-webkit-background-clip:text;background-clip:text;margin-bottom:2px;font-size:1.65rem;font-weight:800}.login-logo-by{color:var(--muted);letter-spacing:.08em;opacity:.6;font-size:.68rem;font-weight:500;display:block}.login-subtitle{text-align:center;color:var(--muted);margin-bottom:28px;font-size:.85rem;font-weight:500}.login-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca;border-radius:10px;margin-bottom:14px;padding:10px 14px;font-size:.83rem;font-weight:500}.tabs,.tab-bar{background:var(--bg-subtle);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;gap:4px;margin-bottom:16px;padding:4px;display:flex;overflow-x:auto}.tab,.tab-btn{cursor:pointer;color:var(--ink-2);white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:4px;padding:7px 16px;font-family:inherit;font-size:.83rem;font-weight:600;transition:all .15s;display:inline-flex}.tab:hover,.tab-btn:hover{background:var(--surface);color:var(--ink)}.tab-active,.tab-btn.active{background:var(--surface);color:var(--accent-ink);font-weight:700;box-shadow:0 1px 3px #0000000f}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0}.page{padding:16px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.page-title{font-size:1.25rem}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:8px 10px}}@media(max-width:480px){.kpi-grid{grid-template-columns:1fr}.page{padding:12px}.login-form{width:92%;padding:28px 24px}.tabs,.tab-bar{flex-wrap:nowrap;overflow-x:auto}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
