:root{--color-bg: #f7f7f8;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-surface-muted: #f0f0f2;--color-text: #111111;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-text-inverse: #ffffff;--color-accent: #2563eb;--color-accent-hover: #1d4ed8;--color-accent-soft: rgba(37, 99, 235, .08);--color-accent-ring: rgba(37, 99, 235, .24);--color-success: #059669;--color-success-soft: rgba(5, 150, 105, .08);--color-border: rgba(0, 0, 0, .06);--color-border-strong: rgba(0, 0, 0, .1);--radius-sm: 10px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .05), 0 4px 12px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .04), 0 12px 28px rgba(0, 0, 0, .06);--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .15s;--duration-normal: .22s;--duration-slow: .32s;--page-padding-x: 24px;--content-max-width: 1280px;--header-height: 64px;--bottom-nav-height: 72px;--safe-bottom: env(safe-area-inset-bottom, 0px);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem}@media(min-width:768px){:root{--page-padding-x: 40px;--header-height: 72px}}@media(min-width:1280px){:root{--page-padding-x: 48px}}*,*:before,*:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{margin:0;min-height:100dvh;font-family:var(--font-sans);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text);background:var(--color-bg)}#root{min-height:100dvh}button,input,textarea{font:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-in{animation:fade-in var(--duration-slow) var(--ease-out) both}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
