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

.sk-app {
  --bg-0:#0a0a0f; --bg-1:#12121a; --bg-2:#1a1a26; --bg-3:#22223a; --border:#2e2e4a;
  --pink:#ff2d78; --yellow:#ffd600; --orange:#ff7c00; --green:#00c853; --red:#f44336;
  --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;
  font-family:var(--font-body); background:var(--bg-0); color:var(--text-1);
  min-height:100vh; overflow-x:hidden; box-sizing:border-box;
}
.sk-app *,.sk-app *::before,.sk-app *::after{box-sizing:border-box;}
.sk-screen{display:none;animation:sk-fade .25s ease;}
.sk-screen--active{display:block;}
@keyframes sk-fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

/* ── Bebas headings ─────────────────────────── */
.sk-card h2,.sk-card h3,.sk-card--action h3,
.sk-waiting__header h2,.sk-rules-card h3,
.sk-choosing__title,.sk-reveal__title,.sk-gameover__title {
  font-family:var(--font-display); letter-spacing:1px;
}
.sk-card h2{font-size:clamp(28px,7vw,40px);margin:0 0 20px;}
.sk-card h3,.sk-card--action h3{font-size:22px;margin:0 0 6px;}
.sk-waiting__header h2{font-size:clamp(28px,7vw,40px);}
.sk-choosing__title{font-size:clamp(32px,8vw,52px);color:var(--pink);margin:0 0 8px;}
.sk-reveal__title{font-size:clamp(36px,9vw,56px);color:var(--pink);margin:0 0 16px;}
.sk-gameover__title{font-size:clamp(40px,10vw,72px);background:linear-gradient(90deg,var(--pink),#ff80b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 24px;}

/* ── Logo ───────────────────────────────────── */
.sk-lobby{max-width:700px;margin:0 auto;padding:40px 20px 120px;}
.sk-logo{text-align:center;margin-bottom:40px;}
.sk-logo__icon svg{filter:drop-shadow(0 0 16px rgba(255,45,120,.5));animation:sk-pulse 2.5s ease-in-out infinite;}
@keyframes sk-pulse{0%,100%{filter:drop-shadow(0 0 16px rgba(255,45,120,.4));}50%{filter:drop-shadow(0 0 32px rgba(255,45,120,.85));}}
.sk-logo__title{font-family:var(--font-display);font-size:clamp(52px,12vw,88px);letter-spacing:4px;margin:0;background:linear-gradient(90deg,var(--pink),var(--yellow));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.sk-logo__tagline{color:var(--text-2);font-size:13px;margin-top:6px;}

/* ── Shared components ──────────────────────── */
.sk-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;}
.sk-card--action{text-align:center;}
.sk-card--action .sk-card__icon{font-size:36px;margin-bottom:8px;}
.sk-card--action p{color:var(--text-2);font-size:13px;margin:0 0 20px;}
.sk-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;}
.sk-input:focus{border-color:var(--pink);}
.sk-input--large{font-size:18px;padding:14px 16px;}
.sk-input--code{font-family:var(--font-display);font-size:28px;letter-spacing:6px;text-align:center;text-transform:uppercase;}
.sk-select{width:100%;padding:9px 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;}
.sk-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;}
.sk-btn--primary{background:linear-gradient(135deg,var(--pink),#ff6ba8);color:#fff;font-weight:700;box-shadow:0 4px 16px rgba(255,45,120,.3);}
.sk-btn--primary:hover{box-shadow:0 6px 24px rgba(255,45,120,.5);transform:translateY(-1px);}
.sk-btn--secondary{background:var(--bg-2);border:1px solid var(--border);color:var(--text-1);}
.sk-btn--secondary:hover{border-color:var(--pink);}
.sk-btn--ghost{background:transparent;border:1px solid var(--border);color:var(--text-2);}
.sk-btn--ghost:hover{border-color:var(--text-2);color:var(--text-1);}
.sk-btn--lg{padding:14px 32px;font-size:16px;width:100%;}
.sk-btn--sm{padding:7px 14px;font-size:12px;}
.sk-btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;}
.sk-card .sk-input + .sk-btn,.sk-card .sk-input--code + .sk-btn,.sk-card .sk-input--large + .sk-btn{margin-top:14px;}
.sk-hint{font-size:11px;color:var(--text-3);}

/* ── Join/Create ────────────────────────────── */
.sk-join-create__top{display:flex;align-items:center;gap:14px;margin-bottom:24px;flex-wrap:wrap;}
.sk-two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;}
@media(max-width:560px){.sk-two-col{grid-template-columns:1fr;}}
.sk-create-options{display:flex;flex-direction:column;gap:11px;margin-bottom:20px;text-align:left;}
.sk-create-options label{font-size:12px;color:var(--text-2);display:flex;flex-direction:column;gap:4px;}

