/* ═══════════════════════════════════════════════════════════════
   SOFTFINGERS — LIVE RACE  (multi.css)
   Auto-matchmaking multiplayer — no invites
   ═══════════════════════════════════════════════════════════════ */

/* ── Theme variables ────────────────────────────────────────── */
:root {
  --bg:#f4f5fb; --bg2:#ffffff; --bg3:#eceef8; --bg4:#e0e4f4;
  --border:#d0d4e8; --text:#1a1d2e; --text2:#4a5068; --text3:#9098b8;
  --accent:#00b3a0; --accent2:#e07800; --accent3:#5048cc;
  --danger:#e8315a; --success:#00a86b;
  --correct:#00a86b; --wrong:#e8315a; --cursor:#00b3a0;
  --radius:14px; --radius-sm:8px;
  --font-ui:'Sora',sans-serif; --font-mono:'JetBrains Mono',monospace;
}
[data-theme="dark"] {
  --bg:#08090f; --bg2:#0d0f1a; --bg3:#131525; --bg4:#1a1d30;
  --border:#1e2135; --text:#e8eaf2; --text2:#848aaa; --text3:#3d4460;
  --accent:#00e5c8; --accent2:#ff9f43; --accent3:#6c63ff;
  --danger:#ff5f7e; --success:#00d68f; --correct:#00d68f; --wrong:#ff5f7e; --cursor:#00e5c8;
}
[data-theme="ocean"] {
  --bg:#020d1a; --bg2:#041428; --bg3:#071e38; --bg4:#0a2848;
  --border:#0f3560; --text:#c8e6ff; --text2:#6ea8d8; --text3:#2e6090;
  --accent:#00cfff; --accent2:#ff7e00; --accent3:#7c3aed;
  --danger:#ff5f7e; --success:#00d68f; --correct:#00d68f; --wrong:#ff5f7e; --cursor:#00cfff;
}
[data-theme="ember"] {
  --bg:#0f0806; --bg2:#1a0f0a; --bg3:#251510; --bg4:#301a14;
  --border:#3d2218; --text:#f5e8d8; --text2:#b8907a; --text3:#6b4535;
  --accent:#ff6b35; --accent2:#ffd166; --accent3:#c77dff;
  --danger:#ff5f7e; --success:#00d68f; --correct:#00d68f; --wrong:#ff5f7e; --cursor:#ff6b35;
}
[data-theme="forest"] {
  --bg:#050d08; --bg2:#0b1810; --bg3:#112218; --bg4:#162e1e;
  --border:#1a3825; --text:#d8f0e0; --text2:#7aab88; --text3:#3a6645;
  --accent:#39d96a; --accent2:#ffd166; --accent3:#6c63ff;
  --danger:#ff5f7e; --success:#00d68f; --correct:#00d68f; --wrong:#ff5f7e; --cursor:#39d96a;
}

/* ── Reset ────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-ui);
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  line-height:1.6;
  transition:background .3s,color .3s;
}

/* ── Topbar ───────────────────────────────────────────────────── */
#multi-topbar{
  height:60px;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  padding:0 24px;
  gap:14px;
  position:sticky;
  top:0;
  z-index:200;
}
.multi-logo{font-weight:800;font-size:1.1rem;color:var(--text);text-decoration:none;display:flex;align-items:center;gap:8px;}
.multi-logo span{color:var(--accent);}
.topbar-spacer{flex:1;}
.topbar-user-pill{display:flex;align-items:center;gap:8px;padding:5px 12px 5px 6px;background:var(--bg3);border:1px solid var(--border);border-radius:20px;font-size:.8rem;font-weight:600;color:var(--text2);}
.topbar-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--bg);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;flex-shrink:0;}

