/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-duration:initial;--tw-space-x-reverse:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-black:#000;--spacing:.25rem;--container-lg:32rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--font-weight-medium:500;--font-weight-semibold:600;--tracking-tight:-.025em;--leading-relaxed:1.625;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.right-4{right:calc(var(--spacing) * 4)}.left-\[50\%\]{left:50%}.z-50{z-index:50}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.h-2{height:calc(var(--spacing) * 2)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.min-h-0{min-height:calc(var(--spacing) * 0)}.min-h-dvh{min-height:100dvh}.w-2{width:calc(var(--spacing) * 2)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-7{width:calc(var(--spacing) * 7)}.w-9{width:calc(var(--spacing) * 9)}.w-full{width:100%}.max-w-lg{max-width:var(--container-lg)}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.gap-8{gap:calc(var(--spacing) * 8)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:calc(var(--radius) + 2px)}.rounded-md{border-radius:var(--radius)}.rounded-sm{border-radius:calc(var(--radius) - 2px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-border,.border-border\/60{border-color:var(--line-soft)}@supports (color:color-mix(in lab,red,red)){.border-border\/60{border-color:color-mix(in oklab,var(--line-soft) 60%,transparent)}}.border-destructive\/50{border-color:#e8585480}.border-input{border-color:var(--bg-elev)}.bg-background{background-color:var(--bg)}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black) 80%,transparent)}}.bg-card,.bg-card\/30{background-color:var(--bg-card)}@supports (color:color-mix(in lab,red,red)){.bg-card\/30{background-color:color-mix(in oklab,var(--bg-card) 30%,transparent)}}.bg-card\/50{background-color:var(--bg-card)}@supports (color:color-mix(in lab,red,red)){.bg-card\/50{background-color:color-mix(in oklab,var(--bg-card) 50%,transparent)}}.bg-destructive{background-color:#e85854}.bg-destructive\/10{background-color:#e858541a}.bg-muted-foreground{background-color:var(--ink-dim)}.bg-muted\/30{background-color:var(--bg-elev)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/30{background-color:color-mix(in oklab,var(--bg-elev) 30%,transparent)}}.bg-muted\/60{background-color:var(--bg-elev)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/60{background-color:color-mix(in oklab,var(--bg-elev) 60%,transparent)}}.bg-primary{background-color:var(--accent)}.bg-secondary{background-color:var(--bg-elev)}.bg-transparent{background-color:#0000}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.text-center{text-align:center}.text-left{text-align:left}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.whitespace-nowrap{white-space:nowrap}.text-destructive{color:#e85854}.text-foreground{color:var(--ink)}.text-muted-foreground{color:var(--ink-dim)}.text-primary{color:var(--accent)}.text-primary-foreground{color:var(--bg)}.text-secondary-foreground{color:var(--ink)}.uppercase{text-transform:uppercase}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--bg)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s;animation-duration:.2s}.fade-in{--tw-enter-opacity:0}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--ink)}.placeholder\:text-muted-foreground::placeholder{color:var(--ink-dim)}@media(hover:hover){.hover\:bg-destructive\/90:hover{background-color:#e85854e6}.hover\:bg-primary\/90:hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--accent) 90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--bg-elev)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--bg-elev) 80%,transparent)}}.hover\:text-foreground:hover{color:var(--ink)}.hover\:text-primary:hover{color:var(--accent)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--accent)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-1:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--accent)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.data-\[state\=closed\]\:animate-out[data-state=closed]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-name:exit;animation-duration:.15s}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--ink-dim)}.data-\[state\=open\]\:animate-in[data-state=open]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-name:enter;animation-duration:.15s}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}@media(min-width:40rem){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}:where(.sm\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:calc(var(--radius) + 2px)}.sm\:p-6{padding:calc(var(--spacing) * 6)}.sm\:text-left{text-align:left}}@media(min-width:48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}@media(min-width:64rem){.lg\:flex{display:flex}.lg\:grid{display:grid}.lg\:hidden{display:none}.lg\:grid-cols-\[minmax\(200px\,280px\)_1fr\]{grid-template-columns:minmax(200px,280px) 1fr}.lg\:grid-cols-\[minmax\(200px\,280px\)_1fr_minmax\(200px\,280px\)\]{grid-template-columns:minmax(200px,280px) 1fr minmax(200px,280px)}.lg\:grid-rows-1{grid-template-rows:repeat(1,minmax(0,1fr))}.lg\:p-8{padding:calc(var(--spacing) * 8)}}@media(prefers-color-scheme:dark){.dark\:border-destructive{border-color:#e85854}}.\[\&_p\]\:leading-relaxed p{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\]\:max-w-full svg{max-width:100%}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:top-4>svg{top:calc(var(--spacing) * 4)}.\[\&\>svg\]\:left-4>svg{left:calc(var(--spacing) * 4)}.\[\&\>svg\]\:text-destructive>svg{color:#e85854}.\[\&\>svg\]\:text-foreground>svg{color:var(--ink)}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y:-3px;translate:var(--tw-translate-x) var(--tw-translate-y)}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:calc(var(--spacing) * 7)}}:root{--bg:oklch(18% .008 60);--bg-elev:oklch(22% .008 60);--bg-card:oklch(24% .01 60);--line:oklch(32% .01 60);--line-soft:oklch(28% .008 60);--ink:oklch(94% .012 80);--ink-dim:oklch(72% .01 70);--ink-faint:oklch(52% .01 70);--accent:oklch(72% .13 45);--accent-dim:oklch(55% .1 45);--board-light:oklch(78% .025 70);--board-dark:oklch(42% .02 50);--highlight:oklch(78% .13 95/.35);--serif:"DM Serif Display", "Cormorant Garamond", Georgia, serif;--sans:"Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--mono:"JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--background:var(--bg);--foreground:var(--ink);--card:var(--bg-card);--card-foreground:var(--ink);--border:var(--line-soft);--input:var(--bg-elev);--primary:var(--accent);--primary-foreground:var(--bg);--secondary:var(--bg-elev);--secondary-foreground:var(--ink);--muted:var(--bg-elev);--muted-foreground:var(--ink-dim);--destructive:oklch(65% .18 25);--ring:var(--accent);--radius:.25rem}*{box-sizing:border-box}html{font-family:var(--sans);height:100%;font-size:15px;line-height:1.5}body{background:var(--bg);height:100%;color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;overflow-x:hidden}#root{flex-direction:column;height:100%;display:flex}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0}button:focus-visible{outline:1px solid var(--accent);outline-offset:2px}a{color:inherit;text-decoration:none}.grain{position:relative}.grain:after{content:"";pointer-events:none;opacity:.06;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");background-size:240px 240px;position:absolute;top:0;right:0;bottom:0;left:0}.app{flex-direction:column;height:100%;display:flex}.topbar{border-bottom:1px solid var(--line-soft);flex-shrink:0;justify-content:space-between;align-items:baseline;padding:22px 32px;display:flex}.brand{font-family:var(--serif);letter-spacing:-.01em;font-size:26px;font-weight:400}.brand .dot{color:var(--accent)}.topbar nav{gap:4px;display:flex}.tab{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);border-radius:999px;padding:8px 14px;font-size:11px;transition:color .15s,background .15s;display:inline-block}.tab:hover{color:var(--ink-dim)}.tab.active{color:var(--ink);background:var(--bg-elev)}.section-label{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);align-items:center;gap:12px;margin:0 0 14px;font-size:10px;display:flex}.section-label:after{content:"";background:var(--line-soft);flex:1;height:1px}.lobby{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:48px 32px 80px;overflow-y:auto}.lobby-hero{grid-template-columns:1.2fr 1fr;align-items:end;gap:64px;margin-bottom:72px;display:grid}.lobby-hero h1{font-family:var(--serif);letter-spacing:-.02em;margin:0;font-size:clamp(48px,7vw,96px);font-weight:400;line-height:.95}.lobby-hero h1 em{color:var(--accent);font-style:italic}.lobby-hero .lede{color:var(--ink-dim);border-left:1px solid var(--line);max-width:36ch;padding-left:20px;font-size:15px}.lobby-grid{grid-template-columns:1.4fr 1fr;gap:48px;display:grid}.time-grid{background:var(--line-soft);border:1px solid var(--line-soft);grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.time-cell{background:var(--bg);text-align:left;flex-direction:column;gap:6px;padding:18px 16px;transition:background .15s;display:flex;position:relative}.time-cell:hover,.time-cell.active{background:var(--bg-elev)}.time-cell.active:before{content:"";background:var(--accent);width:2px;position:absolute;top:0;bottom:0;left:0}.time-cell .cat{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-size:10px}.time-cell .val{font-family:var(--serif);letter-spacing:-.01em;font-size:28px}.time-cell .sub{color:var(--ink-dim);font-size:12px}.side-row{background:var(--line-soft);border:1px solid var(--line-soft);grid-template-columns:1fr 1fr 1fr;gap:1px;display:grid}.side-cell{background:var(--bg);flex-direction:column;align-items:center;gap:10px;padding:22px 16px;transition:background .15s;display:flex}.side-cell:hover,.side-cell.active{background:var(--bg-elev)}.side-cell.active .swatch{box-shadow:0 0 0 2px var(--accent)}.swatch{width:44px;height:44px;font-family:var(--serif);border:1px solid var(--line);border-radius:999px;place-items:center;font-size:22px;transition:box-shadow .2s;display:grid}.swatch.white{background:var(--ink);color:#1a1a1a}.swatch.black{color:var(--ink);background:#111}.swatch.random{background:linear-gradient(135deg,var(--ink) 0% 50%,#111 50% 100%);color:var(--accent)}.side-cell .label{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);font-size:10px}.cta-row{align-items:center;gap:18px;margin-top:32px;display:flex}.btn-primary{background:var(--ink);color:#1a1a1a;font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;cursor:pointer;border:none;align-items:center;gap:12px;padding:16px 28px;font-size:12px;transition:transform .2s,background .15s;display:inline-flex}.btn-primary:hover{background:var(--accent);transform:translateY(-1px)}.btn-primary .arrow{font-family:var(--serif);font-size:18px}.btn-ghost{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);cursor:pointer;background:0 0;border:none;padding:14px 4px;font-size:11px}.btn-ghost:hover{color:var(--ink)}.opponent{background:var(--bg-elev);border:1px solid var(--line-soft);padding:26px;position:relative;overflow:hidden}.opponent .opp-name{font-family:var(--serif);letter-spacing:-.01em;margin:8px 0 4px;font-size:36px}.opponent .opp-rating{font-family:var(--mono);letter-spacing:.14em;color:var(--ink-faint);text-transform:uppercase;font-size:11px}.opponent .opp-bio{color:var(--ink-dim);border-top:1px solid var(--line-soft);margin-top:18px;padding-top:16px;font-size:13px}.opp-portrait{opacity:.18;width:110px;height:110px;color:var(--accent);position:absolute;top:-10px;right:-18px}.game{flex:1;grid-template-columns:minmax(0,1fr) 300px;gap:32px;width:100%;max-width:1300px;min-height:0;margin:0 auto;padding:28px 32px 40px;display:grid}.board-wrap{flex-direction:column;gap:10px;min-height:0;display:flex}.player-strip{justify-content:space-between;align-items:center;gap:12px;padding:6px 0;display:flex}.player-strip .who{align-items:center;gap:12px;display:flex}.who .avatar{background:var(--bg-elev);border:1px solid var(--line-soft);width:36px;height:36px;font-family:var(--serif);color:var(--accent);flex-shrink:0;place-items:center;font-size:18px;display:grid}.who .meta .name{font-family:var(--serif);letter-spacing:-.005em;font-size:17px}.who .meta .sub{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-size:10px}.captures{flex-wrap:wrap;flex:1;justify-content:center;align-items:center;gap:1px;min-height:16px;display:flex}.cap-piece{place-items:center;width:16px;height:16px;display:inline-grid}.cap-piece img{object-fit:contain;width:100%;height:100%}.material-diff{font-family:var(--mono);color:var(--ink-faint);margin-left:4px;font-size:11px}.clock{font-family:var(--serif);letter-spacing:.04em;background:var(--bg-elev);border:1px solid var(--line-soft);font-variant-numeric:tabular-nums;text-align:center;flex-shrink:0;min-width:100px;padding:8px 16px;font-size:28px;transition:background .2s,color .2s,border-color .2s}.clock.active{background:var(--ink);color:#1a1a1a;border-color:var(--ink)}.clock.low{color:var(--accent)}.clock.active.low{color:var(--accent);background:var(--ink)}.board-frame{background:var(--bg-elev);border:1px solid var(--line-soft);flex-direction:column;flex:1;min-height:0;padding:12px;display:flex;position:relative}.board{aspect-ratio:1;-webkit-user-select:none;user-select:none;border:1px solid var(--line);grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);align-self:center;width:100%;max-height:100%;display:grid;position:relative}.square{cursor:pointer;border:none;place-items:center;padding:0;display:grid;position:relative}.square.light{background:var(--board-light)}.square.dark{background:var(--board-dark)}.square:before{content:"";pointer-events:none;opacity:.18;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.5 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");background-size:80px 80px;position:absolute;top:0;right:0;bottom:0;left:0}.square.last-from{background:var(--board-light)}@supports (color:color-mix(in lab,red,red)){.square.last-from{background:color-mix(in oklab,var(--board-light),var(--highlight) 60%)}}.square.dark.last-from{background:var(--board-dark)}@supports (color:color-mix(in lab,red,red)){.square.dark.last-from{background:color-mix(in oklab,var(--board-dark),var(--highlight) 50%)}}.square.last-to{background:var(--board-light)}@supports (color:color-mix(in lab,red,red)){.square.last-to{background:color-mix(in oklab,var(--board-light),var(--highlight) 80%)}}.square.dark.last-to{background:var(--board-dark)}@supports (color:color-mix(in lab,red,red)){.square.dark.last-to{background:color-mix(in oklab,var(--board-dark),var(--highlight) 70%)}}.square.selected{background:var(--board-light)}@supports (color:color-mix(in lab,red,red)){.square.selected{background:color-mix(in oklab,var(--board-light),var(--accent) 50%)}}.square.dark.selected{background:var(--board-dark)}@supports (color:color-mix(in lab,red,red)){.square.dark.selected{background:color-mix(in oklab,var(--board-dark),var(--accent) 45%)}}.square .move-dot{pointer-events:none;z-index:1;background:#1a151252;border-radius:50%;width:30%;height:30%;position:absolute}.square.has-piece .move-dot{background:0 0;border:3px solid oklch(20% .01 60/.32);border-radius:50%;width:88%;height:88%}.square .coord{font-family:var(--serif);color:#1a15128c;pointer-events:none;z-index:1;font-size:clamp(8px,1.2vw,11px);font-style:italic;line-height:1;position:absolute}.square.dark .coord{color:#eae3de8c}.square .coord.file{bottom:2px;right:3px}.square .coord.rank{top:2px;left:3px}body.hide-coords .square .coord{display:none}.piece{pointer-events:none;filter:drop-shadow(0 2px 1px #00000040);z-index:2;place-items:center;width:88%;height:88%;transition:transform .22s cubic-bezier(.2,.7,.2,1);display:grid;position:relative}.piece img{object-fit:contain;width:100%;height:100%;display:block}.square.selected .piece{transform:translateY(-2px)scale(1.04)}.rail{flex-direction:column;gap:16px;min-width:0;display:flex;overflow-y:auto}.card{background:var(--bg-card);border:1px solid var(--line-soft)}.card-head{border-bottom:1px solid var(--line-soft);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.card-head .title{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);font-size:10px}.card-body{padding:12px 16px}.move-list{font-family:var(--mono);grid-template-columns:24px 1fr 1fr;gap:3px 6px;max-height:260px;font-size:12px;display:grid;overflow-y:auto}.move-list .num{color:var(--ink-faint)}.move-list .mv{cursor:default;border-radius:2px;padding:2px 5px}.move-list .mv.current{background:var(--bg-elev);color:var(--accent)}.move-list .mv:hover{background:var(--bg-elev)}.move-list .empty{color:var(--ink-faint);grid-column:1/-1;padding:6px}.actions{background:var(--line-soft);border:1px solid var(--line-soft);grid-template-columns:1fr 1fr;gap:1px;display:grid}.actions button{background:var(--bg-card);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);cursor:pointer;border:none;padding:12px;font-size:11px;transition:background .15s,color .15s}.actions button:hover{background:var(--bg-elev);color:var(--ink)}.actions button.warn:hover{color:var(--accent)}.history{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:48px 32px 80px;overflow-y:auto}.history h2{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 32px;font-size:clamp(40px,5vw,60px);font-weight:400}.history-table{border-top:1px solid var(--line-soft)}.history-row{border-bottom:1px solid var(--line-soft);cursor:pointer;grid-template-columns:52px 1fr 110px 110px 90px 24px;align-items:center;gap:16px;padding:18px 4px;transition:background .15s;display:grid}.history-row:hover{background:var(--bg-elev)}.history-row .idx{font-family:var(--mono);color:var(--ink-faint);font-size:11px}.history-row .opp{font-family:var(--serif);letter-spacing:-.005em;font-size:22px}.history-row .opp .as{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;color:var(--ink-faint);margin-left:10px;font-size:10px}.history-row .when,.history-row .moves,.history-row .mode{font-family:var(--mono);color:var(--ink-dim);font-size:12px}.result-tag{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--line);padding:4px 10px;font-size:10px;display:inline-block}.result-tag.win{color:#80cd82;border-color:#3b723e}.result-tag.loss{color:var(--accent);border-color:var(--accent-dim)}.result-tag.draw{color:var(--ink-dim)}.history-row .chev{font-family:var(--serif);color:var(--ink-faint);font-size:22px}.about{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:48px 32px 80px;overflow-y:auto}.about-hero{grid-template-columns:1.3fr 1fr;align-items:start;gap:48px;margin-bottom:72px;display:grid}.about-hero h2{font-family:var(--serif);letter-spacing:-.02em;margin:8px 0 24px;font-size:clamp(40px,5.4vw,72px);font-weight:400;line-height:.98}.about-hero h2 em{color:var(--accent);font-style:italic}.about-lede{color:var(--ink-dim);max-width:50ch;font-size:16px;line-height:1.65}.profile-card{background:var(--bg-elev);border:1px solid var(--line-soft);padding:28px;position:relative;overflow:hidden}.profile-avatar{border:1px solid var(--line);background:var(--bg-card);width:64px;height:64px;font-family:var(--serif);color:var(--accent);place-items:center;margin-bottom:18px;font-size:32px;display:grid}.profile-name{font-family:var(--serif);letter-spacing:-.01em;margin-bottom:2px;font-size:28px}.profile-role{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:16px;font-size:10px}.profile-bio{color:var(--ink-dim);border-top:1px solid var(--line-soft);margin:0 0 20px;padding-top:16px;font-size:13px}.profile-links{background:var(--line-soft);border:1px solid var(--line-soft);flex-direction:column;gap:1px;margin:0;padding:0;list-style:none;display:flex}.profile-links li{display:contents}.profile-links a{background:var(--bg-elev);color:var(--ink);justify-content:space-between;align-items:center;padding:12px 14px;text-decoration:none;transition:background .15s,color .15s;display:flex}.profile-links a:hover{background:var(--bg-card);color:var(--accent)}.lk-key{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-size:10px}.lk-val{font-family:var(--mono);color:var(--ink-dim);font-size:12px}.profile-links a:hover .lk-val{color:var(--accent)}.about-block{margin-bottom:56px}.about-paragraph{color:var(--ink-dim);max-width:64ch;font-size:15px;line-height:1.7}.about-steps{background:var(--line-soft);border:1px solid var(--line-soft);grid-template-columns:repeat(2,1fr);gap:1px;display:grid}.step{background:var(--bg);flex-direction:column;gap:8px;padding:26px 24px 28px;display:flex}.step-num{font-family:var(--mono);letter-spacing:.18em;color:var(--accent);margin-bottom:4px;font-size:11px}.step h3{font-family:var(--serif);letter-spacing:-.01em;margin:0 0 4px;font-size:24px;font-weight:400}.step p{color:var(--ink-dim);margin:0;font-size:14px;line-height:1.65}.step em{color:var(--ink);font-style:italic}.credits{border-top:1px solid var(--line-soft);margin:0;padding:0;list-style:none}.credits li{border-bottom:1px solid var(--line-soft);grid-template-columns:120px 1fr;gap:24px;padding:14px 4px;display:grid}.cr-key{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);align-self:center;font-size:10px}.cr-val{font-family:var(--serif);color:var(--ink);font-size:18px}.about-foot{border-top:1px solid var(--line-soft);font-family:var(--mono);color:var(--ink-faint);letter-spacing:.12em;text-transform:uppercase;justify-content:space-between;padding-top:20px;font-size:11px;display:flex}.replay{flex:1;grid-template-columns:minmax(0,1fr) 300px;gap:32px;width:100%;max-width:1300px;min-height:0;margin:0 auto;padding:28px 32px 40px;display:grid}.replay-controls{border-top:1px solid var(--line-soft);justify-content:center;align-items:center;gap:6px;padding:10px;display:flex}.replay-controls button{width:38px;height:34px;font-family:var(--serif);color:var(--ink-dim);border:1px solid var(--line-soft);background:var(--bg-card);cursor:pointer;place-items:center;font-size:15px;display:grid}.replay-controls button:hover{color:var(--ink);border-color:var(--line)}.replay-controls .pos{font-family:var(--mono);color:var(--ink-faint);letter-spacing:.1em;margin:0 12px;font-size:11px}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#040302b3;place-items:center;display:grid;position:fixed;top:0;right:0;bottom:0;left:0}.modal{background:var(--bg-elev);border:1px solid var(--line);text-align:center;width:min(92vw,420px);padding:40px 36px}.modal h3{font-family:var(--serif);letter-spacing:-.02em;margin:0 0 4px;font-size:48px;font-weight:400}.modal h3 em{color:var(--accent);font-style:italic}.modal .reason{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:28px;font-size:11px}.modal .modal-actions{justify-content:center;gap:10px;display:flex}.modal .modal-actions button{border:1px solid var(--line);font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink);cursor:pointer;background:0 0;padding:12px 22px;font-size:11px}.modal .modal-actions button.primary{background:var(--ink);color:#1a1a1a;border-color:var(--ink)}.modal .modal-actions button:hover{background:var(--bg-card)}.modal .modal-actions button.primary:hover{background:var(--accent);border-color:var(--accent)}.promo-grid{background:var(--line-soft);border:1px solid var(--line-soft);grid-template-columns:repeat(4,1fr);gap:1px;margin-top:20px;display:grid}.promo-cell{background:var(--bg-card);cursor:pointer;border:none;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;transition:background .15s;display:flex}.promo-cell:hover{background:var(--bg-elev)}.promo-cell img{object-fit:contain;width:48px;height:48px}.promo-cell .piece-name{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim);font-size:10px}.error-toast{z-index:60;background:var(--bg-elev);border:1px solid var(--accent-dim);font-family:var(--mono);color:var(--ink);align-items:center;gap:16px;max-width:min(90vw,480px);padding:14px 20px;font-size:12px;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.error-toast .toast-msg{color:var(--ink-dim);flex:1}.error-toast .toast-btn{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint);cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:11px}.error-toast .toast-btn:hover{color:var(--ink)}.kbd{font-family:var(--mono);border:1px solid var(--line-soft);color:var(--ink-faint);letter-spacing:.04em;padding:2px 5px;font-size:10px}.fade-in{animation:.28s ease-out both fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}@media(max-width:980px){.game{grid-template-columns:1fr;gap:16px;padding:16px 16px 32px}.replay{grid-template-columns:1fr;padding:16px 16px 32px}.board-frame{flex:none}}@media(max-width:860px){.lobby-hero{grid-template-columns:1fr;gap:24px;margin-bottom:48px}.lobby-grid{grid-template-columns:1fr;gap:36px}.lobby{padding:32px 20px 80px}.topbar{padding:18px 20px}.about{padding:32px 20px 80px}.about-hero{grid-template-columns:1fr;gap:28px;margin-bottom:48px}.about-steps{grid-template-columns:1fr}.history{padding:32px 20px 80px}}@media(max-width:640px){.time-grid{grid-template-columns:repeat(2,1fr)}.history-row{grid-template-rows:auto auto;grid-template-columns:1fr auto;gap:4px 12px}.history-row .idx,.history-row .moves{display:none}.history-row .mode{font-size:11px}.history-row .chev{grid-row:1/3;align-self:center}}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-duration{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}
