@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Mono:wght@300;400;500&display=swap');

.ss-app {
  --bg-0:#0a0a0f; --bg-1:#12121a; --bg-2:#1a1a26; --bg-3:#22223a; --border:#2e2e4a;
  --orange:#ff7c00; --yellow:#ffd600; --green:#00c853; --green-dim:#00a846;
  --red:#f44336; --red-dim:#c62828; --text-1:#f0f0ff; --text-2:#9090b8; --text-3:#5050a0;
  --font-display:'Bebas Neue','Impact',sans-serif; --font-body:'DM Mono','Fira Code',monospace;
  --radius:8px; --radius-lg:14px; --shadow:0 4px 24px rgba(0,0,0,.5);
  font-family:var(--font-body); background:var(--bg-0); color:var(--text-1);
  min-height:100vh; position:relative; overflow-x:hidden; box-sizing:border-box;
}
.ss-app *,.ss-app *::before,.ss-app *::after{box-sizing:border-box;}
.ss-screen{display:none;animation:ss-fadein .25s ease;}
.ss-screen--active{display:block;}
@keyframes ss-fadein{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* ── Lobby ─────────────────────────────── */
.ss-lobby{max-width:700px;margin:0 auto;padding:40px 20px 120px;}
.ss-logo{text-align:center;margin-bottom:44px;}
.ss-logo__icon{font-size:56px;line-height:1;filter:drop-shadow(0 0 20px var(--orange));animation:ss-pulse 2.5s ease-in-out infinite;}
@keyframes ss-pulse{0%,100%{filter:drop-shadow(0 0 20px var(--orange));}50%{filter:drop-shadow(0 0 40px var(--orange));}}
.ss-logo__title{font-family:var(--font-display);font-size:clamp(52px,12vw,88px);letter-spacing:4px;margin:0;background:linear-gradient(90deg,var(--orange),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.ss-logo__tagline{color:var(--text-2);font-size:13px;margin-top:8px;}
.ss-lobby-lb-btn{margin-top:16px;}

/* ── Bebas Neue for all game headings ───── */
.ss-card h2,.ss-card h3,.ss-card--action h3,
.ss-waiting__header h2,.ss-rules-card h3,
.ss-modal__header h3,.ss-global-lb h2,
.ss-voting-title,.ss-results-title {
  font-family:var(--font-display);
  letter-spacing:1px;
}
/* Specific sizing so each heading feels right at that scale */
.ss-card h2{font-size:clamp(28px,7vw,40px);margin:0 0 20px;}
.ss-card h3,.ss-card--action h3{font-size:22px;margin:0 0 6px;letter-spacing:.5px;}
.ss-rules-card h3{font-size:20px;}
.ss-waiting__header h2{font-size:clamp(32px,8vw,48px);}
.ss-modal__header h3{font-size:28px;}

/* ── Cards ─────────────────────────────── */
.ss-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;}
.ss-card--action{text-align:center;}
.ss-card--action .ss-card__icon{font-size:36px;margin-bottom:8px;}
.ss-card--action h3{margin:0 0 6px;font-size:18px;}
.ss-card--action p{color:var(--text-2);font-size:13px;margin:0 0 20px;}

/* ── Inputs / Buttons ───────────────────── */
.ss-input{width:100%;padding:12px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-1);font-family:var(--font-body);font-size:15px;outline:none;transition:border-color .15s;}
.ss-input:focus{border-color:var(--orange);box-shadow:0 0 0 2px rgba(255,124,0,.15);}
.ss-input--large{font-size:18px;padding:14px 16px;}
.ss-input--code{font-family:var(--font-display);font-size:28px;letter-spacing:6px;text-align:center;text-transform:uppercase;}
.ss-select{width:100%;padding:10px 12px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-1);font-family:var(--font-body);font-size:13px;outline:none;}
.ss-select:focus{border-color:var(--orange);}
.ss-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 22px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:500;transition:all .15s;text-decoration:none;}
.ss-btn--primary{background:linear-gradient(135deg,var(--orange),#ff9f40);color:#000;font-weight:700;box-shadow:0 4px 16px rgba(255,124,0,.3);}
.ss-btn--primary:hover{box-shadow:0 6px 24px rgba(255,124,0,.5);transform:translateY(-1px);}
.ss-btn--primary:active{transform:scale(.97);}
.ss-btn--secondary{background:var(--bg-2);border:1px solid var(--border);color:var(--text-1);}
.ss-btn--secondary:hover{border-color:var(--orange);}
.ss-btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text-2);}
.ss-btn--ghost:hover{border-color:var(--text-2);color:var(--text-1);}
.ss-btn--lg{padding:14px 32px;font-size:16px;width:100%;}
.ss-btn--sm{padding:7px 14px;font-size:12px;}
.ss-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important;}
/* Gap between input and button inside cards (nickname card, join card) */
.ss-card .ss-input + .ss-btn,.ss-card .ss-input--code + .ss-btn,.ss-card .ss-input--large + .ss-btn{margin-top:14px;}
.ss-credits-badge{display:flex;align-items:center;gap:8px;background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:6px 12px;font-size:12px;color:var(--text-2);}