/* ── Theme switcher ───────────────────────────────────────────── */
.multi-theme-sw{position:relative;}
.multi-theme-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s;}
.multi-theme-btn:hover{border-color:var(--accent);}
.multi-theme-dd{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:6px;display:none;flex-direction:column;gap:2px;min-width:130px;box-shadow:0 12px 32px rgba(0,0,0,.2);z-index:9999;}
.multi-theme-dd.open{display:flex;}
.multi-theme-opt{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:.82rem;font-weight:600;color:var(--text2);transition:background .12s;border:1px solid transparent;}
.multi-theme-opt:hover{background:var(--bg3);color:var(--text);}
.multi-theme-opt.active{background:rgba(0,229,200,.08);border-color:rgba(0,229,200,.2);color:var(--accent);}
.mth-swatch{width:14px;height:14px;border-radius:50%;flex-shrink:0;}

/* ── Main layout ──────────────────────────────────────────────── */
#multi-main{max-width:860px;margin:0 auto;padding:32px 20px 60px;}

/* ── Utility ──────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 22px;border-radius:var(--radius-sm);border:none;font-family:var(--font-ui);font-size:.88rem;font-weight:700;cursor:pointer;transition:all .18s;white-space:nowrap;}
.btn:disabled{opacity:.45;cursor:not-allowed;}
.btn-primary{background:var(--accent);color:var(--bg);}
.btn-primary:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 0 20px rgba(0,229,200,.3);transform:translateY(-1px);}
.btn-secondary{background:var(--bg3);color:var(--text2);border:1px solid var(--border);}
.btn-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent);}
.btn-sm{padding:6px 14px;font-size:.78rem;}
.btn-xl{padding:16px 40px;font-size:1.1rem;width:100%;border-radius:var(--radius);}
.form-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-family:var(--font-ui);font-size:.95rem;color:var(--text);outline:none;transition:border-color .2s;}
.form-input:focus{border-color:var(--accent);}
.form-input::placeholder{color:var(--text3);}

/* ── Screen visibility ────────────────────────────────────────── */
.screen{display:none;}
.screen.active{display:block;}

/* ── Toast ────────────────────────────────────────────────────── */
#multi-toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.multi-toast{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 18px;font-size:.85rem;color:var(--text);box-shadow:0 8px 24px rgba(0,0,0,.2);animation:toastIn .3s ease;pointer-events:auto;}
.multi-toast.success{border-color:rgba(0,214,143,.4);color:var(--success);}
.multi-toast.error{border-color:rgba(232,49,90,.4);color:var(--danger);}
.multi-toast.warn{border-color:rgba(255,159,67,.4);color:var(--accent2);}
.multi-toast.out{animation:toastOut .3s ease forwards;}
@keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}

/* ═══════════════════════════════════════════════════════════════
   SCREEN 1: ENTRY
   ═══════════════════════════════════════════════════════════════ */
.entry-hero{text-align:center;padding:40px 0 28px;}
.entry-icon{font-size:3.5rem;margin-bottom:12px;}
.entry-hero h1{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--text);margin-bottom:8px;}
.entry-hero h1 span{color:var(--accent);}
.entry-hero p{font-size:.95rem;color:var(--text2);line-height:1.7;}

.entry-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:28px;max-width:440px;margin:0 auto 24px;display:flex;flex-direction:column;gap:16px;}

.entry-name-row{display:flex;align-items:center;gap:12px;}
.entry-avatar{width:44px;height:44px;border-radius:50%;background:var(--accent);color:var(--bg);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;flex-shrink:0;transition:background .2s;}

.entry-mode-row{display:flex;gap:8px;}
.mode-pill{flex:1;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg3);color:var(--text2);font-family:var(--font-ui);font-size:.82rem;font-weight:700;cursor:pointer;transition:all .15s;text-align:center;}
.mode-pill.active{background:var(--accent);border-color:var(--accent);color:var(--bg);}
.mode-pill:hover:not(.active){border-color:var(--accent);color:var(--accent);}

.entry-note{font-size:.75rem;color:var(--text3);text-align:center;}

