.login-page{min-height:100vh;min-height:100dvh;display:flex;background:var(--color-surface)}.login__brand{display:none;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);flex:1;padding:var(--space-8);background-color:var(--color-primary);color:#fff;text-align:center;@media(min-width:768px){display:flex}}.login__brand-icon{opacity:.9}.login__brand-name{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin:0}.login__brand-tagline{font-size:var(--font-size-base);opacity:.85;max-width:320px;line-height:1.5;margin:0}.login__form{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-4)}.login__mobile-header{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);color:var(--color-primary);@media(min-width:768px){display:none}}.login__mobile-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0}.login__button{width:100%;max-width:320px;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-3-5)}.login__button:disabled{opacity:.6}.login__remember{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;user-select:none;input{width:1rem;height:1rem;accent-color:var(--color-primary);cursor:pointer}}.login__footer{font-size:.813rem;color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);border-radius:var(--radius-sm);border:none;cursor:pointer;transition:background-color var(--transition-normal);white-space:nowrap;&:disabled{opacity:.6;cursor:not-allowed}&:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}}.btn--sm{padding:var(--space-1-5) var(--space-3);font-size:var(--font-size-sm);gap:var(--space-1-5)}.btn--md{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);gap:var(--space-2)}.btn--lg{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);gap:var(--space-2)}.btn--primary{background-color:var(--color-primary);color:#fff;&:hover:not(:disabled){background-color:var(--color-primary-hover)}}.btn--secondary{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);&:hover:not(:disabled){background-color:var(--color-surface-alt)}}.btn--danger{background-color:var(--color-danger);color:#fff;&:hover:not(:disabled){background-color:var(--color-danger-hover)}}.btn--ghost{background:transparent;color:var(--color-primary);border:none;padding:var(--space-1) var(--space-2);&:hover:not(:disabled){background-color:var(--color-primary-light)}}.spinner{border-radius:var(--radius-full);border-style:solid;border-color:var(--color-border);border-top-color:var(--color-primary);animation:spin 1s linear infinite}.spinner--sm{width:24px;height:24px;border-width:2px}.spinner--md{width:40px;height:40px;border-width:3px}.spinner--lg{width:56px;height:56px;border-width:4px}.loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);color:var(--color-text-muted);padding:var(--space-16)}.loading--full-page{min-height:50vh;justify-content:center;padding:var(--space-8)}.loading__message{font-size:var(--font-size-sm)}.snackbar-container{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column-reverse;align-items:center;gap:var(--space-2);max-width:min(480px,calc(100vw - var(--space-8)));width:100%;pointer-events:none}@media(max-width:767px){.snackbar-container{bottom:calc(var(--size-bottom-nav-height) + var(--space-3))}}.snackbar{--snackbar-accent: var(--color-primary);background-color:var(--color-surface);color:var(--color-text);padding:var(--space-3-5) var(--space-4);border-radius:var(--radius-lg);border-left:4px solid var(--snackbar-accent);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-3);width:100%;pointer-events:auto;animation:snackbarEnter var(--duration-slow) var(--ease-out)}.snackbar--success{--snackbar-accent: var(--color-success)}.snackbar--error{--snackbar-accent: var(--color-danger)}.snackbar--warning{--snackbar-accent: var(--color-warning)}.snackbar--info{--snackbar-accent: var(--color-primary)}.snackbar--exiting{animation:snackbarExit var(--duration-normal) var(--ease-default) forwards}.snackbar__icon{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--snackbar-accent)}.snackbar__message{flex:1;font-weight:var(--font-weight-medium)}.snackbar__action{background:transparent;border:1px solid var(--snackbar-accent);color:var(--snackbar-accent);cursor:pointer;padding:var(--space-1) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast);white-space:nowrap;&:hover{background:color-mix(in srgb,var(--snackbar-accent) 10%,transparent)}&:active{background:color-mix(in srgb,var(--snackbar-accent) 20%,transparent)}}.snackbar--has-action{padding-right:var(--space-3)}.snackbar__dismiss{background:transparent;border:0;color:var(--color-text);cursor:pointer;padding:var(--space-1);opacity:.6;font-size:var(--font-size-base);line-height:1;transition:opacity var(--transition-fast);&:hover{opacity:1}}@font-face{font-family:DM Sans Variable;font-style:normal;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-ext-wght-normal-BOFOeGcA.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans Variable;font-style:normal;font-display:swap;font-weight:100 1000;src:url(/assets/dm-sans-latin-wght-normal-Xz1IZZA0.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Variable;font-style:normal;font-display:swap;font-weight:100 800;src:url(data:font/woff2;base64,d09GMgABAAAAAAfsABQAAAAAEAwAAAeCAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAGhwbHhwoP0hWQVJbBmA/U1RBVIFiJyYAdC9qEQgKhGSEAAsgADCGCAE2AiQDOgQgBYlMB4EUDAcbLQ4onoexrSC/2ZyLAa8p8VHB8/x3Vue+V0hVJalMJg2nx/TCrQXxBeqLjQG7FyM1WEa/X1tEXN7cFz9EJEMmMUz3RihWSSKeQCbcIou0izz/C8v+fq3VfajEa9gDD11CImXS7qL/RJFVzC1qiB6KmKeD6TZdQ6IRGv78dL6uSVVCfgni5mzu7kcgQBgAEAQTQRCoL++STTYybkJxNfQxAAIAGu8OdEB9teW2jh4BpgDqFjAeSEByW3zFP0CBBgNMsMCGEDjgggdhiEAUAeIIED7ABTDUEnkIE9Q9ahFgKttcVhApo4ACB4qobHaccgDfEjFO6aaWUhjMLt2SyIvHKoDqoA4CSUwEIYQCEjhAO9R1G6keDeDZGjNo+AhxOjCEGTr1WeIF3kYBiLAOKvkJSMiKX0VdAyQt3SDJClCkxJCHkCzfqyVTriJZLcolS32JZHUekq2TYNkYtCtjYHMQXSxGjXDz2t/yLWXzDzxz+o3zFwDEaN23F+13pyMdQAEaSKAR9vcGq4A4MTSKCElGW+M7UcY7xqkggITb28ZJhlqc9q2twYKTt0NjixBgYvO9BIihEBLYuOFXQzfIQ7dXGUEEEgFDooBfAzqiQbpJrhiWSuKJCRFKYbHCyJKI2G5GiZbNAvgAu5pc3vwx4G+g3aDkhklABiSz0BICXrYghtYhx/cdJ+44rY2oZ0aMNRFz3VZjb6W33F3gzltqtOCV8tTHSpOeXuItfvr5lCdfzFpqtEitvqdcdGGFd28ZqqC0tPbeChGXgrIlnhSWu/eUso4uKWFLugyDzQJhflY4659+WjQ++6x72WUMv9G8mw6QJl7BVxX5fe/kpUsOvnZwee9uQ0cGXYd0o89XB2748sDSnt8d2VphdOTTgceDVvOds0v9P/s7HPq15aGun/6Vllb56f1dl0t1LejqrNkpdRZsG8TOnM5vkBG5oiVyVGnS8LHps5cfNWJs6qKPfaNSxiQNBUm3cKNWROr0GSur7Za31k1vieq7LH11VF+jXdRIasRKflc7jkobm1Z9te1IyZA0pDkhLR98+H37Zf1c/8at+dB7x+7GfVyTfJMPiYztsnl59Y5l4j+0n1RXlpHnF3Tq7HecmNF/CJodEMAikruxiyJaGLvHOdAfoA+oDvpjBm2b91cHGRZMU9n25xEU0A8fgEEAdKI3Q1iDtc034sug5YVMkE2jsE+BIkwSoQ3gxXMqz9tELp48bd0cFKOKS7xYjEuXBnZP5ia7DyiO/X/YI+PQSbt2uSdqAkWL9nQbV1XB94/+uPfdZz8dnXYFBYrcTl2SIR/ybxJNJPz/Gupb0JaZeens2ekC7EKr8t+Ls/P5VJPYJdHKyqfg2nqU6bhlidzcddQV/7MmecTzJ5VPcKXkNKSEogHjYFx6QZ7rQ+FSe8njaiNuOnXS8H2ScQ619c2mC3VTtauL0rRbXd/CkSOP37FY9Zkjz8+GibYUMOEWF+RdrFS8Ecv1SHOpPUPZGEIpjPvFyU5cXKjd6OXqorTqy9GwRd++HVufPGnVsW+aO3vggKZ18jR9sXaTC1PWTEsVUaK0FkNySbTQDqlm2PfDjZcu4aalnSLKjnOoYQ0nUlqqXcGpPu/4VgV/xU2pAqW4BW3qzhQ8/hFKhV2qE3+BKAtDqBXjfgnVdH4y0wg5tbVNRenNdTWOrenWLcupQdmsbq5b+18piTe/xRdp1xbILxNPJGInm2z6hoB21Lal0i+ePTtd7B45+3XhFJ329evskXm7qurUVREotqSluSo/L29d3qDhI4YOQqWhI4YNvBNfsMHeXKemXrxQfKeuPOGRVayA3JtkJKEgbPp+dXUDluddutRYLFoXGXWX6N3WFaGLbQtRSitVYNacTNSdy7AaG/HSaUEANcBoGXNdcZvZsOqQ1icBDv21/gzAoYPHH/WDW0qNR3QTYKEAEHig6o13NXbND06CQPlRtYjGNnSktRc09k1mAMDvAlDKfQjgy6fssInlfzmNAjKkDxoxHOBLdVRAIVt9j4qo+hA1w9T1aNBNTUOTTNUHLbqokE+UAfJXCIGw/IxCSL5GRUJeR40rL/UxTm4Q08H6MbCs70ObuNyIIXrINHQYInF06UUlevTjbQzTh5upiDMzMMogUtEnjPs/Y7jAHCJeB0GBHh04tC6FiB6ZFB1oArUSIoFoqhzCeAN6lHwm0T4C3VVPWvjpSMXReuWesMEcoqrmgtNBGd2noWeV0hNAz9rFeShNJxHGsPa3HXeKTk8b55hahySYHaYKKFFLpCfN8rsoaJn01CR04Gkc+5k7KVTCmClX8Q10HCrUEkVlSX+XO33oQR9609tJ516H497WSobWs5Up6TLaS10/dessIskgJSLiDlWvHVUywpkQ7hdPZqGyiEF0uVQerVcPamT1A3eKXdyI1vG9OoflrSXihZ1qqGE3nhmAgiIbRCQgPLEPtOM3UQwTLYaYYomNlpA44opnjV6jkD6id80OOrzf6BzmMD6eEa1zKyeYG1fzfEf16V6jw9XYOaar1/b2kP/IYX8oR2mcFvv2GtBV3JXgd437AQAA) format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono Variable;font-style:normal;font-display:swap;font-weight:100 800;src:url(/assets/jetbrains-mono-cyrillic-wght-normal-D73BlboJ.woff2) format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:JetBrains Mono Variable;font-style:normal;font-display:swap;font-weight:100 800;src:url(/assets/jetbrains-mono-greek-wght-normal-Bw9x6K1M.woff2) format("woff2-variations");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:JetBrains Mono Variable;font-style:normal;font-display:swap;font-weight:100 800;src:url(/assets/jetbrains-mono-vietnamese-wght-normal-Bt-aOZkq.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono Variable;font-style:normal;font-display:swap;font-weight:100 800;src:url(/assets/jetbrains-mono-latin-ext-wght-normal-DBQx-q_a.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono Variable;font-style:normal;font-display:swap;font-weight:100 800;src:url(/assets/jetbrains-mono-latin-wght-normal-B9CIFXIH.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{color-scheme:light;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--color-primary-alpha: rgba(37, 99, 235, .2);--color-success: #16a34a;--color-success-light: #dcfce7;--color-caution: #ca8a04;--color-caution-light: #fef9c3;--color-warning: #ea580c;--color-warning-light: #ffedd5;--color-warning-dark: #431407;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-danger-light: #fee2e2;--color-violet: #7c3aed;--color-violet-light: #ede9fe;--color-bg: #f8fafc;--color-surface: #ffffff;--color-surface-alt: #f1f5f9;--color-text: #0f172a;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-neutral-100: #f5f5f5;--color-neutral-200: #e5e5e5;--color-neutral-400: #a3a3a3;--color-neutral-800: #262626;--color-surface-hover: #f3f4f6;--color-surface-secondary: #f5f5f5;--color-surface-mid: #f8fafc;--color-surface-sunken: #f9fafb;--color-surface-raised: #ffffff;--color-border-light: #e5e7eb;--color-border-subtle: #e5e7eb;--color-border-hover: #9ca3af;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-skeleton: #e5e7eb;--color-skeleton-highlight: #f3f4f6;--color-primary-bg: #eff6ff;--color-warning-bg: #fffbeb;--color-backdrop: rgba(0, 0, 0, .5);--color-overlay-dark: rgba(0, 0, 0, .8);--color-overlay-darker: rgba(0, 0, 0, .9);--color-black: #000;--color-danger-border: #fecaca;--color-surface-disabled: #f3f4f6;--color-warning-hover: #c2410c;--color-warning-contrast: #ffffff;--color-primary-subtle: rgba(37, 99, 235, .15);--color-success-subtle: rgba(5, 150, 105, .15);--color-warning-subtle: rgba(217, 119, 6, .05);--color-danger-subtle: rgba(220, 38, 38, .1);--color-debug-success: #0f0}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){color-scheme:dark;--color-bg: #0f172a;--color-surface: #1e293b;--color-surface-alt: #334155;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-border: #475569;--color-primary-light: #172554;--color-success-light: #022c22;--color-warning-light: #451a03;--color-danger-light: #450a0a;--color-caution-light: #713f12;--color-violet-light: #4c1d95;--color-neutral-100: #334155;--color-neutral-200: #475569;--color-neutral-400: #64748b;--color-surface-hover: #334155;--color-surface-secondary: #334155;--color-surface-mid: #283548;--color-surface-sunken: #0f172a;--color-surface-raised: #334155;--color-border-light: #475569;--color-border-subtle: #334155;--color-border-hover: #64748b;--color-info: #60a5fa;--color-info-light: #1e3a5f;--color-skeleton: #334155;--color-skeleton-highlight: #475569;--color-primary-bg: #1e3a5f;--color-warning-bg: #422006;--color-primary-subtle: rgba(59, 130, 246, .25);--color-success-subtle: rgba(34, 197, 94, .2);--color-warning-subtle: rgba(234, 179, 8, .15);--color-danger-subtle: rgba(239, 68, 68, .2);--color-danger-border: #7f1d1d;--color-surface-disabled: #334155;--color-warning-hover: #fb923c;--color-warning-contrast: #000000}}:root[data-theme=dark]{color-scheme:dark;--color-bg: #0f172a;--color-surface: #1e293b;--color-surface-alt: #334155;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-border: #475569;--color-primary-light: #172554;--color-success-light: #022c22;--color-warning-light: #451a03;--color-danger-light: #450a0a;--color-caution-light: #713f12;--color-violet-light: #4c1d95;--color-neutral-100: #334155;--color-neutral-200: #475569;--color-neutral-400: #64748b;--color-surface-hover: #334155;--color-surface-secondary: #334155;--color-surface-mid: #283548;--color-surface-sunken: #0f172a;--color-surface-raised: #334155;--color-border-light: #475569;--color-border-subtle: #334155;--color-border-hover: #64748b;--color-info: #60a5fa;--color-info-light: #1e3a5f;--color-skeleton: #334155;--color-skeleton-highlight: #475569;--color-primary-bg: #1e3a5f;--color-warning-bg: #422006;--color-primary-subtle: rgba(59, 130, 246, .25);--color-success-subtle: rgba(34, 197, 94, .2);--color-warning-subtle: rgba(234, 179, 8, .15);--color-danger-subtle: rgba(239, 68, 68, .2);--color-danger-border: #7f1d1d;--color-surface-disabled: #334155;--color-warning-hover: #fb923c;--color-warning-contrast: #000000}:root[data-theme=light]{color-scheme:light;--color-bg: #f8fafc;--color-surface: #ffffff;--color-surface-alt: #f1f5f9;--color-surface-mid: #f8fafc;--color-surface-sunken: #f9fafb;--color-surface-raised: #ffffff;--color-text: #0f172a;--color-text-muted: #64748b;--color-border: #e2e8f0;--color-border-subtle: #e5e7eb;--color-border-hover: #9ca3af;--color-primary-light: #eff6ff;--color-success-light: #d1fae5;--color-warning-light: #fef3c7;--color-danger-light: #fee2e2;--color-caution-light: #fef9c3;--color-violet-light: #ede9fe;--color-info: #3b82f6;--color-info-light: #dbeafe;--color-skeleton: #e5e7eb;--color-skeleton-highlight: #f3f4f6;--color-neutral-100: #f5f5f5;--color-neutral-200: #e5e5e5;--color-neutral-400: #a3a3a3}:root{--space-0-5: .125rem;--space-1: .25rem;--space-1-5: .375rem;--space-2: .5rem;--space-2-5: .625rem;--space-3: .75rem;--space-3-5: .875rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--size-nav-height: 64px;--size-bottom-nav-height: 56px;--sidebar-width-collapsed: 64px;--sidebar-width-expanded: 220px;--size-progress-bar: 6px;--size-progress-bar-sm: 4px;--size-badge-sm: 1.25rem;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: .875rem;--radius-xl: .875rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--shadow-primary-glow: 0 4px 12px rgb(37 99 235 / .3);--shadow-danger-glow: 0 4px 12px rgb(220 38 38 / .3);--shadow-focus: 0 0 0 3px rgba(59, 130, 246, .3)}:root{--font-sans: "DM Sans Variable", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono Variable", ui-monospace, monospace;--font-size-xs: clamp(.688rem, .65rem + .1vw, .75rem);--font-size-sm: clamp(.813rem, .78rem + .1vw, .875rem);--font-size-base: clamp(.875rem, .85rem + .1vw, 1rem);--font-size-md: clamp(.938rem, .9rem + .1vw, 1rem);--font-size-lg: clamp(1rem, .95rem + .15vw, 1.125rem);--font-size-xl: clamp(1.125rem, 1.05rem + .2vw, 1.25rem);--font-size-2xl: clamp(1.25rem, 1.15rem + .3vw, 1.5rem);--font-size-3xl: clamp(1.5rem, 1.35rem + .4vw, 1.875rem);--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-black: 900;--line-height-none: 1;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--letter-spacing-wider: .05em}:root{--duration-fast: .15s;--duration-normal: .2s;--duration-slow: .3s;--duration-slower: .5s;--ease-default: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--transition-fast: var(--duration-fast) var(--ease-default);--transition-normal: var(--duration-normal) var(--ease-default);--transition-slow: var(--duration-slow) var(--ease-default);--animate-fade-in: fadeIn var(--duration-normal) var(--ease-out);--animate-slide-up: slideUp var(--duration-normal) var(--ease-out);--animate-modal-slide-in: modalSlideIn var(--duration-normal) var(--ease-out)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes snackbarEnter{0%{opacity:0;transform:translateY(100%) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes snackbarExit{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(100%) scale(.95)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--breakpoint-xs: 480px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1400px}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-surface-alt);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}img,picture,video,canvas,svg{display:block;max-width:100%}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:none;color:inherit}a{color:inherit;text-decoration:none}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}input[type=number]{-moz-appearance:textfield;appearance:textfield;&::-webkit-inner-spin-button,&::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}}*{scrollbar-width:thin;scrollbar-color:var(--color-neutral-400) var(--color-surface-alt)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface-alt);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb{background:var(--color-neutral-400);border-radius:var(--radius-sm);&:hover{background:var(--color-text-muted)}}[draggable=true]{cursor:move;&:active{cursor:grabbing;opacity:.8}}@media(pointer:coarse){button,[role=button],a,select,input[type=checkbox],input[type=radio]{min-height:44px}button,[role=button],a{padding-inline:max(var(--space-2),8px)}input[type=text],input[type=number],input[type=email],input[type=password],input[type=search],input[type=tel],input[type=url],input:not([type]),select,textarea{font-size:16px}}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}h4{font-size:var(--font-size-base)}h5{font-size:var(--font-size-sm)}h6{font-size:var(--font-size-xs)}p{line-height:var(--line-height-normal)}strong,b{font-weight:var(--font-weight-semibold)}em,i{font-style:italic}code,kbd,pre,samp{font-family:var(--font-mono);font-size:.9em}code{padding:var(--space-0-5) var(--space-1);background-color:var(--color-surface-alt);border-radius:var(--radius-md)}pre{padding:var(--space-4);background-color:var(--color-surface-alt);border-radius:var(--radius-lg);overflow-x:auto;& code{padding:0;background:none;border-radius:0}}small{font-size:var(--font-size-sm)}mark{background-color:var(--color-warning-light);padding:var(--space-0-5) var(--space-1);border-radius:var(--radius-sm)}abbr[title]{text-decoration:underline dotted;cursor:help}blockquote{padding-inline-start:var(--space-4);border-inline-start:4px solid var(--color-primary);font-style:italic;color:var(--color-text-muted)}hr{border:none;border-block-start:1px solid var(--color-border);margin-block:var(--space-6)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}.skip-link{position:absolute;inset-block-start:-100%;inset-inline-start:0;padding:var(--space-2) var(--space-4);background-color:var(--color-primary);color:#fff;z-index:9999;transition:inset-block-start var(--transition-fast);&:focus{inset-block-start:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(prefers-contrast:more){:root{--color-border: currentColor}button,a,input,select,textarea{border:2px solid currentColor}}@media(forced-colors:active){button{border:1px solid ButtonText}:focus-visible{outline:3px solid Highlight}}.visually-hidden:not(:focus):not(:active){position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}::selection{background-color:var(--color-primary);color:#fff}.flex{display:flex}.inline-flex{display:inline-flex}.flex--col{flex-direction:column}.flex--row{flex-direction:row}.flex--wrap{flex-wrap:wrap}.flex--nowrap{flex-wrap:nowrap}.flex--center{align-items:center;justify-content:center}.flex--align-start{align-items:flex-start}.flex--align-center{align-items:center}.flex--align-end{align-items:flex-end}.flex--align-stretch{align-items:stretch}.flex--justify-start{justify-content:flex-start}.flex--justify-center{justify-content:center}.flex--justify-end{justify-content:flex-end}.flex--between{justify-content:space-between}.flex--around{justify-content:space-around}.flex-1{flex:1}.flex-none{flex:none}.shrink-0{flex-shrink:0}.gap-0{gap:0}.gap-0-5{gap:var(--space-0-5)}.gap-1{gap:var(--space-1)}.gap-1-5{gap:var(--space-1-5)}.gap-2{gap:var(--space-2)}.gap-2-5{gap:var(--space-2-5)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid--cols-1{grid-template-columns:repeat(1,1fr)}.grid--cols-2{grid-template-columns:repeat(2,1fr)}.grid--cols-3{grid-template-columns:repeat(3,1fr)}.grid--cols-4{grid-template-columns:repeat(4,1fr)}.grid--cols-5{grid-template-columns:repeat(5,1fr)}.grid--auto-fill{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.grid--auto-fit{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid--cols-2,.grid--cols-3,.grid--cols-4,.grid--cols-5{grid-template-columns:1fr;@media(min-width:480px){&.grid--cols-2,&.grid--cols-3,&.grid--cols-4,&.grid--cols-5{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){&.grid--cols-2{grid-template-columns:repeat(2,1fr)}&.grid--cols-3{grid-template-columns:repeat(2,1fr)}&.grid--cols-4{grid-template-columns:repeat(2,1fr)}&.grid--cols-5{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){&.grid--cols-3{grid-template-columns:repeat(3,1fr)}&.grid--cols-4{grid-template-columns:repeat(4,1fr)}&.grid--cols-5{grid-template-columns:repeat(5,1fr)}}}.stack{display:flex;flex-direction:column}.stack--gap-1{gap:var(--space-1)}.stack--gap-2{gap:var(--space-2)}.stack--gap-3{gap:var(--space-3)}.stack--gap-4{gap:var(--space-4)}.stack--gap-6{gap:var(--space-6)}.stack--gap-8{gap:var(--space-8)}.app-container{height:100vh;overflow:hidden;display:flex;flex-direction:column;background-color:var(--color-surface-alt);color:var(--color-text)}.app-main{flex:1;width:100%;padding:var(--space-4);padding-bottom:56px;display:flex;flex-direction:column;min-height:0;@media(min-width:768px){padding:var(--space-8);padding-bottom:var(--space-8)}}.container{width:100%;margin-inline:auto;padding-inline:var(--space-4);max-width:1280px}.page{padding:var(--space-4);animation:fadeIn var(--duration-slow) var(--ease-default);@media(min-width:769px){padding:var(--space-8)}}.page__header{margin-block-end:var(--space-4)}.page__title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0;margin-block-end:var(--space-4)}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{inset:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.hide-mobile{@media(max-width:767px){display:none!important}}.show-mobile{display:none!important;@media(max-width:767px){display:block!important}}.hide-mobile-flex{@media(max-width:767px){display:none!important}}.show-mobile-flex{display:none!important;@media(max-width:767px){display:flex!important}}.hide-until-lg{@media(max-width:1023px){display:none!important}}.hide-xs{@media(max-width:479px){display:none!important}}.text-inherit{color:inherit}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-muted{color:var(--color-text-muted)}.text-violet{color:var(--color-violet)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.font-light{font-weight:var(--font-weight-light)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.font-black{font-weight:var(--font-weight-black)}.font-sans{font-family:var(--font-sans)}.font-mono{font-family:var(--font-mono)}.text-start{text-align:start}.text-center{text-align:center}.text-end{text-align:end}.underline{text-decoration:underline}.line-through{text-decoration:line-through}.no-underline{text-decoration:none}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre{white-space:pre}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.leading-none{line-height:var(--line-height-none)}.leading-tight{line-height:var(--line-height-tight)}.leading-normal{line-height:var(--line-height-normal)}.leading-relaxed{line-height:var(--line-height-relaxed)}.tracking-tight{letter-spacing:var(--letter-spacing-tight)}.tracking-normal{letter-spacing:var(--letter-spacing-normal)}.tracking-wide{letter-spacing:var(--letter-spacing-wide)}.tracking-wider{letter-spacing:var(--letter-spacing-wider)}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.mt-0{margin-block-start:0}.mt-1{margin-block-start:var(--space-1)}.mt-2{margin-block-start:var(--space-2)}.mt-3{margin-block-start:var(--space-3)}.mt-4{margin-block-start:var(--space-4)}.mt-6{margin-block-start:var(--space-6)}.mt-8{margin-block-start:var(--space-8)}.mb-0{margin-block-end:0}.mb-0-5{margin-block-end:var(--space-0-5)}.mb-1{margin-block-end:var(--space-1)}.mb-2{margin-block-end:var(--space-2)}.mb-3{margin-block-end:var(--space-3)}.mb-4{margin-block-end:var(--space-4)}.mb-6{margin-block-end:var(--space-6)}.mb-8{margin-block-end:var(--space-8)}.ml-0{margin-inline-start:0}.ml-1{margin-inline-start:var(--space-1)}.ml-2{margin-inline-start:var(--space-2)}.ml-3{margin-inline-start:var(--space-3)}.ml-4{margin-inline-start:var(--space-4)}.ml-auto{margin-inline-start:auto}.mr-0{margin-inline-end:0}.mr-1{margin-inline-end:var(--space-1)}.mr-2{margin-inline-end:var(--space-2)}.mr-3{margin-inline-end:var(--space-3)}.mr-4{margin-inline-end:var(--space-4)}.mr-auto{margin-inline-end:auto}.mx-auto{margin-inline:auto}.p-0{padding:0}.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-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.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)}.px-8{padding-inline:var(--space-8)}.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)}.pt-4{padding-block-start:var(--space-4)}.pb-4{padding-block-end:var(--space-4)}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.w-full{width:100%}.w-auto{width:auto}.min-w-0{min-width:0}.max-w-full{max-width:100%}.h-full{height:100%}.h-auto{height:auto}.min-h-0{min-height:0}.min-h-screen{min-height:100vh}.border{border:1px solid var(--color-border)}.border-0{border:0}.border-t{border-block-start:1px solid var(--color-border)}.border-b{border-block-end:1px solid var(--color-border)}.border-l{border-inline-start:1px solid var(--color-border)}.border-r{border-inline-end:1px solid var(--color-border)}.border-2{border-width:2px}.border-dashed{border-style:dashed}.rounded{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)}.rounded-none{border-radius:0}.bg-transparent{background-color:transparent}.bg-surface{background-color:var(--color-surface)}.bg-surface-alt{background-color:var(--color-surface-alt)}.bg-primary{background-color:var(--color-primary)}.bg-primary-light{background-color:var(--color-primary-light)}.bg-success-light{background-color:var(--color-success-light)}.bg-warning-light{background-color:var(--color-warning-light)}.bg-danger-light{background-color:var(--color-danger-light)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.animate-fade-in{animation:fadeIn var(--duration-slow) var(--ease-default)}.animate-slide-up{animation:slideUp var(--duration-slow) var(--ease-default)}.animate-spin{animation:spin 1s linear infinite}.animate-modal{animation:modalSlideIn var(--duration-normal) var(--ease-default)}.modal-backdrop{position:fixed;inset:0;background-color:var(--color-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal, 1000);animation:var(--animate-fade-in)}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{user-select:none}.select-auto{user-select:auto}.select-all{user-select:all}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-100{opacity:1}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-modal{z-index:1000}.z-tooltip{z-index:1100}.transition{transition:opacity var(--transition-normal),transform var(--transition-normal),background-color var(--transition-normal),color var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal)}.transition-fast{transition:opacity var(--transition-fast),transform var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.transition-slow{transition:opacity var(--transition-slow),transform var(--transition-slow),background-color var(--transition-slow),color var(--transition-slow),border-color var(--transition-slow),box-shadow var(--transition-slow)}.transition-none{transition:none}.loading{display:flex;align-items:center;justify-content:center}.loading--full-page{min-height:50vh}.form-input{width:100%;padding:7px 10px;font-size:var(--font-size-sm);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);&::placeholder{color:var(--color-text-muted)}&:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}&:disabled{background-color:var(--color-surface-alt);cursor:not-allowed;opacity:.7}}.form-select{width:100%;padding:7px 10px;font-size:var(--font-size-sm);color:var(--color-text);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 4.5L6 7.5L9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);&:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}&:disabled{background-color:var(--color-surface-alt);cursor:not-allowed;opacity:.7}}.form-group{margin-bottom:var(--space-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--space-1-5)}.form-label--required:after{content:" *";color:var(--color-danger)}.form-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.form-error{font-size:var(--font-size-sm);color:var(--color-danger);margin-top:var(--space-1)}.form-row{display:grid;grid-template-columns:1fr;gap:var(--space-4);@media(min-width:768px){grid-template-columns:repeat(2,1fr)}}.form-check{display:flex;align-items:center;gap:var(--space-2)}.form-check__input{width:16px;height:16px;accent-color:var(--color-primary)}.form-check__label{font-size:var(--font-size-sm);color:var(--color-text)}