/* ── Join/Create ────────────────────────── */
.ss-join-create__top{display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap;}
.ss-join-create__welcome{margin:0;font-size:15px;}
.ss-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;}
@media(max-width:560px){.ss-two-col{grid-template-columns:1fr;}}
.ss-create-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;text-align:left;}
.ss-create-options label{font-size:12px;color:var(--text-2);display:flex;flex-direction:column;gap:4px;}
.ss-ai-toggle{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-bottom:16px;text-align:left;}
.ss-toggle-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;}
.ss-toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0;margin-top:2px;}
.ss-toggle-switch::before{content:'';position:absolute;inset:0;background:var(--bg-3);border-radius:11px;transition:background .2s;}
.ss-toggle-switch::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s;}
input:checked~.ss-toggle-switch::before{background:var(--orange);}
input:checked~.ss-toggle-switch::after{transform:translateX(18px);}
.ss-toggle-text{font-size:13px;} .ss-toggle-text small{display:block;color:var(--text-2);font-size:11px;margin-top:2px;}
.ss-ai-theme-wrap{margin-top:12px;} .ss-hint{font-size:11px;color:var(--text-3);}

/* ── Waiting ────────────────────────────── */
.ss-waiting{max-width:640px;margin:0 auto;padding:40px 20px 120px;}
.ss-waiting__header{text-align:center;margin-bottom:28px;}
.ss-waiting__header h2{margin:0 0 12px;font-family:var(--font-display);font-size:32px;letter-spacing:2px;}
.ss-room-code-display{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px;}
.ss-code-badge{font-family:var(--font-display);font-size:36px;letter-spacing:6px;color:var(--orange);}
.ss-player-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:24px;}
.ss-player-chip{display:flex;align-items:center;gap:8px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;font-size:13px;}
.ss-rules-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:24px;}
.ss-rules-card h3{margin:0 0 12px;font-size:15px;color:var(--orange);}
.ss-rules-card ul{margin:0;padding-left:20px;color:var(--text-2);font-size:13px;line-height:2;}
.ss-rules-card li strong{color:var(--text-1);}
.ss-waiting__footer{text-align:center;}
.ss-room-type-badge{font-size:12px;color:var(--text-3);}