/* Live stats banner */
.entry-live-stats{display:flex;align-items:center;justify-content:center;gap:0;max-width:440px;margin:0 auto;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.els-item{flex:1;text-align:center;padding:16px 12px;}
.els-num{display:block;font-family:var(--font-mono);font-size:1.3rem;font-weight:700;color:var(--accent);}
.els-lbl{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--text3);margin-top:3px;}
.els-sep{width:1px;height:40px;background:var(--border);flex-shrink:0;}

/* ═══════════════════════════════════════════════════════════════
   SCREEN 2: LOBBY / MATCHMAKING
   ═══════════════════════════════════════════════════════════════ */
.lobby-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px;}
.lobby-status-row{display:flex;align-items:center;gap:10px;font-size:.95rem;font-weight:700;color:var(--text);}

/* Animated pulse dot */
.lobby-pulse{width:10px;height:10px;border-radius:50%;background:var(--accent);position:relative;flex-shrink:0;}
.lobby-pulse::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--accent);animation:lobbypulse 1.4s ease-out infinite;opacity:0;}
@keyframes lobbypulse{0%{transform:scale(.6);opacity:.8}100%{transform:scale(1.6);opacity:0}}

/* Countdown bar */
.lobby-countdown-wrap{margin-bottom:20px;}
.lobby-countdown-track{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;margin-bottom:8px;}
.lobby-countdown-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent3));border-radius:3px;transition:width .1s linear;}
.lobby-countdown-label{font-size:.82rem;color:var(--text2);text-align:right;}
.lobby-countdown-label strong{color:var(--accent);font-family:var(--font-mono);}

/* Player slots in lobby */
.lobby-players{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin-bottom:20px;}
.lobby-slot{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;transition:border-color .2s;}
.lobby-slot.filled{border-color:rgba(0,214,143,.3);}
.lobby-slot.is-me{border-color:rgba(0,229,200,.4);background:rgba(0,229,200,.04);}
.lobby-slot.empty{opacity:.4;border-style:dashed;}
.lobby-slot-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;}
.lobby-slot-name{font-size:.8rem;font-weight:700;color:var(--text);}
.lobby-slot-badge{font-size:.62rem;font-weight:700;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;}
.badge-you{background:rgba(0,229,200,.12);color:var(--accent);}
.badge-ready{background:rgba(0,214,143,.12);color:var(--success);}
.badge-waiting{background:var(--bg4);color:var(--text3);}

/* Text preview */
.lobby-text-preview{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 18px;}
.ltp-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);margin-bottom:10px;}
.ltp-text{font-family:var(--font-mono);font-size:.9rem;color:var(--text2);line-height:1.7;max-height:80px;overflow:hidden;position:relative;}
.ltp-text::after{content:'';position:absolute;bottom:0;left:0;right:0;height:28px;background:linear-gradient(transparent,var(--bg2));}

/* ═══════════════════════════════════════════════════════════════
   SCREEN 3: RACE
   ═══════════════════════════════════════════════════════════════ */
.race-stats-row{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;}
.race-stat-pill{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:6px 14px;}
.rsp-lbl{font-size:.72rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.5px;}
.rsp-val{font-family:var(--font-mono);font-size:.9rem;font-weight:700;color:var(--accent);}

