/*
! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Avenir Next,PingFang TC,PingFang SC,Noto Sans TC,Noto Sans SC,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:SF Mono,IBM Plex Mono,Menlo,Monaco,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.pointer-events-none{pointer-events:none}.absolute{position:absolute}.inset-0{inset:0}.-z-10{z-index:-10}.mx-auto{margin-left:auto;margin-right:auto}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.flex{display:flex}.grid{display:grid}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-5xl{max-width:64rem}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.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}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-emerald-200{--tw-border-opacity:1;border-color:rgb(167 243 208/var(--tw-border-opacity))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity))}.border-stone-100{--tw-border-opacity:1;border-color:rgb(245 245 244/var(--tw-border-opacity))}.border-stone-200{--tw-border-opacity:1;border-color:rgb(231 229 228/var(--tw-border-opacity))}.border-stone-900{--tw-border-opacity:1;border-color:rgb(28 25 23/var(--tw-border-opacity))}.bg-emerald-50{--tw-bg-opacity:1;background-color:rgb(236 253 245/var(--tw-bg-opacity))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity))}.bg-stone-50{--tw-bg-opacity:1;background-color:rgb(250 250 249/var(--tw-bg-opacity))}.bg-stone-900{--tw-bg-opacity:1;background-color:rgb(28 25 23/var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.bg-white\/70{background-color:rgb(255 255 255/.7)}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.font-mono{font-family:SF Mono,IBM Plex Mono,Menlo,Monaco,monospace}.font-sans{font-family:Avenir Next,PingFang TC,PingFang SC,Noto Sans TC,Noto Sans SC,system-ui,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-\[11px\]{font-size:11px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.tracking-\[0\.28em\]{letter-spacing:.28em}.tracking-\[0\.2em\]{letter-spacing:.2em}.tracking-\[0\.3em\]{letter-spacing:.3em}.text-amber-700{--tw-text-opacity:1;color:rgb(180 83 9/var(--tw-text-opacity))}.text-amber-800{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity))}.text-emerald-700{--tw-text-opacity:1;color:rgb(4 120 87/var(--tw-text-opacity))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity))}.text-rose-600{--tw-text-opacity:1;color:rgb(225 29 72/var(--tw-text-opacity))}.text-slate-400{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity))}.text-slate-600{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity))}.text-slate-700{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity))}.text-slate-800{--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity))}.text-stone-400{--tw-text-opacity:1;color:rgb(168 162 158/var(--tw-text-opacity))}.text-stone-500{--tw-text-opacity:1;color:rgb(120 113 108/var(--tw-text-opacity))}.text-stone-600{--tw-text-opacity:1;color:rgb(87 83 78/var(--tw-text-opacity))}.text-stone-700{--tw-text-opacity:1;color:rgb(68 64 60/var(--tw-text-opacity))}.text-stone-800{--tw-text-opacity:1;color:rgb(41 37 36/var(--tw-text-opacity))}.text-stone-900{--tw-text-opacity:1;color:rgb(28 25 23/var(--tw-text-opacity))}.text-teal-800{--tw-text-opacity:1;color:rgb(17 94 89/var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.shadow-sm{--tw-shadow:0 1px 2px 0 rgb(0 0 0/0.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-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,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{color-scheme:light;--bg-a:#f7fafc;--bg-b:#edf3f9;--ink:#0f172a;--surface:rgba(255,255,255,0.78);--line:rgba(148,163,184,0.28)}body{background:radial-gradient(circle at 15% 10%,var(--bg-b),var(--bg-a) 38%,#f8fafc 80%);color:var(--ink);font-family:var(--font-sans),system-ui,sans-serif}.game-root,body{min-height:100vh}.game-root{position:relative;overflow:hidden;padding:2rem 0 2.5rem}.app-shell{width:min(980px,calc(100% - 32px));margin:0 auto;display:flex;flex-direction:column;gap:1.1rem}.surface{border:1px solid var(--line);border-radius:1.25rem;background:var(--surface);backdrop-filter:blur(10px);box-shadow:0 16px 42px rgba(15,23,42,.08)}.hero-card{padding:1.5rem}.action-card,.history-card{padding:1.15rem}.status-banner{padding:.9rem 1rem;font-size:.92rem}.panel{border:1px solid rgba(148,163,184,.22);border-radius:1rem;background:rgba(255,255,255,.7);padding:1rem}.panel-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#64748b}.chip{border:1px solid rgba(148,163,184,.28);border-radius:999px;padding:.45rem .85rem;font-size:.75rem;color:#475569;background:rgba(255,255,255,.7)}.control-row{display:grid;gap:.75rem;margin-top:1.3rem}.lobby-row{display:grid;gap:.7rem;margin-top:.75rem}.room-grid{display:grid;gap:.8rem;margin-top:1.05rem}.entry-row{display:grid;gap:.7rem;margin-top:.75rem}.input-core{width:100%;border:1px solid rgba(148,163,184,.28);border-radius:.875rem;background:rgba(255,255,255,.92);padding:.7rem .9rem;font-size:.92rem;color:#0f172a;outline:none;transition:border-color .14s ease,box-shadow .14s ease}.input-core:focus{border-color:#334155;box-shadow:0 0 0 3px rgba(51,65,85,.14)}.btn-danger,.btn-ghost,.btn-solid{border-radius:.875rem;font-size:.9rem;font-weight:600;min-height:44px;padding:.65rem 1rem;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease,background-color .14s ease,color .14s ease,opacity .14s ease}.btn-solid{border:1px solid #1d4ed8;background:linear-gradient(140deg,#2563eb,#1d4ed8);color:#f8fafc;box-shadow:0 8px 18px rgba(37,99,235,.22)}.btn-solid:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(37,99,235,.28)}.btn-solid:active{transform:translateY(0);box-shadow:0 5px 12px rgba(29,78,216,.24)}.btn-ghost{border:1px solid rgba(148,163,184,.36);background:rgba(255,255,255,.86);color:#334155}.btn-ghost:hover{transform:translateY(-1px);border-color:rgba(51,65,85,.45);background:rgba(255,255,255,.96)}.btn-danger{border:1px solid rgba(239,68,68,.35);background:rgba(254,242,242,.9);color:#b91c1c}.btn-danger:hover{transform:translateY(-1px);border-color:rgba(220,38,38,.55);background:rgba(254,226,226,.95)}.btn-danger:focus-visible,.btn-ghost:focus-visible,.btn-solid:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.2)}.orb{position:absolute;border-radius:999px;filter:blur(40px);opacity:.5}.orb-a{width:16rem;height:16rem;top:-3rem;left:-4rem;background:rgba(14,116,144,.28)}.orb-b{width:17rem;height:17rem;right:-3rem;top:30%;background:rgba(30,64,175,.18)}.orb-c{width:14rem;height:14rem;bottom:-2rem;left:30%;background:rgba(180,83,9,.18)}.history-row{display:flex;align-items:center;justify-content:space-between;border-radius:.75rem;border:1px solid rgba(148,163,184,.25);background:rgba(255,255,255,.68);padding:.72rem .95rem;font-size:.9rem}.history-row-me{border-color:rgba(13,148,136,.32);background:linear-gradient(135deg,rgba(240,253,250,.95),rgba(232,250,247,.9));color:#115e59}.history-row-opponent{border-color:rgba(217,119,6,.28);background:linear-gradient(135deg,rgba(255,251,235,.95),rgba(254,243,199,.9));color:#92400e}.history-side{border-radius:999px;padding:.12rem .48rem;font-size:.72rem;font-weight:600}.history-side-me{background:rgba(15,118,110,.14);color:#0f766e}.history-side-opponent{background:rgba(217,119,6,.16);color:#b45309}.stat-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;border:1px solid rgba(148,163,184,.2);border-radius:.7rem;background:rgba(255,255,255,.66);padding:.55rem .7rem}.chat-list{margin-top:.9rem;display:flex;flex-direction:column;gap:.55rem;max-height:16rem;overflow:auto;padding-right:.2rem}.chat-row{border:1px solid rgba(148,163,184,.24);border-radius:.75rem;padding:.6rem .75rem}.chat-row-grouped{margin-top:-.2rem}.chat-row-system{background:rgba(241,245,249,.8)}.chat-row-me{background:rgba(236,253,245,.85);border-color:rgba(16,185,129,.2)}.chat-row-opponent{background:rgba(239,246,255,.86);border-color:rgba(59,130,246,.2)}.chat-meta{display:flex;align-items:center;justify-content:space-between;color:#64748b;font-size:.72rem}.chat-text{margin-top:.2rem;font-size:.9rem;color:#0f172a;line-height:1.45;white-space:pre-wrap;word-break:break-word}.chat-status{margin-top:.2rem;font-size:.72rem;color:#64748b}.chat-status-failed{color:#b91c1c}.chat-retry-btn{margin-top:.25rem;border:1px solid rgba(239,68,68,.3);border-radius:999px;background:rgba(254,242,242,.9);color:#b91c1c;font-size:.72rem;padding:.18rem .55rem}.chat-unread-chip{margin-top:.55rem;border:1px solid rgba(59,130,246,.35);border-radius:999px;background:rgba(239,246,255,.9);color:#1d4ed8;font-size:.78rem;font-weight:600;padding:.35rem .68rem}.chat-pinned{border:1px solid rgba(51,65,85,.16);border-radius:.72rem;background:rgba(248,250,252,.92);padding:.52rem .62rem}.chat-pinned-title{color:#64748b;font-size:.72rem;margin-bottom:.2rem}.chat-pinned-item{color:#334155;font-size:.82rem;line-height:1.35}.rhythm-banner{animation:rhythm-pulse .42s ease}.rhythm-banner-info{color:#1e40af;background:rgba(239,246,255,.92)}.rhythm-banner-success{color:#166534;background:rgba(240,253,244,.92)}.rhythm-banner-warn{color:#9a3412;background:rgba(255,247,237,.92)}.recap-card{margin-top:.6rem;border:1px solid rgba(148,163,184,.2);border-radius:.9rem;background:rgba(255,255,255,.74);padding:.65rem .8rem}@keyframes rhythm-pulse{0%{transform:scale(.985);opacity:.6}to{transform:scale(1);opacity:1}}.content-grid{display:grid;gap:1rem}.main-column{display:flex;flex-direction:column;gap:1rem;min-width:0}.chat-column{min-width:0}.chat-panel{height:100%}button:disabled{cursor:not-allowed;opacity:.5;transform:none;box-shadow:none}@media (min-width:700px){.hero-card{padding:1.8rem}.control-row{grid-template-columns:1fr auto}.lobby-row{grid-template-columns:auto 1fr auto;align-items:center}.room-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.entry-row{grid-template-columns:1fr auto}.action-card,.history-card{padding:1.3rem 1.5rem}}@media (min-width:1080px){.app-shell{width:min(1260px,calc(100% - 40px))}.content-grid{grid-template-columns:minmax(0,1.75fr) minmax(320px,1fr);align-items:start}.chat-panel{position:sticky;top:1rem}.chat-panel .chat-list{max-height:28rem}}.hover\:-translate-y-0:hover{--tw-translate-y:-0px}.hover\:-translate-y-0:hover,.hover\:-translate-y-0\.5:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-0\.5:hover{--tw-translate-y:-0.125rem}@media (min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-\[1fr_auto\]{grid-template-columns:1fr auto}}