:root{--bg-base: #0F1117;--bg-surface: #1A1D27;--bg-elevated: #242836;--bg-hover: #2E3345;--border-subtle: rgba(255, 255, 255, .08);--border-default: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .2);--text-primary: #E8EAED;--text-secondary: #9AA0B0;--text-muted: #636B80;--text-inverse: #0F1117;--accent-primary: #6C63FF;--accent-primary-hover: #7B73FF;--accent-primary-muted: rgba(108, 99, 255, .15);--accent-primary-rgb: 108, 99, 255;--accent-success: #34D399;--accent-success-muted: rgba(52, 211, 153, .15);--accent-warning: #FBBF24;--accent-warning-muted: rgba(251, 191, 36, .15);--accent-danger: #F87171;--accent-danger-muted: rgba(248, 113, 113, .15);--accent-info: #38BDF8;--accent-info-muted: rgba(56, 189, 248, .15);--glass-bg: rgba(26, 29, 39, .6);--glass-border: rgba(255, 255, 255, .06);--glass-blur: 16px;--overlay: rgba(0, 0, 0, .55);--scrollbar-bg: transparent;--scrollbar-thumb: rgba(255, 255, 255, .12);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-9: 2.5rem;--space-10: 3rem;--space-11: 4rem;--space-12: 6rem;--font-heading: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-extrabold: 800;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .25);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .35), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 8px 10px -6px rgba(0, 0, 0, .35);--shadow-glow: 0 0 20px rgba(var(--accent-primary-rgb), .25);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.45, 0, .55, 1);--ease-bounce: cubic-bezier(.34, 1.56, .64, 1);--ease-spring: cubic-bezier(.22, 1.2, .36, 1);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .35s;--duration-slower: .5s;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600;--z-maximum: 9999}[data-theme=light]{--bg-base: #F4F5F7;--bg-surface: #FFFFFF;--bg-elevated: #FFFFFF;--bg-hover: #EBEDF0;--border-subtle: rgba(0, 0, 0, .06);--border-default: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .18);--text-primary: #1A1D27;--text-secondary: #5A6070;--text-muted: #8B92A5;--text-inverse: #FFFFFF;--accent-primary: #5A4FE8;--accent-primary-hover: #4D42D6;--accent-primary-muted: rgba(90, 79, 232, .1);--accent-success: #10B981;--accent-success-muted: rgba(16, 185, 129, .1);--accent-warning: #D97706;--accent-warning-muted: rgba(217, 119, 6, .1);--accent-danger: #EF4444;--accent-danger-muted: rgba(239, 68, 68, .1);--accent-info: #0EA5E9;--accent-info-muted: rgba(14, 165, 233, .1);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(0, 0, 0, .06);--overlay: rgba(0, 0, 0, .3);--scrollbar-thumb: rgba(0, 0, 0, .15);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -4px rgba(0, 0, 0, .06);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .06);--shadow-glow: 0 0 20px rgba(90, 79, 232, .15)}*,*:before,*:after{box-sizing:border-box}*:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)){margin:0;padding:0}html{color-scheme:dark light;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;-moz-tab-size:4;tab-size:4;hanging-punctuation:first last}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;min-height:100dvh;line-height:var(--leading-normal, 1.5)}h1,h2,h3,h4,h5,h6{text-wrap:balance;overflow-wrap:break-word}p{text-wrap:pretty;overflow-wrap:break-word}ul[role=list],ol[role=list]{list-style:none}a{color:inherit;text-decoration:inherit}img,picture,video,canvas,svg{display:block;max-width:100%}img{height:auto;font-style:italic}input,button,textarea,select{font:inherit;color:inherit;letter-spacing:inherit}input,textarea{width:100%}button{cursor:pointer;border:none;background:none;padding:0}fieldset{border:none}table{border-collapse:collapse;border-spacing:0}summary{cursor:pointer}dialog{padding:0;border:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--scrollbar-bg, transparent)}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb, rgba(255, 255, 255, .12));border-radius:var(--radius-full, 9999px)}::-webkit-scrollbar-thumb:hover{background:#fff3}@supports (scrollbar-width: thin){*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb, rgba(255, 255, 255, .12)) transparent}}@media(prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}body{background-color:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--weight-regular);line-height:var(--leading-normal);letter-spacing:var(--tracking-normal)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--weight-bold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-md)}p{color:var(--text-secondary);line-height:var(--leading-relaxed);max-width:72ch}p+p{margin-top:var(--space-4)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--accent-primary-hover);text-decoration:underline;text-underline-offset:2px}ul,ol{padding-left:var(--space-6);color:var(--text-secondary)}li{line-height:var(--leading-relaxed)}li+li{margin-top:var(--space-1)}strong,b{font-weight:var(--weight-semibold);color:var(--text-primary)}small{font-size:var(--text-sm)}code{font-family:var(--font-mono);font-size:.9em;background:var(--bg-elevated);padding:.15em .4em;border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}mark{background:var(--accent-warning-muted);color:var(--accent-warning);padding:.1em .3em;border-radius:var(--radius-sm)}hr{border:none;height:1px;background:var(--border-subtle);margin:var(--space-8) 0}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px;border-radius:var(--radius-sm)}:focus:not(:focus-visible){outline:none}::selection{background:var(--accent-primary-muted);color:var(--text-primary)}::-moz-selection{background:var(--accent-primary-muted);color:var(--text-primary)}::placeholder{color:var(--text-muted);opacity:1}@layer animations{@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shake{0%,to{transform:translate(0)}10%,50%,90%{transform:translate(-4px)}30%,70%{transform:translate(4px)}}@keyframes floatOrb{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-40px) scale(1.05)}50%{transform:translate(-20px,-60px) scale(.95)}75%{transform:translate(-40px,-20px) scale(1.02)}}@keyframes progressShrink{0%{width:100%}to{width:0%}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.page-enter{animation:fadeInUp .3s var(--ease-out) both}.page-exit{opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.animate-fade-in{animation:fadeIn var(--duration-normal) var(--ease-out) both}.animate-fade-in-up{animation:fadeInUp var(--duration-slow) var(--ease-out) both}.animate-fade-in-scale{animation:fadeInScale var(--duration-slow) var(--ease-out) both}.animate-spin{animation:spin .8s linear infinite}.animate-pulse{animation:pulse 2s var(--ease-in-out) infinite}@media(prefers-reduced-motion:reduce){.page-enter,.page-exit,.stagger-1,.stagger-2,.stagger-3,.stagger-4,.stagger-5,.stagger-6,.animate-fade-in,.animate-fade-in-up,.animate-fade-in-scale,.animate-spin,.animate-pulse{animation:none!important;transition:none!important}}}@layer components{.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--weight-medium);line-height:1;white-space:nowrap;border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn.btn-primary,.btn.btn--primary{background:var(--accent-primary);color:#fff;box-shadow:0 1px 3px rgba(var(--accent-primary-rgb),.3)}.btn.btn-primary:hover:not(:disabled),.btn.btn--primary:hover:not(:disabled){background:var(--accent-primary-hover);box-shadow:0 4px 12px rgba(var(--accent-primary-rgb),.35)}.btn.btn-secondary,.btn.btn--secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-default)}.btn.btn-secondary:hover:not(:disabled),.btn.btn--secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-strong)}.btn.btn-danger,.btn.btn--danger{background:var(--accent-danger);color:#fff}.btn.btn-danger:hover:not(:disabled),.btn.btn--danger:hover:not(:disabled){background:#ef5350;box-shadow:0 4px 12px #f871714d}.btn.btn-ghost,.btn.btn--ghost{background:transparent;color:var(--text-secondary)}.btn.btn-ghost:hover:not(:disabled),.btn.btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn.btn-sm,.btn.btn--sm{padding:var(--space-1) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius-sm)}.btn.btn-md,.btn.btn--md{padding:var(--space-2) var(--space-4);font-size:var(--text-base)}.btn.btn-lg,.btn.btn--lg{padding:var(--space-3) var(--space-6);font-size:var(--text-md);border-radius:var(--radius-lg)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out);flex-shrink:0}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon:active{transform:scale(.92)}.btn-icon.btn-icon-sm,.btn-icon.btn-icon--sm{width:28px;height:28px}.btn-icon.btn-icon-lg,.btn-icon.btn-icon--lg{width:44px;height:44px}.card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.card--hover:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.glass-card{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out)}.glass-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--border-default)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:.175rem var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-semibold);line-height:1.5;border-radius:var(--radius-full);white-space:nowrap;letter-spacing:var(--tracking-wide)}.badge.badge-success,.badge.badge--success{background:var(--accent-success-muted);color:var(--accent-success)}.badge.badge-warning,.badge.badge--warning{background:var(--accent-warning-muted);color:var(--accent-warning)}.badge.badge-danger,.badge.badge--danger{background:var(--accent-danger-muted);color:var(--accent-danger)}.badge.badge-info,.badge.badge--info{background:var(--accent-info-muted);color:var(--accent-info)}.badge.badge-neutral,.badge.badge--neutral{background:#ffffff0f;color:var(--text-secondary)}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-group+.form-group{margin-top:var(--space-4)}.form-group label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary)}.input,.select{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-base);font-family:var(--font-body);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.input:hover:not(:disabled),.select:hover:not(:disabled){border-color:var(--border-default)}.input:focus,.select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-muted)}.input:disabled,.select:disabled{opacity:.5;cursor:not-allowed}.input.select-error,.input.select--error,.select.select-error,.select.select--error{border-color:var(--accent-danger);animation:shake .4s var(--ease-out)}.input.select-error:focus,.input.select--error:focus,.select.select-error:focus,.select.select--error:focus{box-shadow:0 0 0 3px var(--accent-danger-muted);border-color:var(--accent-danger)}.select{-webkit-appearance:none;-moz-appearance:none;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='%239AA0B0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);cursor:pointer}.form-error{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--accent-danger);min-height:1.25rem}.form-error:empty{display:none}.form-hint{font-size:var(--text-xs);color:var(--text-muted)}.table-container{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);background:var(--bg-surface);background:linear-gradient(to right,var(--bg-surface) 30%,transparent),linear-gradient(to left,var(--bg-surface) 30%,transparent),linear-gradient(to right,rgba(0,0,0,.25),transparent 15px),linear-gradient(to left,rgba(0,0,0,.25),transparent 15px);background-position:left,right,left,right;background-size:40px 100%,40px 100%,15px 100%,15px 100%;background-repeat:no-repeat;background-attachment:local,local,scroll,scroll}table{width:100%;font-size:var(--text-sm)}thead{position:sticky;top:0;z-index:var(--z-sticky)}th{padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--weight-semibold);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-muted);background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);white-space:nowrap}th:first-child{position:sticky;left:0;z-index:calc(var(--z-sticky) + 1);background:var(--bg-elevated)}td{padding:var(--space-3) var(--space-4);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);vertical-align:middle;white-space:nowrap}td:first-child{position:sticky;left:0;background:var(--bg-surface);color:var(--text-primary);font-weight:var(--weight-medium);z-index:1}tbody tr:nth-child(2n) td{background:#ffffff05}tbody tr:nth-child(2n) td:first-child{background:color-mix(in srgb,var(--bg-surface) 96%,white)}tbody tr{transition:background-color var(--duration-fast) var(--ease-out)}tbody tr:hover td{background:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10) var(--space-6);border:2px dashed var(--border-default);border-radius:var(--radius-lg);background:transparent;color:var(--text-muted);font-size:var(--text-base);text-align:center;cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.upload-area:hover{border-color:var(--accent-primary);background:var(--accent-primary-muted);color:var(--text-secondary)}.upload-area.dragover,.upload-area.upload-area--dragover{border-color:var(--accent-primary);background:var(--accent-primary-muted);color:var(--accent-primary);border-style:solid;transform:scale(1.01)}.upload-area .upload-icon{font-size:2.5rem;opacity:.6}.upload-area .upload-label{font-weight:var(--weight-medium);color:var(--text-secondary)}.upload-area .upload-hint{font-size:var(--text-xs);color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:var(--overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:fadeIn var(--duration-fast) var(--ease-out) both}.modal-content{width:100%;max-width:520px;max-height:85vh;overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-xl);animation:slideUp .3s var(--ease-out) both}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.modal-title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text-primary)}.modal-body{color:var(--text-secondary);font-size:var(--text-base);line-height:var(--leading-relaxed)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none;max-width:400px;width:100%}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;position:relative;overflow:hidden;animation:slideInRight .35s var(--ease-out) both}.toast.toast-exit,.toast.toast--exit{animation:slideOutRight .3s var(--ease-out) both}.toast .toast-icon,.toast .toast__icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.toast .toast-text,.toast .toast__message,.toast .toast__content{flex:1;min-width:0}.toast .toast-title,.toast .toast__title{font-weight:var(--weight-semibold);font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1)}.toast .toast-text,.toast .toast__message,.toast .toast__content{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-snug)}.toast .toast-close,.toast .toast__close{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease-out)}.toast .toast-close:hover,.toast .toast__close:hover{color:var(--text-primary)}.toast .toast-progress-bar,.toast .toast__progress{position:absolute;bottom:0;left:0;height:3px;border-radius:0 0 var(--radius-lg) var(--radius-lg);animation:progressShrink linear both}.toast.toast-success,.toast.toast--success{border-left:3px solid var(--accent-success)}.toast.toast-success .toast__icon,.toast.toast--success .toast__icon{color:var(--accent-success)}.toast.toast-success .toast__progress,.toast.toast--success .toast__progress{background:var(--accent-success)}.toast.toast-error,.toast.toast--error{border-left:3px solid var(--accent-danger)}.toast.toast-error .toast__icon,.toast.toast--error .toast__icon{color:var(--accent-danger)}.toast.toast-error .toast__progress,.toast.toast--error .toast__progress{background:var(--accent-danger)}.toast.toast-warning,.toast.toast--warning{border-left:3px solid var(--accent-warning)}.toast.toast-warning .toast__icon,.toast.toast--warning .toast__icon{color:var(--accent-warning)}.toast.toast-warning .toast__progress,.toast.toast--warning .toast__progress{background:var(--accent-warning)}.toast.toast-info,.toast.toast--info{border-left:3px solid var(--accent-info)}.toast.toast-info .toast__icon,.toast.toast--info .toast__icon{color:var(--accent-info)}.toast.toast-info .toast__progress,.toast.toast--info .toast__progress{background:var(--accent-info)}.tabs{display:flex;align-items:center;gap:var(--space-1);border-bottom:1px solid var(--border-subtle);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-btn{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-muted);background:none;border:none;cursor:pointer;white-space:nowrap;transition:color var(--duration-fast) var(--ease-out)}.tab-btn:hover{color:var(--text-secondary)}.tab-btn.active,.tab-btn.tab-btn--active{color:var(--accent-primary)}.tab-btn.active:after,.tab-btn.tab-btn--active:after{content:"";position:absolute;bottom:-1px;left:var(--space-4);right:var(--space-4);height:2px;background:var(--accent-primary);border-radius:var(--radius-full) var(--radius-full) 0 0}.stat-card{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5);background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card .stat-icon,.stat-card .stat-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-lg);font-size:1.25rem;flex-shrink:0}.stat-card .stat-icon--primary,.stat-card .stat-card__icon--primary{background:linear-gradient(135deg,var(--accent-primary-muted),rgba(108,99,255,.25));color:var(--accent-primary)}.stat-card .stat-icon--success,.stat-card .stat-card__icon--success{background:linear-gradient(135deg,var(--accent-success-muted),rgba(52,211,153,.25));color:var(--accent-success)}.stat-card .stat-icon--warning,.stat-card .stat-card__icon--warning{background:linear-gradient(135deg,var(--accent-warning-muted),rgba(251,191,36,.25));color:var(--accent-warning)}.stat-card .stat-icon--danger,.stat-card .stat-card__icon--danger{background:linear-gradient(135deg,var(--accent-danger-muted),rgba(248,113,113,.25));color:var(--accent-danger)}.stat-card .stat-icon--info,.stat-card .stat-card__icon--info{background:linear-gradient(135deg,var(--accent-info-muted),rgba(56,189,248,.25));color:var(--accent-info)}.stat-card .stat-body,.stat-card .stat-card__body{flex:1;min-width:0}.stat-card .stat-label,.stat-card .stat-card__label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wider);margin-bottom:var(--space-1)}.stat-card .stat-value,.stat-card .stat-card__value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text-primary);line-height:1}.stat-card .stat-change,.stat-card .stat-card__change{font-size:var(--text-xs);margin-top:var(--space-1);color:var(--text-muted)}.avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),#a78bfa);color:#fff;font-family:var(--font-heading);font-weight:var(--weight-bold);font-size:var(--text-base);text-transform:uppercase;flex-shrink:0;line-height:1;-webkit-user-select:none;user-select:none}.avatar.avatar-sm,.avatar.avatar--sm{width:32px;height:32px;font-size:var(--text-xs)}.avatar.avatar-lg,.avatar.avatar--lg{width:56px;height:56px;font-size:var(--text-xl)}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:.125rem var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);background:#ffffff0f;border-radius:var(--radius-sm);white-space:nowrap;line-height:1.5}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6)}.empty-state .empty-state-icon,.empty-state .empty-state__icon{font-size:3rem;opacity:.3;margin-bottom:var(--space-4)}.empty-state .empty-state-title,.empty-state .empty-state__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state .empty-state-text,.empty-state .empty-state__text{font-size:var(--text-base);color:var(--text-muted);max-width:36ch;line-height:var(--leading-relaxed)}.empty-state .empty-state-action,.empty-state .empty-state__action{margin-top:var(--space-6)}.progress-bar{width:100%;height:6px;background:#ffffff0f;border-radius:var(--radius-full);overflow:hidden}.progress-bar .progress-bar-fill,.progress-bar .progress-bar__fill{height:100%;border-radius:var(--radius-full);background:var(--accent-primary);transition:width .5s var(--ease-out)}.progress-bar .progress-bar-fill-success,.progress-bar .progress-bar__fill--success{background:var(--accent-success)}.progress-bar .progress-bar-fill-warning,.progress-bar .progress-bar__fill--warning{background:var(--accent-warning)}.progress-bar .progress-bar-fill-danger,.progress-bar .progress-bar__fill--danger{background:var(--accent-danger)}.progress-bar.progress-bar-thin,.progress-bar.progress-bar--thin{height:3px}.skeleton{position:relative;overflow:hidden;background:#ffffff0f;border-radius:var(--radius-md)}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.05) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 1.5s linear infinite}.skeleton.skeleton-text,.skeleton.skeleton--text{height:.875rem;width:80%;margin-bottom:var(--space-2)}.skeleton.skeleton-heading,.skeleton.skeleton--heading{height:1.5rem;width:60%;margin-bottom:var(--space-3)}.skeleton.skeleton-avatar,.skeleton.skeleton--avatar{width:40px;height:40px;border-radius:50%}.skeleton.skeleton-button,.skeleton.skeleton--button{height:36px;width:120px;border-radius:var(--radius-md)}.skeleton.skeleton-card,.skeleton.skeleton--card{height:160px;border-radius:var(--radius-xl)}.search-input{position:relative;width:100%}.search-input .search-icon,.search-input .search-input__icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-muted);pointer-events:none}.search-input input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-9);background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.search-input input:hover{border-color:var(--border-default)}.search-input input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-muted)}.tooltip{position:relative}.tooltip:before,.tooltip:after{position:absolute;opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--duration-fast) var(--ease-out),visibility var(--duration-fast) var(--ease-out);z-index:var(--z-tooltip)}.tooltip:after{content:attr(data-tooltip);bottom:calc(100% + 8px);left:50%;transform:translate(-50%);padding:var(--space-1) var(--space-2);background:var(--bg-elevated);color:var(--text-primary);font-size:var(--text-xs);font-weight:var(--weight-medium);white-space:nowrap;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md)}.tooltip:before{content:"";bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--bg-elevated)}.tooltip:hover:before,.tooltip:hover:after{opacity:1;visibility:visible}.divider{width:100%;height:1px;background:var(--border-subtle);margin:var(--space-4) 0;border:none}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--border-default);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .6s linear infinite}.spinner.spinner-sm,.spinner.spinner--sm{width:14px;height:14px}.spinner.spinner-lg,.spinner.spinner--lg{width:32px;height:32px;border-width:3px}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;background:var(--bg-surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;z-index:100;transition:transform var(--duration-normal) var(--ease-out)}@media(max-width:1024px){.sidebar{transform:translate(-100%);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99;opacity:0;visibility:hidden;transition:opacity var(--duration-normal) var(--ease-out),visibility var(--duration-normal) var(--ease-out)}.sidebar-backdrop.open{opacity:1;visibility:visible}.sidebar-brand{padding:var(--space-6) var(--space-5);display:flex;align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border-subtle)}.sidebar-brand .brand-icon{font-size:2rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-info));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-brand .brand-text{display:flex;flex-direction:column}.sidebar-brand .brand-text .brand-name{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary);line-height:1.2;letter-spacing:.05em}.sidebar-brand .brand-text .brand-subtitle{font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--weight-medium);margin-top:2px}.sidebar-menu{flex:1;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--weight-medium);border-radius:var(--radius-md);text-decoration:none;transition:all var(--duration-fast) var(--ease-out);position:relative;cursor:pointer}.sidebar-item:hover{color:var(--text-primary);background:var(--bg-hover);transform:translate(4px)}.sidebar-item.active{color:var(--text-primary);background:#4f46e526;font-weight:var(--weight-semibold);box-shadow:inset 0 0 0 1px #4f46e533}.sidebar-item.active:before{content:"";position:absolute;left:0;top:var(--space-2);bottom:var(--space-2);width:4px;background:var(--accent-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.sidebar-item.active .sidebar-item-icon{color:var(--accent-primary);filter:drop-shadow(0 0 4px var(--accent-primary-muted))}.sidebar-item .sidebar-item-icon{font-size:1.2rem;transition:color var(--duration-fast) var(--ease-out)}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:var(--space-3);background:#ffffff03}.sidebar-user{display:flex;align-items:center;gap:var(--space-3)}.sidebar-user .user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user .user-info .user-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-info .user-role{font-size:var(--text-xs);color:var(--text-muted)}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:90}@media(max-width:1024px){.mobile-header{display:flex}}.hamburger-btn{background:transparent;border:none;color:var(--text-primary);font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:var(--space-2);border-radius:var(--radius-md);transition:background-color var(--duration-fast) var(--ease-out)}.hamburger-btn:hover{background:var(--bg-hover)}.main-layout{margin-left:280px;min-height:100vh;display:flex;flex-direction:column;transition:margin var(--duration-normal) var(--ease-out)}@media(max-width:1024px){.main-layout{margin-left:0}}}@layer layouts{.app-layout{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;width:100%}.login-layout{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-4);position:relative;overflow:hidden;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(108,99,255,.12) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 100%,rgba(56,189,248,.08) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 10% 80%,rgba(248,113,113,.06) 0%,transparent 50%),var(--bg-base)}.login-layout:before,.login-layout:after{content:"";position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);opacity:.4;animation:floatOrb 20s var(--ease-in-out) infinite}.login-layout:before{width:400px;height:400px;top:-10%;left:-5%;background:radial-gradient(circle,rgba(108,99,255,.3),transparent 70%);animation-duration:25s}.login-layout:after{width:350px;height:350px;bottom:-10%;right:-5%;background:radial-gradient(circle,rgba(56,189,248,.2),transparent 70%);animation-duration:30s;animation-delay:-5s}.login-card{width:100%;max-width:420px;position:relative;z-index:1}.dashboard-layout{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto;padding:var(--space-6)}@media(max-width:768px){.dashboard-layout{padding:var(--space-4)}}.dashboard-header{text-align:center;padding:var(--space-8) var(--space-4);margin-bottom:var(--space-6);background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl)}.dashboard-header h1{font-size:var(--text-3xl);font-weight:var(--weight-extrabold);margin-bottom:var(--space-2);background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent-primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-header p{color:var(--text-secondary);font-size:var(--text-md);max-width:none}@media(max-width:640px){.dashboard-header{padding:var(--space-6) var(--space-4)}.dashboard-header h1{font-size:var(--text-2xl)}.dashboard-header p{font-size:var(--text-base)}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}@media(max-width:640px){.dashboard-grid{grid-template-columns:1fr;gap:var(--space-3)}}.content-card{background:var(--bg-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}@media(max-width:768px){.content-card{padding:var(--space-4);border-radius:var(--radius-lg)}}.page-container{width:100%;max-width:1280px;margin-inline:auto;padding-inline:var(--space-6)}@media(max-width:768px){.page-container{padding-inline:var(--space-4)}}@media(max-width:480px){.page-container{padding-inline:var(--space-3)}}.student-layout{width:100%;max-width:900px;margin-inline:auto;padding-inline:var(--space-6)}@media(max-width:768px){.student-layout{padding-inline:var(--space-4)}}.section{margin-bottom:var(--space-8)}.section:last-child{margin-bottom:0}.section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-4)}.section-title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text-primary)}.sidebar-layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh;min-height:100dvh}@media(max-width:1024px){.sidebar-layout{grid-template-columns:1fr}}@media(max-width:640px){.sm\:hidden{display:none!important}}@media(min-width:641px){.sm\:visible{display:block!important}}@media(max-width:768px){.md\:hidden{display:none!important}}@media(max-width:1024px){.lg\:hidden{display:none!important}}}@layer utilities{.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.hidden{display:none!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.self-center{align-self:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh;min-height:100dvh}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mx-auto{margin-inline:auto}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.px-1{padding-inline:var(--space-1)}.px-2{padding-inline:var(--space-2)}.px-3{padding-inline:var(--space-3)}.px-4{padding-inline:var(--space-4)}.px-6{padding-inline:var(--space-6)}.py-1{padding-block:var(--space-1)}.py-2{padding-block:var(--space-2)}.py-3{padding-block:var(--space-3)}.py-4{padding-block:var(--space-4)}.py-6{padding-block:var(--space-6)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.font-regular{font-weight:var(--weight-regular)}.font-medium{font-weight:var(--weight-medium)}.font-semibold{font-weight:var(--weight-semibold)}.font-bold{font-weight:var(--weight-bold)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-primary)}.text-success{color:var(--accent-success)}.text-warning{color:var(--accent-warning)}.text-danger{color:var(--accent-danger)}.text-info{color:var(--accent-info)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.relative{position:relative}.absolute{position:absolute}.sticky{position:sticky}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.pointer-events-none{pointer-events:none}}