/* Player progress list */
.race-progress-section{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px;}
.rps-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);margin-bottom:12px;}
.rpr-row{display:flex;align-items:center;gap:9px;padding:5px 0;border-bottom:1px solid var(--border);}
.rpr-row:last-child{border-bottom:none;}
.rpr-row.me{background:rgba(0,229,200,.04);margin:0 -16px;padding:5px 16px;border-radius:4px;}
.rpr-pos{width:18px;font-family:var(--font-mono);font-size:.7rem;font-weight:700;color:var(--text3);text-align:right;flex-shrink:0;}
.rpr-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.65rem;flex-shrink:0;}
.rpr-name{width:80px;font-size:.78rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;}
.rpr-name .you-tag{font-size:.58rem;color:var(--accent);font-weight:700;margin-left:3px;}
.rpr-bar-wrap{flex:1;height:8px;background:var(--bg4);border-radius:4px;overflow:hidden;position:relative;}
.rpr-bar-fill{height:100%;border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1);position:relative;}
.rpr-bar-fill::after{content:'🚀';position:absolute;right:-7px;top:50%;transform:translateY(-50%);font-size:.75rem;line-height:1;}
.rpr-wpm{width:52px;text-align:right;font-family:var(--font-mono);font-size:.75rem;font-weight:700;color:var(--accent);flex-shrink:0;}
.rpr-wpm.done{color:var(--success);}
.rpr-finish{font-size:.62rem;padding:2px 6px;border-radius:4px;font-weight:700;flex-shrink:0;}
.fn-1{background:rgba(255,215,0,.15);color:#c8a600;}
.fn-2{background:rgba(192,192,192,.15);color:#888;}
.fn-3{background:rgba(205,127,50,.15);color:#a06020;}
.fn-n{background:var(--bg4);color:var(--text3);}

/* Race text box */
.race-text-box{background:var(--bg2);border:2px solid var(--border);border-radius:var(--radius);padding:20px 22px;margin-bottom:12px;cursor:text;transition:border-color .2s;min-height:100px;}
.race-text-box.active{border-color:var(--accent);}
.race-text-box.finished{border-color:var(--success);}
.race-text{font-family:var(--font-mono);font-size:1.15rem;line-height:2;word-wrap:break-word;word-break:break-word;white-space:normal;}

/* Character-level styling */
.rc{color:var(--text3);position:relative;display:inline-block;}
.rc.correct{color:var(--correct);}
.rc.wrong{color:var(--wrong);background:rgba(232,49,90,.1);border-radius:2px;}

/* ── Caret styles (reads data-caret from body) ── */
/* Default = block */
.rc.cursor{background:var(--cursor);color:var(--bg);border-radius:2px;animation:cur-blink .75s step-end infinite;}

body[data-caret="line"] .rc.cursor{background:transparent;color:var(--text);}
body[data-caret="line"] .rc.cursor::after{content:'';position:absolute;left:0;top:14%;bottom:14%;width:2px;background:var(--cursor);border-radius:2px;animation:cur-blink .75s step-end infinite;}

body[data-caret="block"] .rc.cursor{background:var(--cursor);color:var(--bg);border-radius:2px;animation:cur-blink .75s step-end infinite;}

body[data-caret="underline"] .rc.cursor{background:transparent;color:var(--text);}
body[data-caret="underline"] .rc.cursor::after{content:'';position:absolute;left:0;right:0;bottom:1px;height:2px;background:var(--cursor);border-radius:2px;animation:cur-blink .75s step-end infinite;}

body[data-caret="word"] .rc.cursor{background:var(--cursor);color:var(--bg);border-radius:3px 0 0 3px;}
body[data-caret="word"] .rc.word-ahead{background:rgba(0,179,160,.13);color:var(--text);border-radius:0;}
body[data-caret="word"] .rc.word-last{border-radius:0 3px 3px 0;}
body[data-caret="word"] .rc.cursor::after{display:none;}

@keyframes cur-blink{0%,100%{opacity:1}50%{opacity:0}}

/* Words wrap naturally */
.race-text .word{display:inline;white-space:nowrap;}
.race-text .word-space{display:inline;white-space:normal;color:transparent;user-select:none;}

/* Input row */
.race-input-wrap{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:6px;transition:border-color .2s;}
.race-input-wrap.active{border-color:var(--accent);}
.race-input-icon{color:var(--text3);font-size:1rem;flex-shrink:0;}
#race-input{flex:1;background:transparent;border:none;font-family:var(--font-mono);font-size:.95rem;color:var(--text);outline:none;caret-color:var(--accent);}
#race-input::placeholder{color:var(--text3);}
#race-input:disabled{opacity:.5;cursor:not-allowed;}
.race-input-hint{font-size:.68rem;color:var(--text3);font-family:var(--font-mono);white-space:nowrap;}

/* Blocked-space shake */
@keyframes inp-shake{0%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}100%{transform:translateX(0)}}
.race-input-wrap.shake{animation:inp-shake .35s ease;border-color:var(--danger)!important;}
.word-error-hint{min-height:18px;font-size:.72rem;color:var(--danger);font-family:var(--font-mono);text-align:right;transition:opacity .2s;}

/* ═══════════════════════════════════════════════════════════════
   SCREEN 4: RESULTS
   ═══════════════════════════════════════════════════════════════ */
.results-header{text-align:center;padding:28px 0 8px;}
.results-title{font-size:1.6rem;font-weight:800;color:var(--text);}
.results-my-result{font-size:1rem;color:var(--text2);margin-top:6px;}

/* Podium */
.results-podium{display:flex;align-items:flex-end;justify-content:center;gap:12px;margin:24px 0 28px;flex-wrap:wrap;}
.podium-place{display:flex;flex-direction:column;align-items:center;gap:7px;}
.podium-avatar{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.15rem;}
.podium-name{font-size:.8rem;font-weight:700;color:var(--text);max-width:80px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.podium-wpm{font-family:var(--font-mono);font-size:.85rem;font-weight:700;color:var(--accent);}
.podium-block{border-radius:8px 8px 0 0;width:76px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;}
.podium-1 .podium-block{height:88px;background:rgba(255,215,0,.12);border:1px solid rgba(255,215,0,.25);}
.podium-2 .podium-block{height:62px;background:rgba(192,192,192,.1);border:1px solid rgba(192,192,192,.2);}
.podium-3 .podium-block{height:46px;background:rgba(205,127,50,.1);border:1px solid rgba(205,127,50,.2);}

/* Table */
.results-table-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:24px;}
.results-table{width:100%;border-collapse:collapse;font-size:.85rem;}
.results-table th{text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text3);padding:10px 14px;border-bottom:1px solid var(--border);}
.results-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text2);}
.results-table tr:last-child td{border-bottom:none;}
.results-table tr.me-row td{background:rgba(0,229,200,.04);color:var(--text);}
.rt-rank{font-family:var(--font-mono);font-weight:700;}
.rt-wpm{font-family:var(--font-mono);color:var(--accent);font-weight:700;}
.rt-acc{font-family:var(--font-mono);color:var(--text2);}

.results-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ═══════════════════════════════════════════════════════════════
   COUNTDOWN OVERLAY
   ═══════════════════════════════════════════════════════════════ */
#countdown-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.65);
  backdrop-filter:blur(10px);
  z-index:5000;display:none;
  align-items:center;justify-content:center;flex-direction:column;gap:12px;
}
[data-theme="light"] #countdown-overlay{background:rgba(244,245,251,.85);}
#countdown-overlay.show{display:flex;}
.countdown-num{
  font-family:var(--font-mono);
  font-size:clamp(5rem,14vw,9rem);
  font-weight:700;color:var(--accent);
  line-height:1;
  animation:cdPop .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes cdPop{from{transform:scale(2.2);opacity:0}to{transform:scale(1);opacity:1}}
.countdown-label{font-size:1rem;color:var(--text2);font-weight:600;}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:600px){
  #multi-main{padding:16px 12px 48px;}
  .lobby-players{grid-template-columns:repeat(2,1fr);}
  .race-text{font-size:1rem;}
  .results-podium{gap:6px;}
  .podium-block{width:60px;}
  .rpr-name{width:60px;}
  #multi-topbar{padding:0 14px;gap:10px;}
}