/* ── Game (answering) ───────────────────── */
.ss-game-layout{max-width:780px;margin:0 auto;padding:16px 16px 120px;}
.ss-game-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px;}
.ss-round-info,.ss-submit-progress{font-size:13px;color:var(--text-2);}
.ss-theme-badge{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:12px;color:var(--orange);}
.ss-letter-wrap{text-align:center;margin-bottom:20px;}
.ss-letter-reveal{font-family:var(--font-display);font-size:clamp(80px,20vw,140px);line-height:1;color:var(--yellow);text-shadow:0 0 40px rgba(255,214,0,.5),0 0 80px rgba(255,214,0,.2);animation:ss-letter-in .5s cubic-bezier(.175,.885,.32,1.275) forwards;display:inline-block;}
@keyframes ss-letter-in{from{transform:scale(3) rotate(-10deg);opacity:0;}to{transform:scale(1) rotate(0);opacity:1;}}
.ss-letter-reveal--counting{color:var(--text-2);text-shadow:none;font-size:clamp(60px,15vw,100px);}
.ss-letter-label{font-size:12px;color:var(--text-3);margin-top:6px;}
.ss-timer-wrap{margin-bottom:20px;display:flex;align-items:center;gap:12px;}
.ss-timer-bar{flex:1;height:8px;background:var(--bg-3);border-radius:4px;overflow:hidden;}
.ss-timer-fill{height:100%;width:100%;background:linear-gradient(90deg,var(--orange),var(--yellow));border-radius:4px;transition:width 1s linear,background 1s;}
.ss-timer-fill--warning{background:linear-gradient(90deg,var(--red),#ff7c00);}
.ss-timer-count{font-family:var(--font-display);font-size:28px;color:var(--orange);min-width:44px;text-align:center;}
.ss-timer-count--warning{color:var(--red);animation:ss-blink .5s step-end infinite;}
@keyframes ss-blink{0%,100%{opacity:1;}50%{opacity:.4;}}
.ss-category-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px;}
@media(max-width:540px){.ss-category-grid{grid-template-columns:1fr;}}
.ss-category-item{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;transition:border-color .15s;}
.ss-category-item--valid{border-color:rgba(0,200,83,.4);}
.ss-category-item--invalid{border-color:rgba(244,67,54,.4);}
.ss-category-label{font-size:11px;color:var(--orange);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.ss-category-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text-1);font-family:var(--font-body);font-size:14px;padding:4px 0;outline:none;transition:border-color .15s;}
.ss-category-input:focus{border-bottom-color:var(--orange);}
.ss-category-input::placeholder{color:var(--text-3);}
.ss-answers-status{text-align:center;margin-bottom:20px;display:flex;flex-direction:column;align-items:center;gap:10px;}
.ss-locked-msg{color:var(--green);font-size:14px;padding:10px 16px;border:1px solid rgba(0,200,83,.2);border-radius:var(--radius);background:rgba(0,200,83,.06);}
.ss-sidebar{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;}
.ss-sidebar__title{font-size:13px;color:var(--text-2);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px;}
.ss-leaderboard-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px;}
.ss-leaderboard-row:last-child{border-bottom:none;}
.ss-leaderboard-row__rank{color:var(--text-3);min-width:20px;}
.ss-leaderboard-row__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ss-leaderboard-row__score{color:var(--orange);font-weight:700;}
.ss-leaderboard-row--me{background:rgba(255,124,0,.06);border-radius:4px;padding:6px 4px;}

/* ── Voting screen ───────────────────────── */
.ss-voting-layout{max-width:700px;margin:0 auto;padding:20px 16px 120px;}
.ss-voting-header{text-align:center;margin-bottom:24px;}
.ss-voting-meta{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px;}
.ss-voting-round{font-size:13px;color:var(--text-2);}
.ss-voting-title{font-family:var(--font-display);font-size:40px;letter-spacing:2px;margin:0 0 8px;}
.ss-voting-subtitle{color:var(--text-2);font-size:13px;margin:0 0 12px;}
.ss-voting-progress{font-size:13px;color:var(--text-2);}
.ss-letter-badge{font-family:var(--font-display);font-size:28px;color:var(--yellow);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:2px 14px;display:inline-block;}

/* Voting grid */
.ss-voting-grid{display:flex;flex-direction:column;gap:16px;margin-bottom:28px;}
.ss-vote-category{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;}
.ss-vote-cat-header{background:var(--bg-2);padding:10px 16px;font-size:12px;color:var(--orange);text-transform:uppercase;letter-spacing:.5px;font-weight:600;}
.ss-vote-rows{display:flex;flex-direction:column;}

