/*! tailwindcss v4.2.2 | 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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--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-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease: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-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-orange-500:oklch(70.5% .213 47.604);--color-orange-700:oklch(55.3% .195 38.402);--color-amber-500:oklch(76.9% .188 70.08);--color-yellow-50:oklch(98.7% .026 102.212);--color-yellow-200:oklch(94.5% .129 101.54);--color-yellow-300:oklch(90.5% .182 98.111);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-500:oklch(79.5% .184 86.047);--color-yellow-600:oklch(68.1% .162 75.834);--color-green-600:oklch(62.7% .194 149.214);--color-cyan-400:oklch(78.9% .154 211.53);--color-cyan-500:oklch(71.5% .143 215.221);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-purple-400:oklch(71.4% .203 305.504);--color-purple-500:oklch(62.7% .265 303.9);--color-pink-500:oklch(65.6% .241 354.308);--color-rose-500:oklch(64.5% .246 16.439);--color-slate-500:oklch(55.4% .046 257.417);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--container-7xl:80rem;--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-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-6xl:3.75rem;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-widest:.1em;--radius-sm:.25rem;--radius-lg:.5rem;--drop-shadow-lg:0 4px 4px #00000026;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--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{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.collapse{visibility:collapse}.visible{visibility:visible}.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}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.inset-y-0{inset-block:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-4{top:calc(var(--spacing) * 4)}.top-50{top:calc(var(--spacing) * 50)}.top-\[50\%\]{top:50%}.right-0{right:calc(var(--spacing) * 0)}.right-1{right:calc(var(--spacing) * 1)}.right-4{right:calc(var(--spacing) * 4)}.right-6{right:calc(var(--spacing) * 6)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-1{bottom:calc(var(--spacing) * 1)}.bottom-6{bottom:calc(var(--spacing) * 6)}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing) * 2)}.left-\[50\%\]{left:50%}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.col-span-1{grid-column:span 1/span 1}.col-span-2{grid-column:span 2/span 2}.col-span-4{grid-column:span 4/span 4}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.-mx-1{margin-inline:calc(var(--spacing) * -1)}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing) * 1)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.ml-4{margin-left:calc(var(--spacing) * 4)}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.aspect-square{aspect-ratio:1}.h-1{height:calc(var(--spacing) * 1)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-11{height:calc(var(--spacing) * 11)}.h-12{height:calc(var(--spacing) * 12)}.h-16{height:calc(var(--spacing) * 16)}.h-24{height:calc(var(--spacing) * 24)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-48{max-height:calc(var(--spacing) * 48)}.max-h-96{max-height:calc(var(--spacing) * 96)}.min-h-64{min-height:calc(var(--spacing) * 64)}.min-h-screen{min-height:100vh}.w-1{width:calc(var(--spacing) * 1)}.w-2{width:calc(var(--spacing) * 2)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-3\/4{width:75%}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-11{width:calc(var(--spacing) * 11)}.w-12{width:calc(var(--spacing) * 12)}.w-14{width:calc(var(--spacing) * 14)}.w-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-32{width:calc(var(--spacing) * 32)}.w-40{width:calc(var(--spacing) * 40)}.w-48{width:calc(var(--spacing) * 48)}.w-56{width:calc(var(--spacing) * 56)}.w-64{width:calc(var(--spacing) * 64)}.w-72{width:calc(var(--spacing) * 72)}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.max-w-xs{max-width:var(--container-xs)}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-0{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-5{--tw-translate-x:calc(var(--spacing) * 5);translate:var(--tw-translate-x) var(--tw-translate-y)}.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)}.scale-105{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x) var(--tw-scale-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}: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-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * 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)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-sm{border-radius:var(--radius-sm)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-4{border-style:var(--tw-border-style);border-width:4px}.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-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-blue-400{border-color:var(--color-blue-400)}.border-blue-500{border-color:var(--color-blue-500)}.border-gray-200{border-color:var(--color-gray-200)}.border-transparent{border-color:#0000}.border-yellow-300{border-color:var(--color-yellow-300)}.border-yellow-400{border-color:var(--color-yellow-400)}.bg-amber-500{background-color:var(--color-amber-500)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-black\/60{background-color:#0009}@supports (color:color-mix(in lab,red,red)){.bg-black\/60{background-color:color-mix(in oklab,var(--color-black) 60%,transparent)}}.bg-blue-100{background-color:var(--color-blue-100)}.bg-blue-500{background-color:var(--color-blue-500)}.bg-blue-600{background-color:var(--color-blue-600)}.bg-cyan-500{background-color:var(--color-cyan-500)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-gray-300{background-color:var(--color-gray-300)}.bg-gray-700{background-color:var(--color-gray-700)}.bg-green-600{background-color:var(--color-green-600)}.bg-orange-500{background-color:var(--color-orange-500)}.bg-pink-500{background-color:var(--color-pink-500)}.bg-purple-400{background-color:var(--color-purple-400)}.bg-purple-500{background-color:var(--color-purple-500)}.bg-red-500{background-color:var(--color-red-500)}.bg-red-600{background-color:var(--color-red-600)}.bg-rose-500{background-color:var(--color-rose-500)}.bg-slate-500{background-color:var(--color-slate-500)}.bg-transparent{background-color:#0000}.bg-white{background-color:var(--color-white)}.bg-yellow-50{background-color:var(--color-yellow-50)}.bg-yellow-200{background-color:var(--color-yellow-200)}.bg-yellow-500{background-color:var(--color-yellow-500)}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-red-500{--tw-gradient-from:var(--color-red-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-red-600{--tw-gradient-to:var(--color-red-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.fill-current{fill:currentColor}.object-cover{object-fit:cover}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.px-1{padding-inline:calc(var(--spacing) * 1)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-8{padding-block:calc(var(--spacing) * 8)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-4{padding-top:calc(var(--spacing) * 4)}.pr-2{padding-right:calc(var(--spacing) * 2)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pl-8{padding-left:calc(var(--spacing) * 8)}.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-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--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-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--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-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.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)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.whitespace-nowrap{white-space:nowrap}.text-blue-500{color:var(--color-blue-500)}.text-blue-600{color:var(--color-blue-600)}.text-cyan-400{color:var(--color-cyan-400)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-900{color:var(--color-gray-900)}.text-orange-700{color:var(--color-orange-700)}.text-purple-500{color:var(--color-purple-500)}.text-red-500{color:var(--color-red-500)}.text-white{color:var(--color-white)}.text-yellow-500{color:var(--color-yellow-500)}.text-yellow-600{color:var(--color-yellow-600)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.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-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);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-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px 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)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px 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{--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)}.ring-0{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(0px + 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)}.ring-4{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(4px + 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)}.ring-blue-500{--tw-ring-color:var(--color-blue-500)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.drop-shadow-lg{--tw-drop-shadow-size:drop-shadow(0 4px 4px var(--tw-drop-shadow-color,#00000026));--tw-drop-shadow:drop-shadow(var(--drop-shadow-lg));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,)}.grayscale{--tw-grayscale:grayscale(100%);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,)}.invert{--tw-invert:invert(100%);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,)}.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,)}.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-all{transition-property:all;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))}.transition-transform{transition-property:transform,translate,scale,rotate;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}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:bg-blue-600:hover{background-color:var(--color-blue-600)}.hover\:bg-gray-300:hover{background-color:var(--color-gray-300)}.hover\:bg-gray-400:hover{background-color:var(--color-gray-400)}.hover\:text-gray-600:hover{color:var(--color-gray-600)}.hover\:text-gray-900:hover{color:var(--color-gray-900)}.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-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-2:focus-visible{--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-visible\:ring-offset-2:focus-visible{--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-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-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.data-\[state\=active\]\:shadow-sm[data-state=active]{--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)}.data-\[state\=closed\]\:duration-300[data-state=closed]{--tw-duration:.3s;transition-duration:.3s}.data-\[state\=on\]\:bg-transparent[data-state=on]{background-color:#0000}.data-\[state\=on\]\:shadow-sm[data-state=on]{--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)}.data-\[state\=open\]\:duration-500[data-state=open]{--tw-duration:.5s;transition-duration:.5s}@media (min-width:40rem){.sm\:max-w-sm{max-width:var(--container-sm)}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.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\:text-left{text-align:left}}@media (min-width:48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width:64rem){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (prefers-color-scheme:dark){.dark\:border-gray-700{border-color:var(--color-gray-700)}.dark\:bg-gray-600{background-color:var(--color-gray-600)}.dark\:bg-gray-700{background-color:var(--color-gray-700)}.dark\:bg-gray-800{background-color:var(--color-gray-800)}.dark\:bg-gray-900{background-color:var(--color-gray-900)}.dark\:text-gray-300{color:var(--color-gray-300)}.dark\:text-gray-400{color:var(--color-gray-400)}.dark\:text-white{color:var(--color-white)}@media (hover:hover){.dark\:hover\:bg-gray-600:hover{background-color:var(--color-gray-600)}.dark\:hover\:text-gray-300:hover{color:var(--color-gray-300)}.dark\:hover\:text-white:hover{color:var(--color-white)}}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&\>span\]\:line-clamp-1>span{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}}:root{--color-bg:#0a1120;--color-bg-warm:#0d1628;--color-surface-1:#141e35;--color-surface-2:#1a2845;--color-navy-mid:#152240;--color-navy-light:#1a2d4d;--color-primary:#0d9488;--color-primary-light:#14b8a6;--color-primary-bright:#2dd4bf;--color-primary-glow:#2dd4bf40;--color-accent:#e8634a;--color-accent-light:#f08c72;--color-cream:#fff5e0;--color-cream-dark:#f5ebd5;--color-gold:#f5a623;--color-gold-light:#ffd060;--color-felt:#0a2e28;--color-felt-light:#0d3830;--color-felt-border:#ffffff26;--grad-table:radial-gradient(ellipse at 50% 40%, #0d3830 0%, #082a24 40%, #061e1a 100%);--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-red:#e83a30;--color-text:#e8ecf4;--color-text-sec:#8899b0;--color-text-muted:#5a6a80;--color-text-dim:#3d4e63;--color-text-inverse:#0a1120;--color-text-on-felt:#fff;--color-border:#1e2e48;--color-border-subtle:#ffffff0f;--color-border-active:var(--color-primary-bright);--color-winner-bg:#f5a6231f;--color-winner-accent:#f5a623;--color-you-border:var(--color-primary);--grad-teal:linear-gradient(135deg, #0d9488, #14b8a6);--grad-navy:linear-gradient(135deg, #1a2d4d, #253d66);--grad-coral:linear-gradient(135deg, #e8634a, #f08c72);--grad-warm:linear-gradient(135deg, #f5a623, #ffd060);--grad-hero:linear-gradient(135deg, #0d9488, #1a2d4d, #e8634a);--glass-overlay:#0a1120d9;--topnav-height:56px;--topnav-bg:#0a1120f2;--cat-trips-color:#af52de;--cat-trips-bg:#af52de26;--cat-trips-border:#af52de4d;--cat-suited-seq-color:#5ac8fa;--cat-suited-seq-bg:#5ac8fa26;--cat-suited-seq-border:#5ac8fa4d;--cat-seq-color:#22c55e;--cat-seq-bg:#22c55e26;--cat-seq-border:#22c55e4d;--cat-flush-color:#2dd4bf;--cat-flush-bg:#2dd4bf26;--cat-flush-border:#2dd4bf4d;--cat-pair-color:#f5a623;--cat-pair-bg:#f5a62326;--cat-pair-border:#f5a6234d;--cat-high-color:#5a6a80;--cat-high-bg:#5a6a801f;--cat-high-border:#5a6a8040;--font-display:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:ui-monospace, "SF Mono", "Fira Code", monospace;--radius-sm:6px;--radius-base:12px;--radius-card:10px;--radius-lg:14px;--radius-pill:100px;--radius-btn:14px;--shadow-card:0 1px 6px #0003;--shadow-elevated:0 4px 16px #00000040;--shadow-selected:0 0 0 3px var(--color-primary-bright), 0 0 16px var(--color-primary-glow);--shadow-glow-teal:0 4px 16px #0d94884d;--shadow-glow-gold:0 4px 16px #f5a62359;--shadow-glow-coral:0 4px 16px #e8634a4d;--shadow-inset:inset 0 1px 0 #ffffff0a;--glass-bg:#00000059;--glass-blur:blur(12px);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--ease-in-out:cubic-bezier(.45, 0, .55, 1);--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background-color:var(--color-bg);color:var(--color-text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100dvh;font-size:16px;line-height:1.5}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3{font-family:var(--font-display);letter-spacing:.02em;font-weight:600}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.4rem,3vw,2rem)}h3{font-size:1.2rem}.screen{flex-direction:column;justify-content:center;align-items:center;gap:2rem;min-height:100vh;padding:2rem 1rem;display:flex;position:relative;overflow:hidden}.screen-title{font-family:var(--font-display);color:var(--color-primary);text-align:center;letter-spacing:.04em;font-size:clamp(2rem,5vw,3.5rem)}.screen-subtitle{font-family:var(--font-body);color:var(--color-text-muted);text-align:center;font-size:1rem}.ambient-bg{pointer-events:none;z-index:0;position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.ambient-bg__glow{background:radial-gradient(#00b4d80f,#0000 70%);width:600px;height:600px;animation:6s ease-in-out infinite breathe;position:absolute;top:35%;left:50%;transform:translate(-50%,-50%)}.ambient-bg__suit{font-family:var(--font-display);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-text-fill-color:transparent;opacity:.03;-webkit-user-select:none;user-select:none;will-change:transform;-webkit-background-clip:text;background-clip:text;font-size:9rem;animation:18s ease-in-out infinite floatSuit;position:absolute}.ambient-bg__suit:nth-child(2){font-size:7rem;animation-duration:20s;animation-delay:-4s;top:8%;left:6%}.ambient-bg__suit:nth-child(3){animation-duration:22s;animation-delay:-8s;top:12%;right:8%}.ambient-bg__suit:nth-child(4){font-size:11rem;animation-duration:19s;animation-delay:-2s;bottom:15%;left:10%}.ambient-bg__suit:nth-child(5){font-size:8rem;animation-duration:24s;animation-delay:-12s;bottom:10%;right:6%}.btn{border-radius:var(--radius-btn);font-family:var(--font-body);cursor:pointer;transition:background-color var(--transition),border-color var(--transition),color var(--transition),opacity var(--transition),transform var(--transition),box-shadow var(--transition);-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.8rem 2rem;font-size:.9rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";background:linear-gradient(105deg,#0000 40%,#ffffff14,#0000 60%);transition:transform .4s;position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%)}.btn:hover:after{transform:translate(100%)}.btn-primary{background:var(--grad-teal);color:#fff;box-shadow:var(--shadow-glow-teal);border-color:#0000}.btn-primary:hover:not(:disabled){background:var(--color-primary-light);box-shadow:0 4px 20px var(--color-primary-glow);transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:0 2px 8px var(--color-primary-light);transform:translateY(0)}.btn-secondary{border-color:var(--color-primary);color:var(--color-primary-bright);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary-hover);transform:translateY(-1px)}.btn-ghost{border-color:var(--color-border);color:var(--color-text-sec);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--color-text);border-color:#0000002e}.btn-danger{color:var(--color-error);background:0 0;border-color:#ff3b3066}.btn-danger:hover:not(:disabled){border-color:var(--color-error);background:#ff3b301f}.btn:disabled{opacity:.35;cursor:not-allowed}.btn:disabled:after{display:none}.form-input{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;color:var(--color-text);font-family:var(--font-body);transition:border-color var(--transition),box-shadow var(--transition);outline:none;padding:.75rem 1rem;font-size:.95rem}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input::placeholder{color:var(--color-text-dim)}.form-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:.35rem;font-size:.8rem;font-weight:500;display:block}.error-message{border-radius:var(--radius-btn);color:var(--color-error);text-align:center;max-width:400px;animation:slideDown .2s var(--ease-out);background:#ff3b3014;border:1px solid #ff3b3040;padding:.75rem 1.25rem;font-size:.875rem}.toast-container{z-index:1000;pointer-events:none;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--color-border);border-radius:var(--radius-base);box-shadow:var(--shadow-elevated);color:var(--color-text);min-width:280px;max-width:360px;animation:toastIn .3s var(--ease-out);pointer-events:auto;align-items:center;gap:.75rem;padding:.875rem 1.25rem;font-size:.875rem;display:flex;position:relative;overflow:hidden}.toast:before{content:"";border-radius:4px 0 0 4px;width:3px;position:absolute;top:0;bottom:0;left:0}.toast--error:before{background:var(--color-error)}.toast--success:before{background:var(--color-success)}.toast--info:before{background:var(--color-primary)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes spinnerPulse{0%,to{opacity:1}50%{opacity:.4}}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-right-color:var(--color-primary-light);border-radius:50%;width:40px;height:40px;animation:.75s linear infinite spin}.spinner-label{color:var(--color-text-muted);letter-spacing:.04em;margin-top:.75rem;font-size:.875rem;animation:2s ease-in-out infinite spinnerPulse}.card{cursor:pointer;border:2px solid #ffffff14;transition:border-color .2s cubic-bezier(.34,1.56,.64,1),transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;box-shadow:0 2px 8px #00000040}.card:hover{transform:translateY(-5px)scale(1.03);box-shadow:0 8px 24px #0000004d}.card.selected{border-color:var(--color-primary-bright);border-width:2.5px;transform:translateY(-8px)scale(1.05);box-shadow:0 0 20px #2dd4bf66,0 6px 16px #0000004d}.card--face-down{cursor:default}.card--face-down:hover{transform:none;box-shadow:0 2px 8px #0000004d}.card-deal{animation:dealIn .35s var(--ease-out) both}.card-deal:first-child{animation-delay:0s}.card-deal:nth-child(2){animation-delay:80ms}.card-deal:nth-child(3){animation-delay:.16s}.card-deal:nth-child(4){animation-delay:.24s}.card-deal:nth-child(5){animation-delay:.32s}.card-deal:nth-child(6){animation-delay:.4s}.hand-cat{border-radius:var(--radius-pill);letter-spacing:.1em;text-transform:uppercase;animation:fadeIn .2s var(--ease-out);align-items:center;gap:.25rem;padding:.18rem .55rem;font-size:.68rem;font-weight:700;display:inline-flex}.cat-trips{background:var(--cat-trips-bg);color:var(--cat-trips-color);border:1px solid var(--cat-trips-border)}.cat-suited-seq{background:var(--cat-suited-seq-bg);color:var(--cat-suited-seq-color);border:1px solid var(--cat-suited-seq-border)}.cat-seq{background:var(--cat-seq-bg);color:var(--cat-seq-color);border:1px solid var(--cat-seq-border)}.cat-flush{background:var(--cat-flush-bg);color:var(--cat-flush-color);border:1px solid var(--cat-flush-border)}.cat-pair{background:var(--cat-pair-bg);color:var(--cat-pair-color);border:1px solid var(--cat-pair-border)}.cat-high{background:var(--cat-high-bg);color:var(--cat-high-color);border:1px solid var(--cat-high-border)}.auth-screen{flex-direction:column;justify-content:center;align-items:center;gap:1.75rem;min-height:100vh;padding:2rem 1rem;display:flex;position:relative;overflow:hidden}.auth-logo-img{width:100%;max-width:200px;filter:drop-shadow(0 4px 16px var(--color-primary-glow));margin:0 auto;display:block}.auth-tagline{color:var(--color-text-muted);font-family:var(--font-display);text-align:center;letter-spacing:.04em;font-size:1.15rem;font-style:italic}.game-bar{background:var(--glass-bg);height:52px;-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--color-border);z-index:100;justify-content:space-between;align-items:center;gap:1rem;padding:0 1.25rem;display:flex;position:fixed;top:0;left:0;right:0}.game-bar__left{align-items:center;gap:.75rem;min-width:80px;display:flex}.game-bar__back{border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text-muted);font-size:.75rem;font-family:var(--font-body);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:color var(--transition),border-color var(--transition);background:0 0;padding:.35rem .75rem;font-weight:600}.game-bar__back:hover{color:var(--color-text);border-color:#0000002e}.game-bar__logo{font-family:var(--font-display);color:var(--color-primary);letter-spacing:.08em;pointer-events:none;font-size:1.3rem;font-weight:600;position:absolute;left:50%;transform:translate(-50%)}.game-bar__logo-img{width:auto;height:2rem;display:block}.game-bar__center{flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.game-bar__right{justify-content:flex-end;align-items:center;gap:.75rem;min-width:80px;display:flex}.game-bar__variant{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-dim);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-pill);padding:.2rem .6rem;font-size:.7rem;font-weight:600}.game-timer{justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.game-timer__svg{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotate(-90deg)}.game-timer__track{fill:none;stroke:var(--color-border);stroke-width:2.5px}.game-timer__arc{fill:none;stroke:var(--color-primary);stroke-width:2.5px;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke .5s}.game-timer__arc--warning{stroke:var(--color-error);animation:.8s ease-in-out infinite timerPulse}.game-timer__label{font-family:var(--font-mono);color:var(--color-text-muted);z-index:1;letter-spacing:-.02em;font-size:.8rem;font-weight:700;position:relative}.game-timer__label--warning{color:var(--color-error)}.toggle-group{background:var(--color-surface-2,#1a2845);border:1px solid var(--color-border,#1e2e48);border-radius:12px;align-items:center;gap:2px;padding:3px;display:inline-flex}.toggle-group--compact{gap:2px}.toggle-group__label{color:var(--color-text-muted,#5a6a80);white-space:nowrap;padding:0 8px;font-size:12px;font-weight:700}.toggle-group__item{color:var(--color-text-muted,#5a6a80);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;padding:6px 14px;font-size:13px;font-weight:600;line-height:1.2;transition:all .2s}.toggle-group__item:hover{color:var(--color-text-sec,#8899b0);background:#ffffff0a}.toggle-group__item[data-state=on]{background:var(--color-surface-1,#141e35);color:var(--color-text,#e8ecf4);box-shadow:0 1px 4px #00000040}.toggle-group__item[data-disabled]{opacity:.4;cursor:not-allowed}.sound-toggle{background:var(--color-surface-2,#1a2845);border:1px solid var(--color-border,#1e2e48);width:36px;height:36px;color:var(--color-text-sec,#8899b0);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:flex}.sound-toggle:hover{border-color:var(--color-text-sec,#8899b0);background:#ffffff0f}.game-screen{flex-direction:column;flex:1;width:100%;display:flex;overflow:hidden}.game-table{background:var(--grad-table);flex-direction:column;flex:1;justify-content:space-between;display:flex;position:relative;overflow:hidden}.game-table:before{content:"";pointer-events:none;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.035'/%3E%3C/svg%3E");position:absolute;top:0;right:0;bottom:0;left:0}.game-table:after{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#0d948814,#0000 50%),radial-gradient(at 50% 100%,#0d94880d,#0000 40%);position:absolute;top:0;right:0;bottom:0;left:0}.opponent-zone{z-index:1;flex-flow:wrap;justify-content:center;gap:2.5rem;padding:1.25rem 3rem .75rem;display:flex;position:relative}.opponent-grid{background:#00000040;border:1px solid #ffffff0f;border-radius:16px;align-items:center;gap:1rem;padding:.75rem 1.25rem;transition:border-color .3s,box-shadow .3s;display:flex}.opponent-grid--winner{border-color:var(--color-gold);box-shadow:0 0 20px #f5a62340}.opponent-grid__identity{flex-direction:column;align-items:center;gap:.25rem;min-width:50px;display:flex}.opponent-grid__avatar{background:linear-gradient(135deg,var(--color-navy-light),var(--color-surface-2));width:44px;height:44px;color:var(--color-text);border:2.5px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex;box-shadow:0 2px 6px #0000004d}.opponent-grid__info{flex-direction:column;align-items:center;gap:.15rem;display:flex}.opponent-grid__handle{color:var(--color-text-sec);text-overflow:ellipsis;white-space:nowrap;text-align:center;max-width:80px;font-size:.7rem;font-weight:600;overflow:hidden}.opponent-grid__status{align-items:center;gap:.35rem;display:flex}.opponent-grid__score{color:var(--color-gold);background:#f5a6231f;border-radius:100px;padding:.15rem .4rem;font-size:.65rem;font-weight:700}.opponent-grid__hands{gap:1rem;display:flex}.opponent-grid__subhand{flex-direction:column;align-items:center;gap:.25rem;display:flex}.opponent-grid__slot-label{color:#ffffff59;letter-spacing:.5px;font-size:.6rem;font-weight:600}.opponent-grid__cards{align-items:center;gap:.2rem;display:flex}.opponent-grid__rows{gap:1rem;display:flex}.opponent-grid__row{flex-direction:column;align-items:center;gap:.25rem;display:flex}.opponent-status-dot{background:var(--color-text-dim);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite think}.opponent-status-dot--thinking{animation:1.2s ease-in-out infinite think}.opponent-status-dot--done{background:var(--color-success);animation:none;box-shadow:0 0 6px #22c55e80}.opponent-ack{border-radius:var(--radius-btn);color:var(--color-primary);text-align:center;letter-spacing:.04em;animation:slideDown .25s var(--ease-out);background:#0d948826;border:1px solid #0d948859;padding:.4rem 1rem;font-size:.8rem}.table-divider{background:linear-gradient(90deg,transparent,var(--color-felt-border),transparent);z-index:1;height:1px;margin:.25rem 0;position:relative}.player-grid{z-index:1;flex-direction:column;flex:1;align-items:center;gap:.75rem;width:100%;padding:.75rem 3rem 0;display:flex;position:relative}.subhand-slots{justify-content:center;gap:1.5rem;width:100%;display:flex}.subhand-slot{flex-direction:column;flex:1;gap:.4rem;max-width:280px;display:flex}.subhand-slot-header{justify-content:space-between;align-items:center;padding:0 .25rem;display:flex}.subhand-slot-label{text-transform:uppercase;letter-spacing:.15em;color:#fff6;font-size:.8rem;font-weight:700}.subhand-slot-cards{cursor:pointer;background:#ffffff05;border:2px dashed #ffffff26;border-radius:16px;justify-content:center;align-items:center;gap:.625rem;min-height:130px;padding:.75rem 1.25rem;transition:border-color .2s,background .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.subhand-slot:first-child .subhand-slot-cards:after{content:"1"}.subhand-slot:nth-child(2) .subhand-slot-cards:after{content:"2"}.subhand-slot:nth-child(3) .subhand-slot-cards:after{content:"3"}.subhand-slot-cards:after{color:#ffffff0f;pointer-events:none;font-size:2.5rem;font-weight:700;line-height:1;position:absolute;bottom:.4rem;right:.6rem}.subhand-slot-cards.drop-target{border-color:var(--color-primary-bright);background:#2dd4bf1a;box-shadow:0 0 30px #2dd4bf26}.subhand-slot-cards.full{cursor:default;background:#0d94880d;border-style:solid;border-color:#0d948880}.slot-placeholder{color:#fff3;pointer-events:none;font-size:.82rem;font-style:italic}.player-zone{z-index:1;flex-direction:column;align-items:center;gap:.75rem;padding:.75rem 3rem 1.25rem;display:flex;position:relative}.unassigned-pool{background:#0000002e;border:1.5px dashed #ffffff38;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;max-width:560px;min-height:108px;padding:1rem 1.5rem;transition:border-color .2s;display:flex}.unassigned-pool-label{text-transform:uppercase;letter-spacing:.15em;color:#ffffff40;width:100%;font-size:.72rem;font-weight:700}.unassigned-pool-cards{flex-wrap:wrap;justify-content:center;align-items:center;gap:.875rem;display:flex}.btn-submit{cursor:pointer;background:var(--grad-warm);color:#1a1a2e;border:none;border-radius:14px;min-width:220px;padding:.875rem 4rem;font-size:1.05rem;font-weight:800;transition:all .25s;box-shadow:0 6px 24px #f5a62373}.btn-submit:disabled{color:#ffffff40;box-shadow:none;cursor:default;background:#ffffff0f}.game-footer{z-index:1;justify-content:center;padding:.75rem 1.25rem 1.5rem;display:flex;position:relative}.game-hint{color:#ffffff59;text-align:center;letter-spacing:.02em;font-size:.78rem}.waiting-overlay{border:1px solid var(--color-felt-border);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:360px;animation:fadeIn .3s var(--ease-out);-webkit-backdrop-filter:blur(8px);background:#ffffff2e;flex-direction:column;align-items:center;gap:1rem;margin:0 auto;padding:2.5rem 2rem;display:flex}.waiting-overlay p{color:#ffffffd9;letter-spacing:.02em;font-size:.925rem}.game-screen--waiting{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.5rem;padding:2rem 1rem;display:flex;position:relative}.game-phase-container{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2rem;padding:2rem 1rem;display:flex;position:relative}.phase-instruction{justify-content:center;align-items:center;width:100%;display:flex}.phase-instruction__text{color:#fff;text-align:center;letter-spacing:.02em;margin:0;font-size:1.25rem;font-weight:600}.card-selection-area{flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:600px;display:flex}.cards-grid{flex-wrap:wrap;justify-content:center;gap:.75rem;width:100%;display:flex}.cards-grid--pass,.cards-grid--discard{gap:.75rem}.card-button{cursor:pointer;background:#ffffff14;border:2px solid #fff3;border-radius:.5rem;flex:none;padding:.5rem;transition:all .2s ease-in-out;position:relative}.card-button:hover:not(:disabled){background:#ffffff1f;border-color:#fff6;transform:translateY(-2px)}.card-button:active:not(:disabled){transform:translateY(0)}.card-button--selected{background:#4caf504d;border-color:#4caf5099;box-shadow:0 0 8px #4caf5066}.card-button:disabled{opacity:.5;cursor:not-allowed}.card-display{color:#fff;text-align:center;letter-spacing:.05em;font-size:.875rem;font-weight:700}.phase-submit-btn{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:.5rem;padding:.75rem 2rem;font-size:1rem;font-weight:600;transition:all .3s ease-in-out;box-shadow:0 4px 12px #4caf504d}.phase-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#66bb6a,#43a047);transform:translateY(-2px);box-shadow:0 6px 16px #4caf5080}.phase-submit-btn:active:not(:disabled){transform:translateY(0)}.phase-submit-btn:disabled{opacity:.6;cursor:not-allowed;background:linear-gradient(135deg,#9e9e9e,#757575);box-shadow:0 2px 6px #0003}.phase-waiting{color:#b0bec5;text-align:center;letter-spacing:.02em;background:#b0bec51a;border-left:3px solid #b0bec54d;border-radius:.5rem;padding:1rem 2rem;font-size:.95rem;font-weight:500}.results-screen{flex-direction:column;align-items:center;gap:2rem;width:100%;min-height:100vh;padding:3rem 1rem 2.5rem;display:flex;position:relative;overflow:hidden}.results-screen__bg-glow{pointer-events:none;background:radial-gradient(at top,#00b4d814,#0000 70%);width:500px;height:300px;position:absolute;top:0;left:50%;transform:translate(-50%)}.results-title{font-family:var(--font-display);color:var(--color-primary);text-align:center;letter-spacing:.04em;animation:fadeIn .5s var(--ease-out);font-size:clamp(2rem,5vw,3.5rem);position:relative}.results-cards{flex-direction:column;gap:.875rem;width:100%;max-width:500px;display:flex}.result-card{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-card);transition:border-color var(--transition),box-shadow var(--transition);box-shadow:var(--shadow-inset);animation:resultSlideIn .4s var(--ease-out) both;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.result-card:first-child{animation-delay:.1s}.result-card:nth-child(2){animation-delay:.25s}.result-card:nth-child(3){animation-delay:.4s}.result-card:nth-child(4){animation-delay:.55s}.result-card.winner{background:var(--color-winner-bg);box-shadow:0 0 0 1px #ffd60a1f,var(--shadow-inset);border-color:#ffd60a59}.result-card.you{border-color:#00b4d866}.result-player-info{flex-direction:column;gap:.3rem;display:flex}.result-player-name{font-family:var(--font-display);color:var(--color-text);font-size:1.15rem;font-weight:600}.result-badges{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.badge{border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.07em;animation:badgePop .35s var(--ease-spring) both;padding:.18rem .55rem;font-size:.68rem;font-weight:700;display:inline-block}.badge-winner{background:var(--color-winner-accent);color:#1a1400;box-shadow:0 2px 8px #ffd60a59}.badge-perfect{color:#fff;background:linear-gradient(135deg,#7c3aed,#4f46e5);box-shadow:0 2px 8px #7c3aed4d}.badge-you{background:var(--color-primary-light);color:var(--color-primary);border:1px solid #00b4d84d}.result-score{font-family:var(--font-display);color:var(--color-primary);text-shadow:0 0 20px var(--color-primary-glow);font-size:2.25rem;font-weight:700;line-height:1}.result-details{color:var(--color-text-muted);text-align:right;letter-spacing:.04em;margin-top:.15rem;font-size:.72rem}.results-actions{animation:fadeIn .5s var(--ease-out) .6s both;flex-wrap:wrap;justify-content:center;gap:.875rem;display:flex}.score-overlay{z-index:80;background:var(--glass-overlay,#0a1120d9);-webkit-backdrop-filter:blur(12px);justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.score-overlay__content{background:var(--color-surface-1,#141e35);border:1px solid var(--color-border,#1e2e48);text-align:center;width:calc(100% - 2rem);max-width:780px;animation:slideUp .4s var(--ease-out);border-radius:24px;padding:36px 40px;box-shadow:0 16px 64px #00000080}.score-overlay__trophy{margin-bottom:4px;font-size:52px;display:block}.score-overlay__title{letter-spacing:.02em;margin-bottom:6px;font-size:28px;font-weight:800}.score-overlay__title--victory{color:var(--color-gold,#f5a623);text-shadow:0 0 20px #f5a6234d}.score-overlay__title--defeat{color:var(--color-error,#ef4444);text-shadow:0 0 20px #ef444433}.score-overlay__subtitle{color:var(--color-text-muted,#5a6a80);margin-bottom:24px;font-size:14px;line-height:1.5}.score-overlay__players{flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:24px;display:flex}.score-overlay__player-card{transition:background-color var(--transition,.2s ease);background:0 0;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:12px 20px;display:flex;position:relative}.score-overlay__player-card--winner{background:#22c55e14}.score-overlay__player-avatar{background:var(--grad-navy,linear-gradient(135deg, #1a2d4d, #253d66));width:44px;height:44px;color:var(--color-text,#e8ecf4);transition:border-color var(--transition,.2s ease);border:2.5px solid #0000;border-radius:50%;justify-content:center;align-items:center;font-size:20px;font-weight:700;display:flex;position:relative}.score-overlay__player-avatar--winner{border-color:var(--color-gold,#f5a623);box-shadow:0 0 12px #f5a62366}.score-overlay__crown{font-size:14px;position:absolute;top:-7px;right:-4px}.score-overlay__player-handle{color:var(--color-text-sec,#8899b0);font-size:12px;font-weight:600}.score-overlay__score-badge{border-radius:100px;padding:3px 12px;font-size:15px;font-weight:800;display:inline-block}.score-overlay__score-badge--positive{color:var(--color-success,#22c55e);background:#22c55e26}.score-overlay__score-badge--negative{color:var(--color-error,#ef4444);background:#ef444426}.score-overlay__score-badge--zero{color:var(--color-gold,#f5a623);background:#f5a62326}.score-overlay__subhands{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:28px;display:flex}.score-overlay__subhand-card{background:var(--color-surface-2,#1a2845);border:1px solid var(--color-border,#1e2e48);min-width:140px;max-width:200px;transition:border-color var(--transition,.2s ease),background-color var(--transition,.2s ease);border-radius:14px;flex-direction:column;flex:1;gap:8px;padding:14px 12px;display:flex}.score-overlay__subhand-card:hover{border-color:var(--color-border-subtle,#ffffff0f)}.score-overlay__subhand-name{color:var(--color-cream,#fff5e0);letter-spacing:.02em;margin-bottom:6px;font-size:13px;font-weight:700}.score-overlay__subhand-cards{flex-wrap:wrap;justify-content:center;gap:4px;margin:8px 0;display:flex}.score-overlay__subhand-card-mini{background:var(--color-cream,#fff5e0);width:28px;height:40px;color:var(--color-text-inverse,#0a1120);border-radius:3px;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:flex}.score-overlay__comparison{border-top:1px solid var(--color-border,#1e2e48);margin-bottom:28px;padding:16px 0}.score-overlay__opp-tabs{justify-content:center;gap:8px;margin-bottom:16px;display:flex}.score-overlay__opp-tab{color:var(--color-text-sec,#8899b0);border:1.5px solid var(--color-border,#1e2e48);cursor:pointer;transition:all var(--transition,.2s ease);background:0 0;border-radius:100px;padding:6px 18px;font-size:13px;font-weight:600}.score-overlay__opp-tab:hover{border-color:var(--color-text-sec,#8899b0);background:#8899b00d}.score-overlay__opp-tab--active{color:var(--color-teal,#0d9488);border-color:var(--color-teal,#0d9488);background:#0d94881a}.score-overlay__compare-header{grid-template-columns:1fr 80px 1fr;gap:8px;margin-bottom:10px;padding:0 4px;display:grid}.score-overlay__compare-label{color:var(--color-text-muted,#5a6a80);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:700}.score-overlay__compare-label--you{text-align:right}.score-overlay__compare-label--slot{text-align:center}.score-overlay__compare-label--opp{text-align:left}.score-overlay__compare-row{border-bottom:1px solid #1e2e4880;grid-template-columns:1fr 80px 1fr;align-items:center;gap:8px;padding:10px 4px;display:grid}.score-overlay__compare-row:last-child{border-bottom:none}.score-overlay__compare-side{gap:4px;display:flex}.score-overlay__compare-side--you{justify-content:flex-end}.score-overlay__compare-side--opp{justify-content:flex-start}.score-overlay__compare-slot-label{color:var(--color-cream,#fff5e0);text-align:center;white-space:nowrap;font-size:12px;font-weight:700}.score-overlay__actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.score-overlay__btn{cursor:pointer;transition:box-shadow var(--transition,.2s ease),transform var(--transition,.2s ease),border-color var(--transition,.2s ease),color var(--transition,.2s ease),background-color var(--transition,.2s ease);letter-spacing:.02em;border:none;border-radius:14px;padding:14px 32px;font-size:14px;font-weight:600}.score-overlay__btn--primary{background:var(--grad-teal,linear-gradient(135deg, #0d9488, #14b8a6));color:#fff;padding:14px 48px;font-size:16px;font-weight:700;box-shadow:0 8px 24px #0d94884d}.score-overlay__btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #0d948866}.score-overlay__btn--primary:active{transform:translateY(0)}.score-overlay__btn--ghost{color:var(--color-text-sec,#8899b0);border:1.5px solid var(--color-border,#1e2e48);background:0 0}.score-overlay__btn--ghost:hover{border-color:var(--color-text-sec,#8899b0);background-color:#8899b00d}.score-overlay__btn--outline{color:var(--color-text-sec,#8899b0);border:1.5px solid var(--color-border,#1e2e48);background:0 0}.score-overlay__btn--outline:hover{border-color:var(--color-text-sec,#8899b0);background-color:#8899b00d}.confetti-particle{pointer-events:none;z-index:79;position:fixed}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.confetti-particle{animation:2.5s ease-in forwards confettiFall}@media (max-width:640px){.score-overlay__content{border-radius:16px;width:calc(100% - 1.5rem);max-width:100%;padding:24px 20px}.score-overlay__title{font-size:24px}.score-overlay__trophy{font-size:44px}.score-overlay__players{gap:12px}.score-overlay__player-card{padding:10px 16px}.score-overlay__compare-header,.score-overlay__compare-row{grid-template-columns:1fr 60px 1fr}.score-overlay__actions{flex-direction:column;gap:10px}.score-overlay__btn{width:100%}}.lobby-hub{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;min-width:300px;max-width:360px;box-shadow:var(--shadow-elevated);animation:slideUp .3s var(--ease-out);flex-direction:column;align-items:center;gap:1rem;padding:2rem 2rem 1.75rem;display:flex}.lobby-hub__greeting{font-family:var(--font-display);color:var(--color-text-muted);text-align:center;letter-spacing:.03em;font-size:1.1rem}.lobby-hub__stat-row{color:var(--color-text-dim);align-items:center;gap:.75rem;font-size:.8rem;display:flex}.lobby-hub__stat-row strong{color:var(--color-primary);font-weight:600}.lobby-hub__actions{flex-direction:column;gap:.75rem;width:100%;display:flex}.lobby-hub__btn--primary{width:100%}.lobby-hub__btn--secondary{color:var(--color-text-muted);font-size:.875rem;font-family:var(--font-body);cursor:pointer;transition:color var(--transition);letter-spacing:.02em;background:0 0;border:none;padding:.25rem 0;text-decoration:none}.lobby-hub__btn--secondary:hover{color:var(--color-primary)}.lobby-hub__divider{background:var(--color-border);width:100%;height:1px}.lobby-hub__online{color:var(--color-text-dim);align-items:center;gap:.4rem;font-size:.78rem;display:flex}.online-dot{background:var(--color-success);width:5px;height:5px;box-shadow:0 0 4px var(--color-success);border-radius:50%;flex-shrink:0}.lobby-status{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:300px;box-shadow:var(--shadow-elevated),var(--shadow-inset);animation:slideUp .3s var(--ease-out);text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:2.5rem 2rem;display:flex}.lobby-status-text{color:var(--color-text-muted);letter-spacing:.03em;font-size:.95rem}.lobby-status-sub{color:var(--color-text-dim);font-size:.8rem}.lobby-join{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;min-width:300px;max-width:360px;box-shadow:var(--shadow-elevated),var(--shadow-inset);animation:slideUp .3s var(--ease-out);flex-direction:column;align-items:center;gap:1.25rem;padding:2rem;display:flex}.lobby-join__title{font-family:var(--font-display);color:var(--color-text);letter-spacing:.03em;font-size:1.4rem}.lobby-join__code-row{gap:.6rem;display:flex}.lobby-join__char{text-align:center;width:52px;height:60px;font-family:var(--font-mono);letter-spacing:0;background:var(--color-surface-1);border:1.5px solid var(--color-border);border-radius:var(--radius-base);color:var(--color-primary);transition:border-color var(--transition),box-shadow var(--transition);caret-color:var(--color-primary);outline:none;font-size:1.75rem;font-weight:700}.lobby-join__char:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.lobby-join__input{text-align:center;width:100%;max-width:200px;font-family:var(--font-mono);letter-spacing:.3em;background:var(--color-surface-1);border:1.5px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-primary);text-transform:uppercase;transition:border-color var(--transition),box-shadow var(--transition);outline:none;padding:.6rem;font-size:2rem;font-weight:700}.lobby-join__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.lobby-screen--desktop{flex:1;padding:32px 40px}.lobby-desktop-panels{gap:32px;min-height:calc(100vh - 160px);margin-top:16px;display:flex}.lobby-panel{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:16px;padding:24px}.lobby-panel--left{flex-direction:column;flex-shrink:0;gap:20px;width:440px;display:flex}.lobby-panel--right{flex-direction:column;flex:1;gap:16px;display:flex}.lobby-panel__title{color:var(--color-text-sec);margin:0 0 12px;font-size:16px;font-weight:700}.lobby-public-rooms{flex:1}.lobby-join-private{border-top:1px solid var(--color-border);padding-top:16px}.lobby-join-private__label{color:var(--color-text-muted);letter-spacing:2px;margin:0 0 10px;font-size:10px;font-weight:700}.lobby-join-private__row{align-items:center;gap:8px;display:flex}.lobby-config-card{background:var(--color-surface-2);border-radius:12px;flex-direction:column;gap:16px;padding:20px;display:flex}.lobby-config-row{align-items:center;gap:16px;display:flex}.lobby-config-row__label{color:var(--color-text-sec);flex-shrink:0;width:80px;font-size:13px;font-weight:600}.lobby-variant-pills{gap:8px;display:flex}.lobby-variant-pill{border-radius:var(--radius-pill);border:1.5px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.lobby-variant-pill:hover{border-color:var(--color-primary);color:var(--color-primary-bright)}.lobby-variant-pill--active{border-color:var(--color-primary);color:var(--color-primary-bright);background:#0d948826;font-weight:700}.lobby-count-control{align-items:center;gap:12px;display:flex}.lobby-count-btn{border:1.5px solid var(--color-border);width:32px;height:32px;color:var(--color-text);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:all .2s;display:flex}.lobby-count-btn:disabled{opacity:.3;cursor:default}.lobby-count-value{color:var(--color-text);text-align:center;min-width:24px;font-size:20px;font-weight:700}.lobby-config-actions{flex-direction:column;gap:10px;display:flex}.waiting-room{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;min-width:300px;max-width:420px;box-shadow:var(--shadow-elevated),var(--shadow-inset);animation:slideUp .3s var(--ease-out);flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;display:flex}.waiting-room__code{text-align:center;flex-direction:column;align-items:center;gap:.3rem;display:flex}.waiting-room__code-value{font-family:var(--font-mono);color:var(--color-primary);letter-spacing:.25em;cursor:pointer;transition:color var(--transition),text-shadow var(--transition);text-shadow:0 0 20px var(--color-primary-glow);font-size:2.5rem;font-weight:700}.waiting-room__code-value:hover{color:var(--color-primary-hover);text-shadow:0 0 30px var(--color-primary-glow)}.waiting-room__copy-hint{color:var(--color-text-dim);letter-spacing:.06em;text-transform:uppercase;font-size:.72rem}.waiting-room__players{flex-direction:column;gap:.5rem;width:100%;list-style:none;display:flex}.waiting-room__player{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-base);color:var(--color-text);animation:slideDown .2s var(--ease-out);align-items:center;gap:.6rem;padding:.65rem 1rem;font-size:.9rem;display:flex}.waiting-room__player.player--host{color:var(--color-primary);background:var(--color-primary-light);border-color:#00b4d859}.waiting-room__player.player--empty{color:var(--color-text-dim);border-style:dashed;font-size:.82rem;font-style:italic;animation:2s ease-in-out infinite emptySeatPulse}.waiting-room__player-avatar{background:var(--color-surface-3);border:1px solid var(--color-border);width:24px;height:24px;font-size:.65rem;font-family:var(--font-display);color:var(--color-text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(6px);z-index:500;background:#000000bf;justify-content:center;align-items:center;padding:1.5rem;animation:.2s fadeIn;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal-panel{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-elevated);animation:slideUp .25s var(--ease-out);padding:2rem;position:relative}.modal-close{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;width:28px;height:28px;transition:color var(--transition),border-color var(--transition);background:0 0;justify-content:center;align-items:center;font-size:.8rem;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{color:var(--color-text);border-color:#0000002e}.modal-tabs{border-bottom:1px solid var(--color-border);gap:0;margin-bottom:1.5rem;display:flex}.modal-tab{font-family:var(--font-body);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition),border-color var(--transition);letter-spacing:.02em;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem 1.25rem;font-size:.875rem;font-weight:500}.modal-tab:hover{color:var(--color-text)}.modal-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.modal-form{flex-direction:column;gap:.875rem;display:flex}.modal-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:.35rem;font-size:.78rem;font-weight:500;display:block}.modal-input{background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;color:var(--color-text);font-family:var(--font-body);transition:border-color var(--transition),box-shadow var(--transition);outline:none;padding:.7rem .875rem;font-size:.95rem}.modal-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.modal-input:disabled{opacity:.5}.modal-hint{color:var(--color-text-muted);font-size:.85rem;line-height:1.6}.modal-hint strong{color:var(--color-text)}@keyframes breathe{0%,to{opacity:1;transform:translate(-50%,-50%)scale(1)}50%{opacity:.6;transform:translate(-50%,-50%)scale(1.15)}}@keyframes floatSuit{0%{transform:translateY(0)rotate(0)}33%{transform:translateY(-18px)rotate(3deg)}66%{transform:translateY(-8px)rotate(-2deg)}to{transform:translateY(0)rotate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes dealIn{0%{opacity:0;transform:translateY(40px)scale(.9)rotate(-2deg)}to{opacity:1;transform:translateY(0)scale(1)rotate(0)}}@keyframes badgePop{0%{opacity:0;transform:scale(.6)}60%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes resultSlideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes selectedPulse{0%,to{box-shadow:var(--shadow-selected)}50%{box-shadow:0 0 0 3px var(--color-primary),0 6px 32px var(--color-primary-glow)}}@keyframes goldFlash{0%{box-shadow:0 0 0 0 var(--color-primary-glow)}to{box-shadow:0 0 0 8px #0000}}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes think{0%,80%,to{opacity:.3}40%{opacity:1}}@keyframes emptySeatPulse{0%,to{opacity:.4}50%{opacity:.7}}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (max-width:600px){.card{width:54px;height:76px}.result-card{padding:1rem 1.125rem}.result-score{font-size:1.75rem}.results-cards{max-width:100%}.subhand-slot-cards{flex-wrap:wrap}.unassigned-pool{justify-content:center}.hand-setting-area{gap:.875rem;padding:.875rem}.game-bar__logo{font-size:1.1rem}.lobby-hub,.lobby-status,.lobby-join,.waiting-room{width:100%;min-width:0}.results-actions{flex-direction:column;width:100%;max-width:320px}.results-actions .btn{width:100%}}@media (min-width:640px){.hand-setting-area{max-width:560px}.unassigned-pool{max-width:540px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--duration-fast:.1s;--duration-base:.2s;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-6xl:3.75rem;--color-hand-trips:#af52de;--color-hand-suited-seq:#007aff;--color-hand-seq:#34c759;--color-hand-flush:#5ac8fa;--color-hand-pair:#ff9f0a;--color-hand-high:#8e8e93}@media (prefers-reduced-motion:no-preference){@keyframes card-flip{0%{transform:rotateY(0)}50%{transform:rotateY(90deg)}to{transform:rotateY(0)}}}.card--flipping{animation:card-flip .6s var(--ease-in-out)}.app-shell{flex-direction:column;min-height:100vh;display:flex}.nav-shell{z-index:100;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid #0000000f;height:48px;position:sticky;top:0}.nav-shell__inner{align-items:center;gap:1.5rem;max-width:1200px;height:100%;margin:0 auto;padding:0 1rem;display:flex}.nav-shell__logo{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-primary);font-weight:700;text-decoration:none}.nav-shell__logo-img{width:auto;height:1.75rem;display:block}.nav-shell__links{flex:1;gap:1rem;display:flex}.nav-shell__link{color:var(--color-text-muted);font-size:var(--text-sm);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}.nav-shell__link:hover{color:var(--color-text)}.nav-shell__right{align-items:center;gap:.75rem;margin-left:auto;display:flex}.nav-shell__avatar{border-radius:var(--radius-pill);background:var(--color-primary-light);width:32px;height:32px;font-family:var(--font-display);color:var(--color-primary);font-size:var(--text-sm);border:1px solid #00b4d859;justify-content:center;align-items:center;text-decoration:none;display:flex}.nav-shell__settings{color:var(--color-text-muted);font-size:var(--text-base);transition:color var(--duration-fast) var(--ease-out);text-decoration:none}.nav-shell__settings:hover{color:var(--color-primary)}.nav-shell__hamburger{color:var(--color-text-muted);font-size:var(--text-xl);cursor:pointer;background:0 0;border:none;display:none}.nav-shell__drawer{background:var(--color-surface-1);border-bottom:1px solid var(--color-border);flex-direction:column;padding:1rem;display:flex}.nav-shell__drawer-link{color:var(--color-text);border-bottom:1px solid var(--color-border-subtle);font-size:var(--text-base);padding:.75rem 0;text-decoration:none}@media (max-width:639px){.nav-shell__links{display:none}.nav-shell__hamburger{display:block}.nav-shell__settings{display:none}}.landing-screen{background:var(--color-bg);flex-direction:column;min-height:100vh;display:flex}.landing-hero{text-align:center;z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.75rem;padding:2rem 1rem;display:flex;position:relative}.landing-hero__rule{background:#00b4d859;width:280px;height:1px}.landing-hero__title{font-family:var(--font-display);font-size:var(--text-6xl);color:var(--color-primary);text-shadow:0 0 40px var(--color-primary-glow);margin:0;line-height:1}.landing-hero__subtitle{font-size:var(--text-sm);letter-spacing:.3em;color:var(--color-text-muted);margin:0;font-weight:500}.landing-hero__tagline{color:var(--color-text-muted);font-style:italic;font-size:var(--text-xl);margin:.5rem 0 1rem}.landing-hero__ctas{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.landing-hero__btn--primary{min-width:200px}.landing-hero__btn--secondary{min-width:140px}.landing-hero__signin{font-size:var(--text-sm);color:var(--color-text-muted)}.landing-hero__signin-link{color:var(--color-primary)}.landing-how{text-align:center;background:var(--color-surface-1);padding:3rem 1rem}.landing-how__title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:2rem}.landing-how__cards{flex-wrap:wrap;justify-content:center;gap:1.5rem;display:flex}.landing-how__card{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:180px;max-width:240px;transition:border-color var(--duration-base) var(--ease-out);flex:1;padding:1.5rem}.landing-how__card:hover{border-color:#00b4d859}.landing-how__icon{font-size:var(--text-3xl);margin-bottom:.75rem;display:block}.landing-how__step-title{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text);margin:0 0 .5rem}.landing-how__step-desc{color:var(--color-text-muted);font-size:var(--text-sm);margin:0}.landing-footer{text-align:center;color:var(--color-text-dim);font-size:var(--text-xs);padding:1.5rem}.landing-footer__link{color:var(--color-text-dim)}.profile-screen{flex-direction:column;gap:2rem;max-width:800px;margin:0 auto;padding:2rem;display:flex}.profile-card{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;padding:2rem}.profile-avatar{border-radius:var(--radius-pill);background:var(--color-primary-light);width:72px;height:72px;font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-primary);border:1px solid #00b4d859;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}.profile-name{font-size:var(--text-xl);color:var(--color-text);margin:0 0 .25rem}.profile-rating{color:var(--color-primary);font-size:var(--text-sm);margin:0 0 1rem}.profile-edit-btn{margin-top:.5rem}.profile-section-title{font-size:var(--text-lg);color:var(--color-text-muted);margin-bottom:1rem;font-weight:500}.profile-stat-tile{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);text-align:center;padding:1rem}.profile-stat-tile__value{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-text);line-height:1;display:block}.profile-stat-tile__label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:.25rem;display:block}.profile-recent__header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.profile-recent__see-all{color:var(--color-primary);font-size:var(--text-sm);text-decoration:none}.profile-recent__empty{color:var(--color-text-muted);font-size:var(--text-sm)}.leaderboard-screen{max-width:800px;margin:0 auto;padding:2rem 1rem}.leaderboard-title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:1.5rem}.leaderboard-tabs{border-bottom:1px solid var(--color-border);gap:.25rem;margin-bottom:1.5rem;padding-bottom:0;display:flex}.leaderboard-tab{color:var(--color-text-muted);cursor:pointer;font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-out);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.5rem 1rem}.leaderboard-tab:hover{color:var(--color-text)}.leaderboard-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.leaderboard-table{border-collapse:collapse;background:var(--color-surface-1);border-radius:var(--radius-base);width:100%;overflow:hidden}.leaderboard-th{text-align:left;font-size:var(--text-xs);color:var(--color-text-muted);border-bottom:1px solid var(--color-border);text-transform:uppercase;letter-spacing:.08em;padding:.75rem 1rem}.leaderboard-empty-row td{padding:2rem}.leaderboard-empty{color:var(--color-text-muted);font-size:var(--text-sm);text-align:center}.leaderboard-footer{color:var(--color-text-dim);font-size:var(--text-xs);margin-top:1rem}@media (max-width:639px){.leaderboard-th--hide-sm{display:none}}.history-screen{max-width:720px;margin:0 auto;padding:2rem 1rem}.history-title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:1.5rem}.history-list{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);flex-direction:column;gap:0;display:flex;overflow:hidden}.history-empty{color:var(--color-text-muted);font-size:var(--text-sm);text-align:center;padding:2rem}.how-to-play-screen{flex-direction:column;gap:2rem;max-width:720px;margin:0 auto;padding:2rem 1rem;display:flex}.htp-title{font-family:var(--font-display);font-size:var(--text-4xl);color:var(--color-primary);margin-bottom:0}.htp-section{flex-direction:column;gap:1rem;display:flex}.htp-section-title{font-size:var(--text-xl);color:var(--color-text);font-weight:600}.htp-text{color:var(--color-text-muted);line-height:1.6}.htp-table{border-collapse:collapse;background:var(--color-surface-1);border-radius:var(--radius-base);width:100%;overflow:hidden}.htp-th{text-align:left;font-size:var(--text-xs);color:var(--color-text-muted);border-bottom:1px solid var(--color-border);text-transform:uppercase;padding:.75rem 1rem}.htp-tr{border-bottom:1px solid var(--color-border-subtle)}.htp-td{font-size:var(--text-sm);color:var(--color-text);padding:.75rem 1rem}.htp-td--mono{font-family:var(--font-mono)}.htp-list{color:var(--color-text-muted);padding-left:1.5rem;line-height:2}.htp-variants{flex-wrap:wrap;gap:1rem;display:flex}.htp-variant-card{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);flex:1;min-width:160px;padding:1rem}.htp-variant-title{color:var(--color-text);font-size:var(--text-base);margin:0 0 .5rem}.htp-variant-desc{color:var(--color-text-muted);font-size:var(--text-sm);margin:0}.htp-cta{text-align:center;padding:2rem 0}.htp-cta-text{color:var(--color-text-muted);margin-bottom:1rem}.settings-screen{flex-direction:column;gap:2rem;max-width:480px;margin:0 auto;padding:2rem 1rem;display:flex}.settings-title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-primary);margin-bottom:0}.settings-section{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);flex-direction:column;display:flex;overflow:hidden}.settings-section-title{font-size:var(--text-xs);color:var(--color-text-dim);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--color-border);padding:.75rem 1rem}.settings-row{border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;padding:.875rem 1rem;display:flex}.settings-row--divider{border-bottom:1px solid var(--color-border);height:0;padding:0}.settings-row__label{font-size:var(--text-sm);color:var(--color-text)}.settings-row__label--danger{color:var(--color-error)}.settings-row__value{font-size:var(--text-sm);color:var(--color-text-muted)}.settings-row__action{padding:.25rem .75rem}.settings-row__select{background:var(--color-surface-3);border:1px solid var(--color-border);color:var(--color-text);border-radius:var(--radius-sm);font-size:var(--text-sm);padding:.25rem .5rem}.settings-toggle{border-radius:var(--radius-pill);border:1px solid var(--color-border);background:var(--color-surface-3);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);padding:.25rem .75rem}.settings-toggle--on{background:var(--color-primary-light);color:var(--color-primary);border-color:#00b4d859}[data-reduce-motion=true] *{transition-duration:.001ms!important;animation-duration:.001ms!important}.avatar-wrapper{flex-direction:column;align-items:center;gap:4px;display:flex}.avatar{background:var(--grad-navy);color:var(--color-text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex;position:relative;overflow:visible}.avatar--ring-thinking{box-shadow:0 0 0 3px var(--color-warning);animation:1.4s ease-in-out infinite avatarPulse}.avatar--ring-ready{box-shadow:0 0 0 3px var(--color-primary-bright)}.avatar--ring-winner{box-shadow:0 0 0 3px var(--color-gold),var(--shadow-glow-gold)}.avatar__crown{font-size:11px;line-height:1;position:absolute;top:-6px;right:-6px}.avatar__label{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;text-align:center;max-width:60px;font-size:10px;overflow:hidden}@keyframes avatarPulse{0%,to{box-shadow:0 0 0 3px var(--color-warning)}50%{box-shadow:0 0 0 3px #f59e0b4d}}.score-badge{border-radius:var(--radius-pill);white-space:nowrap;justify-content:center;align-items:center;padding:3px 10px;font-size:14px;font-weight:800;line-height:1.2;display:inline-flex}.score-badge--positive{color:var(--color-success);background:#22c55e26}.score-badge--negative{color:var(--color-error);background:#ef444426}.score-badge--zero{color:var(--color-gold);background:#f5a62326}.result-chip{border-radius:var(--radius-pill);white-space:nowrap;align-items:center;gap:3px;padding:2px 8px;font-size:10px;font-weight:700;line-height:1.4;display:inline-flex}.result-chip--win{color:var(--color-success);background:#22c55e26}.result-chip--loss{color:var(--color-error);background:#ef444426}.result-chip--tie{color:var(--color-warning);background:#f59e0b26}.tab-bar{background:var(--glass-bg);height:60px;-webkit-backdrop-filter:var(--glass-blur);border-top:1px solid var(--color-border);padding-bottom:env(safe-area-inset-bottom,0px);z-index:200;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-bar__item{cursor:pointer;transition:opacity var(--transition);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:6px 0 4px;display:flex}.tab-bar__item:hover{opacity:.85}.tab-bar__icon{color:var(--color-text-muted);transition:color var(--transition);font-size:20px;line-height:1}.tab-bar__label{color:var(--color-text-muted);transition:color var(--transition);font-size:10px;font-weight:600}.tab-bar__item--active .tab-bar__icon,.tab-bar__item--active .tab-bar__label{color:var(--color-primary-bright)}.sheet-overlay{z-index:300;background:#00000080;align-items:flex-end;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.sheet-content{background:var(--color-surface-1);border:1px solid var(--color-border);width:100%;max-width:480px;padding:20px 20px calc(20px + env(safe-area-inset-bottom,0px));border-bottom:none;border-radius:20px 20px 0 0;flex-direction:column;gap:18px;margin:0 auto;display:flex}.sheet-drag-indicator{background:var(--color-border);border-radius:2px;width:36px;height:4px;margin:0 auto -8px}.sheet-header{justify-content:space-between;align-items:center;display:flex}.sheet-title{color:var(--color-text);font-size:18px;font-weight:800}.sheet-close-btn{background:var(--color-surface-2);cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);transition:background var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.sheet-close-btn:hover{background:var(--color-border)}.sheet-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:6px;font-size:11px;font-weight:700}.match-type-toggle{background:var(--color-surface-2);border-radius:var(--radius-base);gap:3px;padding:3px;display:flex}.match-type-btn{cursor:pointer;transition:all var(--transition);color:var(--color-text-muted);background:0 0;border:none;border-radius:10px;flex:1;padding:8px;font-size:13px;font-weight:700}.match-type-btn--active{background:var(--color-surface-1);color:var(--color-text);box-shadow:var(--shadow-card)}.player-counter{background:var(--color-surface-2);border-radius:var(--radius-base);align-items:center;gap:16px;padding:10px 16px;display:flex}.player-counter__btn{background:var(--color-surface-1);width:32px;height:32px;color:var(--color-text);cursor:pointer;transition:background var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex}.player-counter__btn:disabled{opacity:.35;cursor:not-allowed}.player-counter__value{text-align:center;color:var(--color-text);flex:1;font-size:18px;font-weight:700}.rule-toggle-row{background:var(--color-surface-2);border-radius:var(--radius-base);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.rule-toggle-label{color:var(--color-text);font-size:14px;font-weight:600}.rule-toggle-switch{background:var(--color-border);cursor:pointer;border:none;border-radius:13px;width:44px;height:26px;transition:background .2s;position:relative}.rule-toggle-switch--on{background:var(--grad-teal)}.rule-toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:3px;left:3px}.rule-toggle-switch--on:after{transform:translate(18px)}.sheet-action-btn{border-radius:var(--radius-btn);cursor:pointer;width:100%;transition:opacity var(--transition);border:none;padding:14px;font-size:15px;font-weight:700}.sheet-action-btn:hover{opacity:.9}.sheet-action-btn--primary{background:var(--grad-teal);color:#fff;box-shadow:var(--shadow-glow-teal)}.sheet-action-btn--coral{background:var(--grad-coral);color:#fff;box-shadow:var(--shadow-glow-coral)}.sheet-action-btn--ghost{color:var(--color-accent);border:1.5px solid var(--color-border);background:0 0}.matchmaking-view{background:linear-gradient(170deg,var(--color-bg),var(--color-navy-mid),var(--color-bg));flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;padding:2rem 1.5rem;display:flex}.matchmaking-players{align-items:center;gap:24px;display:flex}.matchmaking-vs{color:var(--color-text-muted);font-size:20px;font-weight:700;transition:color .3s}.matchmaking-vs--found{color:var(--color-primary-bright)}.matchmaking-circles{gap:8px;display:flex}.matchmaking-circle{border:1.5px dashed var(--color-border);border-radius:50%;width:40px;height:40px;animation:2s linear infinite spinCircle}.matchmaking-circle:nth-child(2){animation-delay:.4s}.matchmaking-circle:nth-child(3){animation-delay:.8s}.matchmaking-circle:nth-child(4){animation-delay:1.2s}.matchmaking-circle:nth-child(5){animation-delay:1.6s}@keyframes spinCircle{0%{border-color:var(--color-border)}50%{border-color:var(--color-primary)}to{border-color:var(--color-border)}}.matchmaking-config-pill{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-sec);padding:6px 16px;font-size:13px}.matchmaking-timer{font-family:var(--font-mono);color:var(--color-text-muted);font-size:16px}.matchmaking-status{color:var(--color-text-sec);font-size:14px;animation:.3s fadeIn}.matchmaking-cancel-btn{color:var(--color-accent);cursor:pointer;background:0 0;border:none;padding:8px 16px;font-size:14px}.landing-screen{background:linear-gradient(170deg,var(--color-bg),var(--color-navy-mid),var(--color-bg));flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;padding:2rem 1rem;display:flex}.landing-logo-img{width:120px;height:auto;display:block}.landing-subtitle{letter-spacing:2px;text-transform:uppercase;color:var(--color-cream);font-size:13px;font-weight:600}.landing-tagline{color:var(--color-text-sec);text-align:center;font-size:14px}.landing-ctas{flex-direction:column;gap:12px;width:100%;max-width:360px;display:flex}.landing-btn-play{background:var(--grad-teal);color:#fff;border-radius:var(--radius-btn);cursor:pointer;width:100%;box-shadow:var(--shadow-glow-teal);transition:opacity var(--transition);text-align:center;border:none;padding:16px;font-size:16px;font-weight:700;text-decoration:none;display:block}.landing-btn-play:hover{opacity:.9}.landing-btn-ghost{width:100%;color:var(--color-cream);border:1.5px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;transition:border-color var(--transition),opacity var(--transition);text-align:center;background:0 0;padding:14px;font-size:15px;font-weight:600;text-decoration:none;display:block}.landing-btn-ghost:hover{border-color:var(--color-text-muted)}.landing-how{text-align:center;width:100%;max-width:360px}.landing-how__title{color:var(--color-text);margin-bottom:12px;font-size:18px;font-weight:700}.landing-how__cards{justify-content:center;gap:12px;display:flex}.landing-how__card{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 10px;display:flex}.landing-how__icon{font-size:22px}.landing-how__step-title{color:var(--color-text);font-size:13px;font-weight:700}.landing-how__step-desc{color:var(--color-text-muted);font-size:11px}.landing-footer{color:var(--color-text-muted);text-align:center;font-size:12px}.landing-footer__link{color:var(--color-primary);text-decoration:none}.auth-screen{background:linear-gradient(170deg,var(--color-bg),var(--color-navy-mid),var(--color-bg));flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;min-height:100vh;padding:2rem 1.5rem;display:flex;position:relative;overflow:hidden}.auth-logo-img{width:80px;height:auto;margin:0 auto;display:block}.auth-logo-mark{font-family:var(--font-display);letter-spacing:.08em;color:var(--color-primary-bright);text-shadow:0 0 60px var(--color-primary-glow),0 2px 4px #0000004d;text-align:center;font-size:clamp(3.5rem,10vw,6rem);font-weight:700;line-height:1}.auth-tagline{color:var(--color-text-sec);text-align:center;font-size:1rem}.auth-divider{width:100%;max-width:320px;color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:1rem;font-size:.75rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-buttons{flex-direction:column;gap:.85rem;width:100%;max-width:320px;display:flex}.auth-buttons .btn{width:100%;padding:.9rem 2rem}.auth-subtitle{font-family:var(--font-body);letter-spacing:.3em;text-transform:uppercase;color:var(--color-text-muted);text-align:center;font-size:.85rem;font-weight:500}.auth-footnote{color:var(--color-text-muted);text-align:center;font-size:.8rem}.auth-footnote a,.auth-footnote button{color:var(--color-text-sec);cursor:pointer;font-size:inherit;transition:color var(--transition);background:0 0;border:none;text-decoration:underline}.auth-footnote a:hover,.auth-footnote button:hover{color:var(--color-primary-bright)}.lobby-screen{background:var(--color-bg-warm);min-height:100vh;padding-bottom:76px}.lobby-hub{max-width:480px;animation:slideUp .3s var(--ease-out);flex-direction:column;gap:1.25rem;margin:0 auto;padding:1.5rem 1rem 1rem;display:flex}.lobby-hub__greeting{color:var(--color-text-sec);font-size:13px}.lobby-hub__greeting strong{color:var(--color-cream);font-weight:800}.hero-play-btn{background:var(--grad-teal);color:#fff;border-radius:var(--radius-btn);cursor:pointer;width:100%;box-shadow:var(--shadow-glow-teal);transition:opacity var(--transition);border:none;justify-content:center;align-items:center;gap:8px;padding:18px;font-size:18px;font-weight:700;display:flex}.hero-play-btn:hover{opacity:.9}.lobby-section-title{color:var(--color-text);margin-bottom:8px;font-size:15px;font-weight:700}.your-games{flex-direction:column;gap:8px;display:flex}.game-row{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);cursor:pointer;transition:border-color var(--transition);align-items:center;gap:12px;padding:12px 14px;display:flex}.game-row:hover{border-color:var(--color-primary)}.game-row__info{flex:1;min-width:0}.game-row__opponent{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.game-row__meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.game-row__status{color:var(--color-text-muted);white-space:nowrap;font-size:11px;font-weight:700}.waiting-room{flex-direction:column;gap:1.25rem;max-width:480px;margin:0 auto;padding:1.5rem 1rem;display:flex}.waiting-room__back-btn{color:var(--color-cream);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:14px;font-weight:600;display:flex}.waiting-room__code-hero{text-align:center}.waiting-room__code{font-family:var(--font-mono);letter-spacing:12px;color:var(--color-primary-bright);text-shadow:0 0 30px #2dd4bf4d;margin-bottom:10px;font-size:48px;font-weight:700;display:block}.waiting-room__copy-btn{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-sec);cursor:pointer;transition:background var(--transition),color var(--transition);padding:6px 16px;font-size:12px;font-weight:600}.waiting-room__copy-btn--copied{color:var(--color-primary-bright);border-color:var(--color-primary);background:#0d948826}.config-pills{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.config-pill{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-sec);padding:4px 12px;font-size:12px}.waiting-room__divider{background:var(--color-border);height:1px}.waiting-room__players-header{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:13px;font-weight:700}.player-list{flex-direction:column;gap:8px;display:flex}.player-list-item{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);align-items:center;gap:12px;padding:12px 14px;display:flex}.player-list-item__info{flex:1}.player-list-item__handle{color:var(--color-text);font-size:14px;font-weight:700}.player-list-item__badges{align-items:center;gap:6px;margin-top:2px;display:flex}.host-badge{color:var(--color-gold);border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.05em;background:#f5a62326;border:1px solid #f5a6234d;padding:1px 7px;font-size:10px;font-weight:700}.player-status-dot{background:var(--color-success);border-radius:50%;flex-shrink:0;width:8px;height:8px}.empty-slot{border:1.5px dashed var(--color-border);border-radius:var(--radius-base);color:var(--color-text-muted);justify-content:center;align-items:center;padding:14px;font-size:13px;font-style:italic;display:flex}.waiting-room__share-btn{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;color:var(--color-text-sec);cursor:pointer;transition:border-color var(--transition);padding:12px;font-size:14px;font-weight:600}.waiting-room__share-btn:hover{border-color:var(--color-text-muted)}.waiting-room__start-btn{background:var(--grad-teal);border-radius:var(--radius-btn);color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-glow-teal);transition:opacity var(--transition);border:none;padding:16px;font-size:16px;font-weight:700}.waiting-room__start-btn:disabled{background:var(--color-surface-2);box-shadow:none;opacity:.5;cursor:not-allowed}.quick-match-view{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:60vh;padding:2rem 1rem;display:flex}.quick-match-view p{color:var(--color-text-sec);font-size:14px}.history-screen{background:var(--color-bg-warm);max-width:480px;min-height:100vh;margin:0 auto;padding:1.5rem 1rem calc(76px + 1rem)}.history-title{color:var(--color-text);margin-bottom:1rem;font-size:26px;font-weight:800}.history-stats-row{gap:10px;margin-bottom:1rem;display:flex}.history-stat-card{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-base);flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px 8px;display:flex}.history-stat-icon{font-size:18px}.history-stat-value{color:var(--color-text);font-size:18px;font-weight:800}.history-stat-label{color:var(--color-text-muted);text-align:center;font-size:10px}.history-filter-pills{scrollbar-width:none;gap:8px;margin-bottom:1rem;padding-bottom:4px;display:flex;overflow-x:auto}.history-filter-pills::-webkit-scrollbar{display:none}.history-filter-pill{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;transition:all var(--transition);flex-shrink:0;padding:5px 14px;font-size:12px;font-weight:500}.history-filter-pill--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:700}.history-list{flex-direction:column;display:flex}.history-row{border-bottom:.5px solid var(--color-border);align-items:center;gap:12px;padding:10px 0;display:flex}.history-row__info{flex:1;min-width:0}.history-row__opponent{color:var(--color-text);font-size:14px;font-weight:700}.history-row__meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.history-empty{color:var(--color-text-muted);text-align:center;padding:2rem 0;font-size:14px}.history-entry{border-bottom:.5px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex}.history-entry-meta{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.history-entry-date{color:var(--color-text-muted);white-space:nowrap;font-size:12px}.history-entry-variant{align-items:center;display:flex}.history-variant-badge{color:#fff;background:var(--color-primary);border-radius:var(--radius-pill);white-space:nowrap;padding:2px 8px;font-size:11px;font-weight:700}.history-entry-opponents{color:var(--color-text-muted);white-space:nowrap;font-size:11px}.history-entry-result{align-items:center;gap:8px;display:flex}.history-score{color:var(--color-text);font-size:14px;font-weight:700}.history-score--win{color:var(--color-gold)}.history-score--loss{color:var(--color-text-muted)}.history-indicator{text-align:center;border-radius:4px;min-width:28px;padding:4px 8px;font-size:12px;font-weight:700}.history-indicator--win{color:var(--color-success);background:#22c55e33}.history-indicator--loss{color:var(--color-error);background:#ef444433}.match-history-screen{background:var(--color-bg-warm,#0a1120);max-width:800px;min-height:100vh;margin:0 auto;padding:2rem 2rem calc(76px + 1rem)}.match-history-screen__header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.match-history-screen__title{color:var(--color-text,#e8ecf4);letter-spacing:.01em;font-size:28px;font-weight:800}.match-history-screen__section-title{color:var(--color-text-muted,#5a6a80);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;font-size:13px;font-weight:700}.match-history-screen__standings{margin-bottom:2rem}.match-history-screen__standings-list{background:var(--color-surface-1,#141e35);border:1px solid var(--color-border,#1e2e48);border-radius:16px;margin:0;padding:0;list-style:none;overflow:hidden}.match-history-screen__standing-row{border-bottom:1px solid var(--color-border,#1e2e48);align-items:center;gap:14px;padding:14px 20px;transition:background-color .15s;display:flex}.match-history-screen__standing-row:last-child{border-bottom:none}.match-history-screen__standing-row--you{background:#0d94880f}.match-history-screen__rank{color:var(--color-gold,#f5a623);min-width:28px;font-size:14px;font-weight:800}.match-history-screen__standing-handle{color:var(--color-text,#e8ecf4);flex:1;font-size:15px;font-weight:600}.match-history-screen__total-score{color:var(--color-teal,#0d9488);text-align:right;min-width:60px;font-size:15px;font-weight:800}.match-history-screen__record{color:var(--color-text-muted,#5a6a80);text-align:right;min-width:60px;font-size:13px;font-weight:600}.match-history-screen__hands{margin-bottom:2rem}.match-history-screen__hand-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.match-history-screen__empty{color:var(--color-text-muted,#5a6a80);text-align:center;padding:2rem 0;font-size:14px}.hand-result-card{background:var(--color-surface-1,#141e35);border:1px solid var(--color-border,#1e2e48);border-radius:16px;transition:border-color .2s;overflow:hidden}.hand-result-card:hover{border-color:#ffffff14}.hand-result-card__header{cursor:pointer;align-items:center;gap:12px;padding:14px 20px;display:flex}.hand-result-card__number{color:var(--color-text-sec,#8899b0);white-space:nowrap;font-size:14px;font-weight:700}.hand-result-card__winner{color:var(--color-gold,#f5a623);white-space:nowrap;background:#f5a6231a;border-radius:100px;padding:2px 10px;font-size:14px;font-weight:700}.hand-result-card__scores{flex-wrap:wrap;flex:1;gap:10px;display:flex}.hand-result-card__score{color:var(--color-text-muted,#5a6a80);font-size:13px;font-weight:600}.hand-result-card__score--you{color:var(--color-teal,#0d9488)}.hand-result-card__toggle{background:var(--color-surface-2,#1a2845);border:1px solid var(--color-border,#1e2e48);width:32px;height:32px;color:var(--color-text-muted,#5a6a80);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;transition:all .15s;display:flex}.hand-result-card__toggle:hover{background:#ffffff0f}.hand-result-card__detail{border-top:1px solid var(--color-border,#1e2e48);flex-direction:column;gap:16px;padding:0 20px 16px;display:flex}.hand-result-card__player-hands{padding-top:14px}.hand-result-card__player-name{color:var(--color-text,#e8ecf4);margin-bottom:10px;font-size:14px;font-weight:700;display:block}.hand-result-card__you-badge{color:var(--color-teal,#0d9488);font-weight:600}.hand-result-card__subhands{flex-wrap:wrap;gap:20px;display:flex}.hand-result-card__subhand{align-items:center;gap:6px;display:flex}.hand-result-card__subhand-label{color:var(--color-cream,#fff5e0);min-width:36px;font-size:12px;font-weight:700}.profile-screen{background:var(--color-bg-warm);max-width:800px;min-height:100vh;margin:0 auto;padding:1.5rem 2rem calc(76px + 1rem)}.profile-hero{text-align:center;flex-direction:column;align-items:center;gap:10px;margin-bottom:1.5rem;display:flex}.profile-handle{color:var(--color-text);font-size:24px;font-weight:800}.profile-since{color:var(--color-text-muted);font-size:12px}.profile-stats{margin-bottom:1.5rem}.profile-stats__grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.profile-stat-tile{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:4px;padding:14px 8px;display:flex}.profile-stat-tile__icon{font-size:20px}.profile-stat-tile__value{color:var(--color-text);font-size:22px;font-weight:700}.profile-stat-tile__label{color:var(--color-text-muted);text-align:center;font-size:11px}.profile-section-title{color:var(--color-text);margin-bottom:12px;font-size:18px;font-weight:700}.profile-card-backs{margin-bottom:1.5rem}.card-backs-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.card-back-thumb{background:var(--grad-navy);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;height:68px;display:flex;position:relative;overflow:hidden}.card-back-thumb--active{border:2.5px solid var(--color-gold);box-shadow:var(--shadow-glow-gold)}.card-back-thumb--locked{opacity:.5;cursor:default}.card-back-thumb__check{font-size:12px;position:absolute;top:4px;right:4px}.card-back-thumb__lock{font-size:18px}.card-back-thumb__watermark{opacity:.2;color:#fff;font-size:12px;font-weight:700}.profile-signout-btn{border:1.5px solid var(--color-border);border-radius:var(--radius-btn);width:100%;color:var(--color-accent);cursor:pointer;transition:border-color var(--transition),opacity var(--transition);background:0 0;padding:14px;font-size:15px;font-weight:600}.profile-signout-btn:hover{border-color:var(--color-accent);opacity:.85}.profile-rating-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:20px;padding:20px 24px}.profile-rating__badge{align-items:baseline;gap:12px;margin-bottom:12px;display:flex}.profile-rating__rank{color:var(--color-gold,#f5a623);font-size:22px;font-weight:700}.profile-rating__pts{color:var(--color-text-secondary);font-size:13px}.profile-rating__bar{background:var(--color-border);border-radius:4px;width:100%;height:8px;margin-bottom:8px;overflow:hidden}.profile-rating__bar-fill{background:linear-gradient(90deg,#f5a623,#ffd060);border-radius:4px;height:100%;transition:width .4s}.profile-rating__next{color:var(--color-text-secondary);font-size:12px}.profile-prefs-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:20px;padding:20px 24px}.profile-pref-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.profile-pref-row:last-child{border-bottom:none}.profile-pref-row__label{color:var(--color-text-secondary);font-size:14px}.profile-pref-toggle{background:var(--color-border);cursor:pointer;width:44px;height:24px;transition:background var(--transition);border:none;border-radius:12px;flex-shrink:0;padding:0;position:relative}.profile-pref-toggle--on{background:var(--color-primary)}.profile-pref-toggle__thumb{width:18px;height:18px;transition:transform var(--transition);pointer-events:none;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.profile-pref-toggle--on .profile-pref-toggle__thumb{transform:translate(20px)}.profile-pref-select{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text-primary);cursor:pointer;padding:6px 10px;font-size:13px}.app-shell{background:var(--color-bg-warm);min-height:100vh}.landing-screen{background:radial-gradient(ellipse at 50% 30%,#0d948826,transparent 60%),var(--color-bg);min-height:calc(100vh - var(--topnav-height,56px));flex-direction:column;flex:1;justify-content:center;align-items:center;padding:48px 24px;display:flex}.landing-screen__hero{text-align:center;flex-direction:column;align-items:center;gap:28px;max-width:640px;display:flex}.landing-screen__tagline{color:var(--color-text-sec);max-width:500px;margin:0;font-size:18px;line-height:1.6}.landing-screen__cta-row{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.landing-screen__cta-primary{padding:14px 32px;font-size:18px;font-weight:700}.landing-screen__stats{flex-wrap:wrap;justify-content:center;gap:40px;display:flex}.landing-screen__stat{flex-direction:column;align-items:center;gap:4px;display:flex}.landing-screen__stat-number{color:var(--color-primary-bright);font-size:28px;font-weight:800}.landing-screen__stat-label{color:var(--color-text-muted);font-size:12px}.how-to-play-modal{background:var(--color-surface-1);border:1px solid var(--color-border);border-radius:24px;width:100%;max-width:640px;max-height:80vh;overflow-y:auto;box-shadow:0 24px 64px #00000080}.how-to-play-modal__header{border-bottom:1px solid var(--color-border);background:var(--color-surface-1);justify-content:space-between;align-items:center;padding:24px 32px 16px;display:flex;position:sticky;top:0}.how-to-play-modal__title{color:var(--color-cream);margin:0;font-size:24px;font-weight:800}.how-to-play-modal__close{border:1px solid var(--color-border);width:36px;height:36px;color:var(--color-text-sec);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex}.how-to-play-modal__body{flex-direction:column;gap:24px;padding:24px 32px 32px;display:flex}.how-to-play-modal__steps{flex-direction:column;gap:16px;display:flex}.how-to-play-step{background:var(--color-surface-2);border-radius:14px;align-items:flex-start;gap:16px;padding:16px 20px;display:flex}.how-to-play-step__icon{flex-shrink:0;font-size:24px}.how-to-play-step__title{color:var(--color-text);margin:0 0 4px;font-size:15px;font-weight:700}.how-to-play-step__desc{color:var(--color-text-sec);margin:0;font-size:13px;line-height:1.5}.how-to-play-modal__got-it{width:100%}.modal-overlay{background:var(--glass-overlay,#0a1120d9);-webkit-backdrop-filter:blur(12px);z-index:200;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.room-screen{background:radial-gradient(ellipse at 50% 30%,#0d948814,transparent 50%),var(--color-bg);flex:1;justify-content:center;align-items:center;padding:48px 24px;display:flex}.room-card{background:var(--color-surface-1);border:1px solid var(--color-border);width:100%;max-width:680px;box-shadow:var(--shadow-elevated);border-radius:20px;overflow:hidden}.room-card__header{text-align:center;border-bottom:1px solid var(--color-border);background:linear-gradient(135deg,#0d948826,#1a2d4d4d);padding:32px 32px 24px}.room-card__code-label{color:var(--color-text-muted);letter-spacing:2px;margin:0 0 8px;font-size:12px;font-weight:700}.room-card__code{color:var(--color-primary-bright);font-size:56px;font-weight:800;font-family:var(--font-mono);letter-spacing:16px;text-shadow:0 0 30px #2dd4bf59;margin-bottom:16px}.room-card__copy-btn{border-radius:var(--radius-pill);border:1px solid var(--color-primary);color:var(--color-primary-bright);cursor:pointer;background:0 0;margin-bottom:16px;padding:8px 20px;font-size:13px;font-weight:600}.room-card__tags{justify-content:center;gap:8px;display:flex}.room-card__tag{border-radius:var(--radius-pill);background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text-sec);padding:4px 14px;font-size:12px;font-weight:600}.room-card__players{border-bottom:1px solid var(--color-border);padding:24px 32px}.room-card__players-title{color:var(--color-text-sec);margin:0 0 16px;font-size:14px;font-weight:700}.room-card__player-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.room-card__player-row{align-items:center;gap:12px;display:flex}.room-card__player-handle{color:var(--color-text);flex:1;font-size:15px;font-weight:600}.room-card__host-badge{color:var(--color-gold);border-radius:var(--radius-pill);letter-spacing:1px;background:#f5a6231f;border:1px solid #f5a6234d;padding:2px 8px;font-size:10px;font-weight:700}.room-card__online-dot{background:var(--color-success);border-radius:50%;flex-shrink:0;width:8px;height:8px}.room-card__player-row--empty{opacity:.5}.room-card__empty-avatar{border:2px dashed var(--color-border);border-radius:50%;width:40px;height:40px}.room-card__waiting-text{color:var(--color-text-muted);font-size:14px;font-style:italic}.room-card__actions{justify-content:flex-end;gap:12px;padding:20px 32px;display:flex}.signin-screen{background:radial-gradient(ellipse at 50% 30%,#0d94881a 0%,transparent 50%),var(--color-bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.signin-card{background:var(--color-surface-1);border:1px solid var(--color-border);text-align:center;z-index:1;border-radius:24px;flex-direction:column;align-items:center;gap:0;width:480px;padding:40px 36px;display:flex;position:relative;box-shadow:0 12px 48px #0006}.signin-card__subtitle{color:var(--color-text-muted);margin:8px 0 28px;font-size:13px}.signin-card__buttons{flex-direction:column;gap:10px;width:100%;display:flex}.signin-btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;height:48px;font-size:15px;font-weight:600;transition:opacity .2s;display:flex}.signin-btn:hover{opacity:.9}.signin-btn--apple{color:#1a1a2e;background:#fff;box-shadow:0 2px 12px #ffffff1a}.signin-btn--outline{color:var(--color-text);border:1.5px solid var(--color-border);background:0 0}.signin-btn--teal{background:var(--grad-teal);color:#fff}.signin-btn--compact{flex-shrink:0;width:auto;padding:0 20px}.signin-email-row{gap:8px;width:100%;display:flex}.signin-email-input{background:var(--color-surface-2);border:1px solid var(--color-border);color:var(--color-text);border-radius:12px;outline:none;flex:1;padding:12px 14px;font-size:14px}.signin-card__divider{align-items:center;gap:12px;width:100%;margin:16px 0;display:flex}.signin-card__divider:before,.signin-card__divider:after{content:"";background:var(--color-border);flex:1;height:1px}.signin-card__divider span{color:var(--color-text-muted);font-size:12px}.signin-card__guest-btn{cursor:pointer;color:var(--color-primary-bright);background:0 0;border:none;padding:8px;font-size:15px;font-weight:600}.signin-card__guest-note{color:var(--color-text-muted);margin:4px 0 0;font-size:11px}.top-nav{height:var(--topnav-height,56px);background:var(--topnav-bg,#0a1120f2);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);z-index:100;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.top-nav__left,.top-nav__right{align-items:center;gap:8px;display:flex}.top-nav__brand{color:var(--color-cream);align-items:center;gap:8px;text-decoration:none;display:flex}.top-nav__brand-name{color:var(--color-cream);letter-spacing:.5px;font-size:18px;font-weight:800}.top-nav__divider{background:var(--color-border);width:1px;height:28px;margin:0 8px}.top-nav__nav-link{color:var(--color-text-muted);border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:all .2s}.top-nav__nav-link:hover{color:var(--color-text-sec);background:#0d948814}.top-nav__nav-link--active{color:var(--color-primary-bright);background:#0d948826;font-weight:700}.top-nav__in-game-pill{border-radius:var(--radius-pill);color:var(--color-primary-bright);background:#0d948826;padding:4px 14px;font-size:12px;font-weight:600}.top-nav__record{color:var(--color-text-sec);font-size:13px}.top-nav__wins{color:var(--color-success);font-weight:700}.top-nav__losses{color:var(--color-error);font-weight:700}.top-nav__profile-btn{background:0 0;border-radius:10px;align-items:center;gap:8px;padding:4px 10px;text-decoration:none;transition:background .2s;display:flex}.top-nav__profile-btn:hover{background:#0d94881a}.top-nav__handle{color:var(--color-cream);font-size:13px;font-weight:600}.top-nav__chevron{color:var(--color-text-muted);font-size:10px}.top-nav__signin-btn{background:var(--grad-teal);color:#fff;border-radius:10px;padding:8px 20px;font-size:13px;font-weight:700;text-decoration:none;transition:opacity .2s}.top-nav__signin-btn:hover{opacity:.9}.page-with-topnav{min-height:100vh;padding-top:var(--topnav-height,56px);flex-direction:column;display:flex}.results-screen-wrapper{background:linear-gradient(135deg,#0a1120,#141e35,#0f1828);flex-direction:column;flex:1;display:flex}.results-screen{flex:1;justify-content:center;align-items:center;padding:24px;display:flex;overflow-y:auto}.results-screen .score-overlay__content{width:100%;max-width:780px;margin:auto}.results-screen .confetti-particle{pointer-events:none;z-index:79;position:fixed}@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-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@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-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@keyframes pulse{50%{opacity:.5}}
