@font-face{font-family:Gilroy;src:url("/assets/fonts/Gilroy-ExtraBold.otf") format("opentype");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:Gilroy;src:url("/assets/fonts/Gilroy-Light.otf") format("opentype");font-weight:300;font-style:normal;font-display:swap}
:root{
  --bg:#16171a;
  --bg-2:#1d1f23;
  --surface:#25272c;
  --surface-2:#2c2e34;
  --raised:#34373e;
  --ink:#f3f4f6;
  --muted:#aeb2bb;
  --faint:#7f828c;
  --line:#34363d;
  --line-2:#3f424a;
  --brand:#4f7cff;        /* clean blue accent */
  --brand-press:#3b67ec;
  --go:#22b07d;           /* green = start / go */
  --go-press:#1c9a6c;
  --gold:#f0b232;
  --red:#ef4761;
  /* kahoot-style answer tile colors */
  --a1:#e4574c;
  --a2:#3c7bf2;
  --a3:#e0a52a;
  --a4:#1f9d6b;
  --sans:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
  --display:Gilroy,var(--sans);
  --r:14px;
  --max:980px;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{min-height:100dvh}
button,input,select{font:inherit}
button{cursor:pointer}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}

/* ---- Lottie preloader ---- */
.mt-preloader-overlay{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:rgba(18,19,22,.92);backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);opacity:1;visibility:visible;transition:opacity .42s cubic-bezier(.22,1,.36,1),visibility .42s cubic-bezier(.22,1,.36,1)}
.mt-preloader-overlay.is-leaving{opacity:0;visibility:hidden;pointer-events:none}
.mt-preloader-card{width:clamp(96px,20vw,128px);height:clamp(96px,20vw,128px);display:grid;place-items:center;border-radius:26px;background:#ffffff;border:1px solid rgba(0,0,0,.06);box-shadow:0 24px 70px rgba(0,0,0,.55);transform:translateY(4px) scale(.97);opacity:0;transition:transform .46s cubic-bezier(.22,1,.36,1),opacity .34s ease}
.mt-preloader-overlay.is-visible .mt-preloader-card{transform:none;opacity:1}
.mt-preloader-overlay.is-leaving .mt-preloader-card{transform:translateY(-4px) scale(.985);opacity:0}
.mt-preloader-lottie{width:80px;height:80px}
.mt-preloader-lottie svg{display:block;width:100%!important;height:100%!important}
.mt-preloader-fallback{width:38px;height:38px;border-radius:50%;border:3px solid rgba(79,124,255,.22);border-top-color:var(--brand);animation:mtSpin .8s linear infinite}
@keyframes mtSpin{to{transform:rotate(360deg)}}

/* flat, calm backdrop — no blobs, no glow */
.bg-stage{position:fixed;inset:0;z-index:-1;background:var(--bg)}
.bg-stage::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 70% at 50% -10%,#22252b 0%,var(--bg) 55%)}
.soft-grad{display:none}
.grid-glow{position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(100% 70% at 50% 0%,#000,transparent 80%)}

/* shell + topbar */
.app-shell{width:min(var(--max),100%);min-height:100dvh;margin:0 auto;padding:14px clamp(14px,3vw,26px) 18px;display:flex;flex-direction:column}
.topbar{height:50px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex:0 0 auto}
.brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:800;color:var(--ink)}
.brand-mark{width:30px;height:30px;display:inline-block;flex:0 0 auto;background:image-set(url("/assets/brand/moodtrue-logo.webp") type("image/webp"),url("/assets/brand/moodtrue-logo.png") type("image/png")) center/contain no-repeat}
.brand-mark.large{width:48px;height:48px}
.brand-word{font-family:var(--sans);font-weight:800;font-size:22px;line-height:1;background:linear-gradient(90deg,#8b24f6 0%,#9d4af8 45%,#b36bf4 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-pill{font-family:var(--sans);font-size:11px;font-weight:800;line-height:1;color:#fff;background:var(--brand);border-radius:6px;padding:6px 8px;letter-spacing:.02em}
.top-actions{display:flex;align-items:center;gap:8px}
.discord-badge,.lang-select{height:38px;border:1px solid var(--line-2);border-radius:9px;background:var(--surface);color:var(--ink);font-size:13px;font-weight:700}
.discord-badge{display:inline-flex;align-items:center;gap:7px;padding:0 13px;color:#fff;background:#5865f2;border-color:transparent}
.discord-badge::before{content:"";width:7px;height:7px;border-radius:999px;background:#3ddc97}
.lang-wrap{position:relative;display:inline-flex;align-items:center}
.lang-select{appearance:none;-webkit-appearance:none;min-width:78px;padding:0 32px 0 14px}
.lang-select:hover{background:var(--surface-2)}
.lang-arrow{position:absolute;right:13px;top:50%;width:7px;height:7px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:translateY(-65%) rotate(45deg);pointer-events:none}

/* screen plumbing */
.screen{display:none;flex:1 1 auto;min-height:0;animation:rise .2s ease both}
.screen.active{display:flex;flex-direction:column}
.landing.active{display:flex;align-items:center;justify-content:center}

.kicker{margin:0 0 6px;color:var(--brand);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.label{font-size:11px;font-weight:800;color:var(--faint);letter-spacing:.08em;text-transform:uppercase}
h1,h2,h3,h4,p{margin-top:0}
h1,h2,h3{font-family:var(--display);font-weight:800;letter-spacing:-.01em}
h1{margin:0 0 6px;font-size:clamp(1.9rem,3.6vw,2.6rem);line-height:1}
h2{font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.05;margin-bottom:10px}
h3{font-size:clamp(1.15rem,2.2vw,1.6rem);line-height:1.1}
.muted{color:var(--muted)}

/* cards */
.card,.panel{position:relative;border:1px solid var(--line);border-radius:18px;background:var(--surface)}
.panel{padding:20px}

/* ============ LANDING — main menu ============ */
.menu-layout{width:min(900px,100%);max-height:calc(100dvh - 86px);display:grid;grid-template-columns:minmax(0,1.45fr) minmax(248px,1fr);gap:16px;align-items:stretch}
.play-card{display:grid;grid-template-columns:224px 1fr;overflow:hidden}
.play-cover{position:relative;background:var(--bg-2);border-right:1px solid var(--line);display:grid;place-items:center;padding:14px}
.play-cover::before{content:"";position:absolute;left:10px;right:10px;top:10px;bottom:10px;border-radius:14px;background:linear-gradient(160deg,#2a2d34,#202227)}
.cover-art{position:relative;z-index:1;width:100%;filter:drop-shadow(0 16px 30px rgba(0,0,0,.5))}
.play-form{padding:22px 24px;display:flex;flex-direction:column;gap:11px;min-width:0}
.hero-sub{margin:0 0 6px;color:var(--muted);font-size:14px;font-weight:600}
.name-row{margin:0}
input,select{width:100%;border:1px solid var(--line-2);border-radius:10px;background:var(--bg-2);color:var(--ink);outline:none}
input{height:48px;padding:0 14px;font-size:15px}
input::placeholder{color:var(--faint)}
select{height:48px;padding:0 36px 0 13px;font-size:14px;font-weight:700;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 17px) 21px,calc(100% - 12px) 21px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
option{background:#202227;color:var(--ink)}
input:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(79,124,255,.22)}
.landing-controls{display:grid;grid-template-columns:1fr 118px;gap:9px}
.landing-controls label,.controls-panel label{display:grid;gap:5px;color:var(--faint);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}

.actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:2px}
.actions.stacked{margin-top:14px;grid-template-columns:1fr}
.btn{height:46px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:10px;padding:0 16px;color:inherit;font-weight:800;font-size:14px;white-space:nowrap;transition:background .12s ease,border-color .12s ease,transform .06s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--go);color:#fff}
.btn-primary:hover{background:var(--go-press)}
.btn-ghost{background:var(--raised);border-color:var(--line-2);color:var(--ink)}
.btn-ghost:hover{background:#3d4047}
#quickStartBtn{grid-column:1/-1;height:52px;font-size:16px}
.account-cta{margin-top:4px;width:100%;height:46px;display:flex;align-items:center;gap:9px;padding:0 13px;border:1px solid var(--line-2);border-radius:10px;background:var(--bg-2);color:var(--ink);font-weight:700;font-size:13px;text-align:left}
.account-cta:hover{border-color:var(--brand)}
.account-cta .brand-mark{width:24px;height:24px}

/* leaderboard card */
.board-card{display:flex;flex-direction:column;padding:18px;background:var(--surface-2)}
.leader-asset{width:150px;margin:6px auto 14px;filter:drop-shadow(0 14px 26px rgba(0,0,0,.45))}
.leader-preview,.global-board,.final-board,.player-list,.mini-scoreboard{display:grid;gap:7px}
.leader-preview{margin:10px 0;min-height:120px;align-content:start}
.empty-board{min-height:108px;display:grid;place-items:center;border:1px dashed var(--line-2);border-radius:12px;color:var(--faint);font-weight:700;text-align:center;padding:14px}
.rank-row,.player{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:9px;padding:9px 11px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);font-size:14px}
.rank-row span:first-child{font-family:var(--display);color:var(--faint)}
.rank-row strong,.player strong{color:var(--gold);font-family:var(--display)}
.avatar{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:var(--brand);color:#fff;font-weight:800;font-size:13px}
.player{grid-template-columns:auto 1fr auto}
.player.me{border-color:var(--brand);background:rgba(79,124,255,.12)}

/* ============ LOBBY ============ */
.section-head{margin:0 0 14px}
.lobby-grid,.final-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(248px,.9fr);gap:14px;flex:1 1 auto;min-height:0;align-content:start}
.room-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.room-id{display:flex;flex-direction:column;gap:6px}
.room-code{display:inline-flex;align-items:center;gap:9px;border:1px solid var(--line-2);border-radius:10px;background:var(--bg-2);color:var(--ink);padding:8px 13px;font-family:var(--display);font-size:1.15rem;letter-spacing:.12em;line-height:1}
.room-code:hover{border-color:var(--brand)}
.copy-ic{width:13px;height:13px;flex:0 0 auto;border:2px solid var(--faint);border-radius:3px;position:relative}
.copy-ic::before{content:"";position:absolute;left:-4px;top:-4px;width:9px;height:9px;border:2px solid var(--faint);border-right:0;border-bottom:0;border-radius:3px 0 0 0;background:var(--bg-2)}
.room-code:hover .copy-ic,.room-code:hover .copy-ic::before{border-color:var(--brand)}
.status-badge{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;background:rgba(240,178,50,.14);color:var(--gold);border:1px solid rgba(240,178,50,.3)}
.status-badge::before{content:"";width:7px;height:7px;border-radius:999px;background:currentColor;animation:blink 1.4s ease-in-out infinite}
.status-badge.live{background:rgba(34,176,125,.16);color:var(--go);border-color:rgba(34,176,125,.34)}
.room-line{margin:12px 0 0;font-size:13px}
.controls-panel{display:grid;gap:12px;align-content:start}
.controls-panel .kicker{margin:0}
.control-hint{margin:0;font-size:12px}
.section-title{display:flex;align-items:center;gap:9px;margin:16px 0 10px}
.section-title h4{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:flex;align-items:center;gap:7px}
.section-title .count{display:inline-grid;place-items:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--brand);color:#fff;font-size:11px;letter-spacing:0}
.icon-dot{width:9px;height:9px;border-radius:999px;background:var(--go)}
.player-list{max-height:46vh;overflow:auto}
.player .p-name{display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.player .you-tag{flex:0 0 auto;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--brand);background:rgba(79,124,255,.16);border-radius:6px;padding:3px 7px}
.player .dot-on{width:8px;height:8px;border-radius:999px;background:var(--faint)}
.player.is-ready{border-color:rgba(34,176,125,.4);background:rgba(34,176,125,.08)}
.ready-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;color:var(--go);background:rgba(34,176,125,.16);border:1px solid rgba(34,176,125,.32);border-radius:999px;padding:4px 9px;white-space:nowrap}
.btn:disabled{opacity:.7;cursor:default;background:var(--raised);color:var(--muted)}
.btn-primary:disabled{background:rgba(34,176,125,.22);color:#bfe7d6}
.player-empty{padding:14px;border:1px dashed var(--line-2);border-radius:12px;color:var(--faint);font-weight:700;text-align:center}

/* ============ GAME — HUD ============ */
#gameScreen.active{gap:13px;justify-content:flex-start}
.game-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex:0 0 auto}
#roundLabel{margin:0 0 2px;font-size:12px;letter-spacing:.1em;color:var(--brand)}
#modeLabel{margin:0;font-family:var(--display);font-size:1.4rem}
.score-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-2);background:var(--surface);border-radius:10px;padding:9px 14px;white-space:nowrap;font-size:12px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.score-pill strong{font-family:var(--display);font-size:19px;color:var(--gold)}
.play-stage{display:grid;grid-template-columns:minmax(110px,160px) 1fr;gap:18px;flex:0 0 auto;padding:16px;border:1px solid var(--line);border-radius:16px;background:var(--surface);color:var(--ink)}
.artwork{aspect-ratio:1;display:grid;place-items:center;border-radius:12px;overflow:hidden;background:var(--bg-2);border:1px solid var(--line)}
.artwork{position:relative}
.artwork img{width:100%;height:100%;object-fit:cover;transition:filter .45s ease,transform .45s ease}
.artwork img.artwork-fallback{width:46%;height:auto;object-fit:contain;opacity:.85}
.artwork.blurred img{filter:blur(17px) brightness(.72);transform:scale(1.12)}
.artwork.blurred::after{content:"?";position:absolute;inset:0;display:grid;place-items:center;font-family:var(--display);font-size:2.4rem;color:rgba(255,255,255,.82);text-shadow:0 2px 12px rgba(0,0,0,.5)}
.audio-panel{display:flex;align-items:center;gap:16px}
.play-btn{width:62px;height:62px;flex:0 0 auto;border:0;border-radius:999px;color:#fff;background:var(--go);display:grid;place-items:center;transition:background .12s ease,transform .06s ease}
.play-btn:hover{background:var(--go-press)}
.play-btn:active{transform:scale(.95)}
.play-btn .ic{width:26px;height:26px;grid-area:1/1;fill:currentColor}
.play-btn .ic-play{margin-left:3px}
.play-btn .ic-pause{display:none;margin-left:0}
.play-btn.playing .ic-play{display:none}
.play-btn.playing .ic-pause{display:block}
.progress-wrap{width:100%}
.timer-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px;color:var(--muted);font-size:13px;font-weight:700}
.timer-row strong{font-family:var(--display);font-size:22px;color:var(--ink)}
.progress{height:10px;border-radius:999px;background:var(--bg-2);overflow:hidden;border:1px solid var(--line)}
.progress span{display:block;width:0;height:100%;border-radius:999px;background:var(--go);transition:width .2s linear}
.volume-row{display:flex;align-items:center;gap:10px;margin-top:12px}
.vol-ic{width:20px;height:20px;flex:0 0 auto;color:var(--muted)}
.vol-ic svg{width:20px;height:20px}
.vol-ic .spk{fill:currentColor}
.vol-ic .w1,.vol-ic .w2{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
.vol-ic.low .w2{display:none}
.vol-ic.muted .w1,.vol-ic.muted .w2{display:none}
.volume{-webkit-appearance:none;appearance:none;width:100%;height:6px;border:0;padding:0;border-radius:999px;background:linear-gradient(90deg,var(--brand),var(--brand)) no-repeat,var(--bg-2);background-size:var(--vol,80%) 100%;cursor:pointer}
.volume::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:0;box-shadow:0 1px 4px rgba(0,0,0,.5)}
.volume::-moz-range-thumb{width:16px;height:16px;border:0;border-radius:50%;background:#fff}
.volume::-moz-range-progress{height:6px;border-radius:999px;background:var(--brand)}

.answer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:11px;flex:0 0 auto}
.answer-btn{position:relative;min-height:62px;border:0;border-radius:13px;padding:14px 16px;color:#fff;font-weight:800;font-size:15px;text-align:left;box-shadow:inset 0 -3px 0 rgba(0,0,0,.22);transition:transform .08s ease,filter .12s ease}
.answer-btn:nth-child(4n+1){background:var(--a1)}
.answer-btn:nth-child(4n+2){background:var(--a2)}
.answer-btn:nth-child(4n+3){background:var(--a3)}
.answer-btn:nth-child(4n+4){background:var(--a4)}
.answer-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.answer-btn:active{transform:translateY(0)}
.answer-btn.correct{background:var(--go);box-shadow:inset 0 0 0 3px #fff,inset 0 -3px 0 rgba(0,0,0,.22);animation:pop .3s ease}
.answer-btn.wrong{filter:grayscale(.6) brightness(.7);animation:shake .3s ease}
.answer-btn:disabled{cursor:default}
.answer-btn:disabled:not(.correct):not(.wrong){opacity:.45}
.answer-btn:disabled:hover{transform:none}
.answer-btn small{position:absolute;right:13px;bottom:9px;color:#fff;font-weight:900;background:rgba(0,0,0,.28);padding:2px 7px;border-radius:7px}
.mini-scoreboard{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));flex:0 0 auto}
.mini-scoreboard .rank-row{padding:8px 11px;font-size:13px}

/* ============ RESULT + FINAL ============ */
#resultScreen.active,#finalScreen.active{justify-content:center;align-items:center}
.result-panel{width:min(620px,100%);text-align:center}
#correctAnswer{color:var(--go)}
.answer-summary{display:grid;gap:8px;margin:14px 0;text-align:left}
.answer-summary div{padding:11px 13px;border-radius:10px;background:var(--bg-2);border:1px solid var(--line);display:flex;justify-content:space-between;gap:10px;align-items:center}
.answer-summary strong{color:var(--gold)}
.final-grid{align-content:center}
.final-panel{text-align:center}
.trophy{width:70px;margin:0 auto 8px}
.account-panel{display:flex;flex-direction:column}
.account-panel .btn{margin:12px 0}

/* modal + toast */
.modal{position:fixed;inset:0;z-index:20;display:grid;place-items:center;background:rgba(0,0,0,.62);padding:20px}
.modal-card{position:relative;width:min(440px,100%);background:var(--surface);border:1px solid var(--line-2);border-radius:18px;padding:28px;text-align:center}
.modal-card .brand-mark{margin:0 auto 6px}
.modal-close{position:absolute;right:13px;top:13px;width:34px;height:34px;border:1px solid var(--line-2);border-radius:9px;background:var(--bg-2);color:var(--ink);font-size:18px;line-height:1}
.modal-card .btn{margin-top:16px}
.toast{position:fixed;left:50%;bottom:20px;z-index:40;width:min(500px,calc(100vw - 32px));transform:translateX(-50%);padding:13px 16px;border-radius:11px;background:#202227;border:1px solid var(--line-2);color:#fff;font-weight:700;text-align:center;box-shadow:0 16px 40px rgba(0,0,0,.5)}
.toast.success{background:var(--go);border-color:transparent}

/* animations (subtle) */
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes blink{50%{opacity:.35}}
@keyframes pop{50%{transform:scale(1.03)}}
@keyframes shake{25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}

/* ============ RESPONSIVE ============ */
/* short landscape (Discord desktop activity) */
@media(max-height:740px) and (min-width:760px){
  .topbar{height:42px;margin-bottom:9px}
  .menu-layout{max-height:calc(100dvh - 72px)}
  .play-card{grid-template-columns:150px 1fr}
  .play-form{padding:16px 18px;gap:9px}
  input,select{height:44px}
  #quickStartBtn{height:48px}
  .play-stage{padding:13px}
  .answer-btn{min-height:54px}
}
/* tablet */
@media(max-width:860px){
  .menu-layout{grid-template-columns:1fr;max-height:none;overflow:visible}
  .lobby-grid,.final-grid{grid-template-columns:1fr}
}
/* phone / narrow Discord portrait */
@media(max-width:600px){
  .app-shell{padding:12px 12px 16px}
  .brand-word{font-size:19px}
  .discord-badge{font-size:0;padding:0 11px}
  .play-card{grid-template-columns:1fr}
  .play-cover{border-right:0;border-bottom:1px solid var(--line);padding:14px}
  .cover-art{width:120px}
  .play-cover::before{display:none}
  .play-form{padding:18px}
  .landing-controls,.actions{grid-template-columns:1fr}
  #quickStartBtn{grid-column:auto}
  .game-head{flex-wrap:wrap;gap:8px}
  .play-stage{grid-template-columns:1fr;gap:14px;text-align:center}
  .artwork{max-width:180px;margin:0 auto}
  .audio-panel{flex-direction:column;gap:14px}
  .answer-grid{grid-template-columns:1fr}
  .answer-btn{min-height:54px}
}