/* Single answer vote row */
.ss-vote-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);}
.ss-vote-row:last-child{border-bottom:none;}
.ss-vote-row__avatar{flex-shrink:0;}
.ss-vote-row__name{font-size:11px;color:var(--text-2);min-width:44px;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ss-vote-row__answer{flex:1;font-size:13px;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ss-vote-row__pts{font-family:var(--font-display);font-size:18px;min-width:40px;text-align:right;transition:color .2s;flex-shrink:0;}
.ss-vote-row__pts--full{color:var(--green);}
.ss-vote-row__pts--partial{color:var(--yellow);}
.ss-vote-row__pts--zero{color:var(--text-3);}

/* Mine badge */
.ss-vote-row--mine .ss-vote-row__answer{color:var(--yellow);}
.ss-vote-badge{font-size:11px;padding:3px 8px;border-radius:10px;font-weight:500;}
.ss-vote-badge--mine{background:rgba(255,214,0,.1);color:var(--yellow);border:1px solid rgba(255,214,0,.2);}
.ss-vote-badge--invalid{background:rgba(244,67,54,.08);color:#ff6b6b;border:1px solid rgba(244,67,54,.2);}

/* The approve/reject toggle */
.ss-vote-toggle{position:relative;width:52px;height:28px;flex-shrink:0;cursor:pointer;border:none;background:none;padding:0;}
.ss-vote-toggle__track{position:absolute;inset:0;border-radius:14px;transition:background .2s,box-shadow .2s;}
.ss-vote-toggle__thumb{position:absolute;top:4px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s,box-shadow .2s;box-shadow:0 1px 4px rgba(0,0,0,.4);}
/* Approved state (default) */
.ss-vote-toggle[data-approved="true"] .ss-vote-toggle__track{background:var(--green);box-shadow:0 0 8px rgba(0,200,83,.3);}
.ss-vote-toggle[data-approved="true"] .ss-vote-toggle__thumb{transform:translateX(28px);}
/* Rejected state */
.ss-vote-toggle[data-approved="false"] .ss-vote-toggle__track{background:var(--red);box-shadow:0 0 8px rgba(244,67,54,.3);}
.ss-vote-toggle[data-approved="false"] .ss-vote-toggle__thumb{transform:translateX(4px);}

.ss-voting-footer{text-align:center;}

/* ── Results ────────────────────────────── */
.ss-results-layout{max-width:860px;margin:0 auto;padding:20px 16px 120px;}
.ss-results-header{text-align:center;margin-bottom:24px;}
.ss-results-title{font-family:var(--font-display);font-size:40px;letter-spacing:2px;margin:8px 0 12px;}
.ss-results-auto{font-size:13px;color:var(--text-2);min-height:20px;}
.ss-results-grid{display:flex;flex-direction:column;gap:16px;}
.ss-result-category{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;animation:ss-fadein .3s ease;}
.ss-result-category__header{background:var(--bg-2);padding:10px 16px;font-size:13px;color:var(--orange);text-transform:uppercase;letter-spacing:.5px;}
.ss-result-answers{display:flex;flex-direction:column;}
.ss-result-answer{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);font-size:14px;}
.ss-result-answer:last-child{border-bottom:none;}
.ss-result-answer__name{color:var(--text-2);font-size:12px;min-width:80px;}
.ss-result-answer__text{flex:1;font-weight:500;}
.ss-result-answer__score{font-family:var(--font-display);font-size:20px;min-width:54px;text-align:right;}
.ss-result-answer__meta{font-size:11px;color:var(--text-3);min-width:90px;text-align:right;}
.ss-result-answer--full .ss-result-answer__text,.ss-result-answer--full .ss-result-answer__score{color:var(--green);}
.ss-result-answer--partial .ss-result-answer__text,.ss-result-answer--partial .ss-result-answer__score{color:var(--yellow);}
.ss-result-answer--zero .ss-result-answer__text{color:var(--text-3);text-decoration:line-through;}
.ss-result-answer--zero .ss-result-answer__score{color:var(--text-3);}
.ss-result-answer--auto0 .ss-result-answer__text,.ss-result-answer--auto0 .ss-result-answer__score{color:var(--text-3);}

/* ── Game over ───────────────────────────── */
.ss-gameover{max-width:560px;margin:0 auto;padding:48px 20px 120px;text-align:center;}
.ss-gameover__trophy{font-size:80px;margin-bottom:8px;animation:ss-trophy .6s cubic-bezier(.175,.885,.32,1.275);}
@keyframes ss-trophy{from{transform:scale(0) rotate(-20deg);}to{transform:scale(1) rotate(0);}}
.ss-gameover__title{font-family:var(--font-display);font-size:clamp(40px,10vw,72px);letter-spacing:3px;margin:0 0 28px;background:linear-gradient(90deg,var(--orange),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.ss-final-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;}
.ss-final-row--1st{border-color:var(--yellow);background:rgba(255,214,0,.06);}
.ss-final-row--2nd{border-color:#a8a8a8;}
.ss-final-row--3rd{border-color:#cd7f32;}
.ss-final-rank{font-family:var(--font-display);font-size:24px;min-width:32px;}
.ss-final-name{flex:1;text-align:left;font-size:15px;font-weight:500;}
.ss-final-score{font-family:var(--font-display);font-size:24px;color:var(--orange);}
.ss-gameover__actions{display:flex;flex-direction:column;gap:12px;}

/* ── Global leaderboard ─────────────────── */
.ss-global-lb{max-width:600px;margin:0 auto;padding:40px 20px 120px;}
.ss-global-lb h2{font-family:var(--font-display);font-size:40px;letter-spacing:2px;margin:0 0 20px;}
.ss-lb-tabs{display:flex;gap:8px;margin-bottom:20px;}
.ss-lb-tab{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 20px;font-family:var(--font-body);color:var(--text-2);cursor:pointer;font-size:13px;}
.ss-lb-tab--active{background:var(--orange);border-color:var(--orange);color:#000;font-weight:700;}
.ss-lb-list{display:flex;flex-direction:column;gap:8px;}
.ss-lb-entry{display:flex;align-items:center;gap:12px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;}
.ss-lb-rank{font-family:var(--font-display);font-size:20px;min-width:28px;color:var(--text-2);}
.ss-lb-name{flex:1;font-size:14px;}
.ss-lb-score{font-family:var(--font-display);font-size:20px;color:var(--orange);}
.ss-lb-games{font-size:11px;color:var(--text-3);}
.ss-your-rank{text-align:center;color:var(--text-2);font-size:13px;margin-top:16px;}
.ss-back-btn{display:inline-flex;align-items:center;gap:6px;margin-bottom:20px;}

/* ── Modal ───────────────────────────────── */
.ss-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;}
.ss-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);}
.ss-modal__box{position:relative;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:440px;}
.ss-modal__close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:var(--text-2);font-size:18px;cursor:pointer;}
.ss-modal__header{text-align:center;margin-bottom:20px;}
.ss-modal__icon{font-size:40px;display:block;margin-bottom:8px;}
.ss-modal__header h3{margin:0 0 8px;}
.ss-modal__header p{color:var(--text-2);font-size:13px;margin:0;}
.ss-credits-balance-row{text-align:center;font-size:13px;color:var(--text-2);margin-bottom:16px;}
.ss-credits-balance-row strong{color:var(--orange);}
.ss-packages{display:flex;flex-direction:column;gap:10px;}
.ss-package{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.ss-package--popular{border-color:var(--orange);}
.ss-package__label{font-size:14px;font-weight:600;}
.ss-package__sublabel{font-size:11px;color:var(--text-2);}
.ss-package__price{font-family:var(--font-display);font-size:22px;color:var(--orange);}
.ss-modal__small{font-size:11px;color:var(--text-3);text-align:center;margin-top:16px;}

/* ── Public lobby ────────────────────────── */
.ss-public-lobby{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;}
.ss-public-lobby h3{margin:0 0 12px;font-size:15px;}
.ss-public-room{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);gap:10px;}
.ss-public-room:last-child{border-bottom:none;}
.ss-public-room__code{font-family:var(--font-display);font-size:18px;letter-spacing:2px;color:var(--orange);}
.ss-public-room__info{font-size:12px;color:var(--text-2);}

/* ── Nav / Reactions ─────────────────────── */
.ss-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-1);border-top:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;justify-content:space-between;z-index:100;backdrop-filter:blur(10px);}
.ss-nav__btn{background:transparent;border:none;color:var(--text-2);font-size:20px;cursor:pointer;padding:6px;}
.ss-nav__center{display:flex;align-items:center;gap:8px;}
.ss-nav__name{font-size:13px;color:var(--text-2);}
.ss-nav__right{display:flex;align-items:center;}
.ss-reaction-nav-wrap{position:relative;}
.ss-reaction-picker{position:absolute;bottom:100%;right:0;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px 14px;display:flex;gap:8px;margin-bottom:8px;animation:ss-fadein .15s ease;white-space:nowrap;}
.ss-reaction-btn{width:48px;height:48px;background:transparent;border:none;font-size:26px;cursor:pointer;padding:6px 4px;border-radius:8px;transition:transform .1s;line-height:1;}
.ss-reaction-btn:hover{transform:scale(1.15);}
.ss-nav-react-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius);font-size:20px;cursor:pointer;padding:6px 10px;}
.ss-reaction-floats{position:fixed;bottom:70px;right:16px;pointer-events:none;z-index:200;display:flex;flex-direction:column-reverse;gap:4px;width:120px;}
.ss-reaction-float{font-size:28px;animation:ss-float 3s ease-out forwards;text-align:right;}
@keyframes ss-float{0%{opacity:1;transform:translateY(0);}100%{opacity:0;transform:translateY(-120px);}}
.ss-loading{position:fixed;inset:0;background:rgba(10,10,15,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:500;gap:16px;}
.ss-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:ss-spin .7s linear infinite;}
@keyframes ss-spin{to{transform:rotate(360deg);}}
.ss-loading p{color:var(--text-2);font-size:14px;}
.ss-toast-container{position:fixed;top:16px;right:16px;z-index:600;display:flex;flex-direction:column;gap:8px;}
.ss-toast{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:13px;max-width:300px;animation:ss-fadein .2s ease;}
.ss-toast--success{border-color:rgba(0,200,83,.4);color:var(--green);}
.ss-toast--error{border-color:rgba(244,67,54,.4);color:var(--red);}
.ss-toast--warning{border-color:rgba(255,214,0,.4);color:var(--yellow);}
.ss-install-banner{position:fixed;bottom:64px;left:0;right:0;background:var(--bg-1);border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;z-index:99;gap:12px;}
.ss-install-banner__content{display:flex;align-items:center;gap:10px;}
.ss-install-banner__icon{font-size:28px;}
.ss-install-banner__text{display:flex;flex-direction:column;}
.ss-install-banner__text strong{font-size:13px;}
.ss-install-banner__text small{font-size:11px;color:var(--text-2);}
.ss-install-banner__actions{display:flex;gap:8px;flex-shrink:0;}
.ss-score-pop{position:fixed;pointer-events:none;font-family:var(--font-display);font-size:28px;color:var(--green);text-shadow:0 0 20px var(--green);animation:ss-scorepop 1.2s ease-out forwards;z-index:300;}
@keyframes ss-scorepop{0%{opacity:1;transform:translateY(0) scale(1);}100%{opacity:0;transform:translateY(-80px) scale(1.3);}}

