/*! tailwindcss v4.2.4 | 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-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-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction: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-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial}}}@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-600:oklch(57.7% .245 27.325);--color-yellow-400:oklch(85.2% .199 91.936);--color-green-500:oklch(72.3% .219 149.579);--color-purple-500:oklch(62.7% .265 303.9);--color-slate-300:oklch(86.9% .022 252.894);--color-slate-400:oklch(70.4% .04 256.788);--color-slate-500:oklch(55.4% .046 257.417);--color-slate-800:oklch(27.9% .041 260.031);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--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);--font-weight-bold:700;--tracking-wider:.05em;--tracking-widest:.1em;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-sm:8px;--blur-md:12px;--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%;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;-webkit-text-decoration:inherit;-webkit-text-decoration: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]){appearance:button}::file-selector-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-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.start\!{inset-inline-start:var(--spacing)!important}.end{inset-inline-end:var(--spacing)}.z-10{z-index:10}.z-20{z-index:20}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.table{display:table}.aspect-\[9\/10\]{aspect-ratio:9/10}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-12{width:calc(var(--spacing) * 12)}.w-full{width:100%}.max-w-\[500px\]{max-width:500px}.flex-1{flex:1}.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)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-9{grid-template-columns:repeat(9,minmax(0,1fr))}.grid-rows-10{grid-template-rows:repeat(10,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}: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)))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-\[\#333\]{border-color:#333}.border-\[\#d32f2f\]{border-color:#d32f2f}.border-purple-500{border-color:var(--color-purple-500)}.border-transparent{border-color:#0000}.border-white{border-color:var(--color-white)}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab, red, red)){.border-white\/20{border-color:color-mix(in oklab, var(--color-white) 20%, transparent)}}.border-white\/50{border-color:#ffffff80}@supports (color:color-mix(in lab, red, red)){.border-white\/50{border-color:color-mix(in oklab, var(--color-white) 50%, transparent)}}.bg-\[\#f4e4c1\]{background-color:#f4e4c1}.bg-green-500{background-color:var(--color-green-500)}.bg-purple-500\/50{background-color:#ac4bff80}@supports (color:color-mix(in lab, red, red)){.bg-purple-500\/50{background-color:color-mix(in oklab, var(--color-purple-500) 50%, transparent)}}.bg-slate-300{background-color:var(--color-slate-300)}.bg-white{background-color:var(--color-white)}.bg-white\/40{background-color:#fff6}@supports (color:color-mix(in lab, red, red)){.bg-white\/40{background-color:color-mix(in oklab, var(--color-white) 40%, transparent)}}.bg-white\/50{background-color:#ffffff80}@supports (color:color-mix(in lab, red, red)){.bg-white\/50{background-color:color-mix(in oklab, var(--color-white) 50%, transparent)}}.bg-yellow-400\/20{background-color:#fac80033}@supports (color:color-mix(in lab, red, red)){.bg-yellow-400\/20{background-color:color-mix(in oklab, var(--color-yellow-400) 20%, transparent)}}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.py-1{padding-block:calc(var(--spacing) * 1)}.pr-2{padding-right:calc(var(--spacing) * 2)}.font-mono{font-family:var(--font-mono)}.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)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-\[\#333\]{color:#333}.text-\[\#d32f2f\]{color:#d32f2f}.text-red-600{color:var(--color-red-600)}.text-slate-400{color:var(--color-slate-400)}.text-slate-500{color:var(--color-slate-500)}.text-slate-800{color:var(--color-slate-800)}.capitalize{text-transform:capitalize}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.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-\[0_4px_0_rgba\(0\,0\,0\,0\.1\)\,0_8px_16px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:0 4px 0 var(--tw-shadow-color,#0000001a), 0 8px 16px 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-\[inset_0_2px_4px_rgba\(0\,0\,0\,0\.1\)\]{--tw-shadow:inset 0 2px 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-inner{--tw-shadow:inset 0 2px 4px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--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-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-purple-500{--tw-ring-color:var(--color-purple-500)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur-md{--tw-backdrop-blur:blur(var(--blur-md));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{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))}.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)}.select-none{-webkit-user-select:none;user-select:none}@media (hover:hover){.hover\:scale-105:hover{--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x) var(--tw-scale-y)}}@media (width>=48rem){.md\:h-12{height:calc(var(--spacing) * 12)}.md\:w-12{width:calc(var(--spacing) * 12)}.md\:p-6{padding:calc(var(--spacing) * 6)}.md\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}}}:root{--font-sans:"Inter", system-ui, sans-serif;--font-display:"Outfit", system-ui, sans-serif;--color-bg:#f4f4f9;--color-surface:#fff;--color-surface-2:#fcfaff;--color-surface-3:#eee7ff;--color-border:#673ab71f;--color-border-hover:#673ab74d;--color-primary:#673ab7;--color-primary-400:#7e57c2;--color-primary-600:#512da8;--color-accent:#f5a623;--color-accent-soft:#f5a6231a;--color-text:#2d1d4d;--color-text-muted:#6a51a3;--color-text-faint:#9e9e9e;--color-success:#059669;--color-error:#dc2626;--color-warning:#d97706;--gradient-primary:linear-gradient(135deg, #673ab7 0%, #512da8 100%);--gradient-gold:linear-gradient(135deg, #f5a623 0%, #f7941d 100%);--gradient-surface:linear-gradient(180deg, #fff 0%, #f4f4f9 100%);--gradient-glass:linear-gradient(135deg, #fffc 0%, #fff6 100%);--shadow-sm:0 2px 8px #0000000d;--shadow-md:0 4px 16px #673ab714;--shadow-lg:0 12px 32px #673ab71f;--shadow-glow:0 0 20px #673ab726;--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-xl:32px;--transition:.25s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg:#0f0f1a;--color-surface:#1a1a2e;--color-surface-2:#252540;--color-surface-3:#2f2f50;--color-border:#ffffff14;--color-border-hover:#ffffff2e;--color-primary:#7c3aed;--color-primary-400:#a78bfa;--color-primary-600:#6d28d9;--color-accent:#f5a623;--color-accent-soft:#f5a62326;--color-text:#e2e8f0;--color-text-muted:#94a3b8;--color-text-faint:#64748b;--color-success:#34d399;--color-error:#f87171;--color-warning:#fbbf24;--gradient-primary:linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);--gradient-gold:linear-gradient(135deg, #f5a623 0%, #f7941d 100%);--gradient-surface:linear-gradient(180deg, #1a1a2e 0%, #0f0f1a 100%);--gradient-glass:linear-gradient(135deg, #1a1a2ecc 0%, #0f0f1a99 100%);--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 12px 32px #00000080;--shadow-glow:0 0 20px #7c3aed4d}[data-theme=dark] .navbar{background:#0f0f1ae6;border-bottom-color:#ffffff0f;box-shadow:0 4px 20px #0000004d}[data-theme=dark] .bottom-nav{background:#0f0f1aeb;border-top-color:#ffffff0f}[data-theme=dark] .circle-icon{background:#252540;border-color:#ffffff0d}@media (width>=640px){[data-theme=dark] body{background:#080812}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;height:100%;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;line-height:1.6;overflow-x:hidden}main{padding:0}#root{background:var(--color-surface);width:100%;max-width:100%;height:100%;box-shadow:none;flex-direction:column;margin:0 auto;display:flex;position:relative;overflow-x:hidden}@media (width>=768px){#root{max-width:680px}}@media (width>=1024px){body{background:#1a1a2e}#root{border-left:1px solid #ffffff0d;border-right:1px solid #ffffff0d;max-width:720px;min-height:100vh;box-shadow:0 0 60px #00000080}}@media (width>=1366px){#root{max-width:800px}}h1,h2,h3,h4{font-family:var(--font-display);color:var(--color-text);line-height:1.2}h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800}h2{font-size:clamp(1.4rem,3vw,2rem);font-weight:700}h3{font-size:1.2rem;font-weight:600}p{color:var(--color-text-muted)}a{color:var(--color-primary-400);transition:color var(--transition);text-decoration:none}a:hover{color:var(--color-text)}.container{width:100%;max-width:480px;margin:0 auto;padding:0 1rem}@media (width>=768px){.container{max-width:640px;padding:0 1.5rem}}@media (width>=1024px){.container{max-width:680px}}@media (width>=1366px){.container{max-width:760px}}.page{flex:1;padding:2rem 0}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.text-center{text-align:center}.w-full{width:100%}.min-h-screen{min-height:100vh}.grid{display:grid}.hidden-mobile{display:block}.show-mobile{display:none}@media (width<=640px){.hidden-mobile{display:none!important}.show-mobile{display:block!important}.container{padding:0 1rem}.page{padding:1rem 0}.card{border-radius:var(--radius-md);padding:1rem}h1{font-size:1.5rem}h2{font-size:1.2rem}}.bottom-nav{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1000;width:100%;max-width:100%;height:65px;padding-bottom:env(safe-area-inset-bottom);transition:all var(--transition);background:#ffffffe6;border-top:1px solid #0000000d;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}@media (width>=768px){.bottom-nav{max-width:680px}}@media (width>=1024px){.bottom-nav{max-width:720px}}@media (width>=1366px){.bottom-nav{max-width:800px}}.nav-item{color:#94a3b8;cursor:pointer;transition:all var(--transition);flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:44px;padding:4px 8px;font-size:.75rem;font-weight:600;display:flex}.nav-item.active{color:var(--color-primary);transform:translateY(-2px)}.nav-item-icon{font-size:1.3rem}.circle-icon{width:72px;height:72px;transition:all var(--transition);background:#f8f9fa;border:1px solid #0000000a;border-radius:24px;justify-content:center;align-items:center;margin-bottom:10px;font-size:2rem;display:flex;box-shadow:0 4px 12px #00000008}.card-game:hover .circle-icon{border-color:#673ab733;transform:translateY(-5px);box-shadow:0 12px 24px #673ab726}.game-label{color:var(--color-text);letter-spacing:-.01em;font-size:.8rem;font-weight:700}.section-title{color:var(--color-text);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:10px;margin-bottom:1.5rem;font-size:.95rem;font-weight:800;display:flex}.section-title:after{content:"";background:#0000000d;flex:1;height:1px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition);padding:1.5rem}.card:hover{border-color:var(--color-border-hover)}.card-glass{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:#12121fcc}.hover-scale{transition:transform var(--transition)}.hover-scale:hover{transform:scale(1.02)}.cursor-pointer{cursor:pointer}.opacity-50{opacity:.5}.btn{border-radius:var(--radius-md);min-height:44px;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-size:.95rem;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 32px #7c3aed80}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-3);border-color:var(--color-border-hover)}.btn-ghost{color:var(--color-text-muted);border:1px solid var(--color-border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--color-surface-2);color:var(--color-text)}.btn-gold{background:var(--gradient-gold);color:#000;font-weight:700}.btn-gold:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 24px #f4b94266}.btn-danger{color:var(--color-error);background:#f8717126;border:1px solid #f871714d}.btn-danger:hover:not(:disabled){background:#f8717140}.btn-lg{border-radius:var(--radius-lg);padding:.9rem 2rem;font-size:1.1rem}.btn-sm{min-height:36px;padding:.4rem .9rem;font-size:.85rem}.btn-icon{border-radius:var(--radius-sm);padding:.6rem}.badge{letter-spacing:.02em;border-radius:100px;align-items:center;gap:.3rem;padding:.2rem .7rem;font-size:.78rem;font-weight:600;display:inline-flex}.badge-purple{color:var(--color-primary-400);background:#7c3aed33;border:1px solid #7c3aed4d}.badge-gold{background:var(--color-accent-soft);color:var(--color-accent);border:1px solid #f4b9424d}.badge-green{color:var(--color-success);background:#34d39926;border:1px solid #34d3994d}.badge-red{color:var(--color-error);background:#f8717126;border:1px solid #f871714d}.badge-gray{background:var(--color-surface-2);color:var(--color-text-muted);border:1px solid var(--color-border)}.input{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-sans);width:100%;transition:border-color var(--transition);outline:none;padding:.65rem 1rem;font-size:.95rem}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed26}.input::placeholder{color:var(--color-text-faint)}.divider{background:var(--color-border);height:1px;margin:1.5rem 0}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid var(--color-surface-3);border-top-color:var(--color-primary);border-radius:50%;width:2rem;height:2rem;animation:.7s linear infinite spin}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{50%{opacity:.5}}@keyframes glow{0%,to{box-shadow:var(--shadow-glow)}50%{box-shadow:0 0 40px #7c3aed80}}.animate-fade-in{animation:.4s both fadeIn}.animate-slide-up{animation:.5s both slideUp}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-glow{animation:2s ease-in-out infinite glow}@keyframes heartFloat{0%{opacity:1;transform:translateY(0)translate(0)scale(.5)rotate(0)}20%{opacity:1;transform:translateY(-20vh) translateX(calc(var(--heart-drift) * .3)) scale(1) rotate(10deg)}60%{opacity:.8;transform:translateY(-60vh) translateX(var(--heart-drift)) scale(1.1) rotate(-5deg)}to{opacity:0;transform:translateY(-105vh) translateX(calc(var(--heart-drift) * 1.2)) scale(.8) rotate(15deg)}}.game-toast-error{border-color:#ef444466!important;border-left-style:solid!important;border-left-width:3px!important;box-shadow:0 8px 32px #00000080,0 0 20px #ef444426,inset 0 0 30px #ef44440d!important}.game-toast-success{border-color:#22c55e66!important;border-left-style:solid!important;border-left-width:3px!important;box-shadow:0 8px 32px #00000080,0 0 20px #22c55e26,inset 0 0 30px #22c55e0d!important}.game-toast-warning{border-color:#f59e0b66!important;border-left-style:solid!important;border-left-width:3px!important;box-shadow:0 8px 32px #00000080,0 0 20px #f59e0b26,inset 0 0 30px #f59e0b0d!important}.game-toast-info{border-color:#7c3aed66!important;border-left-style:solid!important;border-left-width:3px!important;box-shadow:0 8px 32px #00000080,0 0 20px #7c3aed26,inset 0 0 30px #7c3aed0d!important}.navbar{height:68px;padding:env(safe-area-inset-top) 1.25rem 0;min-height:calc(68px + env(safe-area-inset-top));-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);z-index:100;width:100%;max-width:100%;transition:all var(--transition);background:#ffffffd9;align-items:center;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #673ab70d}@media (width>=768px){.navbar{max-width:680px}}@media (width>=1024px){.navbar{max-width:720px}}@media (width>=1366px){.navbar{max-width:800px}}.navbar-logo{font-family:var(--font-display);-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#673ab7 0%,#9c27b0 100%);-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:800}.chess-premium-frame{background:linear-gradient(145deg,#5c3d1e 0%,#7a5230 20%,#6b4425 50%,#4a2e14 80%,#5c3d1e 100%);border-radius:8px;width:100%;max-width:480px;margin:0 auto;padding:8px;position:relative;box-shadow:inset 0 1px #ffd2784d,inset 0 -1px #0000004d,0 6px #2a1808,0 8px #1a0f05,0 12px 24px #00000059,0 20px 50px #0003}.chess-premium-frame:before{content:"";pointer-events:none;z-index:5;border:1.2px solid #dcaf5066;border-radius:5px;position:absolute;inset:5px}.chess-premium-frame>div{border-radius:3px;overflow:hidden}.chess-premium-frame img{filter:drop-shadow(1px 3px 2px #0000004d)}.dc-piece-facedown{cursor:pointer;transition:transform .15s,box-shadow .15s;color:#7aba7a!important;background:radial-gradient(circle at 40% 35%,#2e5a2e 0%,#1a4a1a 50%,#0f3a0f 100%)!important;border:2px solid #4a7a4a!important;box-shadow:inset 0 3px 8px #ffffff1f,inset 0 -3px 8px #0006,0 3px 6px #0006!important}.dc-piece-facedown:hover{transform:scale(1.1);box-shadow:inset 0 3px 8px #fff3,inset 0 -3px 8px #0006,0 4px 12px #00000080,0 0 14px #64c8644d!important}.dc-facedown-red{color:#e88!important;background:radial-gradient(circle at 40% 35%,#8b2020 0%,#6b1515 50%,#4a0f0f 100%)!important;border:2px solid #b03030!important}.dc-facedown-red:hover{box-shadow:inset 0 3px 8px #fff3,inset 0 -3px 8px #0006,0 4px 12px #00000080,0 0 14px #c864644d!important}.dc-facedown-black{color:#88b!important;background:radial-gradient(circle at 40% 35%,#2a2a3e 0%,#1a1a2e 50%,#0f0f1e 100%)!important;border:2px solid #4a4a6a!important}.dc-facedown-black:hover{box-shadow:inset 0 3px 8px #ffffff26,inset 0 -3px 8px #0006,0 4px 12px #00000080,0 0 14px #6464c84d!important}.dc-facedown-mark{opacity:.12;text-shadow:0 0 8px;font-family:Inter,system-ui,sans-serif;font-size:clamp(.85rem,3.5vw,1.3rem);font-weight:900;line-height:1;animation:3s ease-in-out infinite pi-shimmer;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes pi-shimmer{0%,to{opacity:.08;filter:blur(.5px)}50%{opacity:.2;filter:blur()}}.match-page-darkchess{background:linear-gradient(#2e1a0a 0%,#3a2010 30%,#2a1608 60%,#3a2010 100%)!important}.match-page-darkchess .match-topbar{background:linear-gradient(#281608f2 0%,#231206d9 100%)!important;border-bottom:1px solid #c8963c33!important}.match-page-darkchess .match-bottombar{background:linear-gradient(#231206d9 0%,#281608f2 100%)!important;border-top:1px solid #c8963c33!important}.dc-facedown-target{box-shadow:0 0 0 3px #fffff0f2,0 0 12px #fffae699,0 0 24px #fffae640,inset 0 3px 8px #ffffff1f,inset 0 -3px 8px #0006!important}.xiangqi-piece-capturable{box-shadow:0 0 0 3px #fffff0f2,0 0 12px #fffae699,0 0 24px #fffae640!important}.caro-board-wrapper{background:linear-gradient(145deg,#8b6b3d 0%,#6d4f2a 30%,#8b6b3d 60%,#5c3e20 100%);border-radius:10px;flex-direction:column;width:100%;max-width:520px;max-height:100%;margin:0 auto;padding:8px;display:flex;position:relative;box-shadow:0 0 0 1.5px #b48c3c80,0 4px 12px #00000040,0 8px 24px #00000026,inset 0 1px #ffdc8c4d}.caro-board{aspect-ratio:1;background:#f0e6c8;border:1px solid #785a284d;border-radius:4px;grid-template-rows:repeat(15,1fr);grid-template-columns:repeat(15,1fr);width:100%;display:grid;position:relative;overflow:hidden}.caro-square{cursor:pointer;background:#f0e6c8;outline:.5px solid #785a2840;justify-content:center;align-items:center;transition:background .12s;display:flex;position:relative}.caro-square:hover{background:#e8dcb8}.caro-last-move{background:radial-gradient(circle,#64c86440 0%,#0000 60%)!important}.caro-win-cell{animation:.8s ease-in-out infinite alternate caro-win-pulse;background:radial-gradient(circle,#ffd70059 0%,#ffc80026 60%)!important}@keyframes caro-win-pulse{0%{background:radial-gradient(circle,#ffd70033 0%,#ffc8001a 60%)}to{background:radial-gradient(circle,#ffd70073 0%,#ffc80033 60%)}}.caro-threat-cell{animation:.6s ease-in-out infinite alternate caro-threat-pulse;background:radial-gradient(circle,#ef444440 0%,#ef44440d 60%)!important}@keyframes caro-threat-pulse{0%{background:radial-gradient(circle,#ef444426 0%,#ef444400 60%)}to{background:radial-gradient(circle,#ef444466 0%,#ef444426 60%)}}.caro-piece{z-index:5;justify-content:center;align-items:center;font-family:Nunito,Inter,system-ui,sans-serif;font-size:clamp(1rem,3.5vw,1.6rem);font-weight:900;line-height:1;transition:transform .15s,opacity .15s;display:flex;position:absolute;inset:0}.caro-piece-x{color:#3b82f6;text-shadow:0 2px 8px #3b82f680,0 0 2px #3b82f6cc}.caro-piece-o{color:#ef4444;text-shadow:0 2px 8px #ef444480,0 0 2px #ef4444cc}.caro-piece-ghost{opacity:.4;pointer-events:none;transform:scale(.9)}.xiangqi-board-wrapper{background:linear-gradient(145deg,#8b5a30 0%,#6d3a1f 30%,#8b5a30 60%,#5c2e18 100%);border-radius:10px;flex-direction:column;width:100%;max-width:520px;max-height:100%;margin:0 auto;padding:7px;display:flex;position:relative;box-shadow:0 0 0 1.5px #ffd27873,0 2px 0 2px #3d1e0d,0 20px 60px #00000059,0 8px 20px #0003,inset 0 1px #ffdc8c59,0 0 40px #c8963c14}.xiangqi-board-wrapper .xiangqi-board{aspect-ratio:9/10;flex:1;min-height:0}.xiangqi-board-wrapper:before{content:"";pointer-events:none;z-index:5;border:1.5px solid #dcaf5080;border-radius:7px;position:absolute;inset:5px}.xiangqi-board{background:repeating-linear-gradient(90deg,#b4823c0d 0,#0000 2px 18px,#a06e280a 20px),repeating-linear-gradient(0deg,#b4823c0a 0,#0000 2px 22px,#a06e2808 24px),linear-gradient(160deg,#f5dca0 0%,#edc36a 20%,#e6b84e 40%,#edc36a 60%,#f2d48e 80%,#f5dca0 100%);border-radius:5px;grid-template-rows:repeat(10,1fr);grid-template-columns:repeat(9,1fr);width:100%;height:100%;display:grid;position:relative;overflow:visible}.xiangqi-board:after{content:"";pointer-events:none;z-index:1;background:linear-gradient(#c8a03c0f 0%,#b48c321f 50%,#c8a03c0f 100%);width:100%;height:20%;position:absolute;top:40%;left:0}.xiangqi-board:before{content:"楚 河          漢 界";color:#82501466;letter-spacing:.4rem;pointer-events:none;z-index:2;text-shadow:0 1px 2px #ffe6a080;justify-content:center;align-items:center;width:100%;height:20%;font-family:Noto Serif SC,Songti SC,serif;font-size:clamp(1rem,3.5vw,1.8rem);font-weight:900;display:flex;position:absolute;top:40%;left:0}.xiangqi-palace-svg{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.xiangqi-square{cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.xiangqi-square:before,.xiangqi-square:after{content:"";opacity:.6;background:#6b3d10;position:absolute}.xiangqi-square:before{width:100%;height:1.2px;top:50%;left:0}.xiangqi-square:after{width:1.2px;height:100%;top:0;left:50%}.xiangqi-square[data-col="0"]:before{width:50%;left:50%}.xiangqi-square[data-col="8"]:before{width:50%;left:auto;right:50%}.xiangqi-square[data-row="0"]:after{height:50%;top:50%}.xiangqi-square[data-row="9"]:after,.xiangqi-square[data-row="4"]:after{height:50%;top:auto;bottom:50%}.xiangqi-square[data-row="5"]:after{height:50%;top:50%}.xiangqi-square:hover{background:radial-gradient(circle,#ffe18240 0%,#0000 65%)}.xiangqi-square.selected{background:radial-gradient(circle,#ffd70040 0%,#0000 70%)}.xiangqi-square.last-move-from{background:radial-gradient(circle,#78b4ff38 0%,#78b4ff0f 50%,#0000 70%)}.xiangqi-square.last-move-to{background:radial-gradient(circle,#78b4ff4d 0%,#64a0ff1a 50%,#0000 70%)}.xiangqi-square.last-move-to .xiangqi-piece{box-shadow:0 0 0 2.5px #50a0ffb3,0 0 10px #50a0ff4d}.last-move-from-dot{z-index:4;pointer-events:none;border:2.5px dashed #50a0ff8c;border-radius:50%;width:32%;height:32%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.xiangqi-square.selected.last-move-from,.xiangqi-square.selected.last-move-to{background:radial-gradient(circle,#ffd70040 0%,#0000 70%)}@keyframes xq-pulse{0%,to{opacity:1;transform:translate(-50%,-50%)scale(1)}50%{opacity:.75;transform:translate(-50%,-50%)scale(1.2)}}.legal-move-dot{z-index:4;pointer-events:none;background:radial-gradient(circle,#fffff5f2,#e6dcc8cc);border:1.5px solid #c8b48cb3;border-radius:50%;width:32%;height:32%;animation:1.2s ease-in-out infinite xq-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px #fffff0e6,0 0 18px #fffae680,0 1px 3px #0000004d}@keyframes xq-lift{to{transform:translateY(-6px)scale(1.08)}}.xiangqi-piece{z-index:10;-webkit-user-select:none;user-select:none;cursor:pointer;width:86%;height:86%;transform-style:preserve-3d;border-radius:50%;justify-content:center;align-items:center;font-family:Noto Serif SC,Songti SC,KaiTi,serif;font-size:clamp(.85rem,3.5vw,1.5rem);font-weight:900;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s,filter .18s;display:flex;position:relative}.xiangqi-piece:before{content:"";pointer-events:none;z-index:11;border-radius:50%;width:76%;height:76%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.xiangqi-piece-red{color:#b80000;text-shadow:0 1px 1px #fff9,0 -1px 1px #00000014;background:radial-gradient(circle at 50% 28%,#fffff5 0%,#fdf0dc 35%,#e8c89a 70%,#c49a6c 100%);border:1.5px solid #8a4a22;box-shadow:inset 0 5px 10px #ffffffe6,inset 0 -5px 10px #783c0f73,0 3px 6px #00000040,0 1px 2px #00000026}.xiangqi-piece-red:before{background:0 0;border:1.5px solid #b400004d;box-shadow:inset 0 0 4px #64320a40,0 0 2px #ffffff80}.xiangqi-piece-black{color:#ffd45a;text-shadow:0 1px 2px #000000e6,0 0 6px #ffc83226;background:radial-gradient(circle at 50% 28%,#6a5545 0%,#3a2818 45%,#1a0e05 100%);border:1.5px solid #2a1a0a;box-shadow:inset 0 5px 10px #c8a06466,inset 0 -5px 10px #000000bf,0 3px 6px #00000059,0 1px 2px #0003}.xiangqi-piece-black:before{background:0 0;border:1.5px solid #ffd25059;box-shadow:inset 0 0 4px #00000080,0 0 2px #b4823c40}.xiangqi-piece:hover{transform:translateY(-3px)scale(1.04)}.xiangqi-piece-red:hover{box-shadow:inset 0 5px 8px #ffffffe6,inset 0 -6px 12px #64320a80,0 8px 16px #0000004d}.xiangqi-piece-black:hover{box-shadow:inset 0 5px 8px #b4825a66,inset 0 -6px 12px #000000d9,0 8px 16px #0006}.xiangqi-square.selected .xiangqi-piece{z-index:30;position:relative;transform:translateY(-6px)scale(1.1)}.xiangqi-square.selected .xiangqi-piece-red{box-shadow:0 0 0 2px #fbbf24,0 0 15px #fbbf2480,inset 0 5px 8px #ffffffe6,inset 0 -6px 12px #64320a66,0 12px 20px #0000004d}.xiangqi-square.selected .xiangqi-piece-black{box-shadow:0 0 0 2px #fbbf24,0 0 15px #fbbf2480,inset 0 5px 8px #b4825a66,inset 0 -6px 12px #000c,0 12px 20px #0006}.xiangqi-square.legal-move .xiangqi-piece{box-shadow:0 0 0 3px #fffff0f2,0 0 12px #fffae699,0 0 24px #fffae640}@keyframes xq-check-pulse{0%,to{box-shadow:0 0 0 3px #ff1e1ecc,0 0 16px #f009,0 0 32px #ff00004d}50%{box-shadow:0 0 0 5px #ff1e1ee6,0 0 24px #ff0000b3,0 0 48px #f006}}.xiangqi-piece-check{border-color:#ff2020!important;animation:.8s ease-in-out infinite xq-check-pulse!important}@keyframes xq-checkmate-shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-2px)}20%,40%,60%,80%{transform:translate(2px)}}.xiangqi-piece-checkmate{filter:brightness(1.1)saturate(1.3);animation:.6s ease-in-out infinite xq-check-pulse,.5s ease-in-out xq-checkmate-shake!important}@keyframes xq-attacker-pulse{0%,to{box-shadow:0 0 0 2.5px #ffa000cc,0 0 12px #ff780080}50%{box-shadow:0 0 0 3.5px #ffb400e6,0 0 18px #ff8c0099}}.xiangqi-piece-attacker{border-color:#ff8c00!important;animation:1s ease-in-out infinite xq-attacker-pulse!important}.marker-corner{opacity:.75;z-index:1;pointer-events:none;border:1.5px solid #8a5520;width:9px;height:9px;position:absolute}.corner-tl{border-bottom:0;border-right:0;top:22%;left:22%}.corner-tr{border-bottom:0;border-left:0;top:22%;right:22%}.corner-bl{border-top:0;border-right:0;bottom:22%;left:22%}.corner-br{border-top:0;border-left:0;bottom:22%;right:22%}.match-game-area{border-radius:var(--radius-lg);background:radial-gradient(#3a2515 0%,#2a1a0e 100%);padding:1.5rem}.xiangqi-col-numbers{flex-shrink:0;grid-template-columns:repeat(9,1fr);padding:3px 0 1px;display:grid}.xiangqi-col-numbers-top{order:-1;padding:1px 0 3px}.xiangqi-col-num{text-align:center;color:#ffdc8ccc;font-variant-numeric:tabular-nums;letter-spacing:0;-webkit-user-select:none;user-select:none;font-size:clamp(.55rem,1.8vw,.72rem);font-weight:700;line-height:1}.match-page{background:linear-gradient(#4a2e18 0%,#3a2010 30%,#2e1a0c 60%,#3a2010 100%);flex-direction:column;height:100dvh;max-height:100dvh;display:flex;position:relative;overflow:hidden}.match-topbar{width:100%;padding:calc(12px + env(safe-area-inset-top)) 16px 12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(#3c230ff2 0%,#321e0cd9 100%);border-bottom:1px solid #dcaa4633;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.match-topbar-right{align-items:center;gap:8px;display:flex}.match-spectator{color:#ffe6b480;font-size:.8rem}.match-board-area{background:radial-gradient(#c8963c0f 0%,#0000 70%);flex:1;justify-content:center;align-items:center;min-height:0;padding:6px 4px;display:flex;position:relative;overflow:hidden}@media (width>=768px){.match-board-area{padding:8px 16px}.chess-premium-frame,.caro-board-wrapper,.ck-wrapper,.go-board-wrapper{max-width:min(600px,100dvh - 200px)}.xiangqi-board-wrapper{max-width:min(540px,90dvh - 180px)}.bs-wrapper{max-width:560px}.match-topbar,.match-bottombar{padding-left:24px;padding-right:24px}.match-menu-dialog{width:360px}}@media (width>=1024px) and (orientation:landscape){.match-board-area{padding:8px 24px}.chess-premium-frame,.caro-board-wrapper,.ck-wrapper,.go-board-wrapper{max-width:min(660px,100dvh - 180px)}.xiangqi-board-wrapper{max-width:min(600px,90dvh - 162px)}.bs-wrapper{max-width:680px}}.match-bottombar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:100%;padding:8px 8px 8px 14px;padding-bottom:calc(8px + env(safe-area-inset-bottom));background:linear-gradient(#321e0cd9 0%,#3c230ff2 100%);border-top:1px solid #dcaa4633;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.match-bottombar-controls{align-items:center;gap:8px;display:flex}.match-page-caro{background:linear-gradient(#3a4a2e 0%,#2e3b22 30%,#263218 60%,#2e3b22 100%)!important}.match-page-caro .match-topbar{background:linear-gradient(#28371ef2 0%,#233019d9 100%)!important;border-bottom:1px solid #96b46433!important}.match-page-caro .match-bottombar{background:linear-gradient(#233019d9 0%,#28371ef2 100%)!important;border-top:1px solid #96b46433!important}.match-page-caro .match-board-area{background:radial-gradient(#648c3c14 0%,#0000 70%)!important}.match-page-caro .pt-name{color:#e8f0d8!important}.match-page-caro .pt-time{color:#a8d060!important}.match-btn-3d{color:#d1c8b8;cursor:pointer;background:radial-gradient(circle at 30% 30%,#444 0%,#1a1a1a 40%,#000 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .1s,box-shadow .1s,color .2s;display:flex;position:relative;box-shadow:inset 0 2px 4px #ffffff26,inset 0 -2px 6px #000c,0 4px 8px #00000080,0 0 0 2px #0a0a0a}.match-btn-3d:active{color:#fff;transform:translateY(2px)scale(.96);box-shadow:inset 0 4px 8px #000000e6,0 1px 2px #0000004d,0 0 0 2px #0a0a0a}.match-btn-3d svg{filter:drop-shadow(0 2px 2px #00000080)}@keyframes pt-pulse-anim{0%,to{opacity:1;transform:scale(1)}50%{opacity:0;transform:scale(1.5)}}.pt-ring-wrap{flex-shrink:0;position:relative}.pt-ring-wrap svg{position:absolute;inset:0}.pt-avatar-img{-o-object-fit:cover;object-fit:cover;background:#3d2410;border-radius:50%;width:calc(100% - 10px);height:calc(100% - 10px);position:absolute;inset:5px}.pt-avatar-lg-init{background:radial-gradient(circle,#b87333 0%,#6d3a1f 70%,#3d2410 100%);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;box-shadow:inset 0 2px 6px #fff3,inset 0 -4px 8px #0009,0 4px 10px #00000080}.pt-avatar-lg-inner{font-family:var(--font-display);color:#fff;letter-spacing:-.02em;background:radial-gradient(circle at top,#8e24aa 0%,#673ab7 100%);border-radius:50%;justify-content:center;align-items:center;padding-bottom:4px;font-size:1.5rem;font-weight:800;display:flex;position:absolute;inset:6px;box-shadow:inset 0 2px 4px #0000004d}.pt-rank-badge{color:#fff;white-space:nowrap;z-index:10;letter-spacing:.5px;background:linear-gradient(#b87333 0%,#8b4513 50%,#5c3016 100%);border:1px solid #e6c280;border-radius:12px;flex-direction:column;align-items:center;padding:1px 12px;font-size:10px;font-weight:800;display:flex;position:absolute;bottom:-12px;left:50%;transform:translate(-50%);box-shadow:0 4px 8px #0009,inset 0 1px 2px #fff6}.pt-rank-badge-star{color:#f1c40f;filter:drop-shadow(0 1px 1px #00000080);margin-top:-2px;font-size:8px}.pt-avatar-init{color:#e8c46a;background:linear-gradient(135deg,#3d2410 0%,#6d3a1f 100%);border-radius:50%;justify-content:center;align-items:center;width:calc(100% - 10px);height:calc(100% - 10px);font-size:.75rem;font-weight:700;display:flex;position:absolute;inset:5px}.pt-pulse{background:#22c55e;border:2px solid #3a2010;border-radius:50%;width:9px;height:9px;animation:1.4s ease-out infinite pt-pulse-anim;position:absolute;bottom:3px;right:3px}.pt-info{flex-direction:column;gap:1px;display:flex}.pt-info-end{align-items:flex-end}.pt-name{color:#ffefd5;white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-size:.85rem;font-weight:700;overflow:hidden}@media (width>=768px){.pt-name{max-width:220px;font-size:.95rem}}@media (width>=1024px){.pt-name{max-width:300px}}.pt-time{color:#f5a623;font-variant-numeric:tabular-nums;align-items:center;gap:3px;font-size:.78rem;font-weight:600;display:flex}.pt-top,.pt-bottom{align-items:center;gap:10px;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-600)}.match-ctrl-btn{cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.25rem;transition:transform .15s,filter .15s;display:flex;box-shadow:0 2px 8px #0000004d}.match-ctrl-btn:hover{filter:brightness(1.15);transform:scale(1.1)}.match-ctrl-btn:active{transform:scale(.93)}.match-ctrl-btn-resign{background:#ef444433;border:1px solid #ef444459}.match-ctrl-btn-draw{background:#f5a6232e;border:1px solid #f5a6234d}.match-ctrl-btn-rematch{background:#673ab759;border:1px solid #673ab780}.match-menu-overlay{z-index:2000;background:0 0;justify-content:center;align-items:center;animation:.2s ease-out fade-in;display:flex;position:fixed;inset:0}.match-menu-dialog{background:linear-gradient(135deg,#3d2410 0%,#1a0e07 100%);border:2px solid #b87333;border-radius:20px;flex-direction:column;align-items:center;gap:20px;width:280px;padding:24px;display:flex;position:relative;box-shadow:0 20px 40px #000c,inset 0 2px 10px #ffffff1a}.match-menu-title{color:#f1c40f;font-family:var(--font-display);letter-spacing:4px;text-shadow:0 2px 4px #00000080;margin:0;font-size:1.5rem}.match-menu-buttons{flex-direction:column;gap:12px;width:100%;display:flex}.match-menu-btn{color:#fff;cursor:pointer;background:linear-gradient(#444 0%,#222 100%);border:none;border-radius:12px;justify-content:center;align-items:center;gap:12px;width:100%;padding:12px;font-weight:700;transition:transform .1s,filter .2s;display:flex;box-shadow:0 4px #000,0 6px 10px #00000080}.match-menu-btn:hover{filter:brightness(1.2)}.match-menu-btn:active{transform:translateY(2px);box-shadow:0 2px #000,0 3px 5px #00000080}.match-menu-btn-icon{font-size:1.2rem}.match-menu-btn-exit{background:linear-gradient(#8b0000 0%,#4a0000 100%);margin-top:8px}.match-menu-close{color:#fff;cursor:pointer;z-index:10;background:#1a0e07;border:2px solid #b87333;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:20px;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 4px 8px #00000080}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes gameover-enter{0%{opacity:0;transform:scale(.8)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes gameover-icon-bounce{0%{transform:scale(0)}50%{transform:scale(1.3)}70%{transform:scale(.9)}to{transform:scale(1)}}@keyframes float-wager-up{0%{opacity:0;transform:translateY(0)scale(.7)}15%{opacity:1;transform:translateY(-8px)scale(1)}70%{opacity:1;transform:translateY(-40px)scale(1)}to{opacity:0;transform:translateY(-60px)scale(.8)}}.match-wager-float{pointer-events:none;z-index:100;text-shadow:0 2px 8px #0009;white-space:nowrap;font-size:1.1rem;font-weight:900;animation:2.5s ease-out forwards float-wager-up;position:absolute;left:50%;transform:translate(-50%)}.match-wager-float-top{bottom:-8px}.match-wager-float-bottom{top:-8px}.match-gameover-overlay{pointer-events:none;z-index:3000;background:0 0;justify-content:center;align-items:center;animation:.3s ease-out fade-in;display:flex;position:fixed;inset:0}.match-gameover-dialog{pointer-events:auto;background:linear-gradient(145deg,#3d2410 0%,#1a0e07 60%,#0d0704 100%);border:2px solid #b87333;border-radius:24px;flex-direction:column;align-items:center;gap:12px;width:300px;max-width:calc(100vw - 48px);padding:32px 24px 24px;animation:.5s cubic-bezier(.34,1.56,.64,1) gameover-enter;display:flex;position:relative;overflow:hidden;box-shadow:0 0 0 1px #ffc86426,0 20px 60px #000000e6,inset 0 1px #ffc86433}@media (width>=768px){.match-gameover-dialog{width:380px;padding:40px 32px 32px}.match-gameover-result{font-size:2rem}.match-gameover-btn{padding:16px;font-size:1.05rem}}.match-gameover-dialog:before{content:"";background:linear-gradient(90deg,#0000,#f1c40f,#e67e22,#f1c40f,#0000);height:3px;position:absolute;top:0;left:0;right:0}.match-gameover-icon{filter:drop-shadow(0 4px 12px #00000080);font-size:3.5rem;animation:.6s cubic-bezier(.34,1.56,.64,1) .2s both gameover-icon-bounce}.match-gameover-result{font-family:var(--font-display);letter-spacing:2px;text-align:center;font-size:1.8rem;font-weight:900}.match-gameover-win{-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 4px #f1c40f66);background:linear-gradient(135deg,#f1c40f 0%,gold 50%,#f39c12 100%);-webkit-background-clip:text;background-clip:text}.match-gameover-loss{color:#ef4444;text-shadow:0 2px 8px #ef444466}.match-gameover-draw{color:#94a3b8;text-shadow:0 2px 8px #94a3b84d}.match-gameover-winner{color:#f5e6cc;text-shadow:0 2px 4px #00000080;font-size:1rem;font-weight:700}.match-gameover-reason{color:#ffffff80;letter-spacing:1px;text-transform:uppercase;background:#ffffff0f;border:1px solid #ffffff14;border-radius:20px;padding:4px 16px;font-size:.85rem;font-weight:600}.match-gameover-actions{flex-direction:column;gap:10px;width:100%;margin-top:8px;display:flex}.match-gameover-btn{color:#fff;letter-spacing:1px;cursor:pointer;border:none;border-radius:14px;width:100%;padding:14px;font-size:1rem;font-weight:800;transition:transform .1s,filter .2s}.match-gameover-btn-rematch{background:linear-gradient(#f1c40f 0%,#e67e22 50%,#d35400 100%);font-size:1.1rem;box-shadow:0 4px #8b4513,0 6px 12px #0009,inset 0 1px 2px #fff6}.match-gameover-btn-rematch:hover{filter:brightness(1.15)}.match-gameover-btn-rematch:active{transform:translateY(2px);box-shadow:0 2px #8b4513,0 3px 6px #00000080}.match-gameover-btn-rematch:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.3)}.match-gameover-btn-lobby{letter-spacing:.5px;color:#fffc;background:linear-gradient(#555 0%,#333 50%,#1a1a1a 100%);font-size:.9rem;box-shadow:0 3px #111,0 5px 10px #00000080,inset 0 1px 2px #ffffff26}.match-gameover-btn-lobby:hover{filter:brightness(1.2)}.match-gameover-btn-lobby:active{transform:translateY(2px);box-shadow:0 1px #111,0 2px 5px #0006}@keyframes xq-banner-enter{0%{opacity:0;transform:translate(-50%,-50%)scale(2.5)}60%{opacity:1;transform:translate(-50%,-50%)scale(.95)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}@keyframes xq-banner-glow{0%,to{text-shadow:0 0 20px #ff3232cc,0 0 40px #f006,0 4px 8px #000c}50%{text-shadow:0 0 30px #ff3232,0 0 60px #f009,0 4px 8px #000c}}.xq-check-banner{z-index:100;pointer-events:none;font-family:var(--font-display);letter-spacing:6px;color:#ff3030;-webkit-text-stroke:1px #0000004d;font-size:clamp(2rem,8vw,3.5rem);font-weight:900;animation:.4s cubic-bezier(.34,1.56,.64,1) xq-banner-enter,1.2s ease-in-out infinite xq-banner-glow;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.xq-check-banner-checkmate{color:#ff1010;letter-spacing:4px;font-size:clamp(1.6rem,7vw,3rem)}input[type=range]{appearance:none;cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-surface);border:3px solid var(--color-primary);cursor:pointer;border-radius:50%;width:22px;height:22px;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 8px #00000040,0 0 0 2px #673ab726}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 2px 12px #673ab766,0 0 0 4px #673ab71a}input[type=range]::-webkit-slider-thumb:active{transform:scale(1.1)}input[type=range]::-moz-range-thumb{background:var(--color-surface);border:3px solid var(--color-primary);cursor:pointer;border-radius:50%;width:22px;height:22px;box-shadow:0 2px 8px #00000040}.music-toggle-btn{border:1px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.music-toggle-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-surface-2)}.game-selection-grid{grid-template-columns:repeat(2,1fr);gap:.65rem;display:grid}@media (width>=768px){.game-selection-grid{grid-template-columns:repeat(3,1fr);gap:.85rem}}@media (width>=1024px){.game-selection-grid{grid-template-columns:repeat(4,1fr);gap:1rem}}@keyframes home-card-shine-sweep{0%{background-position:200% 0}to{background-position:-50% 0}}.home-game-card{transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s,filter .3s!important}.home-game-card:hover{filter:brightness(1.08);transform:translateY(-4px)scale(1.03)!important}.home-game-card:hover .home-card-shine{animation:.8s ease-out forwards home-card-shine-sweep}.home-game-card:active{filter:brightness(.95);transform:translateY(-1px)scale(.97)!important}.go-board-wrapper{flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:520px;max-height:100%;margin:0 auto;display:flex}@media (width>=768px){.go-board-wrapper{max-width:min(600px,100dvh - 200px)}}@media (width>=1024px) and (orientation:landscape){.go-board-wrapper{max-width:min(660px,100dvh - 180px)}}.go-board{background:linear-gradient(145deg,#dcb35c 0%,#c9a24a 30%,#b8923e 60%,#d4a84a 100%);border:2px solid #8b6914;border-radius:6px;overflow:hidden;box-shadow:0 4px 20px #0006,inset 0 1px #ffffff26,inset 0 -1px #0000001a}.go-intersection{z-index:1;justify-content:center;align-items:center;display:flex}.go-intersection-clickable{cursor:pointer}.go-stone{justify-content:center;align-items:center;transition:transform .15s;display:flex}.go-stone-black{background:radial-gradient(circle at 35% 30%,#555,#222 40%,#0a0a0a 100%);box-shadow:1px 2px 4px #0009,inset 0 1px 2px #ffffff26}.go-stone-white{background:radial-gradient(circle at 35% 30%,#fff,#f0ece4 40%,#d4cfc5 100%);box-shadow:1px 2px 4px #00000059,inset 0 -1px 2px #00000014}.go-stone-last{animation:.25s ease-out go-stone-place}@keyframes go-stone-place{0%{opacity:.6;transform:scale(.5)}60%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.go-last-move-dot{border-radius:50%;width:6px;height:6px}.go-stone-black .go-last-move-dot{background:#ffffffb3}.go-stone-white .go-last-move-dot{background:#00000080}.go-stone-preview{opacity:.35;transition:opacity .1s}.go-preview-black{background:radial-gradient(circle,#333,#111)}.go-preview-white{background:radial-gradient(circle,#eee,#ccc)}.go-captures{color:var(--color-text-muted);align-items:center;gap:1rem;font-size:.8rem;font-weight:700;display:flex}.go-capture-item{align-items:center;gap:.3rem;display:flex}.go-stone-mini{border-radius:50%;width:14px;height:14px;display:inline-block}.go-stone-mini-black{background:radial-gradient(circle at 35% 30%,#555,#111);box-shadow:0 1px 2px #0006}.go-stone-mini-white{background:radial-gradient(circle at 35% 30%,#fff,#d4cfc5);box-shadow:0 1px 2px #0003}.go-pass-indicator{color:#ff9800;background:#ff980026;border-radius:8px;padding:.15rem .5rem;font-size:.7rem;font-weight:700;animation:1.5s ease-in-out infinite pulse}.go-pass-btn{color:#fff;cursor:pointer;letter-spacing:.5px;background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:12px;padding:.6rem 2rem;font-size:.85rem;font-weight:800;transition:all .2s;box-shadow:0 4px 12px #ff98004d}.go-pass-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff980066}.go-pass-btn:active{transform:translateY(0)}@keyframes bsWaterShimmer{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes bsOceanWave{0%{background-position:0 0}50%{background-position:100% 100%}to{background-position:0 0}}@keyframes bsOceanWave2{0%{background-position:100% 0}50%{background-position:0 100%}to{background-position:100% 0}}@keyframes bsCaustic{0%{opacity:.03;transform:scale(1)rotate(0)}33%{opacity:.06;transform:scale(1.1)rotate(1deg)}66%{opacity:.02;transform:scale(.95)rotate(-1deg)}to{opacity:.03;transform:scale(1)rotate(0)}}@keyframes bsWaveRoll{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes bsWaveFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes bsSeagull{0%{opacity:0;top:12%;left:-60px}5%{opacity:1}25%{top:8%}50%{top:14%}75%{top:6%}95%{opacity:1}to{opacity:0;top:10%;left:110%}}@keyframes bsSeagull2{0%{opacity:0;top:22%;right:-40px}5%{opacity:.7}30%{top:18%}60%{top:25%}90%{top:16%}95%{opacity:.7}to{opacity:0;top:20%;right:110%}}@keyframes bsSeagullWing{0%,to{transform:scaleY(1)}50%{transform:scaleY(-.6)}}@keyframes bsScanLine{0%{opacity:0;top:-2px}10%{opacity:.5}90%{opacity:.5}to{opacity:0;top:100%}}@keyframes bsRadarSweep{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bsPulse{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes bsHitFlash{0%{transform:scale(1.15);background:#ffffffb3!important}to{transform:scale(1)}}@keyframes bsFireGlow{0%,to{box-shadow:inset 0 0 12px #f443364d,0 0 4px #f4433633}50%{box-shadow:inset 0 0 18px #ff980066,0 0 8px #ff64004d}}@keyframes bsSunkSmoke{0%,to{filter:brightness();box-shadow:inset 0 0 14px #ff57224d,0 0 6px #ff572233}50%{filter:brightness(1.1);box-shadow:inset 0 0 22px #ff3c0080,0 0 12px #ff572259}}@keyframes bsMissSplash{0%{box-shadow:inset 0 0 #64b5f600}50%{box-shadow:inset 0 0 14px #64b5f633}to{box-shadow:inset 0 0 6px #64b5f614}}@keyframes bsTurnPulse{0%,to{box-shadow:0 0 8px #4caf504d}50%{box-shadow:0 0 16px #4caf5099}}@keyframes bsReticle{0%,to{border-color:#ffeb3b80}50%{border-color:#ffeb3be6}}@keyframes bsProgressGlow{0%,to{box-shadow:0 0 4px #42a5f54d}50%{box-shadow:0 0 12px #42a5f599}}.bs-wrapper{flex-direction:column;justify-content:center;align-items:center;gap:.35rem;width:100%;height:100%;padding:.2rem;display:flex;overflow:hidden}.bs-header-row{justify-content:center;align-items:center;gap:.5rem;display:flex}.bs-phase-badge{color:#e3f2fd;letter-spacing:1.5px;text-transform:uppercase;background:linear-gradient(135deg,#0d47a1,#1565c0,#0d47a1) 0 0/200% 200%;border:1px solid #64b5f633;border-radius:12px;padding:.2rem .75rem;font-size:.6rem;font-weight:800;animation:4s infinite bsWaterShimmer;box-shadow:0 2px 10px #0d47a166,inset 0 1px #ffffff1a}.bs-turn-tag{letter-spacing:.5px;border:1px solid #0000;border-radius:10px;padding:.2rem .6rem;font-size:.6rem;font-weight:800}.bs-turn-mine{color:#69f0ae;background:#4caf5033;border-color:#4caf504d;animation:1.5s ease-in-out infinite bsTurnPulse}.bs-turn-opp{color:#90caf980;background:#ffffff0f;border-color:#ffffff14}.bs-shot-tag{letter-spacing:.5px;border:1px solid #0000;border-radius:10px;padding:.2rem .6rem;font-size:.6rem;font-weight:900;animation:.4s ease-out bsPulse}.bs-shot-hit{color:#ff5252;text-shadow:0 0 8px #f4433666;background:#f4433640;border-color:#f4433659}.bs-shot-miss{color:#90caf9;background:#90caf91a;border-color:#90caf933}.bs-shot-sunk{color:#ffab40;text-shadow:0 0 8px #ff980080;background:linear-gradient(135deg,#ff98004d,#ff572233);border-color:#ff980066}.bs-grids{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.bs-grids-vertical{flex-direction:column;align-items:center;gap:.25rem}.bs-grid-container{flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.bs-grid-label{text-align:center;letter-spacing:2.5px;color:#90caf980;text-transform:uppercase;margin-bottom:2px;font-family:Courier New,monospace;font-size:.55rem;font-weight:800}.bs-grid-label-target{color:#ffeb3b80}.bs-coord{color:#90caf959;justify-content:center;align-items:center;font-family:Courier New,monospace;font-size:.5rem;font-weight:700;display:flex}.bs-grid{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:radial-gradient(at 30% 20%,#00699433,#0000 60%),radial-gradient(at 70% 80%,#004d802e,#0000 60%),#04364a73;border:2px solid #64c8ff2e;border-radius:8px;display:grid;position:relative;overflow:hidden;box-shadow:0 8px 40px #0006,0 0 0 1px #003c644d,inset 0 0 40px #0096c80d}.bs-grid:before{content:"";pointer-events:none;z-index:1;background-color:#0000;background-image:radial-gradient(at 20% 30%,#96dcff0f,#0000 40%),radial-gradient(at 60% 60%,#64c8f00d,#0000 35%),radial-gradient(at 80% 20%,#78d2ff0a,#0000 30%);background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:300% 300%;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;animation:6s ease-in-out infinite bsCaustic;position:absolute;inset:0}.bs-grid:after{content:"";pointer-events:none;z-index:2;filter:blur(1px);background:linear-gradient(90deg,#0000 10%,#96dcff26 30%,#c8f0ff40 50%,#96dcff26 70%,#0000 90%);height:4px;animation:5s ease-in-out infinite bsScanLine;position:absolute;left:0;right:0}.bs-grid-active:after{background:linear-gradient(90deg,#0000 10%,#ffeb3b1a 30%,#fff59626 50%,#ffeb3b1a 70%,#0000 90%);animation:3s ease-in-out infinite bsScanLine}.bs-grid-mine{border-color:#50b4dc1f}.bs-cell{cursor:default;z-index:3;background:#0050821f;border:1px solid #50b4f014;justify-content:center;align-items:center;transition:all .2s;display:flex;position:relative}.bs-cell:nth-child(3n){background:#0064961a}.bs-cell:nth-child(5n+1){background:#00467824}.bs-cell:nth-child(7n+3){background:#0a5a8c1a}.bs-cell:nth-child(11n+5){background:#006ea014}.bs-cell-clickable{cursor:crosshair}.bs-cell-clickable:hover{border-color:#ffeb3b4d;box-shadow:inset 0 0 14px #ffeb3b14;background:radial-gradient(circle,#ffeb3b26,#0000 70%)!important}.bs-cell-ship{border-color:#607d8b59;box-shadow:inset 0 1px #ffffff14,inset 0 -1px #00000040,inset 0 0 8px #00000026;background:linear-gradient(145deg,#2d3e4a,#3d5060,#2d3e4a)!important}.bs-cell-hover{border-color:#4caf5073;box-shadow:inset 0 0 12px #4caf501f,0 0 4px #4caf501a;background:linear-gradient(135deg,#4caf504d,#388e3c33)!important}.bs-cell-hit{border-color:#f4433666;animation:1.5s ease-in-out infinite bsFireGlow;background:radial-gradient(circle,#f4433680,#b71c1c40)!important}.bs-cell-miss{border-color:#90caf91f;animation:.6s ease-out forwards bsMissSplash;background:radial-gradient(circle,#64b5f614,#42a5f505)!important}.bs-cell-sunk{border-color:#ff572280;animation:2s ease-in-out infinite bsSunkSmoke;background:radial-gradient(circle,#ff572280,#b71c1c59)!important}.bs-cell-target-hover{border-color:#ffeb3b73;animation:.8s ease-in-out infinite bsReticle;box-shadow:inset 0 0 16px #ffeb3b1a;background:radial-gradient(circle,#ffeb3b33,#ffeb3b0d)!important}.bs-row-num{color:#90caf940;pointer-events:none;font-family:Courier New,monospace;font-size:.4rem;font-weight:700;line-height:1;position:absolute;top:1px;left:2px}.bs-marker{pointer-events:none;z-index:5;font-weight:900;line-height:1}.bs-marker-hit{color:#ff5252;text-shadow:0 0 8px #f44336b3,0 0 3px #ff643280;font-size:.85em}.bs-marker-miss{color:#90caf973;text-shadow:0 0 4px #90caf933;font-size:.55em}.bs-marker-sunk{color:#ff9800;text-shadow:0 0 10px #ff9800b3,0 0 4px #ff572280;font-size:.85em}.bs-placement-controls{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#0d47a11f,#00000026);border:1px solid #64b5f626;border-radius:14px;flex-direction:column;align-items:center;gap:.5rem;padding:.6rem 1rem;display:flex;box-shadow:0 4px 16px #0000004d}.bs-current-ship{color:#e3f2fd;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;display:flex}.bs-ship-size{color:#42a5f5;letter-spacing:3px;text-shadow:0 0 10px #42a5f566;font-size:1rem}.bs-btn-row{gap:.6rem;display:flex}.bs-btn{color:#90caf9;cursor:pointer;letter-spacing:.5px;background:linear-gradient(135deg,#0d47a14d,#1565c033);border:1px solid #64b5f640;border-radius:12px;padding:.5rem 1.2rem;font-size:.75rem;font-weight:700;transition:all .2s;box-shadow:0 2px 8px #0003}.bs-btn:hover{background:linear-gradient(135deg,#0d47a180,#1565c059);border-color:#64b5f680;transform:translateY(-2px);box-shadow:0 6px 16px #0d47a166}.bs-btn:active{transform:translateY(0)}.bs-btn-random{color:#ffb74d;background:linear-gradient(135deg,#ff980033,#ffa72626);border-color:#ff98004d}.bs-btn-random:hover{background:linear-gradient(135deg,#ff980059,#ffa72640);border-color:#ff980080;box-shadow:0 6px 16px #ff980040}.bs-waiting{color:#90caf999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#0d47a11a,#0000001f);border:1px solid #64b5f61f;border-radius:14px;padding:.6rem 1.2rem;font-size:.8rem;font-weight:600;animation:2s ease-in-out infinite pulse;box-shadow:0 4px 12px #0003}.bs-ship-status{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(135deg,#0d47a11a,#00000026);border:1px solid #64b5f61a;border-radius:10px;flex-direction:column;align-items:center;gap:.3rem;width:100%;max-width:500px;padding:.4rem .6rem;display:flex}.bs-status-row{align-items:center;gap:.25rem;font-size:.7rem;display:flex}.bs-status-label{color:#90caf973;text-transform:uppercase;letter-spacing:1px;font-size:.65rem;font-weight:700}.bs-status-sep{color:#90caf926;margin:0 .15rem}.bs-ship-badge{font-size:.9rem;transition:all .4s}.bs-ship-sunk{opacity:.2;filter:grayscale();transform:scale(.8)}.bs-progress-bar{background:#ffffff0d;border:1px solid #64b5f614;border-radius:3px;width:100%;height:6px;position:relative;overflow:hidden}.bs-progress-fill{background:linear-gradient(90deg,#1565c0,#42a5f5,#1565c0) 0 0/200% 100%;border-radius:3px;height:100%;transition:width .5s;animation:3s infinite bsWaterShimmer,2s ease-in-out infinite bsProgressGlow}.bs-progress-text{color:#ffffffb3;letter-spacing:.5px;justify-content:center;align-items:center;font-size:.45rem;font-weight:800;display:flex;position:absolute;inset:0}.bs-hit-counter{color:#ff5252;text-shadow:0 0 10px #ff52524d;font-size:.75rem;font-weight:900}.match-page-battleship{position:relative;overflow:hidden;background:url(/ocean_bg.png) 50%/cover no-repeat fixed!important}.match-page-battleship:before{content:"";z-index:0;pointer-events:none;background:linear-gradient(#021423a6 0%,#03284159 30%,#0437504d 50%,#03284159 70%,#021423a6 100%);position:fixed;inset:0}.match-page-battleship .match-topbar,.match-page-battleship .match-bottombar,.match-page-battleship .match-board-area{z-index:1;position:relative}.match-page-battleship .match-menu-overlay,.match-page-battleship .match-ready-overlay,.match-page-battleship .match-gameover-overlay{z-index:100}.match-page-battleship .match-topbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(#021423d9 0%,#03284199 100%)!important;border-bottom:1px solid #50b4dc1f!important}.match-page-battleship .match-bottombar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(#03284199 0%,#021423d9 100%)!important;border-top:1px solid #50b4dc1f!important}.bs-ocean-waves{z-index:0;pointer-events:none;height:80px;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.bs-wave{opacity:.3;width:300%;height:100%;position:absolute;bottom:0;left:-100%}.bs-wave svg{width:100%;height:100%}.bs-wave-1{opacity:.15;animation:12s linear infinite bsWaveRoll}.bs-wave-2{opacity:.1;animation:8s linear infinite reverse bsWaveRoll;bottom:4px}.bs-wave-3{opacity:.08;animation:15s linear infinite bsWaveRoll;bottom:8px}.bs-seagull{z-index:2;pointer-events:none;filter:drop-shadow(0 2px 4px #0000004d);position:fixed}.bs-seagull-1{animation:18s ease-in-out 3s infinite bsSeagull}.bs-seagull-2{animation:22s ease-in-out 10s infinite bsSeagull2}.bs-seagull-wing{animation:.4s ease-in-out infinite bsSeagullWing}.bs-seagull-2 .bs-seagull-wing{animation-duration:.35s}.ck-wrapper{flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:480px;max-height:100%;margin:0 auto;display:flex}@media (width>=768px){.ck-wrapper{max-width:min(600px,100dvh - 200px)}}@media (width>=1024px) and (orientation:landscape){.ck-wrapper{max-width:min(660px,100dvh - 180px)}}.ck-status{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:.5rem;padding:.4rem 1rem;display:flex}.ck-turn-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.ck-turn-white{background:#f0d9b5;border:1px solid #c4a76e}.ck-turn-black{background:#3d2b1f;border:1px solid #6a4b35}.ck-turn-text{color:#ffffffd9;font-size:.8rem;font-weight:700}.ck-multijump-badge{color:#fbbf24;background:#fbbf2426;border-radius:10px;padding:.15rem .5rem;font-size:.65rem;font-weight:800;animation:1s ease-in-out infinite ckPulse}.ck-board{border:3px solid #8b5a2b;border-radius:10px;grid-template-columns:repeat(8,1fr);display:grid;overflow:hidden;box-shadow:0 8px 32px #00000080,inset 0 0 0 3px #8b5a2b99}.ck-cell{cursor:default;justify-content:center;align-items:center;transition:background .15s;display:flex;position:relative}.ck-light{background:linear-gradient(135deg,#f0d9b5 0%,#e8c89e 100%)}.ck-dark{background:linear-gradient(135deg,#6b8e4e 0%,#5a7a40 100%)}.ck-selected{box-shadow:inset 0 0 0 2px #fbbf24;background:#fbbf2480!important}.ck-valid-dest{cursor:pointer!important}.ck-valid-dest:hover{background:#4caf5059!important}.ck-last-from{background:#ffeb3b33!important}.ck-last-to{background:#ffeb3b4d!important}.ck-forced{animation:1.2s ease-in-out infinite ckForcedPulse}.ck-moveable{cursor:pointer!important}.ck-moveable:hover{background:#fbbf2433!important}.ck-dot{pointer-events:none;background:#4caf5080;border-radius:50%;width:28%;height:28%}.ck-capture-ring{pointer-events:none;border:3px solid #f4433699;border-radius:50%;position:absolute;inset:6%}.ck-piece{z-index:1;border-radius:50%;width:78%;height:78%;transition:transform .15s;position:relative}.ck-moveable .ck-piece{cursor:pointer}.ck-moveable .ck-piece:hover{transform:scale(1.08)}.ck-piece-inner{border-radius:50%;width:100%;height:100%}.ck-white .ck-piece-inner{background:radial-gradient(circle at 35% 35%,#fff 0%,#f0d9b5 40%,#c4a06a 100%);border:2px solid #a8843e;box-shadow:0 3px 8px #0006,inset 0 -3px 6px #00000026,inset 0 2px 4px #ffffff80}.ck-black .ck-piece-inner{background:radial-gradient(circle at 35% 35%,#7a5032 0%,#4a2c18 40%,#2a1a0e 100%);border:2px solid #6b4226;box-shadow:0 3px 8px #00000080,inset 0 -3px 6px #0000004d,inset 0 2px 4px #ffffff1a}.ck-crown{text-shadow:0 1px 3px #00000080;pointer-events:none;z-index:2;font-size:1.2em;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ck-white .ck-crown{color:#8b5a2b}.ck-black .ck-crown{color:#fbbf24}.ck-king{animation:2s ease-in-out infinite ckKingGlow}@keyframes ckPulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes ckForcedPulse{0%,to{box-shadow:inset 0 0 0 2px #f443364d}50%{box-shadow:inset 0 0 0 3px #f44336b3}}@keyframes ckKingGlow{0%,to{filter:drop-shadow(0 0 3px #fbbf244d)}50%{filter:drop-shadow(0 0 8px #fbbf2499)}}@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-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{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-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
