*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-sans),system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--font-mono),monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.right-0{right:0}.top-0{top:0}.top-\[calc\(100\%\+2px\)\]{top:calc(100% + 2px)}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[120\]{z-index:120}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-0\.5{margin-left:.125rem}.mt-16{margin-top:4rem}.box-border{box-sizing:border-box}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-10{height:2.5rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-7{height:1.75rem}.h-9{height:2.25rem}.min-h-\[11rem\]{min-height:11rem}.min-h-\[44px\]{min-height:44px}.min-h-\[88vh\]{min-height:88vh}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-2{width:.5rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-9{width:2.25rem}.w-full{width:100%}.w-px{width:1px}.min-w-\[160px\]{min-width:160px}.min-w-\[320px\]{min-width:320px}.min-w-\[44px\]{min-width:44px}.max-w-\[100px\]{max-width:100px}.max-w-\[1200px\]{max-width:1200px}.max-w-\[400px\]{max-width:400px}.max-w-\[440px\]{max-width:440px}.max-w-\[520px\]{max-width:520px}.max-w-\[840px\]{max-width:840px}.shrink-0{flex-shrink:0}.-translate-y-1{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-1{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-1{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-rotate-45{--tw-rotate: -45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-45{--tw-rotate: 45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-\[headerLangIn_0\.2s_ease-out\]{animation:headerLangIn .2s ease-out}.animate-\[heroBlink_0\.85s_ease-in-out_infinite\]{animation:heroBlink .85s ease-in-out infinite}.animate-\[heroBlink_1s_ease-in-out_infinite\]{animation:heroBlink 1s ease-in-out infinite}.animate-\[heroPulse_2s_ease-in-out_infinite\]{animation:heroPulse 2s ease-in-out infinite}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-none{border-style:none}.border-border{border-color:var(--border-subtle)}.bg-\[color-mix\(in_srgb\,var\(--bg-primary\)_85\%\,transparent\)\]{background-color:color-mix(in srgb,var(--bg-primary) 85%,transparent)}.bg-\[var\(--accent-cyan\)\],.bg-accent{background-color:var(--accent-cyan)}.bg-accent-dim{background-color:var(--accent-cyan-dim)}.bg-border{background-color:var(--border-subtle)}.bg-card{background-color:var(--bg-card)}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.bg-text-primary{background-color:var(--text-primary)}.bg-transparent{background-color:transparent}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-\[var\(--accent-cyan\)\]{--tw-gradient-from: var(--accent-cyan) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-\[var\(--accent-blue\)\]{--tw-gradient-to: var(--accent-blue) var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pt-12{padding-top:3rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:var(--font-mono),monospace}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[0\.8125rem\]{font-size:.8125rem}.text-\[0\.9375rem\]{font-size:.9375rem}.text-\[1\.0625rem\]{font-size:1.0625rem}.text-\[1\.75rem\]{font-size:1.75rem}.text-\[clamp\(2\.5rem\,5vw\,3\.75rem\)\]{font-size:clamp(2.5rem,5vw,3.75rem)}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-light{font-weight:300}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-\[1\.7\]{line-height:1.7}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-\[var\(--accent-red\,\#ef4444\)\]{color:var(--accent-red,#ef4444)}.text-accent{color:var(--accent-cyan)}.text-inherit{color:inherit}.text-text-muted{color:var(--text-muted)}.text-text-primary{color:var(--text-primary)}.text-text-secondary{color:var(--text-secondary)}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.no-underline{text-decoration-line:none}.opacity-0{opacity:0}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow: var(--shadow-lg);--tw-shadow-colored: var(--shadow-lg);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-\[20px\]{--tw-backdrop-blur: blur(20px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.\[touch-action\:manipulation\]{touch-action:manipulation}:root,[data-theme=dark]{--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-tertiary: #1a2332;--bg-card: rgba(26, 35, 50, .6);--bg-card-hover: rgba(30, 45, 65, .8);--accent-cyan: #06b6d4;--accent-cyan-dim: rgba(6, 182, 212, .15);--accent-blue: #0ea5e9;--accent-violet: #8b5cf6;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-subtle: rgba(148, 163, 184, .08);--border-accent: rgba(6, 182, 212, .3);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 20px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .4);--shadow-glow: 0 0 40px rgba(6, 182, 212, .15);--gradient-mesh-1: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(6, 182, 212, .15), transparent);--gradient-mesh-2: radial-gradient(ellipse 60% 40% at 100% 100%, rgba(139, 92, 246, .08), transparent);--gradient-mesh-3: radial-gradient(ellipse 50% 30% at 0% 80%, rgba(14, 165, 233, .06), transparent);--bg-grid-dot: rgba(148, 163, 184, .25)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: rgba(255, 255, 255, .9);--bg-card-hover: rgba(241, 245, 249, .95);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #64748b;--border-subtle: rgba(15, 23, 42, .06);--border-accent: rgba(6, 182, 212, .4);--shadow-sm: 0 2px 8px rgba(15, 23, 42, .06);--shadow-md: 0 4px 20px rgba(15, 23, 42, .08);--shadow-lg: 0 8px 40px rgba(15, 23, 42, .1);--shadow-glow: 0 0 40px rgba(6, 182, 212, .12);--gradient-mesh-1: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(6, 182, 212, .08), transparent);--gradient-mesh-2: radial-gradient(ellipse 60% 40% at 100% 100%, rgba(139, 92, 246, .05), transparent);--gradient-mesh-3: radial-gradient(ellipse 50% 30% at 0% 80%, rgba(14, 165, 233, .05), transparent);--bg-grid-dot: rgba(15, 23, 42, .12)}:root{--font-sans: "Sora", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}@media(max-width:768px){header[data-menu-open=true]>div>nav{transform:translateY(0)!important;opacity:1!important;visibility:visible!important;pointer-events:auto!important}}body{font-family:var(--font-sans);font-size:16px;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;transition:background var(--duration-normal) var(--ease-out),color var(--duration-normal) var(--ease-out)}body:before{content:"";position:fixed;inset:0;background:var(--gradient-mesh-1),var(--gradient-mesh-2),var(--gradient-mesh-3);pointer-events:none;z-index:0}body:after{content:"";position:fixed;left:-50vw;top:-50vh;width:200vw;height:200vh;background-image:radial-gradient(circle at 2px 2px,var(--bg-grid-dot, rgba(148, 163, 184, .2)) 1.5px,transparent 1.5px);background-size:40px 40px;background-position:0 0;animation:gridFloat 12s linear infinite;will-change:transform;pointer-events:none;z-index:0;opacity:.8}@keyframes gridFloat{0%{transform:translate(0)}to{transform:translate(40px,40px)}}#root{position:relative;z-index:1;min-height:100vh}h1,h2,h3,h4{font-weight:600;letter-spacing:-.02em;line-height:1.2}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}::-moz-selection{background:var(--accent-cyan-dim);color:var(--accent-cyan)}::selection{background:var(--accent-cyan-dim);color:var(--accent-cyan)}@keyframes headerLangIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes heroBlink{0%,to{opacity:1}50%{opacity:.25}}@keyframes heroPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}body:after{animation:gridFloat 12s linear infinite!important}}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-px:hover{--tw-translate-y: -1px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-accent:hover{border-color:var(--accent-cyan)}.hover\:border-border-accent:hover{border-color:var(--border-accent)}.hover\:bg-tertiary:hover{background-color:var(--bg-tertiary)}.hover\:text-accent:hover{color:var(--accent-cyan)}.hover\:text-text-primary:hover{color:var(--text-primary)}.hover\:shadow-\[0_4px_20px_rgba\(6\,182\,212\,0\.4\)\]:hover{--tw-shadow: 0 4px 20px rgba(6,182,212,.4);--tw-shadow-colored: 0 4px 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-glow:hover{--tw-shadow: var(--shadow-glow);--tw-shadow-colored: var(--shadow-glow);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.group:hover .group-hover\:bg-accent-dim{background-color:var(--accent-cyan-dim)}@media not all and (min-width:768px){.max-md\:pointer-events-none{pointer-events:none}.max-md\:\!pointer-events-auto{pointer-events:auto!important}.max-md\:\!visible{visibility:visible!important}.max-md\:invisible{visibility:hidden}.max-md\:fixed{position:fixed}.max-md\:left-0{left:0}.max-md\:right-0{right:0}.max-md\:top-\[57px\]{top:57px}.max-md\:z-\[110\]{z-index:110}.max-md\:order-first{order:-9999}.max-md\:mx-auto{margin-left:auto;margin-right:auto}.max-md\:flex{display:flex}.max-md\:min-h-0{min-height:0px}.max-md\:w-full{width:100%}.max-md\:min-w-0{min-width:0px}.max-md\:\!translate-y-0{--tw-translate-y: 0px !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.max-md\:-translate-y-full{--tw-translate-y: -100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.max-md\:flex-col{flex-direction:column}.max-md\:justify-center{justify-content:center}.max-md\:border-b{border-bottom-width:1px}.max-md\:border-border{border-color:var(--border-subtle)}.max-md\:bg-\[color-mix\(in_srgb\,var\(--bg-primary\)_98\%\,transparent\)\]{background-color:color-mix(in srgb,var(--bg-primary) 98%,transparent)}.max-md\:px-8{padding-left:2rem;padding-right:2rem}.max-md\:py-8{padding-top:2rem;padding-bottom:2rem}.max-md\:pt-12{padding-top:3rem}.max-md\:text-center{text-align:center}.max-md\:\!opacity-100{opacity:1!important}.max-md\:opacity-0{opacity:0}.max-md\:backdrop-blur-\[20px\]{--tw-backdrop-blur: blur(20px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.max-md\:transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.max-md\:duration-200{transition-duration:.2s}}@media(min-width:768px){.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:px-8{padding-left:2rem;padding-right:2rem}}.\[\&_svg\]\:block svg{display:block}.\[\&_svg\]\:h-5 svg{height:1.25rem}.\[\&_svg\]\:h-\[18px\] svg{height:18px}.\[\&_svg\]\:w-5 svg{width:1.25rem}.\[\&_svg\]\:w-\[18px\] svg{width:18px}.tech-card{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm)}.tech-card:hover{border-color:var(--border-accent);background:var(--bg-card-hover);box-shadow:var(--shadow-md)}.tech-card--active{border-color:var(--accent-cyan);background:var(--accent-cyan-dim);box-shadow:0 0 0 1px var(--accent-cyan)}.tech-card__select{flex:1;display:flex;align-items:center;gap:var(--space-lg);background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;padding:0}.tech-card__badge{--tech-bg: var(--tech-color, #06b6d4);width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:color-mix(in srgb,var(--tech-bg) 35%,var(--bg-tertiary));border:none;border-radius:var(--radius-lg);transition:background var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);box-shadow:0 1px 4px color-mix(in srgb,var(--tech-bg) 40%,transparent)}.tech-card__badge--logo{width:64px;height:64px;background:var(--bg-primary, #fff);box-shadow:0 2px 12px #00000014,0 0 0 1px #0000000a}[data-theme=dark] .tech-card__badge--logo,.dark .tech-card__badge--logo{background:var(--bg-secondary, #1e293b);box-shadow:0 2px 12px #00000040,0 0 0 1px #ffffff0f}.tech-card:hover .tech-card__badge{background:color-mix(in srgb,var(--tech-bg) 45%,var(--bg-tertiary));box-shadow:0 2px 8px color-mix(in srgb,var(--tech-bg) 45%,transparent)}.tech-card:hover .tech-card__badge--logo{background:var(--bg-primary, #fff);box-shadow:0 4px 20px #0000001a,0 0 0 1px #0000000f;transform:scale(1.03)}[data-theme=dark] .tech-card:hover .tech-card__badge--logo,.dark .tech-card:hover .tech-card__badge--logo{background:var(--bg-secondary, #1e293b);box-shadow:0 4px 20px #00000059,0 0 0 1px #ffffff14}.tech-card--active .tech-card__badge{background:color-mix(in srgb,var(--tech-bg) 40%,var(--bg-tertiary));box-shadow:0 0 0 2px color-mix(in srgb,var(--tech-bg) 60%,transparent)}.tech-card--active .tech-card__badge--logo{background:var(--bg-primary, #fff);box-shadow:0 0 0 2px var(--accent-cyan),0 2px 12px #00000014}[data-theme=dark] .tech-card--active .tech-card__badge--logo,.dark .tech-card--active .tech-card__badge--logo{background:var(--bg-secondary, #1e293b);box-shadow:0 0 0 2px var(--accent-cyan),0 2px 12px #00000040}.tech-card__badge-label{font-size:1.125rem;font-weight:700;color:var(--tech-color, #06b6d4);line-height:1;-webkit-user-select:none;-moz-user-select:none;user-select:none;letter-spacing:-.02em}.tech-card__logo{width:40px;height:40px;-o-object-fit:contain;object-fit:contain;display:block;transition:transform var(--duration-fast) var(--ease-out)}.tech-card:hover .tech-card__logo{transform:scale(1.08)}.tech-card__content{flex:1;min-width:0}.tech-card__name{font-size:1.125rem;font-weight:600;margin:0 0 var(--space-xs) 0;color:var(--text-primary)}.tech-card__desc{font-size:.875rem;color:var(--text-muted);margin:0 0 var(--space-sm) 0}.tech-card__count{font-size:.8125rem;color:var(--accent-cyan);font-weight:500}.tech-card__arrow{flex-shrink:0;color:var(--text-muted);transition:transform var(--duration-fast) var(--ease-out)}.tech-card:hover .tech-card__arrow{color:var(--accent-cyan);transform:translate(4px)}.tech-card__start{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border:none;border-radius:var(--radius-md);color:#fff;font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;flex-shrink:0;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.tech-card__start:hover{transform:translateY(-2px);box-shadow:0 4px 20px #06b6d459}.tech-card__start:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}@media(max-width:640px){.tech-card{flex-direction:column;align-items:stretch;gap:var(--space-md)}.tech-card__select{flex-wrap:wrap}.tech-card__badge,.tech-card__start{width:100%;justify-content:center}}.practice{max-width:720px;margin:0 auto;padding:var(--space-xl);min-height:80vh;display:flex;flex-direction:column;animation:practiceFadeIn .4s var(--ease-out)}@keyframes practiceFadeIn{0%{opacity:0}to{opacity:1}}.practice__top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.practice__back{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9375rem;font-family:inherit;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.practice__back:hover{border-color:var(--accent-cyan);color:var(--accent-cyan)}.practice__back:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.practice__meta{display:flex;align-items:center;gap:var(--space-md)}.practice__tech{font-size:.875rem;font-weight:600;color:var(--accent-cyan)}.practice__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-2xl) var(--space-lg);min-height:320px}.practice__empty-icon{color:var(--text-muted);opacity:.6;margin-bottom:var(--space-lg)}.practice__empty-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 var(--space-sm) 0}.practice__empty-desc{font-size:.9375rem;color:var(--text-secondary);line-height:1.5;max-width:360px;margin:0 0 var(--space-xl) 0}.practice__empty-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:.9375rem;font-weight:600;font-family:inherit;color:#fff;background:var(--accent-cyan);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.practice__empty-btn:hover{background:var(--accent-blue)}.practice__counter{font-family:var(--font-mono);font-size:.875rem;color:var(--text-muted)}.practice__progress-wrap{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl)}.practice__progress-track{flex:1;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.practice__progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-blue));border-radius:var(--radius-full);transition:width var(--duration-normal) var(--ease-out)}.practice__progress-text{font-family:var(--font-mono);font-size:.8125rem;font-weight:500;color:var(--text-muted);flex-shrink:0}.practice__content{flex:1}.practice__card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-lg);transition:border-color var(--duration-fast) var(--ease-out)}.practice__card:hover{border-color:var(--border-accent)}.practice__question-card{padding:var(--space-xl) var(--space-2xl)}.practice__editor-card{padding:var(--space-xl)}.practice__difficulty{display:inline-block;font-size:.75rem;font-weight:600;padding:var(--space-xs) var(--space-sm);background:color-mix(in srgb,var(--diff-color) 18%,transparent);color:var(--diff-color);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.practice__question{font-size:1.375rem;font-weight:600;line-height:1.4;letter-spacing:-.02em;color:var(--text-primary)}.practice__ask-ai-wrap{position:relative;margin-top:var(--space-lg)}.practice__ask-ai-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.875rem;font-weight:500;font-family:inherit;color:var(--accent-cyan);background:#06b6d41a;border:1px solid rgba(6,182,212,.35);border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.practice__ask-ai-btn:hover{background:#06b6d42e;border-color:var(--accent-cyan);color:var(--accent-cyan)}.practice__ask-ai-btn:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.practice__ask-ai-btn[aria-expanded=true]{background:#06b6d42e;border-color:var(--accent-cyan)}.practice__ask-ai-chevron{transition:transform var(--duration-fast) var(--ease-out)}.practice__ask-ai-btn[aria-expanded=true] .practice__ask-ai-chevron{transform:rotate(180deg)}.practice__ask-ai-dropdown{position:absolute;top:calc(100% + var(--space-xs));left:0;min-width:180px;padding:var(--space-xs);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;animation:practiceDropdownIn .2s var(--ease-out)}@keyframes practiceDropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.practice__ask-ai-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-sm) var(--space-md);font-size:.9375rem;font-family:inherit;text-align:left;color:var(--text-primary);background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.practice__ask-ai-logo{width:24px;height:24px;-o-object-fit:contain;object-fit:contain;flex-shrink:0;border-radius:var(--radius-sm)}.practice__ask-ai-item:hover{background:var(--accent-cyan-dim);color:var(--accent-cyan)}.practice__ask-ai-item:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:-2px}.practice__ask-ai-toast{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--accent-cyan-dim);border:1px solid rgba(6,182,212,.35);border-radius:var(--radius-md);color:var(--accent-cyan);font-size:.9375rem;margin-bottom:var(--space-xl)}.practice__ask-ai-toast svg{flex-shrink:0}.practice__ask-ai-toast--success{display:flex;align-items:center;gap:var(--space-md)}.practice__rate-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border-subtle)}.practice__rate-label{font-size:.8125rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.practice__rate-stars{display:flex;gap:var(--space-xs);align-items:center}.practice__rate-star{padding:var(--space-xs);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.practice__rate-star:hover{color:#eab308;transform:scale(1.15)}.practice__rate-star--active{color:#eab308}.practice__rate-star:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.practice__rate-done{font-size:.8125rem;color:var(--text-muted);margin-left:auto}.practice__label{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.practice__label span:first-child{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.practice__label-hint{font-size:.8125rem;color:var(--text-muted);font-weight:400}.practice__editor{width:100%;padding:var(--space-lg);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-mono);font-size:.9375rem;line-height:1.7;resize:vertical;min-height:160px;transition:border-color var(--duration-fast) var(--ease-out)}.practice__editor::-moz-placeholder{color:var(--text-muted)}.practice__editor::placeholder{color:var(--text-muted)}.practice__editor:hover{border-color:#94a3b833}.practice__editor:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 3px var(--accent-cyan-dim)}.practice__actions{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-bottom:var(--space-xl)}.practice__submit-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border:none;border-radius:var(--radius-md);color:#fff;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.practice__submit-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 20px #06b6d466}.practice__submit-btn:disabled{opacity:.8;cursor:wait}.practice__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:practiceSpin .8s linear infinite}@keyframes practiceSpin{to{transform:rotate(360deg)}}.practice__spinner--sm{width:16px;height:16px;border-width:2px}.practice__complete-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--accent-cyan);border:none;border-radius:var(--radius-md);color:var(--bg-primary);font-size:.9375rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.practice__complete-btn:hover:not(:disabled){filter:brightness(1.1)}.practice__complete-btn:disabled{opacity:.8;cursor:wait}.practice__complete-btn:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.practice__reveal-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.practice__reveal-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--accent-cyan);color:var(--accent-cyan)}.practice__reveal-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:default}.practice__reveal-btn:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.practice__coming-soon{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-xl) var(--space-2xl);background:linear-gradient(135deg,#06b6d41f,#0ea5e914);border:1px solid rgba(6,182,212,.4);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);box-shadow:0 4px 20px #06b6d426;animation:practiceComingSoonIn .35s var(--ease-out)}@keyframes practiceComingSoonIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.practice__coming-soon-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#06b6d433;border-radius:var(--radius-md);color:var(--accent-cyan)}.practice__coming-soon-content{flex:1;min-width:0}.practice__coming-soon-title{display:block;font-size:1.0625rem;font-weight:600;color:var(--accent-cyan);margin:0 0 var(--space-xs) 0;line-height:1.3}.practice__coming-soon-desc{font-size:.9375rem;color:var(--text-secondary);margin:0;line-height:1.5}.practice__error{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#fca5a5;font-size:.9375rem;margin-bottom:var(--space-xl)}.practice__error svg{flex-shrink:0}.practice__ai-block{padding:var(--space-xl);background:#06b6d414;border:1px solid rgba(6,182,212,.25);border-radius:var(--radius-md);margin-bottom:var(--space-xl);animation:practiceSlideIn .3s var(--ease-out)}.practice__ai-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.practice__ai-score{font-family:var(--font-mono);font-size:1.5rem;font-weight:700;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:var(--bg-tertiary)}.practice__ai-score[data-score^="8"],.practice__ai-score[data-score^="9"],.practice__ai-score[data-score="100"]{color:var(--accent-cyan)}.practice__ai-score[data-score^="6"],.practice__ai-score[data-score^="7"]{color:#eab308}.practice__ai-score[data-score^="0"],.practice__ai-score[data-score^="1"],.practice__ai-score[data-score^="2"],.practice__ai-score[data-score^="3"],.practice__ai-score[data-score^="4"],.practice__ai-score[data-score^="5"]{color:#ef4444}.practice__ai-label{font-size:.875rem;font-weight:600;color:var(--accent-cyan)}.practice__ai-feedback{font-size:1rem;line-height:1.75;color:var(--text-secondary);margin:0;white-space:pre-wrap}.practice__answer-block{padding:var(--space-xl);background:#06b6d414;border:1px solid rgba(6,182,212,.25);border-radius:var(--radius-md);animation:practiceSlideIn .3s var(--ease-out)}@keyframes practiceSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.practice__answer-header{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem;font-weight:600;color:var(--accent-cyan);margin-bottom:var(--space-md)}.practice__answer-text{font-size:1rem;line-height:1.75;color:var(--text-secondary);margin:0}.practice__nav{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding-top:var(--space-2xl);margin-top:auto;border-top:1px solid var(--border-subtle)}.practice__nav-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9375rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.practice__nav-btn:hover:not(:disabled){border-color:var(--accent-cyan);color:var(--accent-cyan)}.practice__nav-btn:disabled{opacity:.4;cursor:not-allowed}.practice__nav-btn:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.practice__nav-dots{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center}.practice__nav-dot{width:10px;height:10px;border-radius:50%;background:var(--bg-tertiary);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.practice__nav-dot:hover{background:var(--text-muted)}.practice__nav-dot--active{background:var(--accent-cyan);border-color:var(--accent-cyan);transform:scale(1.2)}@media(max-width:640px){.practice{padding:var(--space-lg)}.practice__question{font-size:1.2rem}.practice__rate-wrap{flex-direction:column;align-items:flex-start}.practice__rate-done{margin-left:0}.practice__nav{flex-wrap:wrap}.practice__nav-dots{order:3;width:100%;padding-top:var(--space-md)}}.profile{max-width:480px;margin:0 auto;padding:var(--space-2xl) var(--space-xl)}.profile__card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;position:relative;transition:border-color var(--duration-fast) var(--ease-out)}.profile__card:hover{border-color:var(--border-accent)}.profile__cover{height:100px;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));opacity:.9}.profile__avatar-wrap{position:relative;margin-top:-48px;padding:0 var(--space-xl)}.profile__avatar{width:96px;height:96px;border-radius:50%;border:4px solid var(--bg-secondary);-o-object-fit:cover;object-fit:cover}.profile__avatar-placeholder{width:96px;height:96px;border-radius:50%;border:4px solid var(--bg-secondary);background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:700;color:#fff}.profile__info{padding:var(--space-xl);padding-top:var(--space-md)}.profile__name{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-xs);color:var(--text-primary)}.profile__email{font-size:.9375rem;color:var(--text-muted)}.profile__stats{display:flex;align-items:center;justify-content:center;gap:var(--space-xl);padding:var(--space-xl);border-top:1px solid var(--border-subtle)}.profile__stat{display:flex;flex-direction:column;align-items:center}.profile__stat-num{font-size:1.5rem;font-weight:700;color:var(--accent-cyan);font-family:var(--font-mono)}.profile__stat-label{font-size:.8125rem;color:var(--text-muted)}.profile__stat-divider{width:1px;height:32px;background:var(--border-subtle)}.profile__signout{flex:1;margin:0 var(--space-xl) var(--space-xl);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9375rem;font-family:inherit;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.profile__signout:hover{border-color:#ef444480;color:#f87171}.auth-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-xl);animation:authFadeIn .2s var(--ease-out)}@keyframes authFadeIn{0%{opacity:0}to{opacity:1}}.auth-modal{position:relative;width:100%;max-width:420px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-2xl);box-shadow:var(--shadow-lg);animation:authSlideUp .3s var(--ease-out)}@keyframes authSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-modal__close{position:absolute;top:var(--space-lg);right:var(--space-lg);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.auth-modal__close:hover{color:var(--text-primary);border-color:var(--border-accent)}.auth-modal__content{text-align:center}.auth-modal__icon{width:64px;height:64px;margin:0 auto var(--space-xl);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-blue));border-radius:var(--radius-lg);font-size:1.75rem;color:#fff}.auth-modal__title{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-sm);color:var(--text-primary)}.auth-modal__desc{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-xl)}.auth-modal__google{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-md) var(--space-xl);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.auth-modal__google-logo{display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-modal__google-logo svg{display:block;width:24px;height:24px}.auth-modal__google-text{white-space:nowrap}.auth-modal__google:hover:not(:disabled){border-color:var(--border-accent);background:var(--bg-card-hover)}.auth-modal__google:disabled{opacity:.7;cursor:wait}.auth-modal__spinner{width:20px;height:20px;border:2px solid var(--border-subtle);border-top-color:var(--accent-cyan);border-radius:50%;animation:authSpin .8s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.auth-modal__notice{padding:var(--space-md);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#fca5a5;font-size:.875rem;margin-bottom:var(--space-md)}.auth-modal__footer{margin-top:var(--space-xl);font-size:.8125rem;color:var(--text-muted)}.start-modal-overlay{position:fixed;inset:0;background:#00000080;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:24px;animation:smo .2s ease-out}@keyframes smo{0%{opacity:0}to{opacity:1}}.start-modal{position:relative;width:100%;max-width:440px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:14px;box-shadow:0 20px 56px -16px #00000040;animation:smi .25s ease-out both}@keyframes smi{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.start-modal__head{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 0;gap:16px}.start-modal__title{font-size:1.375rem;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.02em}.start-modal__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;margin:-8px -8px 0 0;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.start-modal__close:hover{color:var(--text-primary);border-color:var(--border-accent);background:var(--bg-card-hover)}.start-modal__form{padding:20px 24px 24px}.start-modal__desc{font-size:.9375rem;color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.start-modal__row{margin-bottom:18px}.start-modal__row:last-of-type{margin-bottom:22px}.start-modal__label{display:block;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.start-modal__opts{display:flex;gap:8px;flex-wrap:wrap}.start-modal__opt{padding:10px 18px;font-size:.9375rem;font-weight:500;font-family:inherit;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:10px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.start-modal__opt:hover{color:var(--text-primary);border-color:var(--border-accent)}.start-modal__opt--on{color:#fff;background:var(--accent-cyan);border-color:var(--accent-cyan)}.start-modal__tech-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.start-modal__tech-toggle{margin-top:8px;padding:8px 0;font-size:.875rem;font-weight:500;font-family:inherit;color:var(--accent-cyan);background:none;border:none;cursor:pointer;transition:color .15s}.start-modal__tech-toggle:hover{color:var(--accent-blue)}.start-modal__tech{display:flex;align-items:center;gap:12px;padding:12px 14px;font-size:.9375rem;font-weight:500;font-family:inherit;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid transparent;border-radius:10px;cursor:pointer;transition:border-color .15s,color .15s,background .15s;text-align:left}.start-modal__tech:hover{color:var(--text-primary);border-color:var(--border-subtle)}.start-modal__tech--on{color:var(--text-primary);background:color-mix(in srgb,var(--t, var(--accent-cyan)) 10%,var(--bg-tertiary));border-color:color-mix(in srgb,var(--t, var(--accent-cyan)) 35%,transparent)}.start-modal__tech-dot{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;color:var(--t, var(--accent-cyan));background:color-mix(in srgb,var(--t, var(--accent-cyan)) 18%,var(--bg-tertiary));border-radius:8px}.start-modal__tech--on .start-modal__tech-dot{background:var(--t, var(--accent-cyan));color:#fff}.start-modal__tech-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.start-modal__empty{font-size:.9375rem;color:var(--text-muted);padding:14px 0;margin:0;grid-column:1 / -1}.start-modal__err{font-size:.875rem;color:var(--accent-red, #dc2626);padding:10px 14px;margin-bottom:14px;background:color-mix(in srgb,var(--accent-red, #dc2626) 8%,transparent);border-radius:8px}.start-modal__btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 20px;font-size:1rem;font-weight:600;font-family:inherit;color:#fff;background:var(--accent-cyan);border:none;border-radius:10px;cursor:pointer;transition:background .15s,opacity .15s}.start-modal__btn:hover:not(:disabled){background:var(--accent-blue)}.start-modal__btn:disabled{opacity:.7;cursor:not-allowed}.start-modal__spin{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:smspin .6s linear infinite}@keyframes smspin{to{transform:rotate(360deg)}}@media(max-width:480px){.start-modal-overlay{padding:16px}.start-modal__head{padding:20px 20px 0}.start-modal__form{padding:16px 20px 20px}.start-modal__title{font-size:1.25rem}}@media(max-width:360px){.start-modal__tech-grid{grid-template-columns:1fr}}
