*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0a1a;--surface:#1f1333;--surface-2:#2e1c4c;--border:#3e2666;--accent:#9b5fff;--accent-dk:#7c4ccc;--accent-lt:#cbbcf0;--green:#8cc63f;--orange:#f7931e;--text:#eaeaea;--muted:#9ca3af;--error:#f87171;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #00000080;--bot-sidewalks-bg:#2a1650;--bot-sidewalks-fg:#c4a0ff;--bot-uncle-bg:#162e10;--bot-uncle-fg:#8cc63f;--bot-detective-bg:#0e2236;--bot-detective-fg:#47bfff;--bot-support-bg:#1c1608;--bot-support-fg:#f7931e}html,body{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Montserrat,Open Sans,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5}#root{flex-direction:column;min-height:100dvh;display:flex}.app{flex-direction:column;flex:1;display:flex}.screen{flex-direction:column;flex:1;width:100%;max-width:480px;margin:0 auto;padding:24px 20px;display:flex}.screen-header{align-items:center;gap:12px;margin-bottom:24px;display:flex}.screen-header h2{font-size:20px;font-weight:700}.screen-logo{width:auto;height:28px}.lobby-logo{width:100%;max-width:200px;height:auto;margin:0 auto 24px;display:block}.game-header{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:center;align-items:center;padding:10px 20px;display:flex}.game-logo{width:auto;height:24px}.home{justify-content:center;gap:48px}.home-hero{text-align:center}.home-logo{width:100%;max-width:320px;height:auto;margin:0 auto;display:block}.tagline{color:var(--muted);margin-top:8px;font-size:15px}.home-actions{flex-direction:column;gap:12px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;letter-spacing:.3px;border:none;justify-content:center;align-items:center;min-height:52px;padding:14px 20px;font-family:inherit;font-size:16px;font-weight:600;text-decoration:none;transition:opacity .15s,transform .1s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dk)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent)}.btn-lg{min-height:60px;padding:16px 24px;font-size:18px}.btn-icon{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);width:52px;height:52px;font-size:24px}.btn-back{color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-family:inherit;font-size:15px}.btn-back:hover{color:var(--text)}.btn-action{background:var(--surface-2);color:var(--text);border:2px solid var(--accent);letter-spacing:.5px;text-transform:uppercase;border-radius:var(--radius);cursor:pointer;width:100%;min-height:52px;padding:14px 16px;font-family:inherit;font-size:15px;font-weight:700;transition:background .15s,transform .1s}.btn-action:hover{background:var(--accent);color:#fff}.btn-action:active{transform:scale(.97)}.form{flex-direction:column;gap:16px;display:flex}.label{color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:-8px;font-size:12px;font-weight:700}.input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);-webkit-appearance:none;outline:none;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input-code{letter-spacing:8px;text-align:center;text-transform:uppercase;font-size:28px;font-weight:700}.step{flex-direction:column;gap:20px;display:flex}.step h3{font-size:22px;font-weight:700}.trail-list{flex-direction:column;gap:10px;display:flex}.trail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:4px;width:100%;padding:16px;transition:border-color .15s,transform .1s;display:flex}.trail-card:hover{border-color:var(--accent)}.trail-card:active{transform:scale(.98)}.trail-name{color:var(--text);font-size:18px;font-weight:600}.trail-meta{color:var(--muted);font-size:13px}.trail-preselected{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:14px;padding:14px 16px;display:flex}.trail-preselected-icon{object-fit:contain;border-radius:8px;flex-shrink:0;width:56px;height:56px}.trail-preselected-label{color:var(--muted);margin:0;font-size:15px}.trail-preselected-label strong{color:var(--text)}.counter-row{align-items:center;gap:20px;display:flex}.counter-value{text-align:center;min-width:48px;font-size:40px;font-weight:700}.lang-list{grid-template-columns:1fr 1fr;gap:8px;display:grid}.lang-option{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;text-align:left;padding:12px;font-family:inherit;font-size:14px;transition:border-color .15s}.lang-option:hover{border-color:var(--accent)}.lang-option.selected{border-color:var(--accent);background:#9b5fff1a}.summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.summary-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:12px 16px;font-size:15px;display:flex}.summary-row:last-child{border-bottom:none}.summary-row span:first-child{color:var(--muted)}.summary-row.total{font-size:18px;font-weight:700}.lobby{text-align:center;justify-content:center;align-items:center;gap:32px}.lobby h2{font-size:26px;font-weight:700}.lobby-count{align-items:baseline;gap:4px;display:flex}.count-num{color:var(--accent);font-size:64px;font-weight:700}.count-sep{color:var(--muted);font-size:40px}.count-label{color:var(--muted);text-align:center;width:100%;margin-top:4px;font-size:14px}.share-code{letter-spacing:8px;background:var(--surface);border:2px solid var(--accent);border-radius:var(--radius);padding:16px 24px;font-size:36px;font-weight:700}.game{gap:0;padding:0}.game-feed{flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow-y:auto}.game-buttons{background:var(--bg);border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:12px 16px 24px;display:flex}.game-input-row{gap:8px;margin-top:4px;display:flex}.game-text-input{flex:1;min-width:0;padding:12px 14px;font-size:15px}.game-input-row .btn{flex-shrink:0;min-width:52px;font-size:20px}.feed-bubble{border-radius:var(--radius);overflow:hidden}.feed-bubble-header{text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;padding:8px 14px 0;font-size:11px;font-weight:700;display:flex}.bot-avatar{object-fit:cover;border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;width:28px;height:28px}.feed-text{padding:10px 14px 12px;font-size:15px;line-height:1.65}.feed-text p{margin-bottom:6px}.feed-text p:last-child{margin-bottom:0}.feed-text strong{font-weight:700}.feed-text em{color:var(--accent-lt);font-style:italic}.feed-inline-buttons{flex-wrap:wrap;gap:8px;padding:4px 14px 10px;display:flex}.feed-inline-buttons .btn{padding:8px 14px;font-size:13px;text-decoration:none;display:inline-block}.bot-sidewalks .feed-text p.directions strong{color:var(--bot-sidewalks-fg)}.bot-uncle .feed-text p.directions strong{color:var(--bot-uncle-fg)}.bot-sherlockbot .feed-text p.directions strong,.bot-kappa .feed-text p.directions strong,.bot-abberline .feed-text p.directions strong,.bot-bernard .feed-text p.directions strong,.bot-alice .feed-text p.directions strong{color:var(--bot-detective-fg)}.bot-watson .feed-text p.directions strong,.bot-thick .feed-text p.directions strong,.bot-hugo .feed-text p.directions strong,.bot-nicolas .feed-text p.directions strong,.bot-cbot .feed-text p.directions strong{color:var(--bot-support-fg)}.bot-sidewalks,.bot-new_sidewalks{background:var(--bot-sidewalks-bg);border-left:3px solid var(--bot-sidewalks-fg)}.bot-sidewalks .feed-bubble-header,.bot-new_sidewalks .feed-bubble-header{color:var(--bot-sidewalks-fg)}.bot-uncle{background:var(--bot-uncle-bg);border-left:3px solid var(--bot-uncle-fg)}.bot-uncle .feed-bubble-header{color:var(--bot-uncle-fg)}.bot-sherlockbot,.bot-kappa,.bot-abberline,.bot-bernard,.bot-alice{background:var(--bot-detective-bg);border-left:3px solid var(--bot-detective-fg)}.bot-sherlockbot .feed-bubble-header,.bot-kappa .feed-bubble-header,.bot-abberline .feed-bubble-header,.bot-bernard .feed-bubble-header,.bot-alice .feed-bubble-header{color:var(--bot-detective-fg)}.bot-watson,.bot-thick,.bot-hugo,.bot-nicolas,.bot-cbot{background:var(--bot-support-bg);border-left:3px solid var(--bot-support-fg)}.bot-watson .feed-bubble-header,.bot-thick .feed-bubble-header,.bot-hugo .feed-bubble-header,.bot-nicolas .feed-bubble-header,.bot-cbot .feed-bubble-header{color:var(--bot-support-fg)}.bot-unknown{background:var(--surface);border-left:3px solid var(--border)}.feed-image{border-radius:var(--radius);overflow:hidden}.feed-image img{border-radius:var(--radius);width:100%;display:block}.image-caption{color:var(--muted);text-align:center;padding:8px 4px 0;font-size:13px}.feed-prompt{color:var(--muted);text-align:center;padding:2px 0;font-size:13px;font-style:italic}.game-complete{text-align:center;justify-content:center;align-items:center;gap:24px}.audio-toggle{cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:4px 0;font-size:15px;display:flex}.audio-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.feed-user-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 2px var(--radius);align-self:flex-end;max-width:72%;overflow:hidden}.feed-user-header{text-transform:uppercase;letter-spacing:.8px;color:var(--accent-lt);text-align:right;padding:6px 14px 0;font-size:11px;font-weight:700}.feed-user-text{color:var(--accent-lt);text-align:right;word-break:break-word;padding:4px 14px 10px;font-size:14px;font-weight:700}.feed-audio{padding:4px 0}.feed-audio audio{border-radius:var(--radius-sm);width:100%}.muted{color:var(--muted);font-size:14px}.small{font-size:13px}.error{color:var(--error);border-radius:var(--radius-sm);background:#f871711a;padding:10px 14px;font-size:14px}.waiting{color:var(--muted);flex-direction:column;align-items:center;gap:12px;padding:32px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin;display:block}@keyframes spin{to{transform:rotate(360deg)}}.resume-card{background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);text-align:center;flex-direction:column;align-items:center;gap:6px;width:100%;padding:16px 20px;display:flex}.resume-label{font-size:15px;font-weight:600}.resume-sub{color:var(--muted);font-size:13px}.booking-confirmed{text-align:center;justify-content:center;align-items:center;gap:20px;padding:32px 24px}.booking-confirmed h2{font-size:26px;font-weight:700}.summary-row.discount,.summary-row.discount span:first-child{color:var(--accent)}.team-name-setup{text-align:center;flex-direction:column;align-items:center;gap:20px;padding:32px 24px;display:flex}.team-name-setup h2{font-size:24px;font-weight:700}.team-name-setup .input{text-align:center;letter-spacing:2px;text-transform:uppercase;font-size:20px}.completion-card{background:var(--surface);border:2px solid var(--accent);border-radius:var(--radius);text-align:center;flex-direction:column;align-items:center;gap:12px;margin-top:16px;padding:24px;display:flex}.completion-card h2{font-size:24px;font-weight:700}.completion-card p{color:var(--muted);font-size:15px}
