/* TapTap Sushi Battle styles */
.tts-wrap{
    font-family: system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, 'Noto Sans';
    max-width: 900px; margin: 16px auto; padding: 12px 12px 18px;
    background: radial-gradient(1200px 600px at 20% -10%, rgba(244,114,182,.10), transparent 40%),
                radial-gradient(1200px 600px at 120% 110%, rgba(59,130,246,.10), transparent 40%),
                #0b1220;
    color:#e2e8f0; border-radius:16px; box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.tts-header{ display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap; padding-bottom:10px; border-bottom:1px solid rgba(255,255,255,.08);}
.tts-title{ font-size:22px; font-weight:800; }
.tts-badge{ font-size:12px; padding:2px 6px; border-radius:999px; background:#111827; border:1px solid #334155; color:#fda4af; margin-left:8px;}
.tts-controls{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.tts-controls label{ font-size:13px; color:#cbd5e1; display:inline-flex; gap:6px; align-items:center; }
.tts-controls select{ background:#0b1220; color:#e2e8f0; border:1px solid #334155; border-radius:10px; padding:6px; }
.tts-btn{ background:#f97316; color:#1b1205; border:none; border-radius:999px; padding:8px 14px; font-weight:800; cursor:pointer; }
.tts-btn:hover{ transform:translateY(-1px); box-shadow:0 6px 16px rgba(249,115,22,.35); }

.tts-arena{ position:relative; background:#0a0f1a; border:1px solid #1f2937; border-radius:14px; padding:14px; overflow:hidden; min-height:300px; }
.tts-scoreboard{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:8px;}
.tts-label{ font-size:12px; color:#93c5fd; letter-spacing:1px; text-transform:uppercase;}
.tts-num{ font-size:30px; font-weight:900; }
.tts-timer{ font-size:18px; font-weight:800; color:#fef08a; background:#1f2937; padding:4px 12px; border-radius:10px; }

.tts-progress{ width:100%; height:10px; background:#101826; border-radius:999px; overflow:hidden; margin:10px 0 12px; }
.tts-bar{ height:100%; width:50%; background:linear-gradient(90deg,#f97316,#60a5fa); transition:width .08s linear; }

.tts-stage{ position:relative; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:12px; margin:10px 0 12px; }
.tts-chef{ font-size:46px; filter: drop-shadow(0 8px 18px rgba(0,0,0,.45)); transition: transform .1s; }
.tts-chef.hit{ transform: translateY(-6px) scale(1.08) rotate(-4deg); }
.tts-chef.drop{ transform: translateY(6px) scale(.94) rotate(4deg); }
.tts-vs{ font-weight:900; color:#94a3b8; opacity:.7; }
.tts-drop{ position:absolute; left:50%; top:8px; transform:translateX(-50%); background:#ef4444; color:#fff; padding:4px 10px; border-radius:999px; font-weight:900; box-shadow:0 10px 20px rgba(239,68,68,.25); }

.tts-tap{ width:100%; padding:16px; font-size:26px; border-radius:14px; border:2px solid #334155; background:#111827; color:#e2e8f0; cursor:pointer; }
.tts-tap:active{ transform:scale(.99); }

.tts-effects{ position:absolute; left:0; top:0; width:100%; height:100%; pointer-events:none; }
.tts-pop{ position:absolute; font-weight:900; text-shadow:0 2px 8px rgba(0,0,0,.6); animation: tts-pop .9s ease-out forwards; white-space:nowrap; }
.tts-pop.left{ color:#86efac; }
.tts-pop.right{ color:#93c5fd; }
@keyframes tts-pop{
  0%{ transform:translate(-50%,0) scale(.85); opacity:1;}
  100%{ transform:translate(-50%,-46px) scale(1.1); opacity:0;}
}

.tts-result{ text-align:center; padding:14px; }
.tts-result-text{ font-size:28px; font-weight:900; }
.tts-result-scores{ color:#cbd5e1; margin:8px 0; }
.tts-leaderboard{ background:#0b1220; border:1px solid #1f2937; border-radius:12px; padding:8px; text-align:left; max-width:620px; margin:8px auto; }
.tts-leaderboard h4{ margin:0 0 6px 0; }
.tts-row{ display:grid; grid-template-columns:50px 130px 60px 70px 1fr; gap:8px; font-size:12px; color:#a5b4fc; border-bottom:1px dashed rgba(255,255,255,.06); padding:4px 0; }

.tts-footnote{ font-size:12px; color:#94a3b8; margin-top:10px; }

@media (max-width:600px){
  .tts-chef{ font-size:40px; }
  .tts-row{ grid-template-columns:38px 100px 52px 62px 1fr; }
}