/* ============ Smart Family — Design System ============ */
@import url('https://fonts.googleapis.com/css2?family=Tajawal:wght@400;500;700;800;900&family=Cairo:wght@600;700;900&display=swap');

:root {
  --bg-1: #1a1145;
  --bg-2: #2d1b69;
  --bg-3: #3b1f7a;
  --accent: #ffd166;
  --accent-2: #ff6b9d;
  --accent-3: #06d6a0;
  --accent-4: #4cc9f0;
  --purple: #9b5de5;
  --glass: rgba(255, 255, 255, 0.08);
  --glass-strong: rgba(255, 255, 255, 0.14);
  --glass-border: rgba(255, 255, 255, 0.18);
  --text: #ffffff;
  --text-dim: rgba(255, 255, 255, 0.65);
  --danger: #ff5c7c;
  --ok: #06d6a0;
  --radius: 22px;
  --shadow: 0 18px 50px rgba(0, 0, 0, 0.35);
  --font: 'Tajawal', system-ui, sans-serif;
  --font-display: 'Cairo', var(--font);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  color: var(--text);
  min-height: 100vh;
  direction: rtl;
  background: linear-gradient(135deg, var(--bg-1), var(--bg-2), var(--bg-3));
  background-size: 200% 200%;
  animation: bgShift 18s ease infinite;
  overflow-x: hidden;
  position: relative;
}
@keyframes bgShift { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }

/* floating glowing orbs */
.orb { position: fixed; border-radius: 50%; filter: blur(70px); opacity: .55; z-index: 0; pointer-events: none; animation: float 16s ease-in-out infinite; }
.orb.a { width: 380px; height: 380px; background: var(--accent-2); top: -120px; right: -100px; }
.orb.b { width: 320px; height: 320px; background: var(--accent-4); bottom: -120px; left: -80px; animation-delay: -5s; }
.orb.c { width: 260px; height: 260px; background: var(--accent-3); top: 40%; left: 50%; animation-delay: -9s; opacity:.3; }
@keyframes float { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(40px,-30px) scale(1.1)} 66%{transform:translate(-30px,30px) scale(.95)} }

.wrap { position: relative; z-index: 2; max-width: 1080px; margin: 0 auto; padding: 22px 18px 80px; }

/* ============ Header ============ */
.topbar { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom: 26px; flex-wrap: wrap; }
.brand { display:flex; align-items:center; gap:12px; font-family: var(--font-display); font-weight: 900; font-size: 1.6rem; letter-spacing:.5px; }
.brand .logo { width:46px; height:46px; border-radius:14px; display:grid; place-items:center; font-size:1.5rem;
  background: linear-gradient(135deg,var(--accent),var(--accent-2)); box-shadow: 0 8px 24px rgba(255,107,157,.4); animation: pop 2.4s ease-in-out infinite; }
.brand .grad { background: linear-gradient(90deg,var(--accent),var(--accent-2),var(--accent-4)); -webkit-background-clip:text; background-clip:text; color:transparent; }
@keyframes pop { 0%,100%{transform:rotate(-6deg) scale(1)} 50%{transform:rotate(6deg) scale(1.08)} }