/* ── Waiting ────────────────────────────────── */
.sk-waiting{max-width:640px;margin:0 auto;padding:40px 20px 120px;}
.sk-waiting__header{text-align:center;margin-bottom:28px;}
.sk-room-code-display{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px;}
.sk-code-badge{font-family:var(--font-display);font-size:36px;letter-spacing:6px;color:var(--pink);}
.sk-player-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:24px;}
.sk-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;}
.sk-rules-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:24px;}
.sk-rules-card h3{margin:0 0 12px;font-size:20px;color:var(--pink);}
.sk-rules-card ul{margin:0;padding-left:20px;color:var(--text-2);font-size:13px;line-height:2;}
.sk-waiting__footer{text-align:center;}

/* ── Choosing screen ────────────────────────── */
.sk-choosing{max-width:600px;margin:0 auto;padding:60px 20px;text-align:center;}
.sk-choosing__sub{color:var(--text-2);font-size:14px;margin:0 0 32px;}
.sk-word-options{display:flex;flex-direction:column;gap:14px;margin-bottom:28px;}
@media(min-width:500px){.sk-word-options{flex-direction:row;justify-content:center;}}
.sk-word-option{background:var(--bg-1);border:2px solid var(--border);border-radius:var(--radius-lg);padding:18px 28px;cursor:pointer;font-size:18px;font-family:var(--font-display);letter-spacing:1px;transition:all .2s;color:var(--text-1);flex:1;max-width:200px;}
.sk-word-option:hover{border-color:var(--pink);color:var(--pink);transform:scale(1.04);}
.sk-choosing-timer{font-family:var(--font-display);font-size:40px;color:var(--text-3);}
.sk-choosing-timer.urgent{color:var(--red);}
.sk-waiting-for-drawer{text-align:center;padding:60px 20px;}
.sk-waiting-for-drawer h3{font-family:var(--font-display);font-size:32px;color:var(--text-2);margin-bottom:12px;}
.sk-drawing-dots span{animation:sk-dot 1.4s infinite;display:inline-block;}
.sk-drawing-dots span:nth-child(2){animation-delay:.2s;}
.sk-drawing-dots span:nth-child(3){animation-delay:.4s;}
@keyframes sk-dot{0%,80%,100%{transform:scale(0.6);}40%{transform:scale(1.2);}}

/* ── Drawing layout ─────────────────────────── */
.sk-drawing-layout{display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:1fr 280px;grid-template-areas:"topbar topbar" "canvas sidebar" "toolbar sidebar";gap:0;height:100vh;max-height:100vh;overflow:hidden;}
@media(max-width:700px){
  .sk-drawing-layout{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;grid-template-areas:"topbar" "canvas" "toolbar" "sidebar";height:auto;max-height:none;overflow:visible;width:100%;}
  /* Canvas: use aspect-ratio so it never exceeds viewport width/height on mobile */
  .sk-canvas-wrap{aspect-ratio:4/3;width:100%;height:auto !important;}
  #sk-screen-drawing{overflow-y:auto;overflow-x:hidden;}
}
.sk-draw-topbar{grid-area:topbar;display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--bg-1);border-bottom:1px solid var(--border);}
.sk-draw-hint{flex:1;text-align:center;font-family:var(--font-display);font-size:clamp(18px,4vw,28px);letter-spacing:6px;color:var(--yellow);}
.sk-draw-timer-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.sk-timer-bar{width:80px;height:8px;background:var(--bg-3);border-radius:4px;overflow:hidden;}
.sk-timer-fill{height:100%;width:100%;background:linear-gradient(90deg,var(--pink),var(--yellow));border-radius:4px;}
.sk-timer-fill--warn{background:linear-gradient(90deg,var(--red),var(--orange));}
.sk-timer-num{font-family:var(--font-display);font-size:24px;color:var(--pink);min-width:36px;text-align:right;}
.sk-timer-num--warn{color:var(--red);}
.sk-draw-round{font-size:12px;color:var(--text-2);flex-shrink:0;}

