.home-page{justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.home-content{z-index:1;flex-direction:column;align-items:center;gap:2rem;width:100%;max-width:440px;display:flex;position:relative}.home-header{text-align:center}.home-logo{justify-content:center;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.home-logo-icon{background:var(--accent-terra);border-radius:var(--radius-md);color:#fff;width:52px;height:52px;transition:transform .4s var(--ease-spring);justify-content:center;align-items:center;display:flex;transform:rotate(-3deg);box-shadow:0 4px 14px #d4603a4d}.home-logo-icon:hover{transform:rotate(0)scale(1.05)}.home-logo-kanji{font-size:1.75rem;font-weight:700;line-height:1}.home-logo h1{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.03em;font-size:2.4rem;font-style:normal;font-weight:700}.home-tagline{color:var(--text-secondary);letter-spacing:-.01em;max-width:340px;margin:0 auto;font-size:.98rem;line-height:1.7}.home-card{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-lg);flex-direction:column;gap:1.25rem;padding:1.75rem;display:flex}.home-name-section{flex-direction:column;display:flex}.home-tab-bar{background:var(--bg-input);border-radius:var(--radius-md);gap:3px;padding:3px;display:flex}.home-tab{border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);transition:all .25s var(--ease-out);letter-spacing:-.01em;background:0 0;flex:1;justify-content:center;align-items:center;gap:.45rem;padding:.65rem .75rem;font-size:.85rem;font-weight:600;display:flex}.home-tab:hover:not(.active){color:var(--text-secondary)}.home-tab.active{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.home-tab-content{flex-direction:column;gap:1rem;display:flex}.home-feature-list{flex-direction:column;gap:.5rem;display:flex}.home-feature{background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:.7rem;padding:.55rem .75rem;font-size:.84rem;display:flex}.home-feature svg{color:var(--accent-terra);opacity:.8;flex-shrink:0}.home-error{border-radius:var(--radius-sm);color:var(--accent-red);text-align:center;background:#c0392b0f;border:1px solid #c0392b26;padding:.75rem 1rem;font-size:.85rem}[data-theme=dark] .home-error{background:#d94e3f1a;border-color:#d94e3f33}.carousel-loading{background:var(--bg-primary);color:var(--text-secondary);z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:fixed;inset:0}.carousel-loading-spinner{border:2.5px solid var(--border-color);border-top-color:var(--accent-terra);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite carousel-spin}@keyframes carousel-spin{to{transform:rotate(360deg)}}.game-carousel{z-index:10;-webkit-user-select:none;user-select:none;position:fixed;inset:0;overflow:hidden}.carousel-bg{z-index:0;position:absolute;inset:0}.carousel-noise{z-index:1;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:absolute;inset:0}.carousel-header{z-index:20;-webkit-backdrop-filter:blur(16px);background:#0000001f;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:1rem 4rem 1rem 1.5rem;display:flex;position:absolute;top:0;left:0;right:0}.carousel-header-left{align-items:center;gap:.6rem;display:flex}.carousel-status-dot{background:#ef4444;border-radius:50%;flex-shrink:0;width:7px;height:7px;transition:background .3s}.carousel-status-dot[data-connected=true]{background:#4ade80;box-shadow:0 0 6px #4ade8080}.carousel-logo{font-family:var(--font-display);color:#ffffffeb;letter-spacing:-.025em;align-items:center;gap:.4rem;font-size:1.3rem;font-weight:700;display:flex}.carousel-logo-kanji{opacity:.7;font-size:1.15rem}.carousel-header-right{align-items:center;gap:.5rem;display:flex}.carousel-chip{color:#fffc;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff14;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .7rem;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .2s;display:inline-flex}.carousel-chip:hover{background:#ffffff2e}.carousel-chip-code{font-family:var(--font-mono);letter-spacing:.1em;font-weight:700}.carousel-leave{color:#fff9;background:#ffffff14;border:1px solid #ffffff0f;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.carousel-leave:hover{color:#fca5a5;background:#ef444433;border-color:#ef444433}.carousel-viewport{z-index:5;touch-action:pan-y;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.carousel-slide{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.slide-content{text-align:center;flex-direction:column;align-items:center;gap:0;max-width:380px;padding:1rem;display:flex}.slide-icon-wrapper{margin-bottom:2rem;position:relative}.slide-icon-glow{filter:blur(60px);pointer-events:none;border-radius:50%;width:220px;height:220px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.slide-icon-ring{border:1.5px solid;border-radius:50%;justify-content:center;align-items:center;width:160px;height:160px;display:flex;position:relative}.slide-icon-inner{border-radius:50%;justify-content:center;align-items:center;width:130px;height:130px;display:flex}.slide-name{font-family:var(--font-display);letter-spacing:-.04em;margin-bottom:.5rem;font-size:2.8rem;font-weight:700;line-height:1.1}.slide-subtitle{max-width:260px;margin-bottom:1.75rem;font-size:1rem;font-weight:500;line-height:1.5}.slide-action{justify-content:center;align-items:center;min-height:52px;display:flex}.slide-play-btn{letter-spacing:-.01em;background:var(--play-bg);color:var(--play-color);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:.55rem;padding:.85rem 2.2rem;font-size:1rem;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);display:inline-flex;box-shadow:0 4px 20px #0003}.slide-play-btn:hover{transform:translateY(-2px)scale(1.03);box-shadow:0 8px 30px #0000004d}.slide-play-btn:active{transform:translateY(0)scale(.98);box-shadow:0 2px 12px #0003}.slide-waiting{flex-direction:column;align-items:center;gap:.6rem;font-size:.88rem;font-weight:500;display:flex}.slide-waiting-dots{gap:.4rem;display:flex}.slide-waiting-dots span{opacity:.5;border-radius:50%;width:6px;height:6px;animation:1.4s infinite carousel-bounce}.slide-waiting-dots span:nth-child(2){animation-delay:.2s}.slide-waiting-dots span:nth-child(3){animation-delay:.4s}@keyframes carousel-bounce{0%,80%,to{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.slide-soon-label{letter-spacing:.04em;font-size:.9rem;font-style:italic;font-weight:600}.carousel-arrow{z-index:15;color:#ffffffd9;cursor:pointer;-webkit-backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:all .25s cubic-bezier(.22,1,.36,1);display:flex;position:absolute;top:50%;transform:translateY(-50%)}.carousel-arrow:hover{background:#fff3;border-color:#fff3;transform:translateY(-50%)scale(1.08)}.carousel-arrow:active{transform:translateY(-50%)scale(.94)}.carousel-arrow-left{left:1.25rem}.carousel-arrow-right{right:1.25rem}.carousel-arrow-hidden{opacity:0;pointer-events:none;transform:translateY(-50%)scale(.8)}.carousel-bottom{z-index:15;pointer-events:none;flex-direction:column;align-items:center;gap:1rem;padding:0 1.5rem 2rem;display:flex;position:absolute;bottom:0;left:0;right:0}.carousel-bottom>*{pointer-events:auto}.carousel-dots{gap:.6rem;display:flex}.carousel-dot{background:var(--dot-bg);cursor:pointer;border:none;border-radius:2px;width:32px;height:4px;padding:0;transition:all .35s cubic-bezier(.22,1,.36,1)}.carousel-dot.active{background:var(--dot-active);width:44px}.carousel-dot:hover:not(.active){background:var(--dot-active);opacity:.5}.carousel-members{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.carousel-member{-webkit-backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff0f;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .6rem .3rem .3rem;transition:background .2s;display:flex}.carousel-member:hover{background:#ffffff24}.carousel-member-avatar{border:1.5px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.62rem;font-weight:700;display:flex}.carousel-member-name{color:#ffffffd9;white-space:nowrap;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;display:flex}.carousel-member-crown{color:#ffcba4;flex-shrink:0}.panel-backdrop{z-index:25;-webkit-backdrop-filter:blur(4px);background:#00000073;position:fixed;inset:0}.game-panel{background:var(--bg-card);z-index:30;border-top-left-radius:20px;border-top-right-radius:20px;width:100%;max-width:540px;max-height:85dvh;position:fixed;bottom:0;left:50%;overflow-y:auto;box-shadow:0 -8px 50px #00000040}.game-panel-handle{background:var(--border-color);border-radius:2px;width:36px;height:4px;margin:.75rem auto 0}.game-panel-header{background:var(--bg-card);z-index:2;justify-content:space-between;align-items:center;padding:1rem 1.5rem .5rem;display:flex;position:sticky;top:0}.game-panel-header h2{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:1.3rem;font-weight:700}.panel-close{background:var(--bg-input);width:34px;height:34px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.panel-close:hover{background:var(--border-color);color:var(--text-primary)}.game-panel-body{padding:.75rem 1.5rem 2rem}.quiz-picker{flex-direction:column;gap:.6rem;display:flex}.quiz-theme-group{border:1.5px solid var(--border-color);border-radius:var(--radius-md);transition:border-color .2s;overflow:hidden}.quiz-theme-group:has(.quiz-theme-row.expanded){border-color:var(--border-light)}.quiz-theme-row{text-align:left;cursor:pointer;width:100%;color:var(--text-primary);background:var(--bg-card);align-items:center;gap:.85rem;padding:1rem 1.15rem;transition:background .2s;display:flex}.quiz-theme-row:hover{background:var(--bg-card-hover)}.quiz-theme-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.quiz-theme-info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.quiz-theme-name{letter-spacing:-.01em;font-size:.95rem;font-weight:600}.quiz-theme-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.quiz-chevron{color:var(--text-muted);transition:transform .25s var(--ease-out);flex-shrink:0}.quiz-chevron.open{transform:rotate(90deg)}.quiz-list{overflow:hidden}.quiz-list-inner{border-top:1px solid var(--border-color);flex-direction:column;gap:0;display:flex}.quiz-item{text-align:left;color:var(--text-primary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1.15rem .85rem 1.5rem;transition:background .15s;display:flex}.quiz-item:last-child{border-bottom:none}.quiz-item:hover{background:var(--bg-card-hover)}.quiz-item-info{flex-direction:column;gap:.1rem;min-width:0;display:flex}.quiz-item-name{letter-spacing:-.01em;font-size:.9rem;font-weight:600}.quiz-item-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.quiz-item-meta{flex-shrink:0;align-items:center;gap:.45rem;display:flex}.quiz-item-count{color:var(--text-muted);font-size:.7rem;font-weight:600}.sudoku-picker{flex-direction:column;gap:1.25rem;display:flex}.picker-section{flex-direction:column;gap:.5rem;display:flex}.picker-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600}.picker-row{grid-template-columns:repeat(3,1fr);gap:.5rem;display:grid}.picker-row-2{grid-template-columns:repeat(2,1fr)}.picker-chip{border-radius:var(--radius-md);background:var(--bg-card);border:1.5px solid var(--border-color);cursor:pointer;text-align:center;transition:all .2s var(--ease-out);color:var(--text-primary);flex-direction:column;align-items:center;gap:.2rem;padding:.75rem .5rem;display:flex}.picker-chip:hover:not(.selected){border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}.picker-chip.selected{border-color:var(--accent-terra);box-shadow:0 0 0 1px var(--accent-terra);background:#d4603a0f}.picker-chip-label{font-size:.9rem;font-weight:700}.picker-chip-desc{color:var(--text-muted);font-size:.72rem}.picker-mode{border-radius:var(--radius-md);background:var(--bg-card);border:1.5px solid var(--border-color);cursor:pointer;text-align:center;color:var(--text-secondary);transition:all .2s var(--ease-out);flex-direction:column;align-items:center;gap:.3rem;padding:.9rem .75rem;display:flex}.picker-mode:hover:not(.selected){border-color:var(--border-light);box-shadow:var(--shadow-md);transform:translateY(-1px)}.picker-mode.selected{border-color:var(--accent-terra);color:var(--accent-terra);box-shadow:0 0 0 1px var(--accent-terra);background:#d4603a0f}.picker-mode-label{color:var(--text-primary);font-size:.92rem;font-weight:700}.picker-mode-desc{color:var(--text-muted);font-size:.72rem}@media (width<=768px){.carousel-header{padding:.85rem 1rem}.carousel-logo{font-size:1.15rem}.carousel-arrow{width:42px;height:42px}.carousel-arrow-left{left:.75rem}.carousel-arrow-right{right:.75rem}.slide-name{font-size:2.2rem}.slide-subtitle{font-size:.92rem}.slide-icon-ring{width:130px;height:130px}.slide-icon-inner{width:105px;height:105px}.slide-icon-inner svg{width:52px;height:52px}.slide-icon-glow{width:170px;height:170px}.carousel-bottom{padding-bottom:1.5rem}.game-panel{max-height:90dvh}.game-panel-body{padding:.75rem 1rem 2rem}.game-panel-header{padding:1rem 1rem .5rem}}@media (width<=400px){.carousel-chip-code{display:none}.carousel-arrow{width:36px;height:36px}.carousel-arrow-left{left:.5rem}.carousel-arrow-right{right:.5rem}.slide-name{font-size:1.9rem}.slide-icon-ring{width:110px;height:110px}.slide-icon-inner{width:88px;height:88px}.slide-icon-inner svg{width:44px;height:44px}}.quiz-view{flex-direction:column;gap:1.25rem;display:flex}.quiz-header{flex-direction:column;gap:.75rem;display:flex}.quiz-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:1.4rem;font-weight:600}.quiz-progress-section{align-items:center;gap:.75rem;display:flex}.quiz-progress-text{color:var(--text-muted);white-space:nowrap;font-size:.72rem;font-weight:600;font-family:var(--font-mono)}.quiz-friends-progress{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:.85rem 1rem}.quiz-friends-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.72rem;font-weight:600;display:flex}.quiz-friends-list{flex-direction:column;gap:.5rem;display:flex}.quiz-friend-progress{flex-direction:column;gap:.25rem;display:flex}.quiz-friend-info{color:var(--text-secondary);align-items:center;gap:.35rem;font-size:.8rem;display:flex}.quiz-friend-name{font-weight:500}.quiz-friend-done{color:var(--accent-sage)}.quiz-question-card{padding:2rem;position:relative}.quiz-question-card:before{content:"";background:var(--accent-terra);border-radius:var(--radius-lg) var(--radius-lg) 0 0;opacity:.7;height:3px;position:absolute;top:0;left:0;right:0}.quiz-question-number{text-transform:uppercase;letter-spacing:.1em;color:var(--accent-terra);font-size:.72rem;font-weight:600;font-family:var(--font-mono);margin-bottom:.75rem}.quiz-question-text{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;margin-bottom:1.75rem;font-size:1.3rem;font-weight:500;line-height:1.45}.quiz-likert-scale{justify-content:center;gap:.6rem;display:flex}.quiz-likert-option{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out);flex-direction:column;flex:1;align-items:center;gap:.4rem;min-width:0;padding:1rem .4rem .75rem;display:flex}.quiz-likert-option:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);background:var(--bg-card-hover);transform:translateY(-2px)}.quiz-likert-option.selected{border-color:var(--accent-terra);background:#d4603a0f;transform:translateY(-2px);box-shadow:0 0 0 3px #d4603a1a}[data-theme=dark] .quiz-likert-option.selected{background:#e07a561f;box-shadow:0 0 0 3px #e07a562e}.quiz-likert-icon{color:var(--text-secondary);justify-content:center;align-items:center;gap:2px;min-height:1.5rem;display:flex}.quiz-likert-option.selected .quiz-likert-icon{color:var(--accent-terra)}.quiz-likert-label{color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.03em;font-size:.55rem;font-weight:600;line-height:1.3}.quiz-likert-friends{justify-content:center;gap:3px;min-height:12px;display:flex}.quiz-options{flex-direction:column;gap:.65rem;display:flex}.quiz-option{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-md);text-align:left;transition:all .2s var(--ease-out);color:var(--text-primary);box-shadow:var(--shadow-sm);align-items:center;gap:.85rem;padding:1rem 1.25rem;display:flex}.quiz-option:hover{border-color:var(--border-light);box-shadow:var(--shadow-md);background:var(--bg-card-hover)}.quiz-option.selected{border-color:var(--accent-terra);background:#d4603a0a;box-shadow:0 0 0 3px #d4603a14}[data-theme=dark] .quiz-option.selected{background:#e07a561a;box-shadow:0 0 0 3px #e07a5626}.quiz-option-letter{background:var(--bg-input);width:34px;height:34px;color:var(--text-muted);transition:all .2s var(--ease-out);font-size:.78rem;font-weight:700;font-family:var(--font-mono);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.quiz-option.selected .quiz-option-letter{background:var(--accent-terra);color:#fff}.quiz-option-text{flex:1;font-size:.95rem;line-height:1.45}.quiz-option-friends{flex-shrink:0;align-items:center;gap:4px;margin-left:auto;padding-left:.5rem;display:flex}.quiz-option-friend-dot{width:10px;height:10px;animation:fadeIn .3s var(--ease-out) forwards;border:1.5px solid #fff9;border-radius:50%;display:inline-block;box-shadow:0 1px 3px #00000026}.quiz-option-check{color:var(--accent-terra);flex-shrink:0}.quiz-nav{justify-content:space-between;align-items:center;gap:1rem;padding-top:.5rem;display:flex}.quiz-dots{flex-wrap:wrap;justify-content:center;gap:.3rem;display:flex}.quiz-dot{background:var(--border-color);width:10px;height:10px;transition:all .2s var(--ease-out);border:2px solid #0000;border-radius:50%;padding:0}.quiz-dot.active{background:var(--accent-terra);transform:scale(1.25)}.quiz-dot.answered{background:var(--accent-sage)}.quiz-dot.answered.active{background:var(--accent-terra);box-shadow:0 0 0 2.5px var(--accent-sage)}@media (width<=640px){.quiz-question-card{padding:1.5rem}.quiz-question-text{font-size:1.1rem}.quiz-likert-scale{gap:.35rem}.quiz-likert-option{padding:.7rem .2rem .5rem}.quiz-likert-icon svg{width:18px;height:18px}.quiz-likert-label{font-size:.45rem}}.results{flex-direction:column;gap:1.75rem;display:flex}.results-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.results-quiz-name{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);font-size:1.4rem;font-weight:600}.results-my-result{background:var(--bg-card);border:2px solid var(--accent-terra);border-radius:var(--radius-lg);padding:2rem;position:relative;overflow:hidden;box-shadow:0 4px 20px #d4603a14}[data-theme=dark] .results-my-result{box-shadow:0 4px 20px #e07a561f}.results-my-result:before{content:"";background:var(--accent-terra);height:4px;position:absolute;top:0;left:0;right:0}.results-my-badge{text-transform:uppercase;letter-spacing:.12em;color:var(--accent-terra);font-size:.72rem;font-weight:700;font-family:var(--font-mono);margin-bottom:.6rem}.results-my-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.75rem;font-size:1.6rem;font-weight:700;line-height:1.3}.results-my-description{color:var(--text-secondary);font-size:.95rem;line-height:1.7}.results-traits{border-top:1px solid var(--border-color);flex-direction:column;gap:1.25rem;margin-top:1.75rem;padding-top:1.5rem;display:flex}.results-trait-header{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.results-trait-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.results-trait-score{color:var(--text-muted);font-size:.78rem;font-weight:600;font-family:var(--font-mono)}.results-trait-desc{color:var(--text-muted);margin-top:.4rem;font-size:.8rem;line-height:1.55}.results-scores{border-top:1px solid var(--border-color);margin-top:1.75rem;padding-top:1.5rem}.results-pie-section{align-items:center;gap:1.75rem;display:flex}.results-pie-chart{flex-shrink:0}.results-pie-chart svg{display:block}.results-pie-segment{transition:opacity .2s var(--ease-out)}.results-pie-segment:hover{opacity:.85}.results-pie-legend{flex-direction:column;flex:1;gap:.55rem;min-width:0;display:flex}.results-pie-legend-item{border-radius:var(--radius-sm);transition:background .2s var(--ease-out);align-items:center;gap:.6rem;padding:.35rem .5rem;display:flex}.results-pie-legend-item.winner{background:#d4603a0f}[data-theme=dark] .results-pie-legend-item.winner{background:#e07a561a}.results-pie-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.results-pie-legend-label{color:var(--text-secondary);text-transform:capitalize;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.82rem;font-weight:500;overflow:hidden}.results-pie-legend-item.winner .results-pie-legend-label{color:var(--text-primary);font-weight:600}.results-pie-legend-value{color:var(--text-muted);font-size:.78rem;font-weight:600;font-family:var(--font-mono);flex-shrink:0}.results-pie-legend-item.winner .results-pie-legend-value{color:var(--accent-terra)}.results-waiting{text-align:center;padding:2rem}.results-waiting-content{color:var(--text-secondary);flex-direction:column;align-items:center;gap:1rem;display:flex}.results-friends-header{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:.85rem;font-size:.95rem;font-weight:600;display:flex}.results-friends-list{flex-direction:column;gap:.75rem;display:flex}.results-friend-card{transition:all .3s var(--ease-out);padding:0;overflow:hidden}.results-friend-card.expanded{border-color:var(--accent-plum);box-shadow:0 4px 16px #8b4e7d14}[data-theme=dark] .results-friend-card.expanded{box-shadow:0 4px 16px #b07ba51f}.results-friend-toggle{text-align:left;cursor:pointer;width:100%;color:var(--text-primary);font-family:inherit;font-size:inherit;transition:background .2s var(--ease-out);background:0 0;border:none;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;display:flex}.results-friend-toggle:hover{background:var(--bg-card-hover)}.results-friend-summary{flex:1;min-width:0}.results-friend-name{color:var(--accent-plum);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:700;font-family:var(--font-mono);margin-bottom:.3rem}.results-friend-result{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.35rem;font-size:1.15rem;font-weight:600}.results-friend-desc{color:var(--text-muted);font-size:.85rem;line-height:1.55}.results-friend-chevron{color:var(--text-muted);transition:transform .3s var(--ease-out);flex-shrink:0;margin-top:.6rem}.results-friend-chevron.rotated{transform:rotate(180deg)}.results-friend-details{padding:0 1.5rem 1.5rem}.results-friend-details .results-traits,.results-friend-details .results-scores{margin-top:0;padding-top:1rem}.results-friend-details .results-pie-legend-item.winner{background:#8b4e7d0f}[data-theme=dark] .results-friend-details .results-pie-legend-item.winner{background:#b07ba51a}.results-friend-details .results-pie-legend-item.winner .results-pie-legend-value{color:var(--accent-plum)}.results-pending{text-align:center;padding:1rem 0}.results-pending-text{color:var(--text-muted);margin-bottom:.6rem;font-size:.85rem}.results-pending-list{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.results-pending-name{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:999px;padding:.3rem .85rem;font-size:.8rem;animation:1.5s infinite pulse}.results-actions{justify-content:center;padding-top:.5rem;display:flex}@media (width<=640px){.results-my-result{padding:1.5rem}.results-my-title{font-size:1.3rem}.results-friend-toggle{padding:1rem 1.25rem}.results-friend-details{padding:0 1.25rem 1.25rem}.results-pie-section{flex-direction:column;align-items:center;gap:1.25rem}}.sudoku-board-wrapper{flex-direction:column;align-items:center;gap:1.25rem;display:flex}.sudoku-grid{background:var(--border-color);border:3px solid var(--text-primary);border-radius:var(--radius-sm);aspect-ratio:1;grid-template-columns:repeat(9,1fr);gap:0;width:100%;max-width:450px;display:grid;overflow:hidden}.sudoku-cell{aspect-ratio:1;background:var(--bg-card);border:.5px solid var(--border-color);font-size:1.25rem;font-weight:600;font-family:var(--font-mono);color:var(--accent-blue);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:0;transition:background .12s,color .12s,box-shadow .12s;display:flex;position:relative}.sudoku-cell.original{color:var(--text-primary);cursor:default;font-weight:700}.sudoku-cell.selected{box-shadow:inset 0 0 0 2px var(--accent-blue);z-index:2;background:#5b7fa42e}.sudoku-cell.related{background:#5b7fa40f}.sudoku-cell.same-value{background:#5b7fa41f}.sudoku-cell.active-number{color:var(--accent-terra);background:#d4603a21;box-shadow:inset 0 0 0 1.5px #d4603a59}.sudoku-cell.active-number.original{color:var(--accent-terra);font-weight:800}.sudoku-cell.highlighted{box-shadow:inset 0 0 0 2px var(--accent-terra)}.sudoku-cell.error{color:var(--accent-red);background:#c0392b14}.sudoku-cell.box-left{border-left:2.5px solid var(--text-primary)}.sudoku-cell.box-top{border-top:2.5px solid var(--text-primary)}.sudoku-cell:hover:not(.original):not(.selected):not(:disabled){background:#5b7fa41a}.sudoku-numpad{flex-wrap:wrap;justify-content:center;gap:.5rem;max-width:450px;display:flex}.sudoku-numpad-btn{border-radius:var(--radius-sm);background:var(--bg-card);border:1.5px solid var(--border-color);width:44px;height:44px;font-size:1.15rem;font-weight:700;font-family:var(--font-mono);color:var(--text-primary);cursor:pointer;transition:all .2s var(--ease-out);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;display:flex}.sudoku-numpad-btn:hover:not(:disabled){border-color:var(--accent-blue);box-shadow:var(--shadow-md);background:#5b7fa414;transform:translateY(-1px)}.sudoku-numpad-btn:active:not(:disabled){transform:translateY(0)}.sudoku-numpad-btn:disabled{opacity:.4;cursor:not-allowed}.sudoku-numpad-btn.numpad-active{background:var(--accent-terra);color:#fff;border-color:var(--accent-terra);transform:translateY(-1px);box-shadow:0 2px 10px #d4603a59}.sudoku-numpad-btn.numpad-active:hover:not(:disabled){background:var(--accent-terra);border-color:var(--accent-terra);transform:translateY(-2px);box-shadow:0 4px 16px #d4603a66}.sudoku-numpad-erase{color:var(--accent-red)}@media (width<=480px){.sudoku-grid{max-width:100%}.sudoku-cell{font-size:1rem}.sudoku-numpad-btn{width:38px;height:38px;font-size:1rem}}.sudoku-view{flex-direction:column;gap:1.25rem;max-width:520px;margin:0 auto;display:flex}.sudoku-view-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.sudoku-view-info{flex-direction:column;gap:.5rem;display:flex}.sudoku-view-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.35rem;font-weight:600;display:flex}.sudoku-view-badges{gap:.4rem;display:flex}.sudoku-view-stats{align-items:center;gap:1rem;display:flex}.sudoku-stat{color:var(--text-secondary);font-size:.88rem;font-weight:600;font-family:var(--font-mono);align-items:center;gap:.35rem;display:flex}.sudoku-opponents{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:.85rem 1rem}.sudoku-opponents-header{color:var(--text-secondary);align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.85rem;font-weight:600;display:flex}.sudoku-opponents-list{flex-wrap:wrap;gap:.6rem;display:flex}.sudoku-opponent{background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color);align-items:center;gap:.4rem;padding:.35rem .65rem;display:flex}.sudoku-opponent-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.65rem;font-weight:700;display:flex}.sudoku-opponent-name{color:var(--text-primary);font-size:.82rem;font-weight:600}.sudoku-opponent-progress{font-size:.75rem;font-family:var(--font-mono);color:var(--text-muted);font-weight:500}.sudoku-done-banner{text-align:left;align-items:center;gap:1rem;display:flex}.sudoku-done-icon{color:var(--accent-amber);flex-shrink:0}.sudoku-done-text h3{font-family:var(--font-display);color:var(--text-primary);font-size:1.15rem;font-weight:600}.sudoku-done-text p{color:var(--text-secondary);margin-top:.15rem;font-size:.88rem}.sudoku-results{flex-direction:column;gap:.75rem;display:flex}.sudoku-results-title{font-family:var(--font-display);color:var(--text-primary);font-size:1.1rem;font-weight:600}.sudoku-results-list{flex-direction:column;gap:.5rem;display:flex}.sudoku-result-item{background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-color);align-items:center;gap:.75rem;padding:.6rem .85rem;display:flex}.sudoku-result-item.winner{border-color:var(--accent-amber);background:#c8923d14}.sudoku-result-rank{font-weight:700;font-family:var(--font-mono);color:var(--text-muted);width:28px;font-size:.88rem}.sudoku-result-item.winner .sudoku-result-rank{color:var(--accent-amber)}.sudoku-result-name{color:var(--text-primary);flex:1;font-size:.9rem;font-weight:600}.sudoku-result-time{font-family:var(--font-mono);color:var(--text-secondary);font-size:.85rem;font-weight:600}.sudoku-result-trophy{color:var(--accent-amber);flex-shrink:0}.sudoku-actions{justify-content:center;padding-top:.5rem;display:flex}@media (width<=480px){.sudoku-view-header{flex-direction:column;gap:.75rem}.sudoku-view-stats{align-self:flex-start}}.canvas-view{background:var(--bg-primary,#f5f5f5);z-index:10;flex-direction:column;display:flex;position:fixed;inset:0;overflow:hidden}.canvas-toolbar{background:var(--bg-card,#fff);z-index:20;border-bottom:1px solid #00000014;flex-wrap:wrap;align-items:center;gap:12px;min-height:48px;padding:8px 16px;display:flex;box-shadow:0 1px 4px #0000000f}.canvas-toolbar-group{align-items:center;gap:6px;display:flex}.canvas-toolbar-label{color:var(--text-secondary,#888);font-size:.75rem;font-weight:500}.canvas-color-indicator{border:2px solid #0000001f;border-radius:6px;flex-shrink:0;width:24px;height:24px;box-shadow:0 1px 3px #0000001a}.canvas-tool-buttons{background:var(--bg-primary,#f0f0f0);border-radius:8px;gap:2px;padding:3px}.canvas-tool-btn{width:34px;height:34px;color:var(--text-secondary,#666);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.canvas-tool-btn:hover{color:var(--text-primary,#333);background:#0000000f}.canvas-tool-btn.active{background:var(--accent-terra,#d4603a);color:#fff;box-shadow:0 2px 6px #d4603a4d}.canvas-btn-danger{color:#e74c3c}.canvas-btn-danger:hover{color:#c0392b;background:#e74c3c1a}.canvas-zoom-controls{background:var(--bg-primary,#f0f0f0);border-radius:8px;gap:2px;padding:3px}.canvas-zoom-label{color:var(--text-secondary,#666);text-align:center;min-width:38px;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600}.canvas-toolbar-info{gap:12px;margin-left:auto}.canvas-pixel-count{color:var(--text-secondary,#888);font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:500}.canvas-coords{color:var(--text-tertiary,#aaa);font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:500}.canvas-toolbar-right{gap:4px}.canvas-main-area{flex:1;position:relative;overflow:hidden}.canvas-drawing-area{touch-action:none;width:100%;height:100%;display:block}.canvas-cursor-draw{cursor:crosshair}.canvas-cursor-eraser{cursor:cell}.canvas-cursor-grab{cursor:grab}.canvas-cursor-grabbing{cursor:grabbing}.canvas-minimap-container{background:var(--bg-card,#fff);z-index:15;-webkit-user-select:none;user-select:none;border-radius:10px;position:absolute;bottom:48px;right:16px;overflow:hidden;box-shadow:0 4px 20px #0000001f,0 0 0 1px #0000000f}.canvas-minimap-header{color:var(--text-secondary,#888);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #0000000f;align-items:center;gap:5px;padding:5px 10px;font-size:.65rem;font-weight:600;display:flex}.canvas-minimap{cursor:pointer;image-rendering:pixelated;display:block}.canvas-members-panel{background:var(--bg-card,#fff);z-index:15;border-radius:10px;min-width:140px;max-width:200px;position:absolute;top:12px;right:16px;overflow:hidden;box-shadow:0 4px 20px #0000001a,0 0 0 1px #0000000f}.canvas-members-header{color:var(--text-secondary,#888);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #0000000f;align-items:center;gap:5px;padding:8px 12px;font-size:.7rem;font-weight:600;display:flex}.canvas-members-list{max-height:200px;padding:6px 8px;overflow-y:auto}.canvas-member{border-radius:6px;align-items:center;gap:8px;padding:4px;display:flex}.canvas-member-color{border:1px solid #0000001a;border-radius:4px;flex-shrink:0;width:14px;height:14px}.canvas-member-name{color:var(--text-primary,#333);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;font-weight:500;overflow:hidden}.canvas-help-hint{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#ffffffbf;white-space:nowrap;pointer-events:none;z-index:15;background:#000000a6;border-radius:20px;align-items:center;gap:8px;padding:6px 14px;font-size:.68rem;animation:.5s 1s both fadeInUp;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.canvas-help-sep{opacity:.3}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (width<=640px){.canvas-toolbar{gap:8px;padding:6px 10px}.canvas-toolbar-info,.canvas-toolbar-label{display:none}.canvas-minimap-container{bottom:40px;right:8px}.canvas-minimap{width:120px;height:120px}.canvas-members-panel{min-width:120px;top:8px;right:8px}.canvas-help-hint{gap:4px;padding:5px 10px;font-size:.6rem}.canvas-tool-btn{width:30px;height:30px}}[data-theme=dark] .canvas-toolbar{background:var(--bg-card);border-bottom-color:#ffffff0f}[data-theme=dark] .canvas-tool-buttons,[data-theme=dark] .canvas-zoom-controls{background:#ffffff0f}[data-theme=dark] .canvas-tool-btn:hover{background:#ffffff1a}[data-theme=dark] .canvas-minimap-container,[data-theme=dark] .canvas-members-panel{background:var(--bg-card);box-shadow:0 4px 20px #0000004d,0 0 0 1px #ffffff0f}[data-theme=dark] .canvas-minimap-header,[data-theme=dark] .canvas-members-header{border-bottom-color:#ffffff0f}.remote-cursor-label{white-space:nowrap;color:#fff;border-radius:6px;padding:3px 8px;font-size:.65rem;font-weight:600;position:absolute;top:18px;left:10px;box-shadow:0 2px 8px #00000026}.room-page{padding:2rem 0}.room-content{max-width:780px;margin:0 auto;padding:0 1.5rem}@media (width<=768px){.room-page{padding:1.5rem 0}.room-content{padding:0 1rem}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#f7f3ee;--bg-secondary:#efe9e1;--bg-card:#fff;--bg-card-hover:#fbf9f6;--bg-input:#f0ebe4;--text-primary:#2c2825;--text-secondary:#635b53;--text-muted:#9e958b;--accent-terra:#d4603a;--accent-plum:#8b4e7d;--accent-sage:#5e8b6f;--accent-blue:#5b7fa4;--accent-amber:#c8923d;--accent-red:#c0392b;--border-color:#e5ded5;--border-light:#d8d0c5;--shadow-sm:0 1px 3px #2c28250f, 0 1px 2px #2c28250a;--shadow-md:0 4px 12px #2c282514, 0 2px 4px #2c28250a;--shadow-lg:0 12px 40px #2c28251a, 0 4px 12px #2c28250f;--shadow-card:0 1px 4px #2c28250f, 0 8px 24px #2c28250f;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:24px;--font-display:"Fraunces", "Georgia", serif;--font-body:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}[data-theme=dark]{--bg-primary:#1a1a1e;--bg-secondary:#222226;--bg-card:#2a2a2f;--bg-card-hover:#313136;--bg-input:#333338;--text-primary:#e8e4df;--text-secondary:#b0a99f;--text-muted:#7a746c;--accent-terra:#e07a56;--accent-plum:#b07ba5;--accent-sage:#7aaf8e;--accent-blue:#7a9dc0;--accent-amber:#d9a854;--accent-red:#d94e3f;--border-color:#3a3a40;--border-light:#4a4a52;--shadow-sm:0 1px 3px #0003, 0 1px 2px #00000026;--shadow-md:0 4px 12px #00000040, 0 2px 4px #00000026;--shadow-lg:0 12px 40px #0000004d, 0 4px 12px #0003;--shadow-card:0 1px 4px #0003, 0 8px 24px #00000026}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;line-height:1.6;position:relative}body:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;position:fixed;inset:0}[data-theme=dark] body:before{opacity:.03}#root{z-index:1;min-height:100dvh;position:relative}.app{min-height:100dvh;position:relative}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;background:0 0;border:none}input{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.container-sm{max-width:640px;margin:0 auto;padding:0 1.5rem}.page{min-height:100dvh;padding-bottom:3rem}.btn{border-radius:var(--radius-md);transition:all .25s var(--ease-out);white-space:nowrap;letter-spacing:-.01em;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent-terra);color:#fff;box-shadow:0 2px 8px #d4603a40}.btn-primary:hover{background:#c0542f;transform:translateY(-1px);box-shadow:0 4px 16px #d4603a4d}[data-theme=dark] .btn-primary:hover{background:#c86a42}.btn-primary:active{transform:translateY(0);box-shadow:0 1px 4px #d4603a33}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1.5px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-light);box-shadow:var(--shadow-md)}.btn-pink{background:var(--accent-plum);color:#fff;box-shadow:0 2px 8px #8b4e7d40}.btn-pink:hover{background:#7a4370;transform:translateY(-1px);box-shadow:0 4px 16px #8b4e7d4d}[data-theme=dark] .btn-pink:hover{background:#9a6690}.btn-lg{border-radius:var(--radius-lg);padding:1rem 2rem;font-size:1.05rem}.btn-sm{border-radius:var(--radius-sm);padding:.5rem 1rem;font-size:.85rem}.btn-block{width:100%}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none!important;transform:none!important}.input{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all .2s var(--ease-out);box-shadow:var(--shadow-sm);outline:none;padding:.75rem 1rem;font-size:1rem}.input:focus{border-color:var(--accent-terra);box-shadow:0 0 0 3px #d4603a1a, var(--shadow-sm)}.input::placeholder{color:var(--text-muted)}.input-lg{padding:1rem 1.25rem;font-size:1.05rem}.input-code{text-align:center;letter-spacing:.3em;font-size:1.5rem;font-weight:700;font-family:var(--font-mono);text-transform:uppercase}.card{background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-lg);transition:all .25s var(--ease-out);box-shadow:var(--shadow-card);padding:1.5rem}.card-hover:hover{border-color:var(--border-light);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem;font-size:.8rem;font-weight:600;display:block}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .75rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-purple,.badge-pink{color:var(--accent-plum);background:#8b4e7d1a}.badge-amber{color:var(--accent-amber);background:#c8923d1f}.badge-green{color:var(--accent-sage);background:#5e8b6f1f}@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{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes gentle-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn .4s var(--ease-out) forwards}.animate-slide-up{animation:slideUp .5s var(--ease-out) forwards}.bg-gradient-glow{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.bg-gradient-glow:before{content:"";background:radial-gradient(circle,#d4603a0f 0%,#0000 65%);width:50%;height:50%;position:absolute;top:-30%;left:-15%}.bg-gradient-glow:after{content:"";background:radial-gradient(circle,#8b4e7d0a 0%,#0000 65%);width:50%;height:50%;position:absolute;bottom:-15%;right:-15%}[data-theme=dark] .bg-gradient-glow:before{background:radial-gradient(circle,#e07a5614 0%,#0000 65%)}[data-theme=dark] .bg-gradient-glow:after{background:radial-gradient(circle,#b07ba50f 0%,#0000 65%)}.remote-cursor{pointer-events:none;z-index:1000;transition:left .1s linear,top .1s linear;position:fixed}.remote-cursor-dot{border:2px solid #fff;border-radius:50%;width:12px;height:12px}.remote-cursor-label{white-space:nowrap;color:#fff;border-radius:6px;padding:2px 8px;font-size:.7rem;font-weight:600;position:absolute;top:16px;left:8px}.progress-bar{background:var(--bg-input);border-radius:99px;width:100%;height:6px;overflow:hidden}.progress-bar-fill{height:100%;transition:width .4s var(--ease-out);border-radius:99px}.room-code{font-family:var(--font-mono);letter-spacing:.15em;font-weight:700}.btn-danger{background:var(--accent-red);color:#fff;box-shadow:0 2px 8px #c0392b40}.btn-danger:hover{background:#a93226;transform:translateY(-1px);box-shadow:0 4px 16px #c0392b4d}[data-theme=dark] .btn-danger:hover{background:#c44336}.game-terminate-section{justify-content:center;padding-top:1rem;display:flex}.btn-terminate{border-radius:var(--radius-sm);color:var(--text-muted);transition:all .2s var(--ease-out);background:0 0;border:1.5px solid #0000;align-items:center;gap:.4rem;padding:.55rem 1rem;font-size:.82rem;font-weight:600;display:inline-flex}.btn-terminate:hover{color:var(--accent-red);background:#c0392b0f;border-color:#c0392b26}[data-theme=dark] .btn-terminate:hover{background:#d94e3f1a;border-color:#d94e3f33}.terminate-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);background:#00000080;position:fixed;inset:0}.terminate-dialog{z-index:210;background:var(--bg-card);border:1.5px solid var(--border-color);border-radius:var(--radius-xl);text-align:center;width:calc(100% - 2rem);max-width:380px;box-shadow:var(--shadow-lg);padding:2rem;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.terminate-dialog-icon{width:52px;height:52px;color:var(--accent-red);background:#c0392b14;border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1rem;display:flex}[data-theme=dark] .terminate-dialog-icon{background:#d94e3f1f}.terminate-dialog h3{font-family:var(--font-display);color:var(--text-primary);margin-bottom:.5rem;font-size:1.2rem;font-weight:700}.terminate-dialog p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.88rem;line-height:1.5}.terminate-dialog-actions{gap:.75rem;display:flex}.terminate-dialog-actions .btn{flex:1}@media (width<=768px){html{font-size:14px}.container{padding:0 1rem}}
