:root{--bg: linear-gradient(135deg,#ffe6f2,#fff3e6,#e6fff7,#f0e6ff);--card: rgba(255,255,255,.9);--accent: #ff88c2;--mint: #b3ffe6;--lavender: #d5c4ff;--text: #3b2b2b;--radius: 16px;--shadow: 0 12px 30px rgba(120,80,120,.08)}*{box-sizing:border-box}html,body,#root{height:100%}body.game-page{overflow:auto}body{margin:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:var(--bg);background-size:200% 200%;animation:pastelMove 18s ease infinite;color:var(--text);-webkit-font-smoothing:antialiased}body.theme-minimal{--bg: radial-gradient(1200px 800px at 50% -10%, #141416 0%, #0e0e10 40%, #0a0a0c 100%);--card: rgba(22,22,24,.9);--accent: #22d3ee;--mint: #1f1f23;--lavender: #2a2a2e;--text: #e5e7eb;--shadow: 0 14px 34px rgba(0,0,0,.5);font-family:Inter,SF Pro Text,system-ui,-apple-system,Segoe UI,Roboto,Arial;background:var(--bg);animation:none;color:var(--text)}body.theme-minimal .card{background:linear-gradient(180deg,#1a1a1cf5,#141416f0);border:1px solid rgba(255,255,255,.06);box-shadow:0 12px 30px #0000008c;transition:box-shadow .2s ease,transform .2s ease}body.theme-minimal .card:hover{box-shadow:0 18px 44px #0009;transform:translateY(-2px)}body.theme-minimal .title{color:var(--text);letter-spacing:.2px;font-weight:800}body.theme-minimal .btn{background:linear-gradient(180deg,#1f2937,#111827);color:#e5e7eb;border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 22px #00000059;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease,background .16s ease}body.theme-minimal .btn.primary{background:linear-gradient(180deg,#06b6d4,#0891b2);color:#071317;border:1px solid rgba(34,211,238,.6)}body.theme-minimal .btn.secondary{background:linear-gradient(180deg,#202329,#13161a);color:#e5e7eb}body.theme-minimal .btn:not(:disabled):hover,body.theme-minimal .btn:not(:disabled):focus{transform:translateY(-3px) scale(1.01);box-shadow:0 16px 38px #00000080;border-color:#22d3ee59}body.theme-minimal .form input{background:#ffffff0a;color:var(--text);border:1px solid rgba(255,255,255,.08)}body.theme-minimal .avatar{border-color:#ffffff2e}body.theme-minimal .title .brand-name{position:relative}body.theme-minimal .title .brand-name:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5;transform-origin:center;transform:scaleX(.9)}.page.dashboard .card:not(.dashboard-form){max-width:860px;padding:18px 22px 22px;border-radius:16px}.page.dashboard .logo-circle{width:64px;height:64px;margin:6px auto;border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(60% 60% at 50% 40%,#22d3ee2e,#0006);box-shadow:0 14px 28px #00000073,0 0 32px #22d3ee2e;border:2px solid rgba(6,182,212,.55)}.page.dashboard .logo-circle .brand-logo{height:32px;filter:hue-rotate(165deg) saturate(3) brightness(1.2) contrast(1.06) drop-shadow(0 0 10px rgba(6,182,212,.28))}.page.dashboard .choices{gap:12px;margin-top:10px}body.theme-minimal .players-box,body.theme-minimal .chat-box,body.theme-minimal .player-list li,body.theme-minimal .score-card,body.theme-minimal .lobby .player-tile{background:#ffffff08;border:1px solid rgba(255,255,255,.08);box-shadow:0 6px 18px #00000059}body.theme-minimal .chat-message{background:#ffffff0a;border:1px solid rgba(255,255,255,.06)}body.theme-minimal .chat-message.me{background:linear-gradient(180deg,#22d3ee2e,#0891b224)}body.theme-minimal .chat-message.other{background:#ffffff0d}body.theme-minimal .ingredient-chip{background:#ffffff0f;color:var(--text);border:none}body.theme-minimal .ingredient-chip.found-me{background:#22d3ee2e;color:#d9fbff}body.theme-minimal .ingredient-chip.found-other{background:#ffffff14}body.theme-minimal .ingredient-chip.remaining{background:#ef44442e}body.theme-minimal .lobby .card:before{background:none!important;display:none!important;content:none!important}body.theme-minimal .game-head{background:linear-gradient(180deg,#1f2024,#18191d)!important;border-bottom:1px solid rgba(255,255,255,.06)!important}body.theme-minimal .game-head .dish-title{color:var(--text)!important;font-weight:800!important;letter-spacing:.2px}body.theme-minimal .meta{color:#d1d5db!important}body.theme-minimal .meta .rounds{color:#cbd5e1!important;opacity:.9}body.theme-minimal .meta .timer{color:var(--accent)!important;font-weight:700}body.theme-minimal .message-popup{background:#ffffff0a!important;color:var(--text)!important;border:1px solid rgba(255,255,255,.08)!important;box-shadow:0 8px 24px #00000073!important}body.theme-minimal .message-popup.success{background:linear-gradient(180deg,#22d3ee38,#0891b22e)!important;color:#e6fdff!important;border-color:#22d3ee59!important}body.theme-minimal .message-popup.you-found{background:linear-gradient(180deg,#22d3ee47,#0891b238)!important;color:#071317!important;border-color:#22d3ee73!important}body.theme-minimal .message-popup.already-found{background:linear-gradient(180deg,#ef444438,#7f1d1d2e)!important;color:#fee2e2!important;border-color:#ef444459!important}body.theme-minimal .message-popup.notice{background:linear-gradient(180deg,#b4bed229,#94a3b81f)!important;color:#e5e7eb!important;border-color:#94a3b84d!important}body.theme-minimal .players-box li{background:#ffffff08!important;border:1px solid rgba(255,255,255,.08)!important;box-shadow:0 6px 16px #00000059!important}body.theme-minimal .players-box h4{color:#e5e7eb}body.theme-minimal .chat-box{background:#ffffff08!important;border-color:#ffffff14!important}body.theme-minimal .chat-box .chat-head h4{color:#e5e7eb}body.theme-minimal .icon-btn{color:#cbd5e1}body.theme-minimal .icon-btn:hover,body.theme-minimal .icon-btn:focus{background:#ffffff0f;color:#e5e7eb;outline:2px solid rgba(34,211,238,.25);outline-offset:2px}body.theme-minimal .icon-btn{transition:background .16s ease,color .16s ease,outline-color .16s ease}body.theme-minimal .chat-input-row input,body.theme-minimal .guess-box input{background:#ffffff0a!important;color:#e5e7eb!important;border:1px solid rgba(255,255,255,.08)!important}@keyframes pastelMove{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.page{display:flex;align-items:center;justify-content:center;padding:24px;min-height:100vh}.page.dashboard{min-height:100vh;align-items:center;justify-content:center;padding:24px}.page.dashboard .card{margin:0 auto;max-width:760px;width:min(95vw,700px)}.card{width:100%;max-width:1100px;margin:0 auto;background:var(--card);border-radius:20px;padding:22px;box-shadow:var(--shadow);border:1px solid rgba(17,24,39,.08);max-height:none;display:flex;flex-direction:column;overflow:visible}html{-webkit-text-size-adjust:100%}html,body{overscroll-behavior-y:contain}input,select,textarea,button{font-size:16px}@media(hover:none)and (pointer:coarse){.btn{min-height:44px;padding:12px 16px}}.title{font-size:36px;margin:0 0 10px}.choices{display:flex;gap:14px;justify-content:center;margin:18px 0}.brand-logo{height:42px;width:auto;display:inline-block;object-fit:contain}.brand-logo.small{height:24px}body.theme-minimal .brand-logo{filter:hue-rotate(165deg) saturate(1.25) brightness(1.05) drop-shadow(0 2px 8px rgba(0,0,0,.55)) drop-shadow(0 0 10px rgba(34,211,238,.25)) drop-shadow(0 0 24px rgba(34,211,238,.18));transition:transform .18s ease,filter .18s ease,opacity .18s ease;will-change:transform,filter}body.theme-minimal .brand-logo:hover,body.theme-minimal .brand-logo:focus{transform:translateY(-1px) scale(1.02);filter:drop-shadow(0 3px 10px rgba(0,0,0,.6)) drop-shadow(0 0 12px rgba(34,211,238,.35)) drop-shadow(0 0 28px rgba(34,211,238,.22))}body.theme-minimal .brand-logo.small{filter:hue-rotate(165deg) saturate(1.25) brightness(1.05) drop-shadow(0 1px 5px rgba(0,0,0,.5)) drop-shadow(0 0 8px rgba(34,211,238,.22))}.btn{padding:10px 16px;border-radius:12px;border:none;background:linear-gradient(90deg,var(--accent),#ffa7d9);color:#fff;cursor:pointer;box-shadow:0 10px 24px #ff88c22e;font-weight:600;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;will-change:transform,box-shadow;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn.primary{background:linear-gradient(90deg,var(--accent),#ffa7d9);color:#fff;box-shadow:0 10px 24px #ff88c22e}.btn.secondary{background:linear-gradient(90deg,var(--accent),#ffa7d9);color:#fff;box-shadow:0 10px 24px #ff88c22e;padding:10px 18px;min-width:120px;font-weight:700;border:none}.btn.secondary:hover,.btn.secondary:active,.btn.secondary:focus{background:linear-gradient(90deg,var(--accent),#ffa7d9);color:#fff;box-shadow:0 10px 24px #ff88c22e;transform:none;outline:none}.btn:not(:disabled):hover,.btn:not(:disabled):focus{transform:translateY(-4px) scale(1.01);box-shadow:0 16px 36px #7850781f;filter:saturate(1.03) brightness(1.01)}.btn:active{transform:translateY(-1px) scale(.996);box-shadow:0 8px 18px #78507814}.btn:focus{outline:3px solid rgba(255,136,194,.12);outline-offset:3px}.btn[disabled],.btn:disabled{opacity:.55;cursor:not-allowed;pointer-events:none;box-shadow:none}.btn.secondary.slate{background:linear-gradient(90deg,#eef2ff,#f7f9fc);color:#1f2937}.btn.secondary.peach{background:linear-gradient(90deg,#fff3ea,#fff8f2);color:#6b3b2a}.form input{width:100%;padding:12px;margin:8px 0;border-radius:12px;border:1px solid rgba(0,0,0,.06)}@media(max-width:560px){.form input{padding:14px}}.form .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.player-list{list-style:none;padding:0;margin:10px 0}.player-list li{background:#fff;padding:10px;border-radius:12px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 6px 20px #00000008}.lobby .card{padding:14px 16px;border-radius:16px;position:relative;max-width:720px;margin:0 auto;display:flex;flex-direction:column;align-items:center}.lobby .card h2{margin:0 0 8px;font-size:20px;display:flex;align-items:center;gap:8px;justify-content:center;text-align:center;width:100%}.lobby .card h2:before,.lobby .card h2:after{content:"";flex:1;height:1px;background:#e5e7eb}.lobby .card h2:before{margin-right:12px}.lobby .card h2:after{margin-left:12px}.player-list{margin-top:8px}.player-entry{display:flex;gap:8px;align-items:center;padding:8px;background:linear-gradient(180deg,#fff,#fbfbff);border-radius:12px;box-shadow:0 8px 18px #0c14280a}.player-entry .avatar{width:40px;height:40px;border-radius:12px;object-fit:cover;border:2px solid rgba(255,255,255,.6)}.player-entry .player-info{display:flex;flex-direction:column}.player-entry .name{font-weight:700;color:var(--text)}.player-entry .you{font-weight:600;font-size:13px;color:#6b7280;margin-left:6px}.player-entry .meta{font-size:13px;color:#6b7280;margin-top:4px}.player-entry .host-badge{background:linear-gradient(90deg,#fff7ed,#fff3d6);padding:4px 8px;border-radius:999px;font-weight:700;color:#b45309}.player-entry .score{color:#374151}.lobby-settings{display:flex;gap:12px;align-items:center;justify-content:center;margin-top:12px;width:100%;max-width:360px;margin-left:auto;margin-right:auto}.lobby-settings .form-input{padding:10px;border-radius:10px;border:1px solid rgba(0,0,0,.06);width:120px}.lobby-actions{display:flex;gap:10px;align-items:center;justify-content:center;margin-top:12px}.lobby-actions .btn{min-width:96px}.lobby .btn{padding:8px 12px;font-size:14px}.lobby .card:before{content:"";position:absolute;right:-40px;top:-40px;width:140px;height:140px;background:radial-gradient(circle at 30% 30%,rgba(255,200,230,.25),transparent 40%);border-radius:50%;pointer-events:none}.lobby .players{position:relative;width:100%;display:flex;flex-direction:column;align-items:center}.lobby .player-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;max-height:300px;overflow:auto;padding-right:4px;justify-items:center}.lobby .player-list.few{display:flex;flex-direction:column;gap:10px;max-width:100%;margin:0;max-height:none;overflow:visible}.lobby .player-list.few .player-entry{width:100%;flex-direction:row;align-items:center;justify-content:space-between;padding:10px}.lobby .player-list.few .player-entry .player-info{align-items:flex-start}.lobby .player-list.few .player-entry .name{text-align:left}.lobby .player-list li{margin:0}.lobby .player-entry{flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px}.lobby .player-entry .player-info{align-items:center}.lobby .player-entry .name{text-align:center}.lobby .player-entry .meta{margin-top:2px}.lobby .player-grid{display:grid;grid-template-columns:repeat(auto-fill,88px);gap:18px;align-items:start;justify-content:center;justify-items:center;padding-right:0;overflow:visible;max-height:none;margin:0 auto}.lobby .player-tile-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.lobby .player-tile{width:88px;min-width:88px;height:88px;background:#fff;border:2px solid rgba(17,24,39,.08);border-radius:10px;box-shadow:0 4px 12px #00000005;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:6px;position:relative}.lobby .player-tile .avatar{width:42px;height:42px;border-radius:8px;object-fit:cover;border:2px solid rgba(255,255,255,.7);box-shadow:0 2px 6px #0000000d}.lobby .player-name{width:100%;text-align:center;font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby .player-tile .name{width:100%;margin-top:6px;text-align:center;font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby .player-tile .you{font-weight:600;font-size:11px;color:#6b7280;margin-left:4px}.lobby .player-tile .host-badge{position:absolute;top:6px;right:6px;font-size:9px;font-weight:700;color:#b45309;background:linear-gradient(90deg,#fff7ed,#fff3d6);padding:2px 6px;border-radius:999px}.lobby .player-grid.many{grid-template-columns:repeat(auto-fill,72px);gap:12px;overflow:visible;max-height:none;padding-right:0}.lobby .player-grid.many .player-tile{width:72px;min-width:72px;height:72px;padding:6px;flex-direction:column;justify-content:center}.lobby .player-grid.many .player-tile .avatar{width:36px;height:36px;border-radius:8px}.lobby .player-grid.many .player-tile .name{font-size:11px}.lobby .player-grid.many .player-tile .host-badge{font-size:9px;padding:2px 5px}.lobby .players{margin-bottom:8px}.lobby .players h4{margin:4px 0 8px;text-align:center}.lobby .player-grid.few{grid-template-columns:repeat(auto-fill,120px);gap:16px;width:auto;margin:0 auto;justify-content:center}.lobby .player-grid.few .player-tile{width:120px;min-width:120px;height:120px;flex-direction:column;justify-content:center;gap:8px;padding:10px}.lobby .player-grid.few .player-tile .avatar{width:58px;height:58px;border-radius:10px}.lobby .player-grid.few .player-tile .name{font-size:13px;text-align:center}.lobby .player-grid.few .player-name{font-size:13px}@media(max-width:560px){.lobby .player-list.few{display:flex;flex-direction:column;gap:10px;max-width:100%}.lobby .player-list.few .player-entry{width:100%}.lobby .player-grid{grid-template-columns:repeat(auto-fill,80px);gap:12px;justify-content:center;overflow:visible;max-height:none}.lobby .player-tile{width:80px;min-width:80px;height:80px;padding:6px}.lobby .player-tile .avatar{width:38px;height:38px}.lobby-actions{position:sticky;bottom:0;left:0;right:0;margin-top:10px;padding-top:10px;background:linear-gradient(180deg,#fff0,#ffffffd9);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}}.lobby .player-grid.two{grid-template-columns:repeat(2,120px);justify-content:center}@media(max-width:560px){.lobby .player-grid.two{grid-template-columns:repeat(2,80px)}}.lobby .player-grid.scroll{grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:120px;gap:14px;overflow-x:auto;overflow-y:hidden;white-space:nowrap;justify-content:flex-start;margin:0 auto;padding-bottom:6px}.lobby .player-grid.scroll::-webkit-scrollbar{height:8px}.lobby .player-grid.scroll::-webkit-scrollbar-thumb{background:#00000026;border-radius:999px}@media(max-width:560px){.lobby .player-grid.scroll{grid-auto-columns:88px;gap:10px}}.game-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.game-head .dish-title{padding-left:16px}.right-head{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.page.game{position:relative}.page.game .app-brand{display:none}body.game-page .app-brand{display:none!important}.app-brand{position:fixed;top:20px;left:20px;color:var(--text);opacity:.7;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:10;display:flex;align-items:center;justify-content:center}.app-brand .brand-name{font-weight:900;font-size:18px;line-height:1;letter-spacing:-.5px;margin:0;padding:8px 14px;border:2px solid currentColor;border-radius:8px;background:#ffffff80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 4px 12px #00000014}.app-brand .brand-tag{display:none}.card{position:relative;z-index:1}.game-flex{display:flex;gap:20px;flex-wrap:nowrap;flex:1;align-items:flex-start;overflow:visible}.dish-area{flex:1 1 0;min-width:280px;text-align:center}.dish-img{width:100%;max-width:640px;aspect-ratio:4/3;height:auto;object-fit:contain;border-radius:14px;box-shadow:0 10px 30px #0000000f;border:2px solid rgba(17,24,39,.08);background:#fff}.dish-placeholder{height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(90deg,#fff,#fff3);border-radius:12px}.play-area{flex:1 1 0;min-width:320px;max-width:none}.players-box{background:#fff;border:1px solid rgba(17,24,39,.08);border-radius:12px;padding:10px;box-shadow:0 6px 18px #00000008}.players-box ul{list-style:none;padding:0}.players-box li{padding:10px;margin-bottom:8px;background:#fff;border-radius:12px;box-shadow:0 6px 18px #00000008;border:1px solid rgba(17,24,39,.08)}.players-box ul{max-height:260px;overflow:auto}.guess-box{display:flex;gap:8px;margin-top:12px}.guess-box input{flex:1;padding:10px;border-radius:10px;border:1px solid rgba(17,24,39,.12);outline:none}.ingredient-chip{display:inline-block;padding:8px 12px;border-radius:18px;background:var(--mint);margin:6px;border:none}.ingredient-chip.found-me{background:#d1fae5}.ingredient-chip.found-other{background:#e0e7ff}.ingredient-chip.remaining{background:#fee2e2}.chat-box{margin-top:12px;background:#fff;border-radius:12px;padding:10px;box-shadow:0 6px 18px #00000008;border:1px solid rgba(17,24,39,.08)}.chat-box .chat-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.chat-box.collapsed{padding-bottom:8px}.chat-box.collapsed .chat-head{margin-bottom:0}.chat-box .chat-head h4{margin:0;font-size:14px;line-height:1}.icon-btn{appearance:none;-webkit-appearance:none;background:transparent;color:#374151;border:none;border-radius:8px;padding:6px 8px;line-height:1;font-weight:700;cursor:pointer}.icon-btn:active{transform:translateY(0) scale(.98)}.icon-btn:focus{outline:2px solid rgba(17,24,39,.15);outline-offset:2px}.chat-messages{max-height:240px;overflow:auto;display:flex;flex-direction:column;gap:8px;padding:6px}.players-box ul,.chat-messages,.lobby .player-grid.scroll{-webkit-overflow-scrolling:touch}.chat-message{padding:8px 10px;border-radius:10px;background:#f8fafc;border:1px solid rgba(17,24,39,.06)}.chat-message.me{background:linear-gradient(90deg,#d1fae5,#86efac);align-self:flex-end}.chat-message.other{background:#f3f4f6;align-self:flex-start}.chat-meta{font-size:12px;color:#6b7280;margin-bottom:4px}.chat-text{font-size:14px;color:var(--text)}.chat-input-row{display:flex;gap:8px;margin-top:8px}.chat-input-row input{flex:1;padding:8px 10px;border-radius:10px;border:1px solid rgba(17,24,39,.12);outline:none}.game-head{border-bottom:1px solid rgba(17,24,39,.08);padding-bottom:8px}.scoregrid{display:flex;flex-direction:column;gap:10px}.score-card{display:flex;justify-content:space-between;padding:12px;background:#fff;border-radius:12px;box-shadow:0 8px 20px #0000000a}.score-card.winner{background:linear-gradient(90deg,#eafff2,#fff9e6);border:2px solid #ffe8a3}.page.dashboard .card.dashboard-form{max-width:460px;width:min(92vw,460px);aspect-ratio:1 / 1;display:flex;flex-direction:column;justify-content:center;overflow:auto}.page.dashboard .card.dashboard-form .title{text-align:center;font-size:30px;margin-bottom:8px}.page.dashboard .card.dashboard-form .form{max-width:360px;width:100%;margin:0 auto;display:flex;flex-direction:column}.page.dashboard .card.dashboard-form .form h2{margin:8px 0 10px;text-align:center}.page.dashboard .card.dashboard-form .form input{padding:10px;margin:6px 0;width:100%}.page.dashboard .card.dashboard-form .form .actions{margin-top:12px;justify-content:center;width:100%}.page.dashboard .card.dashboard-form .avatar-wrap{display:flex;justify-content:center;align-items:center;margin:8px 0 10px}.page.dashboard .card.dashboard-form .avatar{border-radius:50%;box-shadow:0 8px 24px #00000014}.page.dashboard .card.dashboard-form .actions.edge{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%}.page.dashboard .card.dashboard-form .actions.edge .btn{width:48%;min-width:0}@media(max-width:420px){.page.dashboard .card.dashboard-form{width:92vw;max-width:92vw;aspect-ratio:1 / 1;padding:12px;border-radius:14px}.page.dashboard .card.dashboard-form .title{font-size:26px}}@media(max-width:820px){.card{padding:16px}.game-flex{flex-direction:column}}.page{display:flex;align-items:flex-start;justify-content:center;padding:12px;min-height:auto}.card{width:100%;max-width:980px;padding:16px}@media(max-width:980px){.card{padding:14px;border-radius:14px}}@media(max-width:720px){.page{padding:10px}.card{padding:12px;border-radius:12px}}@media(max-width:560px){.page{padding:14px}.card{padding:14px;border-radius:16px}.game-head{flex-direction:column;align-items:flex-start;gap:6px}.right-head{align-items:flex-start}.dish-area,.play-area{min-width:0}.dish-img{max-width:100%;height:auto;aspect-ratio:auto;max-height:min(42svh,360px);object-fit:contain;border-radius:12px}.guess-box{flex-direction:column}.guess-box .btn{width:100%}.chat-input-row{flex-direction:column}.chat-input-row .btn{width:100%}.players-box ul{max-height:32svh;overflow:auto}.chat-messages{max-height:28svh}.app-brand{transform:scale(.9);top:12px;left:12px}.lobby .player-list{max-height:260px;overflow:auto}.lobby-actions{flex-direction:column;align-items:stretch;gap:10px}.lobby-actions .btn{width:100%}.lobby-settings{flex-wrap:wrap}}@media(max-width:420px){.title{font-size:26px}.btn{min-height:48px;font-size:16px;padding:12px 14px}.choices{flex-direction:column;gap:10px;justify-content:center;align-items:stretch}.choices .btn{width:100%;flex:none;min-width:0;padding:12px 14px}.page.dashboard .card.dashboard-form{aspect-ratio:auto;width:92vw;max-width:420px;padding:12px;justify-content:flex-start}.card{padding:12px}.ingredient-chip{margin:4px 6px}.dish-img{max-height:min(40svh,300px)}.app-brand{display:none}.lobby .card h2{font-size:18px}.lobby .player-list li{padding:8px}}@supports (padding:max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-bottom:max(0px,env(safe-area-inset-bottom))}}.game-root{max-width:1100px;margin:28px auto;padding:18px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0000000f}.game-header{display:flex;gap:16px;align-items:center;justify-content:space-between}.game-head{position:sticky;top:0;z-index:20;background:#fff;padding:8px 0;border-bottom:1px solid rgba(17,24,39,.06)}.dish-image{width:100%;height:auto;max-height:420px;object-fit:contain;border-radius:10px}.game-body{display:flex;gap:18px;margin-top:18px}.dish-panel{flex:1;text-align:center}.play-panel{flex:1;display:flex;flex-direction:column;gap:12px}.players-list ul{list-style:none;padding:0}.guess-box{display:flex;gap:8px}.guess-box input{flex:1;padding:10px}.guess-box button{padding:10px 14px}.game-flex{display:flex;gap:18px;align-items:flex-start}.dish-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center}.dish-placeholder{width:100%;max-width:100%;height:auto;min-height:200px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#f9fafb;color:#6b7280;font-weight:600;margin:0 auto}.dish-img{display:block;margin:0 auto;width:100%;height:auto;border-radius:12px;object-fit:contain;max-height:min(60vh,640px)}.message-popup{position:relative;background:#fafafa;color:#1f2937;padding:12px 16px;border-radius:12px;box-shadow:0 6px 20px #00000026,0 2px 8px #00000014,inset 0 1px #fff6;border:1px solid rgba(0,0,0,.15);font-weight:600;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transform:translateY(0);animation:popupFloat .4s ease-out;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.1) .1px,transparent .1px),radial-gradient(circle at 90% 80%,rgba(255,255,255,.1) .1px,transparent .1px);background-size:30px 30px}@keyframes popupFloat{0%{transform:translateY(10px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.message-popup.success{background:linear-gradient(135deg,#f0fdf4,#e7fbeb);color:#166534;box-shadow:0 6px 20px #22c55e26,0 2px 8px #22c55e14,inset 0 1px #fff6;border:1px solid rgba(34,197,94,.25);font-weight:600;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.15) .1px,transparent .1px),radial-gradient(circle at 90% 80%,rgba(255,255,255,.15) .1px,transparent .1px);background-size:30px 30px}.message-popup.you-found{background:linear-gradient(135deg,#d1fae5,#86efac);color:#065f46;padding:12px 16px;border-radius:12px;box-shadow:0 6px 20px #22c55e26,0 2px 8px #22c55e14,inset 0 1px #fff6;border:1px solid rgba(34,197,94,.25);font-weight:600;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.15) .1px,transparent .1px),radial-gradient(circle at 90% 80%,rgba(255,255,255,.15) .1px,transparent .1px);background-size:30px 30px;animation:popupFloat .4s ease-out}.message-popup.already-found{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#991b1b;box-shadow:0 6px 20px #dc262626,0 2px 8px #dc262614,inset 0 1px #fff6;border:1px solid rgba(220,38,38,.25);font-weight:600;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.15) .1px,transparent .1px),radial-gradient(circle at 90% 80%,rgba(255,255,255,.15) .1px,transparent .1px);background-size:30px 30px;animation:popupFloat .4s ease-out}.popups-root{position:fixed;left:50%;top:24px;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:1000}.message-popup.notice{background:linear-gradient(135deg,#eff6ff,#e0f2fe);color:#1e40af;box-shadow:0 6px 20px #3b82f626,0 2px 8px #3b82f614,inset 0 1px #fff6;border:1px solid rgba(59,130,246,.25);font-weight:600;background-image:radial-gradient(circle at 10% 20%,rgba(255,255,255,.15) .1px,transparent .1px),radial-gradient(circle at 90% 80%,rgba(255,255,255,.15) .1px,transparent .1px);background-size:30px 30px}.lobby-settings{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.lobby-settings .form-row{display:flex;flex-direction:column;font-weight:600;color:var(--text);align-items:flex-start;text-align:left;gap:4px}.lobby-settings .form-input{padding:10px;border-radius:12px;border:1px solid rgba(0,0,0,.06);width:140px}.confetti-root{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:1100}.confetti-piece{position:absolute;top:-10vh;width:10px;height:16px;border-radius:2px;opacity:.95;transform-origin:center;animation-name:confettiFall;animation-timing-function:cubic-bezier(.2,.6,.2,1)}@keyframes confettiFall{0%{transform:translateY(-10vh) rotate(0);opacity:1}60%{opacity:1}to{transform:translateY(120vh) rotate(360deg);opacity:0}}.page.game .card{position:relative}.balloons-root{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1050;display:block}.balloon{position:absolute;bottom:-10vh;width:18px;height:24px;border-radius:10px 10px 12px 12px;opacity:.9;animation-name:balloonRise;animation-timing-function:ease-in;box-shadow:0 6px 14px #00000014}@keyframes balloonRise{0%{transform:translateY(10vh) scale(.9);opacity:.9}60%{opacity:1}to{transform:translateY(-120vh) scale(1.05);opacity:0}}.dish-area{text-align:center}.dish-title{text-align:center;display:inline-block}.meta{font-weight:700;color:#2b2b2b;font-size:16px;display:flex;gap:8px;align-items:center}.meta .rounds{color:var(--text)}.meta .timer{color:#6b6b6b;font-weight:600}.dish-area h3{margin-top:10px;font-size:20px;color:var(--text)}.ingredients-box{margin-top:14px;display:flex;flex-direction:column;gap:8px}.ingredient-group{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.group-title{font-size:13px;font-weight:700;color:var(--text);margin-right:8px}.ingredient-chip{background:#f3f4f6;color:var(--text);padding:6px 10px;border-radius:999px;font-weight:600;margin:4px;display:inline-block}.ingredient-chip.found-me{background:linear-gradient(90deg,#d1fae5,#86efac);color:#065f46}.ingredient-chip.found-other{background:linear-gradient(90deg,#dbeafe,#bfdbfe);color:#1e3a8a}.ingredient-chip.remaining{background:#eef2f7;color:#374151}.by-who{font-size:11px;opacity:.85;margin-left:6px}.avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.6);box-shadow:0 4px 10px #0206170f}.avatar[alt]{background:linear-gradient(90deg,#fff,#f3f4f6)}.scoregrid{display:flex;flex-direction:column;gap:10px;margin-top:12px}.score-card{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;background:#fff;box-shadow:0 6px 16px #0206170a}.score-card.winner{background:linear-gradient(90deg,#fff7ed,#fff1d6);border:1px solid rgba(250,204,21,.12)}.score-card .rank{font-weight:700;color:#6b7280;min-width:36px;text-align:center}.score-card .pname{font-weight:700;color:var(--text);font-size:16px}.score-card .pscore{margin-left:auto;font-weight:800;font-size:18px;color:#111827}.play-area{display:flex;flex-direction:column;gap:12px;padding:8px}.btn.next-round{align-self:center;margin-top:8px}.btn.next-round:hover{transform:none}.actions{display:flex;justify-content:center;margin-top:24px;gap:12px}.actions .btn{min-width:180px}@media(max-width:560px){.game-body{flex-direction:column}.dish-image{width:100%;height:auto;max-height:42svh;object-fit:contain}.popups-root{left:50%;top:12px;transform:translate(-50%)}.message-popup{right:12px;top:auto;bottom:16px;max-width:calc(100% - 24px)}.chat-messages{max-height:200px}.guess-box{flex-direction:column}.guess-box button{width:100%}.lobby-settings{gap:10px}}@media(max-width:900px){.game-flex{flex-direction:column}.dish-img,.dish-placeholder{max-width:100%}}@media(max-width:420px){.actions{flex-direction:column}.actions .btn{min-width:100%;min-height:44px}.players-list ul{max-height:200px;overflow:auto}.game-root{margin:12px;padding:14px;border-radius:14px}.game-header{flex-direction:column;align-items:flex-start;gap:8px}.game-flex{flex-direction:column}.dish-img,.dish-placeholder{max-width:100%}}@media(max-width:900px){.game-body{flex-direction:column}.dish-panel,.play-panel{width:100%}.guess-box{flex-direction:column}.guess-box button{width:100%}}
