@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-weight:var(--font-medium);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;outline:none;text-decoration:none;-webkit-user-select:none;user-select:none}.button--sm{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);min-height:32px}.button--md{padding:var(--space-3) var(--space-4);font-size:var(--text-base);min-height:40px}.button--lg{padding:var(--space-4) var(--space-6);font-size:var(--text-lg);min-height:48px}.button--primary{background-color:var(--color-accent);color:var(--color-text-on-accent)}.button--primary:hover:not(:disabled){background-color:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.button--primary:active:not(:disabled){background-color:var(--color-accent-active);transform:translateY(0);box-shadow:var(--shadow-sm)}.button--secondary{background-color:var(--color-surface-tertiary);color:var(--color-text-primary)}.button--secondary:hover:not(:disabled){background-color:var(--color-surface-secondary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.button--secondary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.button--outline{background-color:transparent;color:var(--color-accent);border:1px solid var(--color-border)}.button--outline:hover:not(:disabled){background-color:var(--color-accent-subtle);border-color:var(--color-accent)}.button--outline:active:not(:disabled){background-color:var(--color-surface-tertiary)}.button--ghost{background-color:transparent;color:var(--color-text-secondary)}.button--ghost:hover:not(:disabled){background-color:var(--color-surface);color:var(--color-text-primary)}.button--ghost:active:not(:disabled){background-color:var(--color-surface-tertiary)}.button--danger{background-color:var(--color-error);color:var(--color-text-inverse)}.button--danger:hover:not(:disabled){background-color:oklch(from var(--color-error) calc(l - .05) c h);transform:translateY(-1px);box-shadow:var(--shadow-md)}.button--danger:active:not(:disabled){background-color:oklch(from var(--color-error) calc(l - .1) c h);transform:translateY(0);box-shadow:var(--shadow-sm)}.button--full-width{width:100%}.button:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.card{background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl);overflow:hidden;transition:all var(--transition-base)}.card--hoverable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--color-border)}.card--clickable{cursor:pointer}.card__header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-surface-secondary)}.card__title{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary)}.card__body{padding:var(--space-6)}.card__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-subtle);background-color:var(--color-surface-secondary)}.modal__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4);overflow-y:auto;animation:modalFadeIn var(--transition-base)}.modal__content{background-color:var(--color-bg-elevated);border-radius:var(--radius-3xl);box-shadow:var(--shadow-xl);width:100%;max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column;z-index:var(--z-modal);animation:modalSlideIn var(--transition-base);overflow:hidden}.modal__content--sm{max-width:400px}.modal__content--md{max-width:600px}.modal__content--lg{max-width:800px}.modal__content--xl{max-width:1200px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--color-border-secondary);flex-shrink:0}.modal__title{margin:0;font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-text-primary)}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-lg);color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;margin-left:var(--space-4)}.modal__close:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.modal__close:active{background-color:var(--color-bg-tertiary)}.modal__body{padding:var(--space-6);overflow-y:auto;flex:1}.modal__footer{padding:var(--space-6);border-top:1px solid var(--color-border-secondary);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);flex-shrink:0}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 640px){.modal__overlay{padding:0;align-items:flex-end}.modal__content{max-height:90vh;border-bottom-left-radius:0;border-bottom-right-radius:0}.modal__header,.modal__body,.modal__footer{padding:var(--space-4)}}.input{display:flex;flex-direction:column;gap:var(--space-2);width:100%}.input__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.input__required{color:var(--color-error);margin-left:var(--space-1)}.input__field{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-primary);border-radius:var(--radius-lg);color:var(--color-text-primary);transition:all var(--transition-fast)}.input__field::placeholder{color:var(--color-text-tertiary)}.input__field:hover:not(:disabled){border-color:var(--color-border-focus)}.input__field:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px oklch(from var(--color-border-focus) l c h / .1)}.input__field:disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-secondary)}.input__field--error{border-color:var(--color-error)}.input__field--error:focus{box-shadow:0 0 0 3px oklch(from var(--color-error) l c h / .1)}.input__error{font-size:var(--text-sm);color:var(--color-error)}.theme-switcher{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background-color:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.theme-switcher:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-border-focus);transform:scale(1.05)}.theme-switcher:active{transform:scale(.95)}.theme-switcher__icon{transition:transform var(--transition-base)}.theme-switcher:hover .theme-switcher__icon{transform:rotate(15deg)}.page{width:100%;max-width:1280px;margin:0 auto;padding:var(--space-6) var(--space-4) var(--space-12)}.hero{text-align:center;padding:var(--space-20) 0 var(--space-16);margin-bottom:var(--space-20)}.hero__title{font-size:var(--text-5xl);font-weight:var(--font-bold);margin-bottom:var(--space-4);color:var(--color-text-primary);letter-spacing:-.02em}.hero__subtitle{font-size:var(--text-xl);color:var(--color-text-secondary);margin-bottom:var(--space-8);max-width:600px;margin-left:auto;margin-right:auto}.hero__actions{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:nowrap}@media (max-width: 640px){.hero__actions{flex-direction:column;align-items:stretch}}.section-title{font-size:var(--text-4xl);font-weight:var(--font-semibold);text-align:center;margin-bottom:var(--space-16);letter-spacing:-.02em}.features{margin-bottom:var(--space-20)}.features__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-8)}.feature{text-align:center}.feature__icon{margin-bottom:var(--space-4);color:var(--color-accent);display:inline-flex;align-items:center;justify-content:center;transition:transform var(--transition-base) cubic-bezier(.4,0,.2,1)}.feature:hover .feature__icon{transform:scale(1.1)}.feature__title{font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:var(--space-3);color:var(--color-text-primary)}.feature__description{font-size:var(--text-base);color:var(--color-text-secondary);line-height:var(--leading-relaxed)}.cta{margin-bottom:var(--space-12)}.cta__content{text-align:center;padding:var(--space-12)}.cta__title{font-size:var(--text-3xl);font-weight:var(--font-semibold);margin-bottom:var(--space-4)}.cta__text{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.cta__actions{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:nowrap}@media (max-width: 640px){.cta__actions{flex-direction:column;align-items:stretch}}.modal-content h3,.modal-content ol{margin-bottom:var(--space-4)}.modal-content li{margin-bottom:var(--space-2)}.modal-content code{font-family:var(--font-mono);background:var(--color-surface-secondary);padding:2px 6px;border-radius:var(--radius-base)}.showcase{margin-bottom:var(--space-20);overflow:hidden}.showcase__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-12);padding:0 var(--space-4)}.showcase__title{font-size:var(--text-3xl);font-weight:var(--font-semibold);color:var(--color-text-primary)}.showcase__description{font-size:var(--text-base);color:var(--color-text-secondary);margin-top:var(--space-2)}.showcase__scroll{display:flex;gap:var(--space-4);overflow-x:auto;overflow-y:hidden;padding:var(--space-2) var(--space-4) var(--space-6);margin:0 calc(var(--space-4) * -1);padding-left:var(--space-4);padding-right:var(--space-4);scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.showcase__scroll::-webkit-scrollbar{height:6px}.showcase__scroll::-webkit-scrollbar-track{background:var(--color-surface);border-radius:var(--radius-full)}.showcase__scroll::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.showcase__scroll::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}.showcase-card{flex:0 0 auto;width:320px;padding:var(--space-6);background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl);scroll-snap-align:start;transition:all var(--transition-fast)}.showcase-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-border)}.showcase-card__header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.showcase-card__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--color-accent);color:var(--color-text-on-accent);border-radius:var(--radius-xl);font-size:24px}.showcase-card__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0}.showcase-card__description{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--space-4)}.showcase-card__footer{display:flex;gap:var(--space-2);flex-wrap:wrap}.showcase-card__tag{font-size:var(--text-xs);padding:var(--space-1) var(--space-3);background-color:var(--color-surface-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);color:var(--color-text-secondary)}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-8);margin-bottom:var(--space-20);padding:var(--space-10);background-color:var(--color-surface);border-radius:var(--radius-3xl);border:1px solid var(--color-border-subtle)}.stat{text-align:center}.stat__value{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--color-accent);margin-bottom:var(--space-2);display:block}.stat__label{font-size:var(--text-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}@media (max-width: 640px){.hero{padding:var(--space-12) 0}.hero__title{font-size:var(--text-4xl)}.showcase__scroll{padding-left:var(--space-4)}.showcase-card{width:280px}.stats{grid-template-columns:1fr;gap:var(--space-4);padding:var(--space-6)}}.app{display:flex;flex-direction:column;min-height:100vh}.header{position:fixed;top:0;left:0;right:0;z-index:var(--z-sticky);padding:var(--space-3) var(--space-4);pointer-events:none}.header__container{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:var(--space-3) var(--space-6);gap:var(--space-4);flex-wrap:nowrap;background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-lg);pointer-events:auto;transition:all var(--transition-base) cubic-bezier(.4,0,.2,1)}.header__logo{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);text-decoration:none;white-space:nowrap;transition:color var(--transition-fast);flex-shrink:0}.header__logo:hover{color:var(--color-accent)}.header__nav{display:flex;align-items:center;gap:var(--space-6);flex:1;justify-content:center;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.nav-link{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-secondary);text-decoration:none;white-space:nowrap;transition:color var(--transition-fast);position:relative;flex-shrink:0}.nav-link:hover{color:var(--color-text-primary)}.nav-link:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background-color:var(--color-accent);transform:scaleX(0);transition:transform var(--transition-fast)}.nav-link:hover:after{transform:scaleX(1)}.header__search{display:flex;align-items:center;gap:var(--space-2);background-color:var(--color-bg-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);flex-shrink:0;min-width:200px;max-width:280px}.header__search:hover{border-color:var(--color-border)}.header__search--focused{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-subtle)}.header__search svg{color:var(--color-text-tertiary);flex-shrink:0}.header__search-input{flex:1;border:none;background:transparent;color:var(--color-text-primary);font-size:var(--text-sm);outline:none;min-width:0}.header__search-input::placeholder{color:var(--color-text-tertiary)}.header__search-kbd{font-size:var(--text-xs);color:var(--color-text-tertiary);background-color:var(--color-surface-secondary);padding:2px 6px;border-radius:var(--radius-base);border:1px solid var(--color-border-subtle);font-family:var(--font-mono);flex-shrink:0}.header__actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.main{flex:1;width:100%;padding-top:calc(var(--space-16) + var(--space-4))}.footer{background-color:var(--color-surface);border-top:1px solid var(--color-border-subtle);margin-top:var(--space-16)}.footer__container{max-width:1440px;margin:0 auto;padding:var(--space-8) var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.footer__text{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0}.footer__links{display:flex;gap:var(--space-6);flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.footer__link{font-size:var(--text-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast);white-space:nowrap;flex-shrink:0}.footer__link:hover{color:var(--color-accent)}@media (max-width: 639px){.header{padding:var(--space-2) var(--space-3)}.header__container{padding:var(--space-3) var(--space-4);gap:var(--space-3);border-radius:var(--radius-full)}.header__logo{font-size:var(--text-lg)}.header__search{display:none}.header__nav{gap:var(--space-4)}.nav-link{font-size:var(--text-sm);padding:var(--space-2);min-height:44px;display:flex;align-items:center}.fab{bottom:var(--space-4);right:var(--space-4);width:48px;height:48px}.fab svg{width:20px;height:20px}}.fab{position:fixed;bottom:var(--space-6);right:var(--space-6);width:56px;height:56px;border-radius:var(--radius-full);background-color:var(--color-accent);color:var(--color-text-on-accent);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-lg);transition:all var(--transition-fast);z-index:var(--z-sticky);animation:fabSlideIn var(--transition-base) cubic-bezier(.34,1.56,.64,1)}.fab:hover{transform:scale(1.1);box-shadow:var(--shadow-xl);background-color:var(--color-accent-hover)}.fab:active{transform:scale(.95);background-color:var(--color-accent-active)}@keyframes fabSlideIn{0%{transform:translateY(100px) scale(0);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.fab-modal-content{display:flex;flex-direction:column;gap:var(--space-4)}.fab-modal-description{margin:0;font-size:var(--text-base);color:var(--color-text-secondary)}.fab-modal-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}.fab-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6);background-color:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl);cursor:pointer;transition:all var(--transition-fast)}.fab-option:hover{background-color:var(--color-surface-secondary);border-color:var(--color-border);transform:translateY(-2px);box-shadow:var(--shadow-md)}.fab-option:active{transform:translateY(0)}.fab-option-icon{color:var(--color-accent);flex-shrink:0}.fab-option-text{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}@media (min-width: 640px) and (max-width: 1023px){.header__container{padding:var(--space-4) var(--space-6)}.header__nav{gap:var(--space-4)}}:root{--color-bg: oklch(98% 0 0);--color-bg-page: oklch(98% 0 0);--color-bg-elevated: oklch(100% 0 0);--color-surface: oklch(96% 0 0);--color-surface-secondary: oklch(94% 0 0);--color-surface-tertiary: oklch(92% 0 0);--color-border: oklch(88% 0 0);--color-border-subtle: oklch(92% 0 0);--color-border-strong: oklch(80% 0 0);--color-text-primary: oklch(20% 0 0);--color-text-secondary: oklch(45% 0 0);--color-text-tertiary: oklch(60% 0 0);--color-text-disabled: oklch(70% 0 0);--color-text-on-accent: oklch(100% 0 0);--color-accent: oklch(30% 0 0);--color-accent-hover: oklch(25% 0 0);--color-accent-active: oklch(20% 0 0);--color-accent-subtle: oklch(95% 0 0);--color-success: oklch(60% .12 145);--color-success-bg: oklch(95% .03 145);--color-success-border: oklch(80% .1 145);--color-error: oklch(55% .15 25);--color-error-bg: oklch(95% .03 25);--color-error-border: oklch(80% .1 25);--color-warning: oklch(65% .12 85);--color-warning-bg: oklch(95% .03 85);--color-warning-border: oklch(85% .1 85);--color-info: oklch(60% .12 250);--color-info-bg: oklch(95% .03 250);--color-info-border: oklch(80% .1 250);--gray-0: oklch(100% 0 0);--gray-2: oklch(98% 0 0);--gray-4: oklch(96% 0 0);--gray-6: oklch(94% 0 0);--gray-12: oklch(92% 0 0);--gray-16: oklch(88% 0 0);--gray-24: oklch(80% 0 0);--gray-40: oklch(60% 0 0);--gray-55: oklch(45% 0 0);--gray-80: oklch(20% 0 0);--gray-100: oklch(0% 0 0);--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--space-32: 128px;--space-40: 160px;--space-48: 192px;--radius-none: 0;--radius-sm: 4px;--radius-base: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-3xl: 24px;--radius-4xl: 32px;--radius-full: 9999px;--shadow-sm: 0 1px 2px oklch(0% 0 0 / .06);--shadow-base: 0 1px 3px oklch(0% 0 0 / .08);--shadow-md: 0 4px 8px oklch(0% 0 0 / .08);--shadow-lg: 0 8px 24px oklch(0% 0 0 / .12);--shadow-xl: 0 16px 48px oklch(0% 0 0 / .16);--shadow-inner: inset 0 2px 4px oklch(0% 0 0 / .06);--color-overlay: oklch(0% 0 0 / .5);--z-base: 0;--z-dropdown: 1000;--z-sticky: 1100;--z-overlay: 1200;--z-modal-backdrop: 1200;--z-modal: 1300;--z-toast: 1400;--z-tooltip: 1500;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-slower: .5s cubic-bezier(.4, 0, .2, 1);--font-mono: "JetBrains Mono", "Consolas", "Monaco", monospace;--breakpoint-mobile-sm: 320px;--breakpoint-mobile-lg: 480px;--breakpoint-tablet: 640px;--breakpoint-desktop: 1024px;--breakpoint-wide: 1440px}[data-theme=dark]{--color-bg: oklch(15% 0 0);--color-bg-page: oklch(15% 0 0);--color-bg-elevated: oklch(20% 0 0);--color-surface: oklch(18% 0 0);--color-surface-secondary: oklch(22% 0 0);--color-surface-tertiary: oklch(26% 0 0);--color-border: oklch(28% 0 0);--color-border-subtle: oklch(24% 0 0);--color-border-strong: oklch(40% 0 0);--color-text-primary: oklch(95% 0 0);--color-text-secondary: oklch(70% 0 0);--color-text-tertiary: oklch(55% 0 0);--color-text-disabled: oklch(40% 0 0);--color-text-on-accent: oklch(0% 0 0);--color-accent: oklch(85% 0 0);--color-accent-hover: oklch(90% 0 0);--color-accent-active: oklch(95% 0 0);--color-accent-subtle: oklch(25% 0 0);--color-success: oklch(70% .15 145);--color-success-bg: oklch(20% .05 145);--color-success-border: oklch(35% .1 145);--color-error: oklch(70% .2 25);--color-error-bg: oklch(20% .05 25);--color-error-border: oklch(35% .1 25);--color-warning: oklch(75% .15 85);--color-warning-bg: oklch(25% .05 85);--color-warning-border: oklch(40% .1 85);--color-info: oklch(70% .15 250);--color-info-bg: oklch(20% .05 250);--color-info-border: oklch(35% .1 250);--gray-100: oklch(0% 0 0);--gray-85: oklch(15% 0 0);--gray-82: oklch(18% 0 0);--gray-78: oklch(22% 0 0);--gray-76: oklch(24% 0 0);--gray-72: oklch(28% 0 0);--gray-60: oklch(40% 0 0);--gray-45: oklch(55% 0 0);--gray-30: oklch(70% 0 0);--gray-5: oklch(95% 0 0);--gray-0: oklch(100% 0 0);--color-overlay: oklch(0% 0 0 / .7);--shadow-sm: 0 1px 2px oklch(0% 0 0 / .2);--shadow-base: 0 1px 3px oklch(0% 0 0 / .3);--shadow-md: 0 4px 8px oklch(0% 0 0 / .3);--shadow-lg: 0 8px 24px oklch(0% 0 0 / .4);--shadow-xl: 0 16px 48px oklch(0% 0 0 / .5);--shadow-inner: inset 0 2px 4px oklch(0% 0 0 / .2)}@media (prefers-color-scheme: dark){:root:not([data-theme]){--color-bg: oklch(15% 0 0);--color-bg-page: oklch(15% 0 0);--color-surface: oklch(18% 0 0);--color-surface-secondary: oklch(22% 0 0);--color-surface-tertiary: oklch(26% 0 0);--color-border: oklch(28% 0 0);--color-border-subtle: oklch(24% 0 0);--color-border-strong: oklch(40% 0 0);--color-text-primary: oklch(95% 0 0);--color-text-secondary: oklch(70% 0 0);--color-text-tertiary: oklch(55% 0 0);--color-text-disabled: oklch(40% 0 0);--color-text-on-accent: oklch(0% 0 0);--color-accent: oklch(85% 0 0);--color-accent-hover: oklch(90% 0 0);--color-accent-active: oklch(95% 0 0);--color-accent-subtle: oklch(25% 0 0);--color-success: oklch(70% .15 145);--color-success-bg: oklch(20% .05 145);--color-success-border: oklch(35% .1 145);--color-error: oklch(70% .2 25);--color-error-bg: oklch(20% .05 25);--color-error-border: oklch(35% .1 25);--color-warning: oklch(75% .15 85);--color-warning-bg: oklch(25% .05 85);--color-warning-border: oklch(40% .1 85);--color-info: oklch(70% .15 250);--color-info-bg: oklch(20% .05 250);--color-info-border: oklch(35% .1 250)}}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 32px;--text-4xl: 40px;--text-5xl: 48px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--leading-loose: 2;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .02em}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-normal);line-height:var(--leading-normal);letter-spacing:var(--tracking-normal);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{margin:0;font-weight:var(--font-semibold);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text-primary)}h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-3xl)}h4{font-size:var(--text-2xl)}h5{font-size:var(--text-xl)}h6{font-size:var(--text-lg)}p{margin:0 0 var(--space-4) 0;line-height:var(--leading-relaxed)}p:last-child{margin-bottom:0}a{color:var(--color-accent);text-decoration:underline;text-decoration-color:var(--color-text-tertiary);text-underline-offset:2px;transition:color var(--transition-fast),text-decoration-color var(--transition-fast)}a:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent)}a:active{color:var(--color-accent-active)}code,pre{font-family:var(--font-mono);font-size:var(--text-sm)}code{padding:2px 6px;background:var(--color-surface-tertiary);border-radius:var(--radius-sm);color:var(--color-text-primary)}pre{padding:var(--space-4);background:var(--color-surface-tertiary);border-radius:var(--radius-md);overflow-x:auto;line-height:var(--leading-relaxed)}pre code{padding:0;background:none}ul,ol{margin:0 0 var(--space-4) 0;padding-left:var(--space-6)}li{margin-bottom:var(--space-2);line-height:var(--leading-relaxed)}.text-normal{font-weight:var(--font-normal)}.text-medium{font-weight:var(--font-medium)}.text-semibold{font-weight:var(--font-semibold)}.text-bold{font-weight:var(--font-bold)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.text-5xl{font-size:var(--text-5xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.font-mono{font-family:var(--font-mono)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.container{width:100%;max-width:1440px;margin-left:auto;margin-right:auto;padding-left:var(--space-4);padding-right:var(--space-4)}@media (min-width: 640px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}@media (min-width: 1024px){.container{padding-left:var(--space-8);padding-right:var(--space-8)}}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.container-xl{max-width:1280px}.container-wide{max-width:1440px}.container-fluid{max-width:100%}.flex{display:flex}.inline-flex{display:inline-flex}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-nowrap{flex-wrap:nowrap}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.self-center{align-self:center}.self-stretch{align-self:stretch}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-initial{flex:0 1 auto}.flex-none{flex:none}.grow{flex-grow:1}.grow-0{flex-grow:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.grid{display:grid}.grid-24{grid-template-columns:repeat(24,minmax(0,1fr))}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.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))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.grid-cols-24{grid-template-columns:repeat(24,minmax(0,1fr))}.col-1{grid-column:span 1}.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-12{grid-column:span 12}.col-16{grid-column:span 16}.col-18{grid-column:span 18}.col-24{grid-column:span 24}.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)}.gap-8{gap:var(--space-8)}.gap-10{gap:var(--space-10)}.gap-12{gap:var(--space-12)}.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-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.p-10{padding:var(--space-10)}.p-12{padding:var(--space-12)}.px-0{padding-left:0;padding-right:0}.px-1{padding-left:var(--space-1);padding-right:var(--space-1)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-0{padding-top:0;padding-bottom:0}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.m-0{margin:0}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:var(--space-4);margin-bottom:var(--space-4)}.my-6{margin-top:var(--space-6);margin-bottom:var(--space-6)}.my-8{margin-top:var(--space-8);margin-bottom:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}.w-screen{width:100vw}.min-w-0{min-width:0}.min-w-full{min-width:100%}.max-w-full{max-width:100%}.max-w-screen{max-width:100vw}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.min-h-0{min-height:0}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-x-scroll{overflow-x:scroll}.overflow-y-auto{overflow-y:auto}.overflow-y-hidden{overflow-y:hidden}.overflow-y-scroll{overflow-y:scroll}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}@media (min-width: 640px){.tablet\:flex{display:flex}.tablet\:grid{display:grid}.tablet\:hidden{display:none}.tablet\:block{display:block}.tablet\:col-6{grid-column:span 6}.tablet\:col-8{grid-column:span 8}.tablet\:col-12{grid-column:span 12}.tablet\:col-16{grid-column:span 16}.tablet\:col-24{grid-column:span 24}.tablet\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.tablet\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.tablet\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width: 1024px){.desktop\:flex{display:flex}.desktop\:grid{display:grid}.desktop\:hidden{display:none}.desktop\:block{display:block}.desktop\:col-4{grid-column:span 4}.desktop\:col-6{grid-column:span 6}.desktop\:col-8{grid-column:span 8}.desktop\:col-12{grid-column:span 12}.desktop\:col-16{grid-column:span 16}.desktop\:col-18{grid-column:span 18}.desktop\:col-24{grid-column:span 24}.desktop\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.desktop\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.desktop\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.desktop\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}@media (min-width: 1440px){.wide\:flex{display:flex}.wide\:grid{display:grid}.wide\:hidden{display:none}.wide\:block{display:block}.wide\:col-6{grid-column:span 6}.wide\:col-8{grid-column:span 8}.wide\:col-12{grid-column:span 12}}.scroll-container{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.scroll-container::-webkit-scrollbar{height:8px}.scroll-container::-webkit-scrollbar-track{background:transparent}.scroll-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-base)}.scroll-container::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}.stack{display:flex;flex-direction:column}.stack>*+*{margin-top:var(--space-4)}.stack-tight>*+*{margin-top:var(--space-2)}.stack-loose>*+*{margin-top:var(--space-6)}.cluster{display:flex;gap:var(--space-2);overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.cluster>*{flex-shrink:0}html{font-size:16px;scroll-behavior:smooth}html,body,#root{height:100%;width:100%}body{background-color:var(--color-bg);color:var(--color-text-primary);transition:background-color var(--transition-base),color var(--transition-base)}::selection{background-color:var(--color-accent);color:var(--color-text-on-accent)}::-moz-selection{background-color:var(--color-accent);color:var(--color-text-on-accent)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-base)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-surface)}input,textarea,select,button{font-family:inherit;font-size:inherit;line-height:inherit;color:inherit}input,textarea,select{width:100%;padding:var(--space-3) var(--space-4);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)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px oklch(from var(--color-accent) l c h / .1)}input::placeholder,textarea::placeholder{color:var(--color-text-tertiary)}button{cursor:pointer;border:none;background:none;padding:0}button:disabled{cursor:not-allowed;opacity:.5}img,svg{display:block;max-width:100%;height:auto}hr{border:none;border-top:1px solid var(--color-border-subtle);margin:var(--space-6) 0}table{width:100%;border-collapse:collapse;border-spacing:0}th,td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border-subtle)}th{font-weight:var(--font-semibold);color:var(--color-text-primary);background-color:var(--color-surface)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.select-none{-webkit-user-select:none;user-select:none}.transition-all{transition:all var(--transition-base)}.transition-colors{transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base)}.bg-page{background-color:var(--color-bg-page)}.bg-surface{background-color:var(--color-surface)}.bg-surface-secondary{background-color:var(--color-surface-secondary)}.bg-surface-tertiary{background-color:var(--color-surface-tertiary)}.border{border:1px solid var(--color-border)}.border-2{border:2px solid var(--color-border)}.border-subtle{border:1px solid var(--color-border-subtle)}.border-strong{border:1px solid var(--color-border-strong)}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-l{border-left:1px solid var(--color-border)}.border-r{border-right:1px solid var(--color-border)}.border-none{border:none}.rounded-none{border-radius:var(--radius-none)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-base{border-radius:var(--radius-base)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-base{box-shadow:var(--shadow-base)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-inner{box-shadow:var(--shadow-inner)}.shadow-none{box-shadow:none}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}