.nav { display:flex; gap:10px; align-items:center; }
.nav a { color:var(--text-dim); text-decoration:none; font-weight:700; padding:9px 14px; border-radius:12px; transition:.2s; }
.nav a:hover, .nav a.active { color:#fff; background: var(--glass); }

.userchip { display:flex; align-items:center; gap:10px; padding:8px 14px; border-radius:16px;
  background: var(--glass); border:1px solid var(--glass-border); backdrop-filter: blur(12px); }
.userchip .av { font-size:1.4rem; }
.userchip .pts { font-weight:900; color:var(--accent); }

/* ============ Glass card ============ */
.card { background: var(--glass); border:1px solid var(--glass-border); border-radius: var(--radius);
  backdrop-filter: blur(16px); box-shadow: var(--shadow); padding: 26px; }

/* ============ Login ============ */
.login-stage { min-height: 78vh; display:grid; place-items:center; }
.login-card { width:min(460px,94vw); text-align:center; padding: 38px 30px; animation: rise .6s cubic-bezier(.2,.8,.2,1); }
.login-card h1 { font-family:var(--font-display); font-size:2.2rem; margin-bottom:6px; }
.login-card p.sub { color:var(--text-dim); margin-bottom:24px; }
.field { text-align:right; margin-bottom:16px; }
.field label { display:block; font-weight:700; margin-bottom:8px; font-size:.92rem; color:var(--text-dim); }
input, select { width:100%; padding:14px 16px; border-radius:14px; border:1px solid var(--glass-border);
  background: rgba(255,255,255,.06); color:#fff; font-family:var(--font); font-size:1rem; outline:none; transition:.2s; }
input:focus, select:focus { border-color: var(--accent); background: rgba(255,255,255,.12); box-shadow:0 0 0 4px rgba(255,209,102,.15); }
input::placeholder { color: rgba(255,255,255,.4); }

.avatar-pick { display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin:6px 0 18px; }
.avatar-pick button { width:48px; height:48px; font-size:1.5rem; border-radius:14px; border:2px solid transparent;
  background: rgba(255,255,255,.06); cursor:pointer; transition:.18s; }
.avatar-pick button:hover { transform:translateY(-3px) scale(1.08); }
.avatar-pick button.sel { border-color: var(--accent); background: rgba(255,209,102,.2); transform: scale(1.1); }

.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; width:100%; padding:15px 20px;
  border:none; border-radius:16px; font-family:var(--font); font-weight:800; font-size:1.05rem; cursor:pointer;
  color:#1a1145; background: linear-gradient(135deg,var(--accent),var(--accent-2)); transition:.2s; box-shadow:0 10px 28px rgba(255,107,157,.35); }
.btn:hover { transform: translateY(-2px); box-shadow:0 14px 34px rgba(255,107,157,.5); }
.btn:active { transform: translateY(0) scale(.98); }
.btn.ghost { background: var(--glass); color:#fff; border:1px solid var(--glass-border); box-shadow:none; }
.btn.sm { width:auto; padding:10px 18px; font-size:.95rem; }
.err { color: var(--danger); font-weight:700; min-height: 22px; margin-top:6px; }

/* ============ Stats strip ============ */
.stats { display:grid; grid-template-columns: repeat(auto-fit,minmax(150px,1fr)); gap:14px; margin-bottom: 26px; }
.stat { padding:18px; text-align:center; }
.stat .v { font-family:var(--font-display); font-size:1.9rem; font-weight:900; }
.stat .l { color:var(--text-dim); font-size:.88rem; margin-top:2px; }
.stat .v.gold { color:var(--accent); } .stat .v.green{color:var(--accent-3);} .stat .v.blue{color:var(--accent-4);} .stat .v.pink{color:var(--accent-2);}

/* ============ Day grid ============ */
.section-title { font-family:var(--font-display); font-size:1.4rem; margin:8px 0 16px; display:flex; align-items:center; gap:10px; }
.days { display:grid; grid-template-columns: repeat(auto-fill,minmax(220px,1fr)); gap:16px; }
.day-card { padding:20px; position:relative; overflow:hidden; cursor:pointer; transition:.25s; border-radius:20px; }
.day-card:hover { transform: translateY(-5px); border-color: var(--accent); }
.day-card .num { font-family:var(--font-display); font-size:.85rem; color:var(--accent); font-weight:800; letter-spacing:1px; }
.day-card h3 { font-size:1.15rem; margin:6px 0; }
.day-card .meta { color:var(--text-dim); font-size:.85rem; }
.day-card .prog { height:8px; border-radius:8px; background: rgba(255,255,255,.1); margin-top:14px; overflow:hidden; }
.day-card .prog i { display:block; height:100%; background: linear-gradient(90deg,var(--accent-3),var(--accent-4)); border-radius:8px; transition:width .6s; }
.day-card .mult { position:absolute; top:14px; left:14px; background:rgba(255,209,102,.16); color:var(--accent); font-weight:800; font-size:.78rem; padding:4px 10px; border-radius:20px; }
.day-card.finale { border-color: rgba(255,209,102,.5); background: linear-gradient(135deg, rgba(255,209,102,.14), rgba(255,107,157,.14)); }
.day-card.finale .num { color:#fff; }
.day-card.locked { cursor:not-allowed; opacity:.85; }
.day-card.locked .lockface { position:absolute; inset:0; display:grid; place-items:center; background: rgba(15,8,40,.55); backdrop-filter: blur(3px); z-index:3; }
.day-card.locked .lockface .ic { font-size:2rem; margin-bottom:6px; }
.day-card.locked .lockface .cd { font-family:var(--font-display); font-weight:800; color:var(--accent); letter-spacing:1px; }
.day-card .done-badge { position:absolute; top:14px; left:14px; background:var(--ok); color:#06301f; font-weight:800; font-size:.75rem; padding:4px 10px; border-radius:20px; }

/* ============ Question view ============ */
.qview { display:none; }
.qview.show { display:block; animation: rise .4s ease; }
.qhead { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; flex-wrap:wrap; gap:10px; }
.qhead .back { cursor:pointer; color:var(--text-dim); font-weight:700; background:var(--glass); padding:9px 16px; border-radius:12px; border:1px solid var(--glass-border); }
.qhead .back:hover{color:#fff;}
.qprogress { display:flex; gap:6px; }
.qdot { width:30px; height:8px; border-radius:6px; background: rgba(255,255,255,.15); transition:.3s; }
.qdot.cur { background: var(--accent); }
.qdot.ok { background: var(--ok); }
.qdot.bad { background: var(--danger); }

.qcard { padding:30px; position:relative; }
.qtags { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.tag { font-size:.78rem; font-weight:800; padding:5px 12px; border-radius:20px; }
.tag.cat { background: rgba(76,201,240,.16); color: var(--accent-4); }
.tag.easy { background: rgba(6,214,160,.16); color: var(--accent-3); }
.tag.medium { background: rgba(255,209,102,.16); color: var(--accent); }
.tag.hard { background: rgba(255,92,124,.16); color: var(--danger); }
.qtext { font-family:var(--font-display); font-size:1.55rem; line-height:1.6; margin-bottom:8px; }
.qemoji { font-size:4.5rem; text-align:center; margin:10px 0 22px; letter-spacing:8px; animation: pop 3s ease-in-out infinite; }
.qimg { display:block; max-width:100%; max-height:300px; margin:0 auto 22px; border-radius:16px; }

.choices { display:grid; gap:12px; margin-top:18px; }
.choice { text-align:right; padding:16px 18px; border-radius:14px; border:1px solid var(--glass-border);
  background: rgba(255,255,255,.05); color:#fff; font-family:var(--font); font-size:1.05rem; font-weight:600; cursor:pointer; transition:.18s; display:flex; align-items:center; gap:12px; }
.choice .k { width:30px; height:30px; border-radius:9px; background:var(--glass-strong); display:grid; place-items:center; font-weight:800; flex:none; }
.choice:hover:not([disabled]) { transform: translateX(-4px); border-color:var(--accent); background: rgba(255,255,255,.1); }
.choice.correct { border-color: var(--ok); background: rgba(6,214,160,.2); animation: pulseOk .5s; }
.choice.wrong { border-color: var(--danger); background: rgba(255,92,124,.18); animation: shake .4s; }
.choice[disabled] { cursor:default; opacity:.85; }
@keyframes pulseOk { 0%{transform:scale(1)} 40%{transform:scale(1.04)} 100%{transform:scale(1)} }
@keyframes shake { 0%,100%{transform:translateX(0)} 20%{transform:translateX(-8px)} 40%{transform:translateX(8px)} 60%{transform:translateX(-6px)} 80%{transform:translateX(6px)} }

.text-answer { display:flex; gap:10px; margin-top:8px; }
.text-answer input { flex:1; }
.attempts-info { color:var(--text-dim); font-size:.9rem; margin-top:14px; display:flex; align-items:center; gap:8px; }
.hearts { color:var(--accent-2); letter-spacing:2px; }

.feedback { margin-top:18px; padding:16px; border-radius:14px; font-weight:700; display:none; }
.feedback.show { display:block; animation: rise .3s ease; }
.feedback.good { background: rgba(6,214,160,.15); color: var(--accent-3); border:1px solid rgba(6,214,160,.3); }
.feedback.bad { background: rgba(255,92,124,.12); color: var(--danger); border:1px solid rgba(255,92,124,.3); }
.feedback .pts { font-family:var(--font-display); font-size:1.3rem; }

.qfooter { display:flex; justify-content:space-between; gap:12px; margin-top:22px; }

/* ============ Leaderboard / dashboard ============ */
.podium { display:flex; align-items:flex-end; justify-content:center; gap:14px; margin: 10px 0 34px; flex-wrap:wrap; }
.pod { width:170px; text-align:center; }
.pod .av { font-size:2.6rem; margin-bottom:6px; animation: bob 3s ease-in-out infinite; }
.pod .crown { font-size:1.6rem; }
.pod .name { font-weight:800; font-size:1.05rem; margin:4px 0; }
.pod .score { font-family:var(--font-display); font-weight:900; color:var(--accent); }
.pod .stand { border-radius:16px 16px 0 0; margin-top:10px; display:grid; place-items:center; font-family:var(--font-display); font-size:2.4rem; font-weight:900; }
.pod.p1 .stand { height:150px; background: linear-gradient(180deg,var(--accent),#d99b2b); color:#5a3c00; box-shadow:0 -10px 40px rgba(255,209,102,.4); }
.pod.p2 .stand { height:110px; background: linear-gradient(180deg,#dfe6ee,#9aa6b2); color:#3a4350; }
.pod.p3 .stand { height:86px; background: linear-gradient(180deg,#e8a87c,#b5764b); color:#4a2a14; }
@keyframes bob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

.lb-list { display:flex; flex-direction:column; gap:10px; }
.lb-row { display:flex; align-items:center; gap:14px; padding:14px 18px; border-radius:16px;
  background: var(--glass); border:1px solid var(--glass-border); transition:.25s; }
.lb-row:hover { background: var(--glass-strong); transform: translateX(-4px); }
.lb-row .rank { width:38px; height:38px; border-radius:11px; display:grid; place-items:center; font-weight:900; font-family:var(--font-display); background: var(--glass-strong); flex:none; }
.lb-row .av { font-size:1.6rem; }
.lb-row .who { flex:1; }
.lb-row .who .nm { font-weight:800; }
.lb-row .who .sub { color:var(--text-dim); font-size:.82rem; display:flex; gap:10px; }
.lb-row .pts { font-family:var(--font-display); font-weight:900; font-size:1.3rem; color:var(--accent); }
.lb-row.me { border-color: var(--accent); background: rgba(255,209,102,.1); }
.flame { color:var(--accent-2); font-weight:800; }

.empty { text-align:center; color:var(--text-dim); padding:50px 20px; }
.empty .big { font-size:3rem; margin-bottom:10px; }

/* live ping */
.live { display:inline-flex; align-items:center; gap:7px; color:var(--accent-3); font-weight:700; font-size:.85rem; }
.live .dot { width:9px; height:9px; border-radius:50%; background: var(--accent-3); animation: ping 1.4s infinite; }
@keyframes ping { 0%{box-shadow:0 0 0 0 rgba(6,214,160,.6)} 70%{box-shadow:0 0 0 8px rgba(6,214,160,0)} 100%{box-shadow:0 0 0 0 rgba(6,214,160,0)} }

/* admin */
.admin-q { padding:16px; margin-bottom:12px; border-radius:14px; background: rgba(255,255,255,.05); border:1px solid var(--glass-border); }
.admin-q .row { display:grid; grid-template-columns: 110px 110px 1fr; gap:10px; margin-bottom:8px; }
.admin-q textarea { width:100%; padding:10px 12px; border-radius:12px; border:1px solid var(--glass-border); background: rgba(255,255,255,.06); color:#fff; font-family:var(--font); resize:vertical; }
.admin-day { margin-bottom:24px; }
.tabs { display:flex; gap:8px; margin-bottom:20px; flex-wrap:wrap; }
.tabs button { padding:10px 18px; border-radius:12px; border:1px solid var(--glass-border); background:var(--glass); color:var(--text-dim); font-weight:700; cursor:pointer; transition:.2s; font-family:var(--font); }
.tabs button.active { background: linear-gradient(135deg,var(--accent),var(--accent-2)); color:#1a1145; border-color:transparent; }
.muted { color: var(--text-dim); }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:600px){ .grid2{grid-template-columns:1fr} .admin-q .row{grid-template-columns:1fr} .qtext{font-size:1.3rem} }

@keyframes rise { from{opacity:0; transform: translateY(18px)} to{opacity:1; transform:none} }

/* confetti canvas */
#confetti { position: fixed; inset:0; pointer-events:none; z-index: 9999; }

/* ============ Adventure mode ============ */
.adv-inventory { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; padding:10px 14px; border-radius:14px; background:var(--glass); border:1px solid var(--glass-border); }
.adv-inventory .inv-label { font-weight:800; }
.inv-item { background: rgba(6,214,160,.16); color:#9affdd; border:1px solid rgba(6,214,160,.3); padding:5px 11px; border-radius:20px; font-weight:700; font-size:.9rem; animation: pop .4s; }

.adv-map { display:flex; align-items:center; gap:0; flex-wrap:wrap; margin-bottom:18px; padding:12px; border-radius:14px; background:var(--glass); border:1px solid var(--glass-border); overflow-x:auto; }
.map-node { width:38px; height:38px; flex:none; border-radius:11px; display:grid; place-items:center; font-size:1.1rem; font-weight:900; background: rgba(255,255,255,.07); border:2px solid transparent; color:var(--text-dim); }
.map-node.done { background: rgba(6,214,160,.2); color:var(--accent-3); border-color:var(--accent-3); }
.map-node.cur { background: linear-gradient(135deg,var(--accent),var(--accent-2)); color:#5a3c00; border-color:#fff; animation: pulseCur 1.4s infinite; transform:scale(1.1); }
@keyframes pulseCur { 0%,100%{box-shadow:0 0 0 0 rgba(255,209,102,.5)} 50%{box-shadow:0 0 0 8px rgba(255,209,102,0)} }
.map-link { width:18px; height:3px; background:rgba(255,255,255,.18); flex:none; }

.scene-card { padding:0; overflow:hidden; animation: rise .5s ease; }
.scene-img { position:relative; height:300px; background-size:cover; background-position:center; }
.scene-img::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(15,8,40,0) 40%, rgba(20,12,45,.85)); }
.scene-badge { position:absolute; top:14px; right:14px; z-index:3; background:rgba(10,6,30,.6); backdrop-filter:blur(8px); padding:8px 16px; border-radius:14px; font-family:var(--font-display); font-weight:800; border:1px solid var(--glass-border); }
.scene-body { padding:24px 26px 28px; }
.scene-story { font-size:1.12rem; line-height:1.9; margin-bottom:18px; }
.finale-done .scene-body h2 { font-family:var(--font-display); font-size:1.6rem; margin-bottom:10px; }
.finale-done .scene-body p { line-height:1.8; margin-bottom:8px; }

/* search hotspots */
.hotspots { position:absolute; inset:0; z-index:4; }
.hotspot { position:absolute; border:2px dashed rgba(255,255,255,.5); background:rgba(255,255,255,.08); border-radius:14px; cursor:pointer; display:grid; place-items:center; font-size:1.6rem; transition:.2s; }
.hotspot:hover { background:rgba(255,209,102,.25); border-color:var(--accent); transform:scale(1.05); }
.hotspot.found { border-style:solid; border-color:var(--accent-3); background:rgba(6,214,160,.25); cursor:default; }
.hs-pulse { animation: pop 1.5s infinite; opacity:.85; }
.search-status { margin-bottom:14px; font-size:1rem; }

/* use-item / finale requirements */
.req-row { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:18px; font-weight:700; }
.req-item { padding:7px 13px; border-radius:20px; font-weight:800; font-size:.92rem; }
.req-item.ok { background:rgba(6,214,160,.18); color:var(--accent-3); border:1px solid rgba(6,214,160,.35); }
.req-item.missing { background:rgba(255,92,124,.14); color:var(--danger); border:1px solid rgba(255,92,124,.3); }

/* choices */
.choice-row { display:flex; gap:14px; flex-wrap:wrap; }
.choice-btn { background:var(--glass-strong) !important; color:#fff !important; border:1px solid var(--glass-border); font-size:1.05rem; }
.choice-btn:hover { border-color:var(--accent); }

.puzzle-box { background:rgba(255,255,255,.03); border:1px solid var(--glass-border); border-radius:18px; padding:20px; }
.reward-hint { margin-top:12px; font-size:.9rem; }

/* ============ Game HUD / economy ============ */
.chip-btn { display:inline-flex; align-items:center; gap:5px; padding:9px 13px; border-radius:13px; border:1px solid var(--glass-border);
  background: var(--glass); color:#fff; font-family:var(--font); font-weight:800; cursor:pointer; transition:.2s; font-size:.95rem; }
.chip-btn:hover { background: var(--glass-strong); transform: translateY(-2px); }
#btnDaily { background: linear-gradient(135deg,var(--accent),var(--accent-2)); color:#5a3c00; border-color:transparent; animation: pop 1.6s ease-in-out infinite; }
.userchip { gap:12px; flex-wrap:wrap; }
.userchip .coins { font-weight:900; color:var(--accent); cursor:default; }
.userchip .rankchip { font-weight:800; background: rgba(155,93,229,.22); color:#d3b6ff; padding:3px 10px; border-radius:20px; font-size:.85rem; }
.coins-stat { cursor:pointer; } .coins-stat:hover { border-color: var(--accent); }

.rank-bar { margin-bottom:18px; padding:16px 20px; }
.rank-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; font-size:1rem; }
.rank-track { height:12px; border-radius:10px; background: rgba(255,255,255,.1); overflow:hidden; }
.rank-track i { display:block; height:100%; background: linear-gradient(90deg,var(--purple),var(--accent-2),var(--accent)); border-radius:10px; transition: width .8s cubic-bezier(.2,.8,.2,1); }

/* power-up bar */
.powerbar { display:flex; gap:10px; margin-top:18px; flex-wrap:wrap; }
.powerbtn { display:inline-flex; align-items:center; gap:6px; padding:10px 16px; border-radius:13px; border:1px solid var(--glass-border);
  background: rgba(255,255,255,.06); color:#fff; font-family:var(--font); font-weight:800; cursor:pointer; transition:.18s; }
.powerbtn:hover { background: rgba(155,93,229,.25); transform: translateY(-2px); }
.powerbtn b { background: var(--accent); color:#5a3c00; border-radius:8px; padding:1px 8px; font-size:.85rem; }
.powerbtn.buy { margin-inline-start:auto; background: rgba(255,209,102,.14); }

/* combo popup */
.combo-pop { position:fixed; top:30%; left:50%; transform:translate(-50%,-20px) scale(.8); z-index:9997; opacity:0; pointer-events:none;
  font-family:var(--font-display); font-weight:900; font-size:2.4rem; color:var(--accent-2); text-shadow:0 4px 20px rgba(255,107,157,.6); text-align:center; transition:.3s cubic-bezier(.2,.8,.2,1); }
.combo-pop small { display:block; font-size:1rem; color:var(--accent); }
.combo-pop.show { opacity:1; transform:translate(-50%,-50%) scale(1); }

/* floating gain */
.float-gain { position:fixed; z-index:9998; font-family:var(--font-display); font-weight:900; font-size:1.3rem; pointer-events:none;
  animation: floatUp 1.3s ease-out forwards; text-shadow:0 2px 10px rgba(0,0,0,.4); }
@keyframes floatUp { 0%{opacity:0; transform:translateY(0) scale(.6)} 20%{opacity:1; transform:translateY(-10px) scale(1.1)} 100%{opacity:0; transform:translateY(-60px) scale(1)} }

/* celebration overlay */
.celebrate { position:fixed; inset:0; z-index:9996; display:grid; place-items:center; background:rgba(10,6,30,.55); backdrop-filter:blur(4px); opacity:0; transition:.3s; }
.celebrate.show { opacity:1; }
.celebrate-card { text-align:center; padding:36px 50px; border-radius:26px; background: linear-gradient(135deg, rgba(155,93,229,.4), rgba(255,107,157,.35)); border:1px solid var(--glass-border); box-shadow:var(--shadow); transform:scale(.7); transition:.4s cubic-bezier(.2,.9,.3,1.3); }
.celebrate.show .celebrate-card { transform:scale(1); }
.ce-emoji { font-size:4.5rem; animation: bob 1.6s ease-in-out infinite; }
.ce-title { font-family:var(--font-display); font-size:1.7rem; font-weight:900; margin-top:8px; }
.ce-sub { color:var(--accent); font-weight:800; font-size:1.2rem; margin-top:4px; }

/* modal */
.modal-overlay { position:fixed; inset:0; z-index:9995; display:grid; place-items:center; background:rgba(10,6,30,.6); backdrop-filter:blur(5px); animation: rise .25s ease; padding:18px; }
.modal-card { width:min(540px,96vw); max-height:88vh; overflow:auto; background: linear-gradient(135deg,var(--bg-2),var(--bg-3)); border:1px solid var(--glass-border); border-radius:24px; box-shadow:var(--shadow); padding:26px; }
.modal-head { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.modal-head h2 { font-family:var(--font-display); }
.modal-head .x { background:var(--glass); border:1px solid var(--glass-border); color:#fff; width:36px; height:36px; border-radius:11px; cursor:pointer; font-size:1rem; }
.shop-list { display:flex; flex-direction:column; gap:12px; }
.shop-item { display:flex; align-items:center; gap:14px; padding:14px; border-radius:16px; background: rgba(255,255,255,.05); border:1px solid var(--glass-border); }
.shop-item .si-emoji { font-size:2rem; } .shop-item .si-info { flex:1; display:flex; flex-direction:column; } .shop-item .si-info b { font-size:1.05rem; }
.badge-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:12px; }
.badge { text-align:center; padding:16px 10px; border-radius:16px; border:1px solid var(--glass-border); display:flex; flex-direction:column; gap:4px; }
.badge.on { background: linear-gradient(135deg, rgba(255,209,102,.16), rgba(255,107,157,.12)); border-color: rgba(255,209,102,.4); }
.badge.off { background: rgba(255,255,255,.03); opacity:.65; }
.badge .b-emoji { font-size:2.2rem; } .badge b { font-size:.95rem; } .badge .muted { font-size:.78rem; }
.odd-tile.removed { opacity:.3; text-decoration: line-through; }
.wordle-hintrow { text-align:center; min-height:0; margin-bottom:6px; color:var(--accent); font-weight:800; display:flex; gap:6px; align-items:center; justify-content:center; flex-wrap:wrap; }

/* ============ Interactive challenge components ============ */
.tag.timer { background: rgba(155,93,229,.18); color:#c9a3ff; }
.tag.speed { background: rgba(255,209,102,.18); color: var(--accent); font-weight:900; }
.shakeit { animation: shake .45s; }

/* Wordle */
.wordle-grid { display:flex; flex-direction:column; gap:8px; align-items:center; margin-top:8px; }
.wrow { display:flex; gap:8px; }
.wtile { width:52px; height:52px; display:grid; place-items:center; border-radius:12px; border:2px solid var(--glass-border);
  font-family:var(--font-display); font-size:1.5rem; font-weight:900; background: rgba(255,255,255,.04); transition:.3s; }
.wtile.correct { background: var(--ok); border-color: var(--ok); color:#06301f; animation: pop .4s; }
.wtile.present { background: var(--accent); border-color: var(--accent); color:#5a3c00; animation: pop .4s; }
.wtile.absent { background: rgba(255,255,255,.06); border-color: transparent; color: var(--text-dim); }
@media(max-width:480px){ .wtile{width:42px;height:42px;font-size:1.2rem} }

/* Connections */
.conn-found-wrap { display:flex; flex-direction:column; gap:8px; margin-bottom:12px; }
.conn-found { padding:12px 16px; border-radius:14px; border:2px solid; text-align:center; animation: rise .4s; }
.conn-found b { display:block; font-size:1.05rem; } .conn-found span { color:var(--text-dim); font-size:.9rem; }
.conn-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:10px; }
.conn-tile { padding:18px 6px; border-radius:14px; border:2px solid var(--glass-border); background: rgba(255,255,255,.05);
  color:#fff; font-family:var(--font); font-weight:700; cursor:pointer; transition:.15s; font-size:.95rem; min-height:62px; }
.conn-tile:hover { background: rgba(255,255,255,.1); }
.conn-tile.sel { background: var(--purple); border-color:#fff; transform: scale(1.04); }
.conn-foot { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:16px; flex-wrap:wrap; }
@media(max-width:560px){ .conn-grid{grid-template-columns:repeat(2,1fr)} .conn-tile{font-size:.85rem;padding:14px 4px} }

/* Ordering */
.order-list { display:flex; flex-direction:column; gap:10px; }
.order-item { display:flex; align-items:center; gap:12px; padding:14px 16px; border-radius:14px; cursor:grab;
  background: rgba(255,255,255,.06); border:1px solid var(--glass-border); transition:.15s; }
.order-item:hover { background: rgba(255,255,255,.1); }
.order-item.dragging { opacity:.5; border-color: var(--accent); }
.rank-num { width:30px; height:30px; border-radius:9px; background: var(--accent); color:#5a3c00; display:grid; place-items:center; font-weight:900; flex:none; }
.oimg { font-size:1.6rem; } .otext { flex:1; font-weight:700; }
.ord-btns { display:flex; flex-direction:column; gap:3px; }
.ord-btns button { width:30px; height:24px; border-radius:7px; border:1px solid var(--glass-border); background:var(--glass-strong); color:#fff; cursor:pointer; font-size:.7rem; }
.ord-btns button:hover { background: var(--accent); color:#5a3c00; }

/* Image */
.img-stage { display:grid; place-items:center; padding:10px; background: rgba(0,0,0,.18); border-radius:16px; min-height:180px; }
.img-stage img { max-width:100%; max-height:300px; border-radius:12px; transition: filter .6s; }
.img-stage .qemoji { transition: filter .6s; margin:0; }

/* Memory */
.mem-stage { min-height:80px; display:grid; place-items:center; }
/* Emoji sequences are direction-neutral; force LTR so the on-screen order
   matches the logical (array) order the server compares against. */
.mem-seq, .mem-built, .mem-pad { direction: ltr; }
.mem-seq { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.mem-cell { font-size:2rem; width:56px; height:56px; display:grid; place-items:center; border-radius:14px; background: rgba(255,255,255,.06); border:1px solid var(--glass-border); }
.mem-cell.flash { animation: memflash .8s; background: var(--purple); transform: scale(1.15); }
@keyframes memflash { 0%{transform:scale(.6);opacity:.3} 30%{transform:scale(1.2);opacity:1} 100%{transform:scale(1)} }
.mem-built { display:flex; gap:8px; flex-wrap:wrap; min-height:60px; padding:10px; border-radius:12px; background: rgba(255,255,255,.04); }
.mem-pad { display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.mem-key { font-size:1.8rem; width:60px; height:60px; border-radius:14px; border:1px solid var(--glass-border); background: rgba(255,255,255,.06); cursor:pointer; transition:.15s; }
.mem-key:hover { background: var(--purple); transform: translateY(-3px); }

/* Matching */
.match-wrap { display:grid; grid-template-columns:1fr 1fr; gap:30px; }
.match-col { display:flex; flex-direction:column; gap:10px; }
.match-item { padding:15px; border-radius:14px; border:2px solid var(--glass-border); background: rgba(255,255,255,.05); color:#fff; font-family:var(--font); font-weight:700; cursor:pointer; transition:.15s; }
.match-item:hover { background: rgba(255,255,255,.1); }
.match-item.sel { background: var(--purple); transform: scale(1.03); }

/* Odd one out */
.odd-grid { display:grid; grid-template-columns: repeat(2,1fr); gap:12px; }
.odd-tile { padding:24px; border-radius:16px; border:2px solid var(--glass-border); background: rgba(255,255,255,.05); color:#fff; font-family:var(--font-display); font-weight:700; font-size:1.15rem; cursor:pointer; transition:.15s; }
.odd-tile:hover:not([disabled]) { background: rgba(255,255,255,.1); transform: translateY(-3px); }
.odd-tile.correct { border-color: var(--ok); background: rgba(6,214,160,.2); }
.odd-tile.wrong { border-color: var(--danger); background: rgba(255,92,124,.18); animation: shake .4s; }

/* Anagram */
.ana-built { display:flex; gap:8px; flex-wrap:wrap; min-height:62px; padding:12px; border-radius:14px; background: rgba(255,255,255,.04); border:1px dashed var(--glass-border); align-items:center; justify-content:center; }
.ana-pool { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:14px; }
.ana-tile { width:52px; height:52px; display:grid; place-items:center; border-radius:12px; border:1px solid var(--glass-border); background: rgba(255,255,255,.07); color:#fff; font-family:var(--font-display); font-size:1.5rem; font-weight:900; cursor:pointer; transition:.15s; }
.ana-pool .ana-tile:hover { background: var(--accent); color:#5a3c00; transform: translateY(-3px); }
.ana-tile.filled { background: var(--purple); cursor:default; }

/* toast */
.toast { position: fixed; bottom: 24px; right: 50%; transform: translateX(50%) translateY(120px); z-index: 9998;
  background: var(--glass-strong); border:1px solid var(--glass-border); backdrop-filter: blur(14px);
  padding:14px 22px; border-radius:14px; font-weight:700; box-shadow: var(--shadow); transition: transform .4s cubic-bezier(.2,.8,.2,1); }
.toast.show { transform: translateX(50%) translateY(0); }
.toast.good{ border-color: var(--ok);} .toast.bad{ border-color: var(--danger);}