/* Canvas */
.sk-canvas-wrap{grid-area:canvas;position:relative;background:#fff;overflow:hidden;}
#sk-canvas{display:block;width:100%;height:100%;cursor:crosshair;touch-action:none;}
.sk-canvas-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,10,15,.6);pointer-events:none;}
.sk-canvas-overlay span{font-family:var(--font-display);font-size:clamp(24px,6vw,40px);color:#fff;text-align:center;padding:20px;}

/* ── Toolbar — 3 stacked rows: tools / sizes+word / colors ── */
.sk-toolbar{
    grid-area:toolbar;
    display:flex;
    flex-direction:column;
    gap:8px;
    padding:10px 12px 12px;
    background:var(--bg-1);
    border-top:1px solid var(--border);
    /* Prevent toolbar contents from ever causing page-level horizontal scroll */
    overflow:hidden;
    width:100%;
    box-sizing:border-box;
}
/* Row 1: tool buttons */
.sk-toolbar__tools{display:flex;gap:8px;}
/* Row 2: size buttons + word banner — same row */
.sk-toolbar__sizes-row{display:flex;align-items:center;gap:8px;}
.sk-toolbar__sizes{display:flex;gap:6px;}
/* Row 3: colour grid — wraps into multiple rows, never overflows */
.sk-toolbar__colors{
    display:flex;
    flex-wrap:wrap;   /* grid-like wrapping — no horizontal scroll */
    gap:6px;
    width:100%;
}

/* Tool & size buttons — large enough to tap comfortably on mobile */
.sk-tool,.sk-size{
    background:var(--bg-2);
    border:2px solid var(--border);
    border-radius:var(--radius);
    width:48px;height:48px;
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;
    font-size:24px;
    transition:all .15s;
    color:var(--text-1);
    flex-shrink:0;
}
.sk-tool--active,.sk-size--active{border-color:var(--pink);background:rgba(255,45,120,.18);}
.sk-tool:hover,.sk-size:hover{border-color:var(--pink);}
.sk-size{font-size:13px;font-family:var(--font-body);font-weight:700;}

/* Colour swatches — sized so 8 fit comfortably per row on a 390px screen */
.sk-color-swatch{
    width:28px;height:28px;
    border-radius:50%;
    border:3px solid transparent;
    cursor:pointer;
    flex-shrink:0;
    transition:transform .12s;
}
.sk-color-swatch:hover,.sk-color-swatch--active{transform:scale(1.2);border-color:#fff;}

/* Word shown to drawer */
.sk-word-banner{margin-left:auto;font-family:var(--font-display);font-size:18px;color:var(--pink);letter-spacing:1px;white-space:nowrap;}

/* Sidebar */
.sk-draw-sidebar{grid-area:sidebar;display:flex;flex-direction:column;background:var(--bg-1);border-left:1px solid var(--border);overflow:hidden;}
@media(max-width:700px){.sk-draw-sidebar{border-left:none;border-top:1px solid var(--border);height:280px;}}
.sk-draw-players{padding:10px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:6px;max-height:180px;overflow-y:auto;}
.sk-draw-player-row{display:flex;align-items:center;gap:8px;padding:4px;border-radius:var(--radius);font-size:12px;}
.sk-draw-player-row--guessed{opacity:.6;}
.sk-draw-player-row__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sk-draw-player-row__score{font-family:var(--font-display);font-size:16px;color:var(--yellow);}
.sk-draw-player-row--drawing{background:rgba(255,45,120,.08);border:1px solid rgba(255,45,120,.2);}

/* Chat */
.sk-chat-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.sk-chat-log{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px;}
.sk-chat-msg{font-size:12px;padding:4px 8px;border-radius:4px;word-break:break-word;}
.sk-chat-msg--correct{background:rgba(0,200,83,.12);color:var(--green);font-weight:700;}
.sk-chat-msg--close{color:var(--yellow);}
.sk-chat-msg--system{color:var(--text-3);font-style:italic;}
.sk-chat-msg--wrong{background:rgba(244,67,54,.10);color:#ff6b6b;}
.sk-chat-msg--mine{color:var(--text-2);}
.sk-chat-msg__name{color:var(--pink);margin-right:4px;}
.sk-chat-input-row{display:flex;gap:6px;padding:8px;}
.sk-chat-input{flex:1;padding:8px 10px;font-size:13px;}
.sk-guessed-banner{padding:8px;text-align:center;font-size:12px;color:var(--green);background:rgba(0,200,83,.08);border-top:1px solid rgba(0,200,83,.2);}

/* ── Reveal ──────────────────────────────────── */
.sk-reveal{max-width:600px;margin:0 auto;padding:48px 20px 120px;text-align:center;}
.sk-reveal__word{font-family:var(--font-display);font-size:clamp(40px,10vw,68px);color:var(--pink);letter-spacing:3px;margin-bottom:28px;}
.sk-reveal__scores{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;}
.sk-reveal-score-row{display:flex;align-items:center;gap:12px;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:10px 16px;font-size:14px;}
.sk-reveal-score-row__name{flex:1;}
.sk-reveal-score-row__pts{font-family:var(--font-display);font-size:22px;color:var(--pink);}
.sk-reveal-score-row__delta{font-size:13px;color:var(--green);}
.sk-reveal__next{font-size:14px;color:var(--text-2);}

/* ── Game over ────────────────────────────────── */
.sk-gameover{max-width:560px;margin:0 auto;padding:48px 20px 120px;text-align:center;}
.sk-gameover__trophy{font-size:80px;margin-bottom:8px;animation:sk-trophy .6s cubic-bezier(.175,.885,.32,1.275);}
@keyframes sk-trophy{from{transform:scale(0) rotate(-20deg);}to{transform:scale(1) rotate(0);}}
.sk-gameover__board{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;}
.sk-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);}
.sk-final-row--1st{border-color:var(--pink);}
.sk-final-rank{font-family:var(--font-display);font-size:24px;min-width:32px;}
.sk-final-name{flex:1;text-align:left;}
.sk-final-score{font-family:var(--font-display);font-size:24px;color:var(--pink);}
.sk-gameover__actions{display:flex;flex-direction:column;gap:12px;}

/* ── Leaderboard ─────────────────────────────── */
.sk-global-lb{max-width:560px;margin:0 auto;padding:40px 20px 120px;}
.sk-global-lb h2{font-family:var(--font-display);font-size:40px;letter-spacing:2px;margin:0 0 20px;}
.sk-lb-tabs{display:flex;gap:8px;margin-bottom:20px;}
.sk-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;}
.sk-lb-tab--active{background:var(--pink);border-color:var(--pink);color:#fff;font-weight:700;}
.sk-lb-list{display:flex;flex-direction:column;gap:8px;}
.sk-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;}
.sk-lb-rank{font-family:var(--font-display);font-size:20px;min-width:28px;color:var(--text-2);}
.sk-lb-name{flex:1;font-size:14px;}
.sk-lb-score{font-family:var(--font-display);font-size:20px;color:var(--pink);}

