@import "https://fonts.googleapis.com/css2?family=Baloo+2:wght@400;500;600;700;800&family=Fredoka:wght@300;400;500;600;700&display=swap";
@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-border-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}}}@layer theme{:root,:host{--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-font-family:"Fredoka", sans-serif;--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{.start{inset-inline-start:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.hidden{display:none}.inline-block{display:inline-block}.w-full{width:100%}.border{border-style:var(--tw-border-style);border-width:1px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.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,)}}:root{--bg-primary:#f8fafc;--bg-secondary:#f1f5f9;--bg-board:#fff;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--accent-primary:#6366f1;--accent-secondary:#0ea5e9;--accent-success:#10b981;--accent-warning:#f59e0b;--accent-info:#06b6d4;--accent-neutral:#94a3b8;--cell-bg:#fff;--cell-hover:#f8fafc;--cell-border:#cbd5e1;--shadow-soft:#0000000d;--shadow-medium:#0000001a;--gradient-hero:linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);--gradient-card:linear-gradient(145deg, #fff 0%, #f8fafc 100%);--gradient-board:linear-gradient(145deg, #eef2ff 0%, #e0f2fe 100%);--gradient-x:linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--gradient-o:linear-gradient(135deg, #14b8a6 0%, #0ea5e9 100%)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;margin:0;padding:0}html,body{background:var(--gradient-hero);color:var(--text-primary);touch-action:manipulation;-webkit-user-select:none;user-select:none;overscroll-behavior:none;min-height:100vh;font-family:Fredoka,sans-serif;overflow-x:hidden}.main-container{z-index:1;position:relative}.settings-page{z-index:1;padding:1rem;position:relative}.settings-card{background:linear-gradient(145deg,#fffffff5,#f8fafcf0);border:2px solid #e0c8f059;border-radius:2rem;max-width:640px;margin:0 auto;padding:1.5rem;box-shadow:0 20px 50px #0f172a14}.settings-topbar{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.settings-title{color:var(--accent-primary);font-family:"Baloo 2",cursive;font-size:2rem;font-weight:800}.settings-subtitle{color:var(--text-muted);margin-top:.2rem}.settings-reset-btn{color:var(--accent-primary);background:#fff;border:2px solid #6366f12e;border-radius:999px;align-items:center;gap:.45rem;padding:.7rem 1rem;font-family:Fredoka,sans-serif;font-weight:600;display:inline-flex}.settings-section{background:#ffffffc7;border:2px solid #cbd5e173;border-radius:1.5rem;margin-top:1.25rem;padding:1.15rem}.settings-toggle-panel{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.settings-section-head{flex:auto;align-items:center;gap:.9rem;min-width:0;display:flex}.settings-section-head h3{color:var(--text-primary);font-family:"Baloo 2",cursive;font-size:1.3rem}.settings-section-head p{color:var(--text-muted);margin-top:.1rem}.settings-icon{border-radius:1rem;flex:none;justify-content:center;align-items:center;width:3rem;height:3rem;font-size:1.2rem;display:inline-flex}.settings-icon.music{color:#5b5ce2;background:#6366f11f}.settings-icon.sfx{color:#0284c7;background:#0ea5e924}.settings-icon.turns{color:#0f9c74;background:#10b98124}.settings-switch{background:#fff;border:2px solid #94a3b838;border-radius:999px;flex:none;justify-content:space-between;align-items:center;gap:.7rem;min-width:7.3rem;margin-left:auto;padding:.45rem .55rem .45rem .7rem;display:inline-flex;box-shadow:inset 0 1px #ffffffe6}.settings-switch-track{background:#94a3b847;border-radius:999px;align-items:center;width:3.55rem;height:2rem;padding:.18rem;transition:background .2s;display:flex}.settings-switch-thumb{background:linear-gradient(#fff,#e2e8f0);border-radius:50%;width:1.45rem;height:1.45rem;transition:transform .22s;box-shadow:0 4px 10px #0f172a2e}.settings-switch-text{text-align:right;min-width:1.7rem;color:var(--text-secondary);font-family:"Baloo 2",cursive;font-size:1.15rem;font-weight:700}.settings-switch.active{background:linear-gradient(135deg,#6366f114,#0ea5e914);border-color:#6366f133}.settings-switch.active .settings-switch-track{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary))}.settings-switch.active .settings-switch-thumb{background:linear-gradient(#fff,#f8fafc);transform:translate(1.52rem)}.settings-switch.active .settings-switch-text{color:var(--accent-primary)}.settings-turn-grid{gap:.9rem;margin-top:1rem;display:grid}.settings-turn-card{text-align:left;background:#fff;border:2px solid #94a3b833;border-radius:1.35rem;grid-template-columns:auto 1fr;align-items:center;gap:.15rem .85rem;width:100%;padding:1rem 1.1rem;display:grid}.settings-turn-card.active{background:linear-gradient(135deg,#6366f11f,#0ea5e91a);border-color:#6366f14d;box-shadow:0 10px 24px #6366f11f}.settings-turn-icon{width:2.7rem;height:2.7rem;color:var(--accent-primary);background:#6366f11f;border-radius:1rem;grid-row:span 2;justify-content:center;align-items:center;display:inline-flex}.settings-turn-label{color:var(--text-primary);font-family:"Baloo 2",cursive;font-size:1.1rem}.settings-turn-desc{color:var(--text-muted);font-size:.9rem}.settings-back-link{width:fit-content;margin:1.5rem auto 0}.lobby-notice{text-align:center;border-radius:1rem;margin-top:1rem;padding:.85rem 1rem;font-weight:600}.lobby-notice.warning{color:#9a6700;background:#f59e0b24;border:1px solid #f59e0b59}.lobby-wait-time{color:var(--text-muted);margin-top:.75rem;font-weight:500}.lobby-timeout-card{background:#ffffffb8;border:1px solid #94a3b859;border-radius:1rem;margin-top:1rem;padding:1rem;box-shadow:0 10px 25px #0f172a0f}.lobby-timeout-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:1rem;display:flex}.bubbles-container{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.bubble{opacity:.12;border-radius:50%;animation:linear infinite float-bubble;position:absolute}@keyframes float-bubble{0%{opacity:0;transform:translateY(110vh)rotate(0)scale(.5)}10%{opacity:.12}90%{opacity:.12}to{opacity:0;transform:translateY(-10vh)rotate(360deg)scale(1)}}.header{text-align:center;z-index:1;padding:1.5rem 1rem .5rem;position:relative}.header-settings-link{width:2.9rem;height:2.9rem;color:var(--accent-primary);background:#ffffffc7;border:2px solid #6366f129;border-radius:999px;justify-content:center;align-items:center;font-size:1.1rem;transition:transform .2s,box-shadow .2s;display:inline-flex;position:absolute;top:1.35rem;right:1rem;box-shadow:0 8px 24px #0f172a14}.header-settings-link:hover{transform:translateY(-2px)rotate(12deg);box-shadow:0 12px 28px #0f172a1f}.header-title{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary), var(--accent-success));-webkit-text-fill-color:transparent;text-shadow:none;background-size:200% 200%;-webkit-background-clip:text;background-clip:text;font-family:"Baloo 2",cursive;font-size:3rem;font-weight:800;line-height:1.2;animation:4s ease-in-out infinite gradient-shift}.header-subtitle{color:var(--text-muted);margin-top:.15rem;font-size:1.1rem;font-weight:400}@keyframes gradient-shift{0%,to{background-position:0%}50%{background-position:100%}}.game-container{z-index:1;flex-direction:column;align-items:center;gap:1.25rem;max-width:540px;margin:0 auto;padding:1rem 1rem 2rem;display:flex;position:relative}.scoreboard{flex-flow:row;justify-content:center;gap:.75rem;width:100%;max-width:480px;display:flex}.score-card{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #0000;border-radius:1rem;flex:1;min-width:0;padding:.5rem .25rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.score-card:before{content:"";border-radius:inherit;opacity:.08;z-index:0;position:absolute;inset:0}.score-card-x{background:linear-gradient(145deg,#6366f11a,#a855f70d);border-color:#6366f133}.score-card-x:before{background:var(--gradient-x)}.score-card-draw{background:linear-gradient(145deg,#f59e0b1a,#fbbf240d);border-color:#f59e0b33}.score-card-draw:before{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.score-card-o{background:linear-gradient(145deg,#14b8a61a,#0ea5e90d);border-color:#14b8a633}.score-card-o:before{background:var(--gradient-o)}.score-card.active{box-shadow:0 4px 20px var(--shadow-medium);transform:scale(1.03)}.score-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);z-index:1;white-space:nowrap;justify-content:center;align-items:center;gap:.2rem;font-size:.65rem;font-weight:600;display:flex;position:relative}.score-value{z-index:1;font-family:"Baloo 2",cursive;font-size:1.5rem;font-weight:800;line-height:1.2;position:relative}.score-card-x .score-value{background:var(--gradient-x);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.score-card-o .score-value{background:var(--gradient-o);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.score-card-draw .score-value{-webkit-text-fill-color:transparent;background:linear-gradient(135deg,#f59e0b,#fbbf24);-webkit-background-clip:text;background-clip:text}.game-status{text-align:center;background:var(--gradient-card);box-shadow:0 2px 12px var(--shadow-soft);border:1.5px solid var(--cell-border);border-radius:2rem;min-width:220px;padding:.6rem 1.5rem}.status-text{justify-content:center;align-items:center;gap:.5rem;font-family:"Baloo 2",cursive;font-size:1.15rem;font-weight:700;display:flex}.status-text .icon-bounce{animation:.8s ease-in-out infinite bounce-icon}@keyframes bounce-icon{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.board-wrapper{padding:1rem;position:relative}.board{background:var(--gradient-board);width:320px;height:320px;box-shadow:0 8px 32px var(--shadow-medium), 0 2px 8px var(--shadow-soft), inset 0 1px 0 #fffc;touch-action:manipulation;border:2px solid #e0c8f066;border-radius:1.5rem;grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);gap:10px;padding:12px;display:grid}input,textarea{-webkit-user-select:text;user-select:text}.cell{aspect-ratio:1;background:var(--cell-bg);cursor:pointer;border:1.5px solid var(--cell-border);width:100%;min-width:0;height:100%;min-height:0;box-shadow:0 2px 8px var(--shadow-soft);border-radius:1rem;justify-content:center;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.cell:before{content:"";border-radius:inherit;opacity:0;background:radial-gradient(circle at 30% 30%,#fff9,#0000 60%);transition:opacity .3s;position:absolute;inset:0}.cell:hover:not(.cell-filled):not(.cell-disabled){background:var(--cell-hover);border-color:var(--accent-primary);box-shadow:0 4px 16px var(--shadow-medium);transform:scale(1.04)}.cell:hover:not(.cell-filled):not(.cell-disabled):before{opacity:1}.cell:active:not(.cell-filled):not(.cell-disabled){transform:scale(.96)}.cell-filled{cursor:default}.cell-disabled{cursor:default;opacity:.7}.cell-winner{z-index:2;animation:1.2s ease-in-out infinite winner-glow;transform:scale(1.05);border:4px solid var(--accent-warning)!important;background:#fff!important}@keyframes winner-glow{0%,to{box-shadow:0 0 8px #f59e0b4d}50%{box-shadow:0 0 20px #f59e0b80,0 0 40px #f59e0b33}}.cell-mark{z-index:1;font-size:2.8rem;line-height:1;position:relative}.cell-mark-enter{animation:.4s cubic-bezier(.34,1.56,.64,1) pop-in}@keyframes pop-in{0%{opacity:0;transform:scale(0)rotate(-180deg)}60%{transform:scale(1.15)rotate(10deg)}to{opacity:1;transform:scale(1)rotate(0)}}.mark-x{color:#0000;background:var(--gradient-x);-webkit-background-clip:text;background-clip:text}.mark-o{color:#0000;background:var(--gradient-o);-webkit-background-clip:text;background-clip:text}.actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.btn{cursor:pointer;border:2px solid #0000;border-radius:2rem;align-items:center;gap:.5rem;padding:.65rem 1.4rem;font-family:Fredoka,sans-serif;font-size:.95rem;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(#fff3 0%,#0000 50%);position:absolute;inset:0}.btn:hover{box-shadow:0 6px 20px var(--shadow-medium);transform:translateY(-2px)}.btn:active{transform:translateY(0)scale(.97)}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;border-color:#6366f14d}.btn-secondary{background:var(--gradient-card);color:var(--text-primary);border-color:var(--cell-border);box-shadow:0 2px 8px var(--shadow-soft)}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#f87171);border-color:#ef444433}.confetti-container{pointer-events:none;z-index:100;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.confetti-piece{animation:linear forwards confetti-fall;position:absolute;top:-20px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-20px)rotate(0)scale(1)}80%{opacity:1}to{opacity:0;transform:translateY(100vh)rotate(720deg)scale(.5)}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:50;background:#4a2d6b66;justify-content:center;align-items:center;padding:1rem;animation:.3s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--gradient-card);text-align:center;border:2px solid #e0c8f066;border-radius:2rem;width:100%;max-width:380px;padding:2rem;animation:.4s cubic-bezier(.34,1.56,.64,1) slide-up;box-shadow:0 20px 60px #4a2d6b4d}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-family:"Baloo 2",cursive;font-size:1.6rem;font-weight:700}.modal-subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.player-options{justify-content:center;gap:1rem;margin-bottom:1.5rem;display:flex}.player-option{cursor:pointer;background:var(--cell-bg);text-align:center;border:3px solid #0000;border-radius:1.25rem;flex:1;padding:1.25rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.player-option:hover{box-shadow:0 6px 20px var(--shadow-medium);transform:translateY(-3px)}.player-option.selected{border-color:var(--accent-primary);background:#6366f10d;box-shadow:0 4px 16px #6366f126}.player-option-icon{margin-bottom:.35rem;font-size:2.5rem}.player-option-label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.theme-badge{z-index:10;gap:.4rem;display:flex;position:absolute;top:1rem;right:1rem}.theme-dot{cursor:pointer;border:1.5px solid #ffffff80;border-radius:50%;width:10px;height:10px;transition:all .3s}.theme-dot:hover{transform:scale(1.3)}.theme-dot.active{transform:scale(1.4);box-shadow:0 0 8px}.win-line{z-index:5;opacity:0;background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:6px;animation:.5s ease-out forwards draw-line;position:absolute}@keyframes draw-line{0%{opacity:0;transform:scaleX(0)}to{opacity:.7;transform:scaleX(1)}}.footer{text-align:center;color:var(--text-muted);z-index:1;padding:1rem;font-size:.8rem;position:relative}.footer a{color:var(--accent-primary);text-decoration:none}@media (max-width:480px){.header-title{font-size:2.2rem}.settings-topbar{flex-direction:column;align-items:stretch}.settings-section{padding:1rem}.settings-section-head{gap:.7rem}.settings-section-head h3{font-size:1.1rem}.settings-icon{width:2.7rem;height:2.7rem;font-size:1.05rem}.settings-switch{gap:.45rem;min-width:6.4rem;padding:.35rem .4rem .35rem .55rem}.settings-switch-track{width:3rem;height:1.7rem}.settings-switch-thumb{width:1.18rem;height:1.18rem}.settings-switch.active .settings-switch-thumb{transform:translate(1.28rem)}.settings-switch-text{font-size:1rem}.board{gap:8px;width:280px;height:280px;padding:10px}.cell-mark{font-size:2.2rem}.scoreboard{gap:.5rem}.score-card{padding:.5rem}.score-value{font-size:1.6rem}.modal-content{padding:1.5rem}}@media (min-width:481px) and (max-width:768px){.board{width:340px;height:340px}}@media (max-width:380px) and (max-height:700px) and (hover:none) and (pointer:coarse){.header{padding:.7rem .75rem .2rem}.header-settings-link{width:2.45rem;height:2.45rem;font-size:.95rem;top:.55rem;right:.75rem}.header-title{font-size:1.8rem;line-height:1.05}.main-container{padding-bottom:.5rem}.game-container,.game-layout{gap:.6rem;padding:.35rem .75rem .75rem}.game-sidebar{width:100%}.game-main{gap:.7rem}.bot-profile-card{border-radius:1.2rem;height:40px;margin-bottom:.55rem;padding:.4rem .8rem}.bot-difficulty{font-size:.7rem}.bot-thinking-spinner{font-size:.75rem}.scoreboard{gap:.45rem;max-width:290px}.score-card{border-radius:.9rem;padding:.4rem .2rem}.score-label{letter-spacing:.03em;font-size:.55rem}.score-value{font-size:1.3rem}.game-status{border-radius:1.4rem;width:100%;min-width:0;max-width:255px;padding:.45rem .8rem}.status-text{gap:.35rem;font-size:.95rem}.board-wrapper{padding:.45rem}.board{border-radius:1.25rem;gap:7px;width:248px;height:248px;padding:8px}.cell{border-radius:.85rem}.cell-mark{font-size:2rem}.actions{flex-wrap:nowrap;gap:.5rem;width:100%;max-width:320px}.btn{border-radius:1.2rem;flex:1 1 0;justify-content:center;gap:.35rem;min-width:0;padding:.58rem .7rem;font-size:.82rem}.lobby{align-items:flex-start;min-height:auto;padding:.35rem .75rem .9rem}.lobby-card{border-radius:1.35rem;padding:1rem 1rem .85rem}.lobby-icon{margin-bottom:.25rem;font-size:2.7rem}.lobby-title{margin-bottom:.1rem;font-size:1.3rem}.lobby-subtitle{margin-bottom:.9rem;font-size:.84rem;line-height:1.3}.lobby-actions{gap:.7rem}.lobby-btn{border-radius:1rem;gap:.8rem;padding:.9rem 1rem}.lobby-btn-icon{font-size:1.55rem}.lobby-btn-label{font-size:1rem;line-height:1.05}.lobby-btn-desc{font-size:.72rem;line-height:1.2}.lobby-divider{gap:.5rem;font-size:.72rem}.join-form{gap:.45rem}.join-label{font-size:.82rem}.join-input{padding:.6rem .8rem;font-size:.9rem}.join-btn{padding:.6rem .9rem;font-size:.85rem}.settings-page{padding:.25rem .75rem}.settings-card{border-radius:1.25rem;padding:.85rem}.settings-title{font-size:1.35rem;line-height:.95}.settings-section{border-radius:1rem;margin-top:.65rem;padding:.65rem}.settings-toggle-panel{gap:.55rem}.settings-section-head{gap:.5rem}.settings-section-head h3{font-size:.92rem;line-height:1.1}.settings-icon{border-radius:.7rem;width:2.15rem;height:2.15rem;font-size:.82rem}.settings-switch{gap:.3rem;min-width:5.35rem;padding:.2rem .25rem .2rem .35rem}.settings-switch-track{width:2.45rem;height:1.4rem;padding:.12rem}.settings-switch-thumb{width:.98rem;height:.98rem}.settings-switch.active .settings-switch-thumb{transform:translate(1.03rem)}.settings-switch-text{font-size:.82rem}.settings-turn-grid{gap:.45rem;margin-top:.55rem}.settings-turn-card{border-radius:.9rem;gap:.05rem .55rem;padding:.58rem .65rem}.settings-turn-icon{border-radius:.65rem;width:1.9rem;height:1.9rem;font-size:.8rem}.settings-turn-label{font-size:.86rem;line-height:1}.settings-turn-desc{font-size:.68rem;line-height:1.1}.settings-back-link{z-index:5;margin-top:1rem}.btn-leave{margin-top:.75rem;font-size:.66rem}}.animate-wiggle{animation:.5s ease-in-out wiggle}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.animate-pulse-soft{animation:2s ease-in-out infinite pulse-soft}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.7}}.lobby{z-index:1;justify-content:center;align-items:center;min-height:50vh;padding:1rem 1rem 2rem;display:flex;position:relative}.lobby-card{background:var(--gradient-card);width:100%;max-width:420px;box-shadow:0 12px 40px var(--shadow-medium);text-align:center;border:2px solid #e0c8f066;border-radius:2rem;padding:2.5rem 2rem;animation:.5s cubic-bezier(.34,1.56,.64,1) slide-up}.lobby-icon{margin-bottom:.5rem;font-size:3.5rem;line-height:1}.lobby-icon-searching{place-items:center;width:5.5rem;height:5.5rem;margin-inline:auto;display:inline-grid;position:relative}.lobby-search-ring{border:4px solid #6366f129;border-top-color:var(--accent-primary);border-right-color:var(--accent-secondary);border-radius:50%;animation:1s linear infinite search-spin;position:absolute;inset:.35rem}.lobby-search-emoji{z-index:1;justify-content:center;align-items:center;animation:1.8s ease-in-out infinite search-float;display:inline-flex;position:relative}@keyframes search-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes search-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.lobby-title{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.25rem;font-family:"Baloo 2",cursive;font-size:1.8rem;font-weight:700}.lobby-subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem;line-height:1.4}.lobby-connecting{color:var(--text-muted);flex-direction:column;align-items:center;gap:.75rem;font-size:.9rem;display:flex}.lobby-actions{flex-direction:column;gap:.5rem;display:flex}.lobby-btn{cursor:pointer;border:2px solid #0000;border-radius:1.25rem;flex-direction:column;align-items:center;gap:.35rem;padding:1.25rem 1.5rem;font-family:Fredoka,sans-serif;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.lobby-btn:hover{box-shadow:0 8px 24px var(--shadow-medium);transform:translateY(-3px)}.lobby-btn:active{transform:translateY(0)scale(.98)}.lobby-btn-create{color:#fff;background:linear-gradient(135deg,#c77dff,#ff8fab);border-color:#c77dff4d}.lobby-btn-icon{font-size:1.8rem}.lobby-btn-label{font-size:1.1rem;font-weight:700}.lobby-btn-desc{opacity:.85;font-size:.8rem}.lobby-divider{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.85rem;font-weight:500;display:flex}.lobby-divider:before,.lobby-divider:after{content:"";background:var(--cell-border);flex:1;height:1px}.join-form{flex-direction:column;gap:.6rem;display:flex}.join-label{color:var(--text-secondary);justify-content:center;align-items:center;gap:.4rem;font-size:.9rem;font-weight:600;display:flex}.join-input-group{gap:.5rem;display:flex}.join-input{border:2px solid var(--cell-border);background:var(--cell-bg);color:var(--text-primary);border-radius:1rem;outline:none;flex:1;padding:.7rem 1rem;font-family:Fredoka,sans-serif;font-size:.95rem;transition:border-color .2s}.join-input:focus{border-color:var(--accent-purple)}.join-input::placeholder{color:var(--text-muted);opacity:.6}.join-btn{white-space:nowrap;padding:.7rem 1.2rem}.room-code-display{background:var(--cell-bg);border:2px dashed var(--accent-purple);border-radius:1rem;justify-content:center;align-items:center;gap:.6rem;max-width:320px;margin:1rem auto;padding:.85rem 1.25rem;display:flex}.room-code-text{color:var(--text-primary);letter-spacing:.02em;font-family:"Baloo 2",cursive;font-size:1.35rem;font-weight:700}.btn-copy{border:1.5px solid var(--cell-border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;background:#fff;border-radius:.6rem;justify-content:center;align-items:center;font-size:.9rem;transition:all .2s;display:flex}.btn-copy:hover{border-color:var(--accent-purple);color:var(--accent-purple)}.copy-feedback{color:var(--accent-mint);margin-top:-.25rem;font-size:.8rem;font-weight:600}.lobby-hint{color:var(--text-muted);justify-content:center;align-items:center;gap:.4rem;margin:.75rem 0;font-size:.9rem;display:flex}.lobby-error{color:#c44;background:#fca5a526;border:1.5px solid #fca5a566;border-radius:.75rem;margin-top:1rem;padding:.7rem 1rem;font-size:.85rem;font-weight:500}.waiting-dots{justify-content:center;gap:.4rem;margin-top:1rem;display:flex}.waiting-dots .dot{background:var(--accent-purple);opacity:.3;border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite dot-bounce}.waiting-dots .dot:first-child{animation-delay:0s}.waiting-dots .dot:nth-child(2){animation-delay:.2s}.waiting-dots .dot:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{opacity:.3;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.mark-badge{border-radius:2rem;align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:.8rem;font-weight:600;display:inline-flex}.mark-badge-x{color:#d06088;background:#ff8fab26}.mark-badge-o{color:#5b8ec9;background:#93c5fd26}.room-info{background:var(--gradient-card);border:1.5px solid var(--cell-border);width:100%;max-width:420px;box-shadow:0 2px 8px var(--shadow-soft);border-radius:1rem;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding:.5rem .75rem;display:flex}.room-info-left{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.75rem;display:flex}.room-info-dot{background:#86efac;border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 6px #86efac80}.room-info-code{letter-spacing:.01em;font-size:.72rem;font-weight:600}.room-info-center{flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem;display:flex}.turn-indicator{border-radius:2rem;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.your-turn{color:#3a9e5e;background:#86efac26;animation:1.5s ease-in-out infinite pulse-soft}.their-turn{color:#b8921a;background:#fde68a26}.btn-leave{width:fit-content;color:var(--accent-coral);cursor:pointer;background:#fca5a514;border:1.5px solid #fca5a54d;border-radius:.6rem;justify-content:center;align-self:center;align-items:center;gap:.3rem;margin-top:1rem;padding:.3rem .6rem;font-family:Fredoka,sans-serif;font-size:.7rem;font-weight:600;transition:all .2s;display:flex}.go-back-button-mode-selector{justify-content:center;align-self:center;align-items:center;width:100%;display:flex}.btn-leave:hover{background:#fca5a533;border-color:#fca5a580}.board-waiting{opacity:.75;pointer-events:none}@media (max-width:480px){.lobby-card{border-radius:1.5rem;padding:1rem}.lobby-title{font-size:1.5rem}.room-code-text{font-size:1.1rem}.room-info{padding:.4rem .6rem;font-size:.7rem}}.vertical-actions{flex-direction:column;gap:1.25rem;width:100%;display:flex}.lobby-btn{border:2.5px solid var(--cell-border);background:var(--bg-board);cursor:pointer;text-align:left;width:100%;box-shadow:0 4px 12px var(--shadow-soft);border-radius:1.25rem;align-items:center;gap:1.25rem;padding:1.25rem 1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);flex-direction:row!important;display:flex!important}.lobby-btn:hover{border-color:var(--accent-primary);box-shadow:0 10px 25px var(--shadow-medium);transform:translateY(-4px)}.bot-mode-btn{background:linear-gradient(135deg,#6366f10d,#a855f70d);border-color:#6366f133}.bot-mode-btn:hover{border-color:var(--accent-primary)}.local-mode-btn{background:linear-gradient(135deg,#10b9810d,#14b8a60d);border-color:#10b98133}.multiplayer-mode-btn{background:linear-gradient(135deg,#0ea5e90d,#06b6d40d);border-color:#0ea5e933}.lobby-btn-icon{color:var(--accent-primary);flex-shrink:0;font-size:2.2rem}.bot-mode-btn .lobby-btn-icon{color:var(--accent-primary)}.local-mode-btn .lobby-btn-icon{color:var(--accent-success)}.multiplayer-mode-btn .lobby-btn-icon{color:var(--accent-info)}.lobby-btn-text{flex-direction:column;gap:.1rem;display:flex}.lobby-btn-label{color:var(--text-primary);font-family:"Baloo 2",cursive;font-size:1.25rem;font-weight:700}.lobby-btn-desc{color:var(--text-muted);font-size:.85rem}.difficulty-container{border:1.5px dashed var(--accent-primary);background:#ffffff80;border-radius:1.5rem;margin:1.5rem 0 2rem;padding:1.5rem}.difficulty-visual{flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.diff-emoji{font-size:4rem;line-height:1}.diff-name{color:var(--accent-primary);letter-spacing:.05em;font-family:"Baloo 2",cursive;font-size:1.5rem;font-weight:800}.slider-wrapper{margin:1rem 0;position:relative}.difficulty-slider{appearance:none;cursor:pointer;background:#e2e8f0;border-radius:6px;outline:none;width:100%;height:12px}.difficulty-slider::-webkit-slider-thumb{appearance:none;background:var(--accent-primary);cursor:pointer;border:4px solid #fff;border-radius:50%;width:28px;height:28px;transition:transform .2s;box-shadow:0 4px 10px #6366f166}.difficulty-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-labels{color:var(--text-muted);letter-spacing:.1em;justify-content:space-between;margin-top:.75rem;font-size:.7rem;font-weight:700;display:flex}.diff-description{color:var(--text-secondary);margin-top:1rem;font-size:.85rem;font-style:italic}.game-layout{flex-direction:column;align-items:center;gap:1rem;max-width:900px;margin:0 auto;padding:1rem;display:flex}@media (min-width:840px){.game-layout{flex-direction:column;justify-content:center;align-items:center;gap:2rem}.game-sidebar{flex-direction:column;gap:1.5rem;width:100%;max-width:480px;display:flex}}.game-main{flex-direction:column;align-items:center;gap:1rem;display:flex}.bot-profile-card{background:var(--gradient-card);box-shadow:0 6px 24px var(--shadow-medium);border:2px solid var(--accent-primary);text-align:center;border-radius:1.5rem;justify-content:space-between;align-items:center;width:100%;height:45px;margin-bottom:1rem;padding:.5rem 1rem;animation:.5s ease-out slide-right;display:flex;position:relative;overflow:hidden}@keyframes slide-right{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.bot-avatar{margin-bottom:.5rem;font-size:3.5rem}.bot-name{font-family:"Baloo 2",cursive;font-size:1.4rem;line-height:1.2}.bot-difficulty{color:var(--text-muted);letter-spacing:.05em;font-size:.75rem;font-weight:600}.bot-thinking-spinner{color:var(--accent-primary);font-size:.85rem;font-weight:700;animation:1s infinite pulse-soft}.main-container{flex-direction:column;justify-content:center;min-height:70vh;display:flex}.w-full{width:100%}.btn-large{padding:1rem 2rem;font-size:1.1rem}@property --tw-border-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}
