.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-4);background:var(--color-surface-alt)}.login-card{max-width:400px;width:100%;padding:var(--space-6);@media(min-width:480px){width:90%;padding:var(--space-8)}}.login__header{text-align:center;margin-bottom:var(--space-6);@media(min-width:480px){margin-bottom:var(--space-8)}}.login__icon{margin:0 auto var(--space-4);color:var(--color-primary)}.login__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)}.login__error{background-color:var(--color-danger-light);color:var(--color-danger);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-6);font-size:var(--font-size-sm);line-height:1.5}.login__button{width:100%;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;justify-content:center;gap:var(--space-2);margin-top:var(--space-4);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{margin-top:var(--space-6);text-align:center;font-size:.813rem;color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);border:none;cursor:pointer;transition:background-color var(--transition-normal),transform var(--transition-normal),box-shadow var(--transition-normal);white-space:nowrap;&:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}&: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-5) var(--space-5);font-size:var(--font-size-sm);gap:var(--space-2)}.btn--primary{background-color:var(--color-primary);color:#fff;&:hover:not(:disabled){background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-primary-glow)}&:active:not(:disabled){transform:translateY(0)}}.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);transform:translateY(-2px);box-shadow:var(--shadow-danger-glow)}&:active:not(:disabled){transform:translateY(0)}}.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)}}.btn--icon{padding:var(--space-2-5);min-width:44px;min-height:44px}.btn--full{width:100%}.card{background-color:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.card--p-0{padding:0}.card--p-4{padding:var(--space-4)}.card--p-6{padding:var(--space-6)}.card--clickable{cursor:pointer;transition:transform var(--transition-normal),box-shadow var(--transition-normal);&:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}}.card__header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border)}.card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.card__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.card__body{padding:var(--space-6)}.card__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.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--inline{padding:var(--space-4);flex-direction:row}.loading__message{font-size:var(--font-size-sm)}.error-boundary{position:fixed;inset:0;z-index:10001;background-color:var(--color-overlay-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center}.error-boundary__box{background-color:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-lg);padding:var(--space-8);max-width:500px;width:100%}.error-boundary__icon{font-size:3rem;margin-bottom:var(--space-4)}.error-boundary__title{color:var(--color-danger);margin-bottom:var(--space-2);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.error-boundary__message{color:var(--color-text-muted);margin-bottom:var(--space-6);font-size:var(--font-size-sm)}.error-boundary__details{text-align:left;margin-bottom:var(--space-6);padding:var(--space-4);background-color:var(--color-surface);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-family:var(--font-mono);overflow:auto;max-height:200px}.error-boundary__details-summary{cursor:pointer;margin-bottom:var(--space-2)}.error-boundary__details-content{white-space:pre-wrap;word-break:break-word}.error-boundary__actions{display:flex;gap:var(--space-3);justify-content:center}.error-boundary__btn{padding:var(--space-2-5) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-sm);display:inline-flex;align-items:center;gap:var(--space-2);transition:background-color var(--transition-normal),transform var(--transition-normal),box-shadow var(--transition-normal);font-weight:var(--font-weight-medium);cursor:pointer;border:none}.error-boundary__btn--primary{background-color:var(--color-primary);color:#fff;&:hover{background-color:var(--color-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}}.error-boundary__btn--secondary{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);&:hover{background-color:var(--color-neutral-100)}}.connection-status{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);z-index:9998;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-3);font-weight:var(--font-weight-medium);animation:slideUp var(--duration-slow) var(--ease-default)}.connection-status--online{background-color:var(--color-success)}.connection-status--offline{background-color:var(--color-warning)}.connection-status__icon{font-size:var(--font-size-xl)}.toast-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2);max-width:400px}.toast{color:#fff;padding:var(--space-3-5) var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-3);animation:slideInRight var(--duration-slow) var(--ease-default)}.toast--success{background-color:var(--color-success)}.toast--error{background-color:var(--color-danger)}.toast--warning{background-color:var(--color-warning)}.toast--info{background-color:var(--color-primary)}.toast__icon{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.toast__message{flex:1;font-weight:var(--font-weight-medium)}.toast__action{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;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:#ffffff4d}&:active{background:#fff6}}.toast--has-action{padding-right:var(--space-3)}.toast__copy{background:transparent;border:0;color:#fff;cursor:pointer;padding:var(--space-1);opacity:.7;font-size:var(--font-size-sm);line-height:1;transition:opacity var(--transition-fast);&:hover{opacity:1}}.toast__dismiss{background:transparent;border:0;color:#fff;cursor:pointer;padding:var(--space-1);opacity:.8;font-size:var(--font-size-base);line-height:1;transition:opacity var(--transition-fast);&:hover{opacity:1}}.theme-toggle{min-height:auto;padding:var(--space-1-5);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color var(--transition-normal);width:32px;height:32px;color:var(--color-text);@media(min-width:768px){padding:var(--space-2);width:40px;height:40px}&:hover{background-color:var(--color-surface-alt)}&:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}}.theme-toggle__icon{width:16px;height:16px;@media(min-width:768px){width:20px;height:20px}}.admin-menu{position:relative}.admin-menu__trigger{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-normal)}.admin-menu__trigger:hover{background-color:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-hover)}.admin-menu__trigger:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(min-width:768px){.admin-menu__trigger{width:40px;height:40px}}.admin-menu__dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;z-index:var(--z-dropdown, 100);min-width:180px;padding:var(--space-1);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:admin-menu-fade-in .15s ease-out}@keyframes admin-menu-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.admin-menu__item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text);font-size:var(--font-size-sm);text-align:left;cursor:pointer;transition:background-color var(--transition-fast)}.admin-menu__item:hover{background-color:var(--color-surface-hover)}.admin-menu__item:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.admin-menu__item svg{flex-shrink:0;color:var(--color-text-muted)}.admin-menu__item:hover svg{color:var(--color-text)}.admin-menu__spinner{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@media(min-width:768px){.admin-menu__spinner{width:40px;height:40px}}.nav{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:110}.nav__container{display:flex;align-items:center;justify-content:space-between;height:48px;padding-inline:var(--space-4);@media(min-width:768px){height:64px;padding-inline:var(--space-8)}}.nav__brand{display:flex;align-items:center;gap:var(--space-3);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--color-text);& span{display:none;@media(min-width:768px){display:inline}}}.nav__brand-icon{color:var(--color-primary)}.nav__mobile-title{flex:1;display:flex;justify-content:center;align-items:center;padding:0 var(--space-2);@media(min-width:768px){display:none}}.nav__page-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.nav__page-toggle{display:flex;align-items:center;gap:var(--space-2)}.nav__toggle-separator{font-size:var(--font-size-lg);color:var(--color-text-muted);font-weight:var(--font-weight-normal)}.nav__toggle-btn{min-height:auto;padding:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-normal);color:var(--color-text-muted);transition:color var(--transition-fast)}.nav__toggle-btn--active{font-weight:var(--font-weight-bold);color:var(--color-text)}.nav__links{display:none;@media(min-width:768px){display:flex;gap:var(--space-1)}@media(min-width:1024px){gap:var(--space-2)}}.nav__link{padding:var(--space-2) var(--space-3);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);color:var(--color-text-muted);transition:color var(--transition-normal),background-color var(--transition-normal);@media(min-width:769px){padding:var(--space-2-5) var(--space-4)}&:hover{color:var(--color-text);background-color:var(--color-neutral-100)}}.nav__link--active{color:var(--color-primary);background-color:var(--color-primary-light)}.nav__actions{display:flex;align-items:center;gap:var(--space-4)}.nav__logout-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-lg);background-color:transparent;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-normal),background-color var(--transition-normal);&:hover{color:var(--color-text);background-color:var(--color-neutral-100)}@media(min-width:768px){display:none}}.nav__user{display:none;font-size:var(--font-size-sm);color:var(--color-text-muted);@media(min-width:768px){display:inline}}.nav__logout{display:none;padding:var(--space-1-5) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;transition:background-color var(--transition-normal);align-items:center;gap:var(--space-2);@media(min-width:768px){display:inline-flex}&:hover{background-color:var(--color-surface-alt)}}.bottom-nav{display:flex;justify-content:space-around;align-items:center;position:fixed;bottom:0;left:0;right:0;z-index:100;background-color:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:var(--shadow-lg);padding:var(--space-1) 0;padding-bottom:env(safe-area-inset-bottom,var(--space-1));@media(min-width:768px){display:none}}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-0-5);padding:var(--space-1) var(--space-2);min-width:64px;min-height:48px;border-radius:var(--radius-lg);color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-normal),background-color var(--transition-normal),transform var(--transition-normal);background:none;border:none;cursor:pointer;font-family:inherit;&:hover{color:var(--color-text);background-color:var(--color-neutral-100)}&:active{transform:scale(.95)}}.bottom-nav__item--active{color:var(--color-primary);.bottom-nav__label{font-weight:var(--font-weight-semibold)}}.bottom-nav__label{font-size:.625rem;font-weight:var(--font-weight-medium);line-height: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,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) 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-surface: #ffffff;--color-surface-alt: #f5f5f5;--color-text: #111827;--color-text-muted: #6b7280;--color-border: #d1d5db;--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-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-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-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-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-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-surface: #ffffff;--color-surface-alt: #f5f5f5;--color-surface-sunken: #f9fafb;--color-surface-raised: #ffffff;--color-text: #111827;--color-text-muted: #6b7280;--color-border: #d1d5db;--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: 72px;--size-progress-bar: 6px;--size-progress-bar-sm: 4px;--size-badge-sm: 1.25rem;--radius-sm: .125rem;--radius-md: .25rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--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)}}@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:var(--space-2-5) var(--space-3-5);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-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);&::placeholder{color:var(--color-text-muted)}&:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-color:var(--color-primary)}&:disabled{background-color:var(--color-surface-alt);cursor:not-allowed;opacity:.7}}.form-input--mono{font-family:var(--font-mono)}.form-input--compact{padding:var(--space-1-5) var(--space-2)}.form-input--lg{padding:var(--space-3) var(--space-4);font-size:var(--font-size-base)}.form-select{width:100%;padding:var(--space-2-5) var(--space-3-5);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-md);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:2px solid var(--color-primary);outline-offset:2px;border-color:var(--color-primary)}&:disabled{background-color:var(--color-surface-alt);cursor:not-allowed;opacity:.7}}.form-textarea{min-height:100px;resize:vertical}.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)}
