:root{--bg-0: #0a0e14;--bg-1: #0f141c;--bg-2: #161c28;--bg-3: #1c2633;--border: #2a3544;--border-strong: #3d4a5c;--text: #f0ebe3;--muted: #8f95a3;--gold: #d4a574;--gold-bright: #f0c49a;--gold-dim: #8b6910;--sand-glow: rgba(212, 165, 116, .12);--crimson: #b83232;--crimson-bright: #ff7a6a;--emerald: #4bc4a2;--ocean: #2a6b8a;--shadow: 0 10px 40px rgba(0, 0, 0, .55)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}body{background:radial-gradient(ellipse 120% 80% at 50% -10%,#2a4a6a 0%,transparent 45%),radial-gradient(ellipse 100% 60% at 50% 100%,#1a2a22 0%,var(--bg-0) 50%) fixed;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.5}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(900px 500px at 50% 95%,rgba(212,165,116,.08),transparent 65%),radial-gradient(500px 280px at 15% 20%,rgba(42,107,138,.12),transparent 70%),radial-gradient(400px 200px at 85% 30%,rgba(184,50,50,.06),transparent 70%);pointer-events:none;z-index:0}h1,h2,h3{font-family:Cinzel,serif;font-weight:700;letter-spacing:.5px;margin:0}h2{font-size:1.05rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:12px}h3{font-size:.85rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:10px}.muted{color:var(--muted);font-size:.85rem}.view{position:relative;z-index:1;min-height:100vh;padding:32px 24px}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:8px;padding:12px 22px;font-size:.95rem;font-weight:600;font-family:inherit;letter-spacing:.5px;cursor:pointer;transition:all .18s ease;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-small{padding:6px 12px;font-size:.8rem}.btn-primary{background:linear-gradient(180deg,#d4a574,#a67c3d);color:#140c06;box-shadow:0 4px 14px #d4a5744d}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#f0c49a,#c4925a);transform:translateY(-1px);box-shadow:0 6px 18px #d4a57473}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border-strong)}.btn-ghost:hover:not(:disabled){background:#d4a5741a;border-color:var(--gold);color:var(--gold)}.field{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--muted)}.field span{text-transform:uppercase;font-size:.75rem;letter-spacing:1.5px;font-weight:600;color:var(--gold)}input[type=text],input[type=number]{background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:11px 14px;border-radius:8px;font-size:1rem;font-family:inherit;outline:none;transition:all .15s}input[type=text]:focus,input[type=number]:focus{border-color:var(--gold);background:var(--bg-3);box-shadow:0 0 0 3px #d4a5742e}#code-input{text-transform:uppercase;letter-spacing:4px;text-align:center;font-weight:700;font-family:Cinzel,serif}.toast{position:fixed;top:24px;left:50%;transform:translate(-50%) translateY(-200%);background:var(--bg-2);border:1px solid var(--crimson);color:var(--crimson-bright);padding:12px 24px;border-radius:10px;z-index:1000;transition:transform .3s ease;box-shadow:var(--shadow)}.toast.show{transform:translate(-50%) translateY(0)}.home-container{max-width:560px;margin:40px auto;display:flex;flex-direction:column;gap:28px;align-items:center}.brand{text-align:center}.brand-crab{display:inline-flex;padding:12px;margin-bottom:8px;animation:pulseCrab 4s ease-in-out infinite}@keyframes pulseCrab{0%,to{filter:drop-shadow(0 0 8px rgba(212,165,116,.45))}50%{filter:drop-shadow(0 0 18px rgba(232,122,90,.35))}}.title{font-size:3rem;margin:4px 0;letter-spacing:4px}.title-accent{color:#e88a6a;font-style:italic}.tagline{color:var(--muted);margin:0 auto;font-style:italic;max-width:420px}.home-card{width:100%;background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:28px;box-shadow:var(--shadow)}.home-actions{display:flex;flex-direction:column;gap:14px;margin-top:18px}.home-actions>.btn{width:100%}.join-group{display:flex;gap:10px;align-items:stretch}.join-group input{flex:1;min-width:0}.join-group .btn{width:auto;padding:11px 22px;flex-shrink:0}@media (max-width: 520px){.home-container{margin:24px auto;padding:0 4px}.title{font-size:2.1rem;letter-spacing:2px}.home-card{padding:20px}.join-group{flex-direction:column;gap:12px}.join-group input{width:100%;min-height:48px;font-size:1rem}.join-group .btn{width:100%;min-height:48px;justify-content:center}}.name-preview{margin:0 0 10px;font-size:.88rem;color:var(--muted);text-align:center}.name-preview strong{color:var(--gold-bright)}.rules{width:100%;background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:14px 20px}.rules summary{cursor:pointer;font-weight:600;color:var(--gold);letter-spacing:1px;text-transform:uppercase;font-size:.85rem}.rules summary:hover{color:var(--gold-bright)}.rules-body{padding-top:14px;color:var(--muted)}.rules-body strong{color:var(--text)}.rules-body ol{padding-left:20px}.lobby-grid{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.lobby-header{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.code-display{display:flex;gap:14px;align-items:center}.code-display #lobby-code{font-family:Cinzel,serif;font-size:2rem;font-weight:900;letter-spacing:8px;color:var(--gold);text-shadow:0 0 20px rgba(212,165,116,.45)}.host-grace-banner{padding:12px 18px;background:#2a6b8a26;border:1px solid rgba(42,107,138,.35);border-radius:10px;color:var(--muted);font-size:.92rem;line-height:1.45;text-align:center;margin:0}.host-grace-banner strong{color:var(--gold-bright)}.lobby-main{display:grid;grid-template-columns:1fr 1.4fr;gap:24px}@media (max-width: 800px){.lobby-main{grid-template-columns:1fr}}.panel{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--shadow)}.player-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.player-list li{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;transition:all .15s}.player-list li.is-host{border-color:var(--gold-dim)}.player-list li.is-you{background:var(--bg-3)}.player-list .pname{font-weight:600;display:flex;align-items:center;gap:8px}.player-list .badge{font-size:.65rem;padding:2px 8px;background:var(--gold);color:#1a0f00;border-radius:999px;font-weight:700;letter-spacing:1px}.player-list .badge.you{background:var(--bg-3);color:var(--gold);border:1px solid var(--gold-dim)}.player-list .disconnected{color:var(--crimson-bright);font-size:.75rem}.btn-kick{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:.8rem}.btn-kick:hover{color:var(--crimson-bright)}.settings-display{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px}.settings-display .setting-row{display:flex;flex-direction:column}.settings-display .label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.settings-display .value{font-size:1.05rem;font-weight:600;color:var(--text)}.settings-form{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.settings-form .field{font-size:.8rem}.settings-form .field-wide{grid-column:1 / -1}.derived-value{background:var(--bg-2);border:1px dashed var(--border);color:var(--gold);padding:11px 14px;border-radius:8px;font-size:1rem;font-family:Cinzel,serif;font-weight:700;letter-spacing:1px}.lobby-footer{display:flex;justify-content:center;padding-top:12px}.lobby-footer .btn-primary{max-width:320px;min-width:200px}.game-header{max-width:1400px;margin:0 auto 20px;display:flex;justify-content:space-between;align-items:center;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.game-meta{display:flex;gap:14px;align-items:center}.round-pill{background:var(--bg-2);border:1px solid var(--border);padding:8px 18px;border-radius:999px;font-family:Cinzel,serif;font-weight:700;letter-spacing:1px;color:var(--gold)}.phase-pill{background:linear-gradient(180deg,#d4a57433,#d4a5740f);border:1px solid var(--gold-dim);color:var(--gold-bright);padding:8px 18px;border-radius:999px;font-family:Cinzel,serif;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:.85rem}.phase-pill.results{background:linear-gradient(180deg,#45c78a26,#45c78a0d);border-color:#45c78a66;color:var(--emerald)}.timer{display:flex;align-items:center;justify-content:center;position:relative;width:48px;height:48px}.timer svg{transform:rotate(0)}.timer-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-weight:700;font-size:.95rem;color:var(--gold)}.game-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:280px 1fr;gap:24px}@media (max-width: 900px){.game-grid{grid-template-columns:1fr}}.players-panel{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--shadow);max-height:80vh;overflow-y:auto}.game-players{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:8px}.game-players li{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px}.game-players li.is-you{border-color:var(--gold-dim);background:var(--bg-3)}.game-players li.advanced{opacity:.55;border-style:dashed}.game-players li.eliminated{opacity:.55;border-color:var(--crimson)}.game-players li.last-winner{animation:glowWin 1.6s ease}@keyframes glowWin{0%{box-shadow:0 0 #d4a57480}to{box-shadow:0 0 0 12px #d4a57400}}.gp-top{display:flex;justify-content:space-between;align-items:center}.gp-name{font-weight:600;display:flex;gap:8px;align-items:center}.gp-score{color:var(--gold);font-family:Cinzel,serif;font-weight:700}.gp-tokens{font-size:.75rem;color:var(--muted);margin-top:4px}.gp-status{font-size:.7rem;padding:2px 8px;border-radius:999px}.gp-status.advanced{background:#45c78a1f;color:var(--emerald);border:1px solid rgba(69,199,138,.3)}.gp-status.eliminated{background:#c628281f;color:var(--crimson-bright);border:1px solid rgba(198,40,40,.3)}.gp-status.host{background:#d4a57424;color:var(--gold);border:1px solid var(--gold-dim)}.gp-ready{font-size:.7rem;color:var(--emerald);margin-top:4px}.gp-waiting{font-size:.7rem;color:var(--muted);margin-top:4px}.history-block{border-top:1px solid var(--border);padding-top:14px}.history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}.history-list li{font-size:.78rem;padding:6px 10px;background:var(--bg-2);border-radius:6px}.history-list .h-round{color:#94b4c3d9;font-family:Cinzel,serif}.history-list .h-winner{color:var(--gold);font-weight:600}.history-list .h-card{color:var(--gold-bright)}.history-list .h-none{color:var(--muted);font-style:italic}.board{background:var(--bg-1);border:1px solid var(--border);border-radius:14px;padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:24px;min-height:70vh}.phase-instructions{text-align:center;font-family:Cinzel,serif;font-size:1.2rem;letter-spacing:1.5px;color:var(--gold)}.opponents-area{display:flex;flex-direction:column;gap:12px}.opponents-row{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}.opponent{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:12px;min-width:140px;text-align:center;transition:all .2s}.opponent.advanced{opacity:.4;border-style:dashed}.opponent.last-winner{border-color:var(--gold);box-shadow:0 0 16px #d4a57459}.opp-name{font-weight:600;margin-bottom:8px;font-size:.9rem}.opp-cards{display:flex;gap:6px;justify-content:center;min-height:90px;align-items:center;position:relative}.opp-sat-out{flex:1;min-height:90px;display:flex;align-items:center;justify-content:center;padding:0 12px;font-size:.8rem;font-weight:600;letter-spacing:.5px;color:var(--muted);font-style:italic}.opp-status{font-size:.7rem;color:var(--muted);margin-top:6px}.opp-status.ready{color:var(--emerald)}.card{width:60px;height:86px;border-radius:8px;border:2px solid var(--gold-dim);background:radial-gradient(circle at 50% 25%,rgba(255,255,255,.06),transparent 60%),linear-gradient(160deg,#1a1a2e,#14141f);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:2rem;font-weight:900;position:relative;-webkit-user-select:none;user-select:none;cursor:pointer;transition:box-shadow .18s ease,border-color .18s ease,color .18s ease;text-shadow:0 1px 6px rgba(0,0,0,.6);backface-visibility:hidden}.card.large{width:76px;height:108px;font-size:2.4rem}.card.tiny{width:40px;height:56px;font-size:1.3rem;border-width:1.5px}.card.selectable:hover{border-color:var(--gold-bright);box-shadow:0 6px 14px #00000073}.card.selected{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-bright),0 0 18px #d4a57480}.card.played{border-color:var(--crimson-bright);box-shadow:0 0 0 2px var(--crimson-bright),0 0 22px #ff5b5b8c;color:var(--crimson-bright)}.card.winner{animation:winnerPulse 1.4s ease-in-out infinite}@keyframes winnerPulse{0%,to{box-shadow:0 0 0 2px var(--gold),0 0 30px #d4a5748c}50%{box-shadow:0 0 0 3px var(--gold-bright),0 0 40px #d4a574d9}}.card.confiscated{background:linear-gradient(160deg,#1a0c0c,#14080a);border-color:#c6282866;color:#c62828b3;cursor:not-allowed}.card.confiscated:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(0,0,0,.3) 5px,rgba(0,0,0,.3) 6px);border-radius:6px}.card.unusable{background:linear-gradient(160deg,#1a1a14,#14140e);border-color:#78501e80;color:#d4a57473;cursor:not-allowed}.card.unusable:after{content:"🔒";position:absolute;top:4px;right:4px;font-size:.7rem;opacity:.7}.card.facedown{background:repeating-linear-gradient(45deg,#2a0e0e,#2a0e0e 6px,#1a0808 6px,#1a0808 12px),linear-gradient(160deg,#2a0e0e,#1a0808);color:transparent;border-color:#c6282866}.card.facedown:after{content:"?";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#c6282899;font-family:Cinzel,serif;font-size:1.6rem;font-weight:900}.card.dimmed{opacity:.45}.card.locked{cursor:not-allowed}.card.locked:hover{transform:none;box-shadow:none}.your-area{margin-top:auto;border-top:1px solid var(--border);padding-top:18px;display:flex;flex-direction:column;gap:14px}.your-info{display:flex;justify-content:space-between;align-items:center}.your-info .muted{text-transform:uppercase;letter-spacing:1.5px;font-size:.75rem}.selected-info{display:flex;gap:14px;align-items:center}.selected-info #selected-info-text{color:var(--gold);font-weight:600}.your-hand{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.result-banner{text-align:center;padding:16px 24px;background:linear-gradient(180deg,#d4a5742e,#d4a5740f);border:1px solid var(--gold-dim);border-radius:12px;font-family:Cinzel,serif;font-size:1.1rem;color:var(--gold-bright)}.result-banner.no-winner{background:linear-gradient(180deg,#78788c26,#78788c0d);border-color:var(--border-strong);color:var(--muted)}.result-banner strong{color:var(--gold);font-weight:900;margin:0 4px}.result-banner .pts{color:var(--crimson-bright)}.end-container{max-width:700px;margin:40px auto;background:var(--bg-1);border:1px solid var(--border);border-radius:16px;padding:40px;box-shadow:var(--shadow)}.end-flavor{text-align:center;color:var(--muted);font-size:.95rem;line-height:1.55;max-width:520px;margin:-12px auto 20px}.end-result{text-align:center;padding:20px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;margin-bottom:28px}.end-result .piece-winner{font-family:Cinzel,serif;font-size:1.4rem;color:var(--gold-bright);margin-bottom:8px}.end-result .eliminated{font-family:Cinzel,serif;font-size:1.1rem;color:var(--crimson-bright)}.end-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.end-list li{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--bg-2);border:1px solid var(--border);border-radius:10px}.end-list li.advanced{border-left:4px solid var(--emerald)}.end-list li.eliminated{border-left:4px solid var(--crimson)}.end-list li.piece{border-left:4px solid var(--gold)}.end-list .e-rank{font-family:Cinzel,serif;color:var(--muted);margin-right:12px}.end-list .e-name{flex:1;font-weight:600}.end-list .e-tag{font-size:.75rem;padding:3px 10px;border-radius:999px;margin-right:10px}.end-list .e-tag.advanced{background:#45c78a26;color:var(--emerald)}.end-list .e-tag.eliminated{background:#c6282826;color:var(--crimson-bright)}.end-list .e-tag.succumbed{background:#e87a5a1f;color:#e8a090}.end-list .e-score{font-family:Cinzel,serif;color:var(--gold);font-weight:700}.end-actions{margin-top:28px;display:flex;gap:14px;justify-content:center}.end-actions .btn{min-width:180px}.phase-banner-wrap{position:fixed;top:0;left:0;right:0;display:flex;justify-content:center;pointer-events:none;z-index:50}.phase-banner{margin-top:18vh;padding:20px 60px;background:linear-gradient(180deg,#d4a574f2,#a67c3df2);color:#14070a;font-family:Cinzel,serif;font-weight:900;letter-spacing:6px;font-size:1.6rem;text-transform:uppercase;border-radius:12px;box-shadow:0 14px 40px #0009,0 0 50px #d4a57459;border:1px solid rgba(255,255,255,.28);text-shadow:0 1px 0 rgba(255,255,255,.22)}.phase-banner.results{background:linear-gradient(180deg,#45c78af2,#2e845cf2);box-shadow:0 14px 40px #0009,0 0 50px #45c78a66;color:#04150c}.phase-banner.choose{background:linear-gradient(180deg,#ff5b5bf2,#b43232f2);box-shadow:0 14px 40px #0009,0 0 50px #ff5b5b66;color:#1a0608}.phase-banner small{display:block;font-size:.7rem;letter-spacing:3px;font-weight:700;margin-top:4px;opacity:.75}.score-float{position:absolute;font-family:Cinzel,serif;font-weight:900;font-size:1.6rem;color:var(--gold-bright);text-shadow:0 2px 12px rgba(212,165,116,.65);pointer-events:none;z-index:5}.celebration{position:relative;display:flex;justify-content:center;align-items:center;pointer-events:none}.celebration .spark{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--gold-bright);box-shadow:0 0 12px var(--gold-bright)}.celebration .ring{position:absolute;border:2px solid var(--gold);border-radius:50%;width:200px;height:200px;opacity:.6}.piece-glow{position:relative;display:inline-block}.piece-glow:before{content:"";position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;background:radial-gradient(circle,rgba(212,165,116,.45) 0%,transparent 70%);border-radius:50%;z-index:-1;animation:pieceGlow 2.5s ease-in-out infinite}@keyframes pieceGlow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.round-pill{overflow:hidden}.round-num-wrap{display:inline-block;position:relative;min-width:1.2em;height:1em;vertical-align:-.15em}.round-num{display:inline-block}
