*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.mt-1{margin-top:.25rem}.flex{display:flex}.hidden{display:none}.h-\[18px\]{height:18px}.w-\[18px\]{width:18px}.w-full{width:100%}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.origin-center{transform-origin:center}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.text-center{text-align:center}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-100{transition-duration:.1s}:root{--bg-base: #f8f9fc;--bg-surface: #ffffff;--bg-surface-hover: #f1f3f8;--bg-muted: #eef0f6;--text-primary: #1a1d2e;--text-secondary: #5c6178;--text-tertiary: #9ca3bd;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: rgba(99, 102, 241, .1);--accent-medium: rgba(99, 102, 241, .2);--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--border: #e2e5f0;--border-hover: #cdd1e0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .03);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06), 0 4px 12px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08), 0 8px 24px rgba(0, 0, 0, .04);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .1), 0 16px 48px rgba(0, 0, 0, .05);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 9999px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-standard: cubic-bezier(.4, 0, .2, 1)}@media(prefers-color-scheme:dark){:root{--bg-base: #0f1117;--bg-surface: #1a1d2e;--bg-surface-hover: #242840;--bg-muted: #242840;--text-primary: #eef0f6;--text-secondary: #9ca3bd;--text-tertiary: #5c6178;--accent: #818cf8;--accent-hover: #6366f1;--accent-light: rgba(129, 140, 248, .12);--accent-medium: rgba(129, 140, 248, .2);--success: #34d399;--danger: #f87171;--warning: #fbbf24;--border: #2d3148;--border-hover: #3d4260;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3), 0 4px 12px rgba(0, 0, 0, .2);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4), 0 8px 24px rgba(0, 0, 0, .25);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .5), 0 16px 48px rgba(0, 0, 0, .3)}}body{background:var(--bg-base);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;margin:0;padding:0;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#board-canvas{cursor:pointer;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);transition:box-shadow .3s var(--ease-standard),transform .2s var(--ease-out)}#board-canvas:hover{box-shadow:var(--shadow-xl)}.game-btn{border-radius:.5rem;font-size:.875rem;line-height:1.25rem;font-weight:600;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.game-btn:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-offset-width: 2px}.game-btn:active{--tw-scale-x: .97;--tw-scale-y: .97;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.game-btn{letter-spacing:.02em;position:relative;overflow:hidden}.game-btn-primary{background:var(--accent);color:#fff;border:none;box-shadow:0 1px 3px #6366f14d}.game-btn-primary:hover{background:var(--accent-hover);box-shadow:0 2px 8px #6366f159;transform:translateY(-1px)}.game-btn-primary:active{transform:translateY(0) scale(.97)}.game-btn-primary:focus{--tw-ring-color: var(--accent)}.game-btn-secondary{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.game-btn-secondary:hover{background:var(--bg-surface-hover);border-color:var(--border-hover);color:var(--text-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.game-btn-secondary:active{transform:translateY(0) scale(.97)}.game-btn-secondary:focus{--tw-ring-color: var(--accent-light)}.game-btn:disabled{cursor:not-allowed;opacity:.4}.game-btn:disabled:active{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.game-btn:disabled{transform:none!important;box-shadow:none!important}.icon-btn{display:flex;align-items:center;justify-content:center;border-radius:9999px;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.icon-btn:focus{outline:2px solid transparent;outline-offset:2px}.icon-btn{width:40px;height:40px;background:var(--bg-surface);color:var(--text-tertiary);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.icon-btn:hover{color:var(--text-primary);border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.icon-btn:active{transform:scale(.93)}.icon-btn:disabled{cursor:not-allowed;opacity:.3;transform:none!important;box-shadow:none!important}.icon-btn-active{color:var(--accent);border-color:var(--accent);background:var(--accent-light)}.mode-landing{position:fixed;inset:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;background:var(--bg-base);transition:opacity .4s var(--ease-out),visibility .4s}.mode-landing.hidden{opacity:0;visibility:hidden;pointer-events:none}.mode-option{display:flex;align-items:center;gap:14px;width:100%;padding:16px 20px;border-radius:var(--radius-lg);background:var(--bg-surface);border:1.5px solid var(--border);cursor:pointer;transition:all .3s var(--ease-out);box-shadow:var(--shadow-md)}.mode-option:hover{border-color:var(--accent);box-shadow:var(--shadow-lg),0 0 0 3px var(--accent-light);transform:translateY(-2px)}.mode-option:active{transform:translateY(0) scale(.98)}.mode-option-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-md);background:var(--accent-light);color:var(--accent)}.mode-option-text{display:flex;flex-direction:column;gap:2px}.mode-option-title{font-weight:700;font-size:1rem;letter-spacing:.04em;color:var(--text-primary)}.mode-option-desc{font-size:.75rem;color:var(--text-tertiary);letter-spacing:.03em}.online-panel{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:#0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:opacity .3s ease,visibility .3s}.online-panel.hidden{opacity:0;visibility:hidden;pointer-events:none}.online-card{width:min(340px,90vw);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:28px 24px;display:flex;flex-direction:column;gap:20px}.online-card-title{font-weight:700;font-size:1.125rem;letter-spacing:.02em;color:var(--text-primary);text-align:center}.online-card-section{display:flex;flex-direction:column;gap:10px}.online-card-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;color:var(--text-tertiary);text-transform:uppercase}.online-card-divider{height:1px;background:var(--border);margin:4px 0}.online-card-row{display:flex;gap:8px;align-items:center}.room-input{flex:1;padding:10px 14px;font-size:16px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-base);color:var(--text-primary);text-align:center;text-transform:uppercase;letter-spacing:.4em;font-weight:700;transition:border-color .2s ease,box-shadow .2s ease}.room-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.room-input::-moz-placeholder{font-weight:400;letter-spacing:.1em;color:var(--text-tertiary);font-size:13px}.room-input::placeholder{font-weight:400;letter-spacing:.1em;color:var(--text-tertiary);font-size:13px}.room-id-display{font-weight:900;font-size:2.25rem;letter-spacing:.5em;color:var(--accent);text-align:center}.online-status-dot{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:4px}.online-status-dot.connected{background:var(--success);box-shadow:0 0 6px #22c55e80}.online-status-dot.disconnected{background:var(--danger)}.player-bar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:400px;padding:0 4px}.player-side{display:flex;align-items:center;gap:8px}.player-side .stone-icon{width:22px;height:22px}.player-label{font-weight:600;font-size:.875rem;letter-spacing:.02em;color:var(--text-tertiary);transition:color .2s ease}.player-side-active .player-label{color:var(--text-primary)}.player-side-active .stone-icon{box-shadow:0 0 0 2.5px var(--accent),0 0 12px var(--accent-light)}.game-status-center{font-weight:700;font-size:1.25rem;letter-spacing:.06em;color:var(--text-primary);padding:6px 18px;border-radius:var(--radius-full);background:var(--accent-light);transition:all .3s ease;white-space:nowrap}.game-status-center.status-win{color:#fff;font-size:1.375rem;font-weight:800;background:var(--accent);animation:winPulse 1.2s ease-in-out infinite}.game-status-center.status-draw{color:var(--warning);background:#f59e0b1a}.stone-icon{border-radius:50%}.stone-icon-black{background:radial-gradient(circle at 35% 35%,#555,#222 50%,#0a0a0a);box-shadow:0 1px 3px #0000004d}.stone-icon-white{background:radial-gradient(circle at 35% 35%,#fff,#f5f5f5 50%,#e0e0e0);box-shadow:0 1px 3px #0000001f}.action-bar{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;max-width:400px}.action-bar .game-btn-primary{flex:1;padding:10px 16px}.game-toast{position:fixed;top:24px;left:50%;transform:translate(-50%) translateY(-120%);z-index:1000;padding:12px 28px;border-radius:var(--radius-full);font-size:14px;font-weight:500;letter-spacing:.02em;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);opacity:0;transition:all .4s var(--ease-out);pointer-events:none}.game-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.title-main{font-weight:800;letter-spacing:.06em;color:var(--text-primary);position:relative;display:inline-block}.title-main:after{content:"";position:absolute;bottom:-4px;left:15%;right:15%;height:3px;background:linear-gradient(90deg,transparent,var(--accent),transparent);border-radius:2px}.waiting-dots:after{content:"";animation:dots 1.5s steps(3) infinite}@keyframes dots{0%{content:""}33%{content:"·"}66%{content:"··"}to{content:"···"}}@keyframes winPulse{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.anim-fade-in{animation:fadeInUp .5s var(--ease-out) both}.anim-delay-1{animation-delay:.08s}.anim-delay-2{animation-delay:.16s}.anim-delay-3{animation-delay:.24s}.game-main-layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:12px 12px 0;gap:8px;position:relative}@media(min-width:768px){.game-main-layout{justify-content:center;padding:16px;gap:12px}}.touchpad-area{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:320px;flex:1;min-height:0;padding-bottom:16px;padding-bottom:max(16px,env(safe-area-inset-bottom))}.touchpad{flex:1;width:100%;min-height:100px;border-radius:16px;background:var(--bg-surface);border:1.5px solid var(--border-default);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;position:relative;touch-action:none;-moz-user-select:none;user-select:none;-webkit-user-select:none;box-shadow:0 1px 3px #0000000f}.touchpad:active{background:var(--bg-surface-hover)}.touchpad-grid{display:grid;grid-template-columns:repeat(3,36px);grid-template-rows:repeat(3,36px);gap:4px;align-items:center;justify-items:center}.touchpad-arrow{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text-tertiary)}.touchpad-arrow-up{grid-column:2;grid-row:1}.touchpad-arrow-left{grid-column:1;grid-row:2}.touchpad-arrow-right{grid-column:3;grid-row:2}.touchpad-arrow-down{grid-column:2;grid-row:3}.touchpad-center-dot{grid-column:2;grid-row:2;width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);opacity:.3}.touchpad-hint{font-size:.625rem;color:var(--text-tertiary);opacity:.5;letter-spacing:.08em}.touchpad-place-btn{width:100%;max-width:200px;padding:14px 24px;border-radius:14px;font-size:1.0625rem;font-weight:700;letter-spacing:.15em;border:none;cursor:pointer;background:var(--accent);color:#fff;transition:all .15s ease;box-shadow:0 2px 8px #6366f14d}.touchpad-place-btn:active{transform:scale(.96);background:var(--accent-hover)}@media(min-width:768px){.touchpad-area{display:none!important}}@media(max-width:400px){.player-side .stone-icon{width:18px;height:18px}.player-label{font-size:.8125rem}.icon-btn{width:36px;height:36px}.online-card{padding:24px 18px}}.hover\:opacity-100:hover{opacity:1}@media(min-width:640px){.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}}
