/* ============ 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; }

/* ============ 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);}