/* ── Nav / Reactions / Util ──────────────────── */
.sk-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);}
.sk-nav__btn{background:transparent;border:none;color:var(--text-2);font-size:20px;cursor:pointer;padding:6px;}
.sk-nav__center{display:flex;align-items:center;gap:8px;}
.sk-nav__name{font-size:13px;color:var(--text-2);}
.sk-reaction-wrap{position:relative;}
.sk-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:sk-fade .15s ease;white-space:nowrap;}
.sk-reaction-btn{background:transparent;border:none;width:48px;height:48px;font-size:26px;cursor:pointer;padding:6px 4px;border-radius:8px;transition:transform .1s;line-height:1;display:flex;align-items:center;justify-content:center;}
.sk-reaction-btn:hover{transform:scale(1.15);}
.sk-nav-react-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius);font-size:20px;cursor:pointer;padding:6px 10px;}
.sk-reaction-floats{position:fixed;bottom:70px;right:16px;pointer-events:none;z-index:200;display:flex;flex-direction:column-reverse;gap:4px;width:120px;}
.sk-reaction-float{font-size:28px;animation:sk-float 3s ease-out forwards;text-align:right;}
@keyframes sk-float{0%{opacity:1;transform:translateY(0);}100%{opacity:0;transform:translateY(-120px);}}
.sk-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;}
.sk-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--pink);border-radius:50%;animation:sk-spin .7s linear infinite;}
@keyframes sk-spin{to{transform:rotate(360deg);}}
.sk-loading p{color:var(--text-2);font-size:14px;}
.sk-toast-container{position:fixed;top:16px;right:16px;z-index:600;display:flex;flex-direction:column;gap:8px;}
.sk-toast{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:13px;max-width:300px;animation:sk-fade .2s ease;}
.sk-toast--success{border-color:rgba(0,200,83,.4);color:var(--green);}
.sk-toast--error{border-color:rgba(244,67,54,.4);color:var(--red);}
.sk-toast--info{border-color:rgba(255,45,120,.3);color:var(--pink);}
.sk-score-pop{position:fixed;pointer-events:none;font-family:var(--font-display);font-size:32px;color:var(--green);text-shadow:0 0 20px var(--green);animation:sk-scorepop 1.2s ease-out forwards;z-index:300;}
@keyframes sk-scorepop{0%{opacity:1;transform:translateY(0) scale(1);}100%{opacity:0;transform:translateY(-80px) scale(1.3);}}
