:root{--bg: #000000;--surface: #1c1c1e;--surface-elevated: #2c2c2e;--separator: #38383a;--text: #ffffff;--text-secondary: #8e8e93;--text-tertiary: #636366;--primary: #0a84ff;--primary-dim: rgba(10, 132, 255, .15);--danger: #ff453a;--danger-dim: rgba(255, 69, 58, .15);--success: #30d158;--success-dim: rgba(48, 209, 88, .15);--warning: #ff9f0a;--warning-dim: rgba(255, 159, 10, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 22px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--header-height: 52px;--tab-bar-height: 56px}.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;width:100%;height:100%;overflow:hidden;overscroll-behavior:none;touch-action:none}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.4;-webkit-font-smoothing:antialiased}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{border:none;background:none;cursor:pointer;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}input{background:transparent;border:none;outline:none}a{color:var(--primary);text-decoration:none}.app{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg)}.page{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.page-content{flex:1;overflow-y:auto;overflow-x:hidden;overscroll-behavior-y:none;padding-bottom:calc(var(--safe-bottom) + 16px)}.page-content::-webkit-scrollbar{display:none}.group-list{margin:16px 0;padding:0 16px}.group-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin:24px 16px 8px}.group-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden}.group-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;min-height:48px;background:var(--surface);border-bottom:1px solid var(--separator)}.group-row:last-child{border-bottom:none}.group-row:active{background:var(--surface-elevated)}.group-row-label{font-size:16px;color:var(--text)}.group-row-value{font-size:16px;color:var(--text-secondary);text-align:right}.group-row-note{display:block;padding:10px 16px;font-size:13px;color:var(--text-secondary);line-height:1.4}.group-row-chevron{color:var(--text-tertiary);margin-left:6px;font-size:14px}.group-row-title{font-size:16px;font-weight:400;color:var(--text);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-row-subtitle{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 9px;border-radius:999px;font-size:11px;font-weight:700;line-height:1;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;flex-shrink:0}.badge-waiting{background:var(--primary-dim);color:var(--primary)}.badge-playing{background:var(--success-dim);color:var(--success)}.badge-paused{background:var(--warning-dim);color:var(--warning)}.badge-finished{background:var(--surface-elevated);color:var(--text-secondary)}.room-groups{padding:8px 0 calc(var(--safe-bottom) + 16px)}.room-group{margin-bottom:8px}.room-group-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin:16px 16px 8px}.room-group-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;margin:0 16px}.room-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;min-height:64px;background:var(--surface);border-bottom:1px solid var(--separator)}.room-row:last-child{border-bottom:none}.room-row:active{background:var(--surface-elevated)}.room-row-highlight{box-shadow:inset 3px 0 0 var(--primary)}.room-row-leading{flex-shrink:0;order:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--surface-elevated);margin-right:12px}.status-icon{flex-shrink:0}.status-icon-waiting{color:var(--primary)}.status-icon-playing{color:var(--success)}.status-icon-paused{color:var(--warning)}.status-icon-finished{color:var(--text-secondary)}.room-row-body{flex:1;min-width:0;overflow:hidden;text-align:left}.room-row-title{font-size:16px;font-weight:500;color:var(--text);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-row-subtitle{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-row-subtitle>*+*{margin-left:8px}.room-row-winner{color:var(--text)}.creator-tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;font-size:11px;font-weight:600;line-height:1;color:var(--primary);background:var(--primary-dim)}.room-row .badge{flex-shrink:0;margin-left:12px}.btn{display:flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:var(--radius-xl);font-size:16px;font-weight:600;min-height:48px;transition:transform .08s ease,opacity .15s ease}.btn:active{transform:scale(.98);opacity:.9}.btn-primary{background:var(--primary);color:#fff}.btn-primary:disabled{opacity:.5}.btn-secondary{background:var(--surface-elevated);color:var(--primary)}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{color:var(--primary);background:transparent}.btn-block{width:100%}.btn-sm{padding:6px 12px;min-height:32px;border-radius:var(--radius-md);font-size:13px;font-weight:600}.room-row-actions{flex-shrink:0;display:flex;align-items:center;gap:8px;margin-left:12px}.room-row-share-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--primary);font-size:18px}.game-rules-fab{min-width:64px;height:36px;padding:0 14px;display:flex;align-items:center;justify-content:center;border-radius:18px;background:var(--surface);color:var(--primary);font-size:14px;font-weight:600;border:1px solid var(--primary);box-shadow:0 2px 8px #0000004d}.game-rules-fab:active{background:var(--primary-dim)}.game-hud{flex-shrink:0;margin:8px 12px 0;padding:8px 12px;z-index:50;display:flex;flex-direction:column;gap:8px;background:#1c1c1eeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:14px;border:1px solid rgba(56,56,58,.6);pointer-events:none;min-height:76px}.game-hud-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.game-hud-left,.game-hud-right{display:flex;align-items:center;gap:8px}.game-hud-left{gap:6px}.game-hud-turn{font-size:13px;font-weight:700;color:var(--text)}.game-hud-status{font-size:11px;color:var(--text-secondary)}.game-hud-countdown{font-weight:700;color:var(--warning)}.game-hud-countdown.urgent{color:var(--danger);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.game-hud-stats{display:flex;flex-direction:column;gap:4px}.game-hud-stats-row{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600}.hud-stats-label{min-width:36px;font-weight:700}.hud-stats-label.player-a{color:#60a5fa}.hud-stats-label.player-b{color:#f87171}.game-hud-stats-row .hud-stat{flex:1;text-align:center;color:var(--text)}.hud-stat-divider{color:var(--text-tertiary)}.badge-player-a{background:#2563eb33;color:#60a5fa}.badge-player-b{background:#dc262633;color:#f87171}.badge-observer{background:var(--surface-elevated);color:var(--text-secondary)}.hud-submit-dot{width:10px;height:10px;border-radius:50%;background:var(--text-tertiary)}.hud-submit-dot.submitted{background:var(--success)}.planning-panel-host{flex-shrink:0;margin:8px 12px 0;height:68px;z-index:50}.planning-panel{height:100%;padding:8px 12px;display:flex;flex-direction:column;justify-content:center;background:#1c1c1eeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:14px;border:1px solid rgba(56,56,58,.6)}.planning-panel-empty{align-items:center;justify-content:center;color:var(--text-tertiary);font-size:13px;background:#1c1c1e99;border-style:dashed}.planning-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.planning-count{display:flex;align-items:center;gap:8px}.planning-stepper{width:32px;height:32px;min-height:32px;padding:0;border-radius:50%;font-size:18px;font-weight:500}.planning-count-value{min-width:28px;text-align:center;font-size:18px;font-weight:700}.planning-shortcuts{display:flex;align-items:center;gap:4px}.planning-shortcut{min-height:28px;padding:4px 8px;font-size:12px;font-weight:600;border-radius:var(--radius-md)}.planning-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-shrink:0}.planning-icon-btn{width:32px;height:32px;min-height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:16px;font-weight:700;line-height:1}.planning-cancel-btn{background:var(--surface-elevated);color:var(--text-secondary)}.planning-confirm-btn{background:var(--primary);color:#fff}.planning-icon-btn:disabled{opacity:.4}.order-item{display:flex;align-items:center;gap:10px;background:#11182799;border-radius:10px;padding:10px 12px;cursor:pointer;transition:background .15s ease,box-shadow .15s ease;pointer-events:auto}.order-item.selected{background:#0a84ff33;box-shadow:inset 0 0 0 1px #0a84ff80}.order-item:active{background:#ffffff14}.segmented-control{display:flex;background:var(--surface-elevated);border-radius:var(--radius-md);padding:2px}.segmented-control button{flex:1;padding:8px 12px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;color:var(--text-secondary);transition:background .15s ease,color .15s ease}.segmented-control button.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #0000004d}.form-field{background:var(--surface);border-radius:var(--radius-lg);padding:0 16px;margin-bottom:12px}.form-field input{width:100%;height:48px;font-size:16px;color:var(--text)}.form-field input::placeholder{color:var(--text-tertiary)}.card{background:var(--surface);border-radius:var(--radius-lg);padding:16px;margin:0 16px 12px}.card-title{font-size:18px;font-weight:700;margin-bottom:8px}.card-subtitle{font-size:13px;color:var(--text-secondary)}.lobby-header{padding:calc(var(--safe-top) + 8px) 16px 12px;padding-left:calc(var(--safe-left) + 16px);padding-right:calc(var(--safe-right) + 16px);background:var(--bg);flex-shrink:0}.lobby-header-content{display:flex;align-items:center;justify-content:space-between}.lobby-title{font-size:34px;font-weight:700;line-height:1.2;letter-spacing:-.02em;margin:0}.header-create-btn{padding:8px 14px;min-height:36px;border-radius:var(--radius-xl);font-size:15px;font-weight:600;gap:6px}.lobby-header-actions{display:flex;align-items:center;gap:8px}.header-refresh-btn{width:36px;height:36px;padding:0;border-radius:50%}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;text-align:center;color:var(--text-secondary)}.empty-state-icon{width:72px;height:72px;border-radius:var(--radius-xl);background:var(--surface);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--primary)}.empty-state-title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 6px}.empty-state-desc{font-size:15px;color:var(--text-secondary);margin:0;line-height:1.4}.empty-state-btn{margin-top:8px;gap:6px}.mobile-header{height:calc(var(--header-height) + var(--safe-top));padding-top:var(--safe-top);padding-left:var(--safe-left);padding-right:var(--safe-right);display:flex;align-items:center;justify-content:space-between;background:#000000d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--separator);position:sticky;top:0;z-index:100}.mobile-header-title{font-size:17px;font-weight:600;flex:1;text-align:center;padding:0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-left,.mobile-header-right{min-width:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:var(--primary);font-size:22px}.header-text-btn{height:34px;padding:0 12px;display:flex;align-items:center;justify-content:center;border-radius:17px;color:var(--primary);background:#0a84ff1f;font-size:15px;font-weight:600;white-space:nowrap}.header-btn:active,.header-text-btn:active{background:var(--surface)}.tab-bar{height:calc(var(--tab-bar-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);padding-left:var(--safe-left);padding-right:var(--safe-right);background:#000000e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--separator);display:flex;align-items:center;justify-content:space-around;z-index:100}.tab-item{flex:1;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-secondary);transition:color .15s ease}.tab-item.active{color:var(--primary)}.tab-icon{font-size:22px;line-height:1}.tab-label{font-size:11px;font-weight:500}.bottom-sheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding-bottom:var(--safe-bottom);padding-left:var(--safe-left);padding-right:var(--safe-right);z-index:201;animation:sheet-up .3s cubic-bezier(.2,.8,.2,1);max-height:80vh;display:flex;flex-direction:column}.bottom-sheet-handle{width:36px;height:5px;border-radius:3px;background:var(--text-tertiary);margin:8px auto 12px}.bottom-sheet-content{flex:1;overflow-y:auto;padding:0 16px 16px}.bottom-sheet-title{font-size:18px;font-weight:700;text-align:center;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;padding:0 16px}.bottom-sheet-title span{flex:1;text-align:center}.bottom-sheet-close{background:transparent;border:none;color:var(--text-primary);font-size:24px;line-height:1;padding:0 4px;cursor:pointer}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.ios-toggle{position:relative;width:50px;height:30px;display:inline-block;flex-shrink:0}.ios-toggle input{opacity:0;width:0;height:0}.ios-toggle span{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--surface-elevated);border-radius:999px;transition:background .2s ease}.ios-toggle span:before{content:"";position:absolute;top:2px;left:2px;width:26px;height:26px;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;transition:transform .25s cubic-bezier(.2,.8,.2,1)}.ios-toggle input:checked+span{background:var(--success)}.ios-toggle input:checked+span:before{transform:translate(20px)}.ios-toggle-primary input:checked+span{background:var(--primary)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:300;padding:24px}.overlay-content{background:var(--surface);border-radius:var(--radius-xl);padding:24px;width:100%;max-width:320px;text-align:center}.overlay-content h2{margin:0 0 8px;font-size:20px}.overlay-content p{margin:0 0 20px;color:var(--text-secondary)}.loading{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.skeleton{background:linear-gradient(90deg,var(--surface-elevated) 25%,rgba(255,255,255,.06) 50%,var(--surface-elevated) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-shimmer 1.4s infinite linear}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.room-row-skeleton{pointer-events:none}.skeleton-icon{width:32px;height:32px;border-radius:50%;flex-shrink:0}.skeleton-title{width:55%;height:16px;margin-bottom:8px}.skeleton-subtitle{width:35%;height:13px}.skeleton-badge{width:52px;height:22px;border-radius:999px;flex-shrink:0}.toast{position:fixed;top:calc(var(--safe-top) + 60px);left:50%;transform:translate(-50%);background:var(--surface-elevated);color:var(--text);padding:10px 16px;border-radius:var(--radius-xl);font-size:14px;font-weight:500;z-index:250;box-shadow:0 4px 16px #0006;animation:toast-in .25s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-primary{color:var(--primary)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mx-16{margin-left:16px;margin-right:16px}.p-16{padding:16px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-8{gap:8px}.gap-12{gap:12px}.w-full{width:100%}.game-rules-modal{position:fixed;top:0;right:0;bottom:0;left:0;height:100vh;background:#000000d9;z-index:300;display:flex;align-items:flex-end;animation:fade-in .2s ease}.game-rules-modal.closing{animation:fade-out .3s ease forwards}.game-rules-panel{width:100%;max-height:85vh;background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;display:flex;flex-direction:column;padding-bottom:var(--safe-bottom);animation:sheet-up .3s cubic-bezier(.2,.8,.2,1) forwards}.game-rules-panel.closing{animation:sheet-down .3s cubic-bezier(.2,.8,.2,1) forwards}@keyframes fade-out{0%{opacity:1}to{opacity:0}}@keyframes sheet-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}.game-rules-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--separator);font-size:18px;font-weight:700}.game-rules-close{background:transparent;border:none;color:var(--text-primary);font-size:28px;line-height:1;padding:0 4px;cursor:pointer}.game-rules-content{flex:1;overflow-y:auto;padding:16px}.game-rules-section{margin-bottom:20px}.game-rules-section-title{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:8px}.game-rules-section ul{margin:0;padding-left:18px}.game-rules-section li{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:4px}.game-page{display:flex;flex-direction:column;min-height:0;height:100%}.game-canvas-container{position:relative;flex:1;min-height:0;overflow:hidden}.game-bottom-controls{flex-shrink:0;padding:0 12px calc(var(--safe-bottom) + 12px);height:64px;background:#0f172a;z-index:60}.game-hud-status-decisive{color:var(--warning);font-weight:700;animation:decisive-pulse 1.2s ease-in-out infinite}@keyframes decisive-pulse{0%,to{opacity:1}50%{opacity:.65}}.game-over-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:400;padding:24px;animation:game-over-fade-in .25s ease-out both}.game-over-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.game-over-content{position:relative;width:100%;max-width:340px;background:var(--surface);border-radius:var(--radius-xl);padding:28px 22px 22px;text-align:center;box-shadow:0 20px 60px #00000080;animation:game-over-pop-in .45s cubic-bezier(.22,1,.36,1) both;overflow:hidden}.game-over-content:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.08;pointer-events:none}.game-over-win .game-over-content:before{background:radial-gradient(circle at 50% 0%,var(--warning),transparent 70%)}.game-over-lose .game-over-content:before{background:radial-gradient(circle at 50% 0%,var(--danger),transparent 70%)}.game-over-draw .game-over-content:before{background:radial-gradient(circle at 50% 0%,var(--primary),transparent 70%)}.game-over-badge{width:72px;height:72px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin-bottom:14px;animation:badge-pop .45s cubic-bezier(.22,1,.36,1) .15s both}.game-over-win .game-over-badge{background:linear-gradient(135deg,#ff9f0a40,#ffd7001f);color:#ffd60a;box-shadow:0 0 24px #ff9f0a40}.game-over-lose .game-over-badge{background:linear-gradient(135deg,#ff453a33,#ff453a14);color:var(--danger);box-shadow:0 0 24px #ff453a26}.game-over-draw .game-over-badge{background:linear-gradient(135deg,#0a84ff33,#0a84ff14);color:var(--primary);box-shadow:0 0 24px #0a84ff26}.game-over-title{margin:0 0 6px;font-size:28px;font-weight:800;letter-spacing:-.02em;animation:game-over-text-in .4s ease-out .2s both}.game-over-win .game-over-title{color:#ffd60a}.game-over-lose .game-over-title{color:var(--danger)}.game-over-draw .game-over-title{color:var(--primary)}.game-over-subtitle{margin:0 0 22px;font-size:14px;color:var(--text-secondary);animation:game-over-text-in .4s ease-out .28s both}.game-over-stats{display:flex;align-items:stretch;justify-content:space-between;gap:10px;margin-bottom:24px;padding:14px;background:#ffffff0a;border-radius:var(--radius-lg);animation:game-over-stats-in .45s ease-out .4s both}.game-over-stat-column{flex:1;display:flex;flex-direction:column;gap:8px}.game-over-stat-label{font-size:12px;color:var(--text-secondary);font-weight:600}.game-over-stat-row{display:flex;align-items:baseline;justify-content:center;gap:4px}.game-over-stat-value{font-size:20px;font-weight:800;color:var(--text);min-width:24px}.game-over-stat-unit{font-size:11px;color:var(--text-tertiary)}.game-over-stat-vs{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:var(--text-tertiary);letter-spacing:.08em;padding-top:18px}.game-over-actions{display:flex;flex-direction:column;gap:10px;animation:game-over-actions-in .4s ease-out .7s both}.game-over-actions .btn-block{width:100%}.game-over-bar{position:fixed;left:12px;right:12px;bottom:calc(var(--safe-bottom) + 12px);z-index:350;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:#1c1c1eeb;border:1px solid var(--separator);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 24px #00000059;animation:game-over-bar-in .35s ease-out both}.game-over-bar span{font-size:14px;font-weight:600;color:var(--text-secondary)}@keyframes game-over-fade-in{0%{opacity:0}to{opacity:1}}@keyframes game-over-pop-in{0%{opacity:0;transform:scale(.85) translateY(24px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes badge-pop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes game-over-text-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes game-over-stats-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes game-over-actions-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes game-over-bar-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.planning-panel-replay{background:#0a84ff14;border-bottom:1px solid rgba(10,132,255,.2)}.planning-panel-replay span{color:var(--primary);font-weight:600}.game-replay-controls{background:#0f172a}.game-replay-controls .btn{flex:1 1 0;padding:10px 8px;font-size:14px;min-height:40px;white-space:nowrap}.game-replay-controls .btn-secondary:disabled{opacity:.4}.replay-panel{padding:8px 0 16px;max-height:60vh;overflow-y:auto}.replay-panel::-webkit-scrollbar{display:none}.replay-summary{display:flex;align-items:center;justify-content:space-between;padding:0 16px 12px;margin-bottom:8px;border-bottom:1px solid var(--separator);font-size:14px;color:var(--text-secondary)}.replay-winner{font-weight:700;color:var(--warning)}.replay-turn-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:var(--surface-elevated);border:1px solid var(--separator);border-radius:var(--radius-md);margin:0 16px 12px;width:calc(100% - 32px);text-align:left}.replay-turn-item.active{border-color:var(--primary);background:#0a84ff1f}.replay-turn-number{font-size:15px;font-weight:700;color:var(--text)}.replay-turn-desc{font-size:13px;color:var(--text-secondary)}.replay-divider{height:1px;background:var(--separator);margin:4px 16px 12px}.replay-turns{display:flex;flex-direction:column;gap:8px;padding:0 16px}.replay-turn-card{background:var(--surface-elevated);border:1px solid var(--separator);border-radius:var(--radius-md);overflow:hidden}.replay-turn-card.active{border-color:var(--primary)}.replay-turn-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;text-align:left}.replay-turn-meta{font-size:12px;color:var(--text-tertiary);font-weight:600}.replay-turn-body{padding:0 14px 12px;border-top:1px solid var(--separator);animation:replay-body-in .2s ease-out}.replay-orders-group{margin-top:10px}.replay-orders-label{font-size:12px;font-weight:700;color:var(--text-secondary);margin-bottom:4px}.replay-orders-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.replay-order-item{font-size:13px;color:var(--text);padding:6px 8px;background:#ffffff0a;border-radius:var(--radius-sm)}.replay-orders-empty{font-size:13px;color:var(--text-tertiary);padding:6px 8px}@keyframes replay-body-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
