:root{--bg: #1a1a2e;--bg-card: #16213e;--bg-card-hover: #1c2a4a;--text: #e2e8f0;--text-muted: #94a3b8;--text-dim: #64748b;--border: #2d3a5c;--player-bg: #3d2c08;--player-text: #e9b44c;--host-bg: #1e293b;--host-text: #94a3b8;--yes: #4ade80;--no: #f87171;--irrelevant: #94a3b8;--unknown: #64748b;--cta: #e94560;--cta-hover: #d63d56;--badge-history: #3b82f6;--badge-author: #a855f7;--badge-other: #f59e0b;--easy: #4ade80;--medium: #f59e0b;--hard: #f87171;--radius: 12px;--radius-sm: 8px;--max-width: 720px;--font: system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans", sans-serif}@media(prefers-color-scheme:light){:root{--bg: #f1f5f9;--bg-card: #ffffff;--bg-card-hover: #f8fafc;--text: #1e293b;--text-muted: #475569;--text-dim: #94a3b8;--border: #e2e8f0;--player-bg: #fef3c7;--player-text: #92400e;--host-bg: #f1f5f9;--host-text: #475569}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100dvh}#app{max-width:var(--max-width);margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.home{padding:24px 16px;flex:1}.home-header{text-align:center;margin-bottom:32px;padding-top:24px}.home-header h1{font-size:2.5rem;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}.home-header .tagline{color:var(--text-muted);font-size:1.1rem}.random-btn{display:block;width:100%;max-width:360px;margin:0 auto 32px;padding:16px 24px;background:var(--cta);color:#fff;border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;min-height:52px;touch-action:manipulation}.random-btn:hover{background:var(--cta-hover)}.random-btn:active{transform:scale(.98)}.puzzle-grid{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:540px){.puzzle-grid{grid-template-columns:1fr 1fr}}.puzzle-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:background .15s,border-color .15s;display:flex;flex-direction:column;gap:8px;min-height:44px;position:relative}.puzzle-card:hover{background:var(--bg-card-hover);border-color:var(--text-dim)}.puzzle-card.completed{opacity:.7}.puzzle-card.completed:after{content:"✓";position:absolute;top:12px;right:12px;color:var(--yes);font-size:1.2rem;font-weight:700}.puzzle-card-title{font-weight:600;font-size:1rem}.puzzle-card-preview{color:var(--text-muted);font-size:.875rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.puzzle-card-meta{display:flex;align-items:center;gap:8px;margin-top:auto}.badge{display:inline-block;font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:999px;color:#fff}.badge-history{background:var(--badge-history)}.badge-author{background:var(--badge-author)}.badge-other{background:var(--badge-other)}.difficulty{font-size:.8rem;letter-spacing:1px}.difficulty .filled{color:var(--easy)}.difficulty.medium .filled{color:var(--medium)}.difficulty.hard .filled{color:var(--hard)}.difficulty .empty{color:var(--text-dim)}.game{display:flex;flex-direction:column;min-height:100dvh}.game-header{position:sticky;top:0;z-index:10;background:var(--bg);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:12px}.back-btn{background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:8px;margin:-8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:color .15s}.back-btn:hover{color:var(--text)}.game-title{font-size:1rem;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.condition-section{padding:16px}.condition-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.condition-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:none;border:none;color:var(--text);font:inherit;width:100%;text-align:left;padding:0;gap:8px}.condition-toggle-label{font-weight:600;font-size:.9rem;color:var(--text-muted)}.condition-toggle-arrow{font-size:.8rem;color:var(--text-dim);transition:transform .2s}.condition-card.collapsed .condition-toggle-arrow{transform:rotate(-90deg)}.condition-text{margin-top:12px;white-space:pre-wrap;line-height:1.7}.condition-card.collapsed .condition-text{display:none}.condition-meta{display:flex;align-items:center;gap:8px;margin-top:12px}.condition-card.collapsed .condition-meta{display:none}.chat{flex:1;padding:16px 16px 260px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.chat-empty{text-align:center;color:var(--text-dim);padding:32px 16px;font-size:.95rem}.chat-bubble{max-width:85%;padding:12px 16px;border-radius:var(--radius);line-height:1.6;white-space:pre-wrap;word-break:break-word;font-size:.95rem}.chat-bubble.player{align-self:flex-end;background:var(--player-bg);color:var(--player-text);border-bottom-right-radius:4px}.chat-bubble.host{align-self:flex-start;background:var(--host-bg);color:var(--host-text);border-bottom-left-radius:4px}.chat-bubble .cat-icon{display:inline-block;margin-right:6px;font-weight:700;font-size:.85rem}.cat-yes{color:var(--yes)}.cat-no{color:var(--no)}.cat-irrelevant{color:var(--irrelevant)}.cat-unknown{color:var(--unknown)}.input-area{position:fixed;bottom:0;left:0;right:0;background:var(--bg);border-top:1px solid var(--border);padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));z-index:10}.input-area-inner{max-width:var(--max-width);margin:0 auto}.input-row{display:flex;gap:8px}.input-field{flex:1;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font:inherit;font-size:1rem;outline:none;transition:border-color .15s;min-height:48px}.input-field::placeholder{color:var(--text-dim)}.input-field:focus{border-color:var(--text-muted)}.send-btn{padding:12px 20px;background:var(--cta);color:#fff;border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .15s;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}.send-btn:hover{background:var(--cta-hover)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.give-up-btn{display:block;width:100%;margin-top:8px;padding:10px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font:inherit;font-size:.9rem;cursor:pointer;transition:color .15s,border-color .15s;min-height:44px}.give-up-btn:hover{color:var(--text);border-color:var(--text-dim)}.answer-section{padding:16px 16px 32px}.answer-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.answer-card h3{font-size:1.1rem;margin-bottom:12px;color:var(--text)}.answer-text{white-space:pre-wrap;line-height:1.7;color:var(--text-muted)}.answer-actions{display:flex;flex-direction:column;gap:8px;margin-top:20px}.next-btn{padding:16px 24px;background:var(--cta);color:#fff;border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:52px;touch-action:manipulation}.next-btn:hover{background:var(--cta-hover)}.home-link-btn{padding:12px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font:inherit;font-size:.95rem;cursor:pointer;transition:color .15s,border-color .15s;min-height:44px}.home-link-btn:hover{color:var(--text);border-color:var(--text-dim)}@media(prefers-reduced-motion:no-preference){.chat-bubble{animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}}.llm-badge{display:inline-block;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.llm-badge-ready{background:var(--yes);color:#000}.llm-badge-loading{background:var(--badge-other);color:#000}.llm-badge-fallback{background:var(--text-dim);color:#fff}.chat-bubble-loading{padding:12px 20px}.loading-dots{display:inline-flex;gap:4px;align-items:center}.loading-dots span{width:6px;height:6px;border-radius:50%;background:var(--host-text);animation:dotPulse 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}:focus-visible{outline:2px solid var(--cta);outline-offset:2px}.input-field:focus-visible{outline:2px solid var(--cta);outline-offset:-1px}:focus:not(:focus-visible){outline:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.chat-bubble.host.cat-yes-bubble{border-left:3px solid var(--yes)}.chat-bubble.host.cat-no-bubble{border-left:3px solid var(--no)}.chat-bubble.host.cat-irrelevant-bubble{border-left:3px solid var(--irrelevant)}.chat-bubble.host.cat-unknown-bubble{border-left:3px solid var(--unknown)}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.input-field.shake{animation:shake .3s ease;border-color:var(--no)!important}.send-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.progress-section{max-width:360px;margin:0 auto 24px;text-align:center}.progress-bar-home{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill-home{height:100%;background:var(--cta);border-radius:4px;transition:width .3s ease}.progress-label{font-size:.85rem;color:var(--text-muted)}.filter-tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;justify-content:center}.filter-tab{padding:6px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;color:var(--text-muted);font:inherit;font-size:.85rem;cursor:pointer;transition:all .15s;min-height:36px}.filter-tab:hover{border-color:var(--text-dim);color:var(--text)}.filter-tab.active{background:var(--cta);border-color:var(--cta);color:#fff}.puzzle-group-header{font-size:.9rem;font-weight:600;color:var(--text-muted);margin:20px 0 8px;padding-left:2px}.puzzle-group-header:first-child{margin-top:0}.tutorial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:24px;text-align:center}.tutorial-card h2{font-size:1.2rem;margin-bottom:8px}.tutorial-card p{color:var(--text-muted);font-size:.95rem;line-height:1.6}.tutorial-hint{margin-top:8px;font-size:.85rem!important;color:var(--text-dim)!important}.welcome-back{text-align:center;color:var(--text-muted);font-size:.95rem;margin-bottom:16px}.resume-btn{display:block;width:100%;max-width:360px;margin:0 auto 12px;padding:14px 24px;background:var(--bg-card);border:1px solid var(--cta);border-radius:var(--radius);color:var(--cta);font:inherit;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s;min-height:48px}.resume-btn:hover{background:var(--cta);color:#fff}.suggestion-chips{display:flex;flex-direction:column;gap:8px;padding:16px;align-items:center}.suggestion-chip{display:inline-block;padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;color:var(--text-muted);font:inherit;font-size:.85rem;cursor:pointer;transition:all .15s;max-width:100%;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion-chip:hover{border-color:var(--cta);color:var(--cta)}.question-counter{font-size:.75rem;color:var(--text-dim);background:var(--bg-card);border:1px solid var(--border);padding:2px 8px;border-radius:999px;flex-shrink:0;white-space:nowrap}.facts-section{padding:0 16px}.facts-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--yes);border-radius:var(--radius);padding:12px 16px}.facts-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:none;border:none;color:var(--text);font:inherit;width:100%;text-align:left;padding:0;gap:8px}.facts-toggle-label{font-weight:600;font-size:.85rem;color:var(--yes)}.facts-card.collapsed .facts-list{display:none}.facts-card.collapsed .condition-toggle-arrow{transform:rotate(-90deg)}.facts-list{list-style:none;margin-top:8px;display:flex;flex-direction:column;gap:4px}.facts-list li{font-size:.85rem;color:var(--text-muted);padding:4px 0;border-bottom:1px solid var(--border)}.facts-list li:last-child{border-bottom:none}.guess-section{margin-top:8px}.guess-input-field{width:100%;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font:inherit;font-size:.95rem;outline:none;transition:border-color .15s;min-height:48px;margin-bottom:8px;resize:vertical}.guess-input-field::placeholder{color:var(--text-dim)}.guess-input-field:focus{border-color:var(--text-muted)}.guess-actions{display:flex;gap:8px}.guess-submit-btn{flex:1;padding:10px 16px;background:var(--yes);color:#000;border:none;border-radius:var(--radius-sm);font:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s;min-height:44px}.guess-submit-btn:hover{opacity:.9}.guess-cancel-btn{padding:10px 16px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font:inherit;font-size:.9rem;cursor:pointer;transition:color .15s,border-color .15s;min-height:44px}.guess-cancel-btn:hover{color:var(--text);border-color:var(--text-dim)}.guess-btn{display:block;width:100%;margin-top:8px;padding:10px;background:none;border:1px solid var(--yes);border-radius:var(--radius-sm);color:var(--yes);font:inherit;font-size:.9rem;cursor:pointer;transition:all .15s;min-height:44px}.guess-btn:hover{background:var(--yes);color:#000}.hint-btn{display:block;width:100%;margin-top:8px;padding:10px;background:none;border:1px solid var(--badge-other);border-radius:var(--radius-sm);color:var(--badge-other);font:inherit;font-size:.9rem;cursor:pointer;transition:all .15s;min-height:44px}.hint-btn:hover{background:var(--badge-other);color:#000}.hint-btn:disabled{opacity:.4;cursor:not-allowed}.hints-display{padding:0 16px;margin-bottom:8px}.hint-card{background:var(--bg-card);border:1px solid var(--badge-other);border-left:3px solid var(--badge-other);border-radius:var(--radius);padding:12px 16px;margin-bottom:8px}.hint-label{font-size:.75rem;font-weight:600;color:var(--badge-other);margin-bottom:4px}.hint-text{font-size:.9rem;color:var(--text-muted);line-height:1.5}.stars{display:inline-flex;gap:4px;font-size:1.3rem}.star-filled{color:var(--badge-other)}.star-empty{color:var(--text-dim)}.answer-solved{color:var(--yes)!important}.answer-gave-up{color:var(--text-muted)}.answer-detail-stats{display:flex;flex-direction:column;gap:4px;margin-top:12px;font-size:.85rem;color:var(--text-dim)}.llm-banner{position:relative;background:var(--bg-card);border-bottom:1px solid var(--border);padding:8px 40px 8px 16px;font-size:.8rem;color:var(--text-muted);overflow:hidden}.llm-banner-bar{position:absolute;top:0;left:0;height:3px;background:var(--cta);transition:width .3s ease}.llm-banner-text{position:relative;z-index:1}.llm-banner-dismiss{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-dim);font-size:1.1rem;cursor:pointer;padding:4px 8px;line-height:1}.llm-banner-dismiss:hover{color:var(--text)}.give-up-btn.confirming{border-color:var(--no);color:var(--no);font-weight:600}.llm-ready-toast{position:fixed;top:60px;left:50%;transform:translate(-50%);background:var(--yes);color:#000;padding:8px 20px;border-radius:999px;font-size:.85rem;font-weight:600;z-index:50;animation:toastIn .3s ease,toastOut .3s ease 2s forwards;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}