/* ── Sticky timer bar (answering phase) ──────────────────────────────────── */
#ss-sticky-timer {
  position: fixed; top: 0; left: 0; right: 0; z-index: 9999;
  display: flex; align-items: center; gap: 10px;
  background: var(--bg-1); border-bottom: 1px solid var(--border);
  padding: 6px 16px; box-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.ss-sticky-timer__track {
  flex: 1; height: 6px; background: var(--bg-3); border-radius: 3px; overflow: hidden;
}
.ss-sticky-timer__fill {
  height: 100%; width: 100%;
  background: linear-gradient(90deg, var(--orange), var(--yellow));
  border-radius: 3px;
  /* No CSS transition — RAF updates every frame, transition causes double-animation */
}
.ss-sticky-timer__fill.ss-timer-fill--warning {
  background: linear-gradient(90deg, var(--red), #ff7c00);
}
.ss-sticky-timer__count {
  font-family: var(--font-display); font-size: 20px; color: var(--orange);
  min-width: 36px; text-align: right; line-height: 1;
}
.ss-sticky-timer__count.ss-timer-count--warning { color: var(--red); }
/* Push game content below sticky timer */

/* ── Logo SVG tile hover ─────────────────────────────────────────────────── */
.ss-logo__icon svg { filter: drop-shadow(0 0 16px rgba(255,124,0,.5)); animation: ss-pulse 2.5s ease-in-out infinite; }
