:root {
  --bg: #0f1115;
  --panel: #181b22;
  --text: #f5f6f8;
  --muted: #8b92a1;
  --accent: #5b8cff;
  --accent-2: #2d3344;
  --font-scale: 1;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

.screen {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.hidden { display: none !important; }

/* ---- صفحه انتخاب زبان (هم‌سبکِ سایت) ---- */
#langScreen {
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 34px 20px;
  background: radial-gradient(1100px 520px at 50% -8%, rgba(91, 140, 255, .16), transparent 62%);
}
.lang-inner {
  width: 100%;
  max-width: 470px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  text-decoration: none;
  margin-bottom: 30px;
}
.brand-mark {
  width: 40px; height: 40px; border-radius: 12px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--accent), #7b5bff);
  box-shadow: 0 8px 22px rgba(91, 140, 255, .4);
}
.brand-mark svg { width: 22px; height: 22px; }
.brand-word { font-size: 21px; font-weight: 800; letter-spacing: -.4px; color: #eef2ff; }
.brand-word i {
  font-style: normal;
  background: linear-gradient(135deg, #6f9cff, #9a63ff, #ff7ad5);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
#hallName { font-size: 27px; font-weight: 800; letter-spacing: -.5px; margin-bottom: 8px; }
.subtitle-hint {
  color: var(--muted); margin-bottom: 26px; font-size: 14.5px;
  display: flex; gap: 8px; align-items: center; justify-content: center; flex-wrap: wrap;
}
.subtitle-hint .dot { opacity: .45; }
.lang-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 11px;
  width: 100%;
}
.lang-btn {
  background: var(--panel);
  border: 1px solid rgba(255, 255, 255, .08);
  color: var(--text);
  padding: 16px 14px;
  border-radius: 14px;
  font-size: 16.5px;
  font-weight: 600;
  cursor: pointer;
  transition: transform .12s, border-color .15s, background .15s, box-shadow .15s;
}
.lang-btn:hover { border-color: rgba(91, 140, 255, .55); background: #1c2030; box-shadow: 0 8px 22px rgba(0, 0, 0, .3); }
.lang-btn:active { transform: scale(.97); }
.wait-banner {
  margin-top: 22px; width: 100%;
  color: #cdd9ff;
  background: linear-gradient(135deg, rgba(91, 140, 255, .12), rgba(123, 91, 255, .08));
  border: 1px solid rgba(91, 140, 255, .28);
  border-radius: 14px;
  padding: 14px 16px;
  font-size: 13.5px;
  line-height: 1.55;
}
.muted { color: var(--muted); }

/* ---- صفحه زیرنویس ---- */
.live-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--panel);
  border-bottom: 1px solid var(--accent-2);
  position: sticky;
  top: 0;
  z-index: 20; /* همیشه بالای زیرنویس‌های اسکرول‌شونده بماند (وگرنه از زیرش معلوم می‌شوند) */
}
.brand-small { display: inline-flex; align-items: center; color: #eef2ff; font-weight: 800; font-size: 15px; letter-spacing: -.3px; }
.brand-small i { font-style: normal; background: linear-gradient(135deg, #6f9cff, #9a63ff, #ff7ad5); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.controls { display: flex; gap: 8px; align-items: center; }
.controls button, .controls select {
  background: var(--accent-2);
  color: var(--text);
  border: none;
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 14px;
  cursor: pointer;
}
.status-bar {
  background: rgba(255, 181, 84, .12);
  color: #ffc97a;
  border-bottom: 1px solid rgba(255, 181, 84, .2);
  padding: 9px 16px;
  text-align: center;
  font-size: 13.5px;
}

.subtitles {
  flex: 1;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  padding: 26px 18px 42vh;
  display: flex;
  flex-direction: column;
  gap: 13px;
  overflow-y: auto;
  text-align: start;
  /* لازم برای فلکس: تا زیرنویس‌ها داخلِ همین کادر اسکرول شوند، نه اینکه کلِ صفحه
     اسکرول شده و خط‌ها از پشتِ هدر (منوها) رد شوند و قاطی شوند. */
  min-height: 0;
}
.subtitles.waiting-mode { justify-content: center; padding-bottom: 26px; }

.line {
  text-align: start;
  line-height: 1.62;
  letter-spacing: .2px;
  opacity: 0;
  animation: fadeIn .3s ease forwards;
  transition: color .5s ease, font-size .4s ease;
  /* هنگام اسکرول به جدیدترین خط، این فاصله پایین می‌ماند تا زیرِ دکمهٔ شناورِ
     «عضویت/جوایز» پنهان نشود (روی موبایل دکمه پایینِ صفحه است). */
  scroll-margin-bottom: 96px;
}
.line.old {
  color: var(--muted);
  font-size: calc(18px * var(--font-scale));
}
.line.latest {
  color: #fff;
  font-size: calc(26px * var(--font-scale));
  font-weight: 600;
  padding: 15px 18px;
  border-radius: 16px;
  border: 1px solid rgba(91, 140, 255, .20);
  border-inline-start: 3px solid var(--accent);
  background: linear-gradient(135deg, rgba(91, 140, 255, .13), rgba(123, 91, 255, .07));
  box-shadow: 0 10px 34px rgba(0, 0, 0, .28);
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
/* پیش‌نمایش (هنوز در حالِ اصلاح): کمی محو + نشانگرِ «…» تا رسیدنِ نسخهٔ نهایی */
.line.latest.interim { color: #c7d2e6; border-inline-start-color: rgba(91, 140, 255, .45); }
.line.latest.interim::after { content: ' …'; opacity: .55; font-weight: 500; }

/* کارتِ انتظارِ خوش‌نقش پیش از شروعِ پخش — هم‌سبکِ سایت */
.waiting {
  align-self: center;
  width: 100%;
  max-width: 440px;
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  text-align: center;
  padding: 34px 26px;
  background: linear-gradient(135deg, rgba(91, 140, 255, .11), rgba(123, 91, 255, .06));
  border: 1px solid rgba(91, 140, 255, .26);
  border-radius: 20px;
  box-shadow: 0 16px 50px rgba(0, 0, 0, .35);
}
.waiting-ico {
  width: 62px; height: 62px; border-radius: 50%;
  display: grid; place-items: center; font-size: 28px;
  background: rgba(91, 140, 255, .16);
  border: 1px solid rgba(91, 140, 255, .32);
  animation: waitPulse 1.9s ease-in-out infinite;
}
.waiting-text { font-size: calc(15.5px * var(--font-scale)); line-height: 1.6; color: #cdd9ff; }
@keyframes waitPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(91, 140, 255, .35); } 50% { box-shadow: 0 0 0 12px rgba(91, 140, 255, 0); } }

/* نشانِ کوچکِ لوگو در هدرِ صفحهٔ زنده */
.brand-mark-sm {
  width: 26px; height: 26px; border-radius: 8px;
  display: inline-grid; place-items: center; vertical-align: middle; margin-inline-end: 8px;
  background: linear-gradient(135deg, var(--accent), #7b5bff);
  box-shadow: 0 4px 12px rgba(91, 140, 255, .4);
}
.brand-mark-sm svg { width: 15px; height: 15px; }

/* ---- آرشیو ---- */
.ghost-btn {
  margin-top: 28px; background: transparent; border: 1px solid var(--accent-2);
  color: var(--muted); padding: 12px 20px; border-radius: 12px; font-size: 15px; cursor: pointer;
}
.ghost-btn:hover { border-color: var(--accent); color: var(--text); }
.back-btn { background: var(--accent-2); color: var(--text); border: none; border-radius: 8px;
  width: 32px; height: 32px; font-size: 20px; line-height: 1; cursor: pointer; }
.archive-body { flex: 1; overflow-y: auto; padding: 16px 16px 30vh; display: flex; flex-direction: column; gap: 14px; }
.ar-search { width: 100%; padding: 12px 14px; border-radius: 12px; background: var(--panel);
  border: 1px solid var(--accent-2); color: var(--text); font-size: 15px; }
.ar-search:focus { outline: none; border-color: var(--accent); }
.archive-list { display: flex; flex-direction: column; gap: 10px; }
.archive-item { text-align: start; background: var(--panel); border: 1px solid var(--accent-2);
  border-radius: 12px; padding: 14px 16px; cursor: pointer; color: var(--text); }
.archive-item:hover { border-color: var(--accent); }
.ai-title { font-size: 16px; font-weight: 600; }
.ai-meta { color: var(--muted); font-size: 13px; margin-top: 4px; }
.ai-snippet { color: var(--muted); font-size: 13px; margin-top: 8px; line-height: 1.5; }
.ai-snippet b { color: var(--accent); }
.ae-video { position: relative; width: 100%; aspect-ratio: 16/9; border-radius: 12px;
  overflow: hidden; background: #000; }
.ae-video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.ae-langs { display: flex; flex-wrap: wrap; gap: 8px; position: sticky; top: 0; z-index: 2;
  background: var(--bg); padding: 4px 0 10px; border-bottom: 1px solid var(--line, rgba(255,255,255,.08)); }
.ae-lang { background: var(--accent-2); border: 1px solid transparent; color: var(--text);
  border-radius: 999px; padding: 7px 14px; font-size: 14px; font-weight: 600; cursor: pointer; }
.ae-lang.active { background: var(--accent); }
.ae-text { white-space: pre-wrap; line-height: 1.85; font-size: calc(17px * var(--font-scale));
  color: var(--text); }
/* ویدیوی یوتیوب: یک دکمهٔ کوچک ثانویه، نه نمایش بزرگ بالای صفحه */
.ae-video-btn { align-self: flex-start; background: transparent; border: 1px solid var(--accent);
  color: var(--accent); border-radius: 999px; padding: 9px 16px; font-size: 14px; font-weight: 600;
  cursor: pointer; margin-top: 6px; }
.ae-video-btn:active { transform: translateY(1px); }

/* ============================================================
   جوایز / کوییز / عضویت (گیمیفیکیشن)
   ============================================================ */
.rewards-fab {
  position: fixed; right: 16px; bottom: 18px; z-index: 150;
  display: inline-flex; align-items: center; gap: 7px;
  padding: 11px 15px; border: none; border-radius: 999px; cursor: pointer;
  background: linear-gradient(135deg, var(--accent), #7b5bff); color: #fff;
  box-shadow: 0 10px 30px rgba(91,140,255,.45); font: inherit; font-weight: 800;
}
.rewards-fab .rf-ico { font-size: 19px; line-height: 1; }
.rewards-fab .rf-label { font-size: 12.5px; font-weight: 700; letter-spacing: .1px; white-space: nowrap; }
.rewards-fab .rf-points { font-size: 14px; font-weight: 800; }
.rewards-fab:active { transform: scale(.95); }

.rewards-overlay {
  position: fixed; inset: 0; z-index: 200; background: var(--bg);
  display: flex; flex-direction: column;
  padding-top: env(safe-area-inset-top); animation: rwUp .22s ease;
}
@keyframes rwUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
.rewards-overlay.hidden { display: none; }
.rw-chip { background: rgba(91,140,255,.16); color: #cdd9ff; border: 1px solid rgba(91,140,255,.3);
  padding: 5px 11px; border-radius: 999px; font-size: 13px; font-weight: 700; }
.rw-chip b { font-weight: 800; }
/* گروهِ سمتِ راستِ هدرِ جوایز: امتیاز + دکمهٔ خروج */
.rw-head-actions { margin-left: auto; display: inline-flex; align-items: center; gap: 8px; }
.rw-logout-btn { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px;
  border-radius: 9px; background: rgba(255,255,255,.05); border: 1px solid var(--accent-2); color: #cdd6ea;
  cursor: pointer; padding: 0; transition: background .15s, border-color .15s, color .15s; }
.rw-logout-btn:hover { background: rgba(255,107,107,.12); border-color: rgba(255,107,107,.4); color: #ff8a8a; }
.rw-logout-btn:active { transform: scale(.94); }
.rw-logout-btn svg { width: 18px; height: 18px; }
.rewards-body { flex: 1; overflow-y: auto; padding: 16px; -webkit-overflow-scrolling: touch; }

/* آموزش (How it works) */
.how-cta { display: inline-flex; align-items: center; gap: 7px; margin: 2px auto 14px; padding: 9px 17px;
  background: rgba(91,140,255,.14); color: #cdd9ff; border: 1px solid rgba(91,140,255,.42);
  border-radius: 999px; font-size: 13.5px; font-weight: 700; cursor: pointer; }
.how-cta:hover { background: rgba(91,140,255,.22); border-color: var(--accent); }
#howBtnLive { font-weight: 800; background: rgba(91,140,255,.22); color: #dbe6ff; white-space: nowrap; }
.how-body { max-width: 540px; margin: 0 auto; }
.how-intro { color: var(--muted); font-size: 14px; line-height: 1.6; margin: 4px 0 16px; text-align: center; }
.how-step { background: var(--panel); border: 1px solid var(--accent-2); border-radius: 14px;
  padding: 14px 16px; margin-bottom: 11px; }
.how-step-t { font-size: 15.5px; font-weight: 700; margin-bottom: 5px; color: var(--text); }
.how-step-b { font-size: 13.5px; line-height: 1.7; color: var(--muted); }
.how-tip { background: rgba(91,140,255,.1); border: 1px solid rgba(91,140,255,.28); border-radius: 14px;
  padding: 13px 15px; font-size: 13px; line-height: 1.65; color: #cdd9ff; margin-top: 4px; }

/* auth */
.rw-auth .rw-card { max-width: 380px; margin: 18px auto; background: var(--panel);
  border: 1px solid var(--accent-2); border-radius: 18px; padding: 26px 22px; text-align: center; }
.rw-trophy { font-size: 40px; margin-bottom: 8px; }
.rw-auth h2 { font-size: 20px; margin: 0 0 6px; }
.rw-sub { color: var(--muted); font-size: 13.5px; line-height: 1.55; margin: 0 0 18px; }
.rw-input { width: 100%; box-sizing: border-box; background: var(--bg); border: 1px solid var(--accent-2);
  border-radius: 11px; padding: 12px 14px; color: var(--text); font: inherit; font-size: 15px; margin-bottom: 10px; }
.rw-input:focus { outline: none; border-color: var(--accent); }
.rw-err { color: #ff7a8a; font-size: 13px; margin: 2px 0 8px; }
.rw-btn { width: 100%; border: none; border-radius: 11px; padding: 13px; font: inherit; font-weight: 800;
  font-size: 15px; cursor: pointer; color: #fff; background: linear-gradient(135deg, var(--accent), #7b5bff); }
.rw-btn.ghost { background: transparent; border: 1px solid var(--accent-2); color: var(--muted); margin-top: 16px; }
.rw-btn:active { transform: scale(.99); }
.rw-switch { font-size: 13.5px; color: var(--muted); margin: 14px 0 0; }
.rw-switch a { color: var(--accent); font-weight: 700; text-decoration: none; }

/* tabs */
.rw-tabs { display: flex; gap: 6px; background: var(--panel); border: 1px solid var(--accent-2);
  border-radius: 13px; padding: 5px; margin-bottom: 14px; position: sticky; top: 0; z-index: 2; }
.rw-tab { flex: 1; border: none; background: transparent; color: var(--muted); font: inherit; font-weight: 700;
  font-size: 13.5px; padding: 9px 4px; border-radius: 9px; cursor: pointer; }
.rw-tab.active { background: linear-gradient(135deg, var(--accent), #7b5bff); color: #fff; }
.rw-pane { animation: rwUp .2s ease; }
.rw-empty { text-align: center; color: var(--muted); padding: 36px 16px; font-size: 14px; }

/* quiz */
/* شمارشِ معکوسِ ۲ دقیقه‌ایِ کوییز */
.rw-quiz-timer { position: sticky; top: 0; z-index: 5; align-self: flex-start; margin: 0 0 12px;
  display: inline-block; padding: 6px 14px; border-radius: 999px; font-size: 15px; font-weight: 800;
  letter-spacing: .3px; color: #cdd9ff; background: rgba(91,140,255,.16); border: 1px solid rgba(91,140,255,.35); }
.rw-quiz-timer.low { color: #ffd07a; background: rgba(255,176,32,.16); border-color: rgba(255,176,32,.45); animation: pulseTimer 1s infinite; }
.rw-quiz-timer.expired { color: #ff9a9a; background: rgba(255,107,107,.14); border-color: rgba(255,107,107,.4); }
@keyframes pulseTimer { 50% { opacity: .55; } }
.rw-q.expired { opacity: .6; }
.rw-q { background: var(--panel); border: 1px solid var(--accent-2); border-radius: 15px; padding: 16px; margin-bottom: 12px; position: relative; }
.rw-q-num { position: absolute; top: -9px; left: 14px; width: 24px; height: 24px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), #7b5bff); color: #fff; font-size: 12px; font-weight: 800;
  display: grid; place-items: center; }
.rw-q-text { font-size: 16px; font-weight: 600; margin: 4px 0 12px; line-height: 1.5; }
.rw-opts { display: flex; flex-direction: column; gap: 8px; }
.rw-opt { text-align: start; background: var(--bg); border: 1px solid var(--accent-2); color: var(--text);
  border-radius: 11px; padding: 12px 14px; font: inherit; font-size: 14.5px; cursor: pointer; transition: border-color .15s, background .15s; }
.rw-opt:not(:disabled):hover { border-color: var(--accent); }
.rw-opt:disabled { opacity: .7; cursor: default; }
.rw-opt.correct { border-color: #46c98c; background: rgba(70,201,140,.15); }
.rw-opt.wrong { border-color: #ff6b6b; background: rgba(255,107,107,.13); }
.rw-q-res { margin-top: 10px; font-size: 13.5px; font-weight: 700; }
.rw-q-res.ok { color: #46c98c; } .rw-q-res.no { color: #ff8a8a; }

/* store */
.rw-item { display: flex; align-items: center; gap: 12px; background: var(--panel); border: 1px solid var(--accent-2);
  border-radius: 14px; padding: 14px; margin-bottom: 10px; }
.rw-item-main { flex: 1; min-width: 0; }
.rw-item-name { font-size: 15.5px; font-weight: 700; }
.rw-item-desc { font-size: 13px; color: var(--muted); margin-top: 3px; }
.rw-item-side { text-align: end; flex: none; }
.rw-item-cost { font-size: 13px; font-weight: 800; color: #ffd166; margin-bottom: 7px; white-space: nowrap; }
.rw-item-btn { border: none; border-radius: 10px; padding: 9px 14px; font: inherit; font-weight: 700; font-size: 13px;
  color: #fff; background: linear-gradient(135deg, var(--accent), #7b5bff); cursor: pointer; white-space: nowrap; }
.rw-item-btn:disabled { background: var(--accent-2); color: var(--muted); cursor: default; }
.rw-item-btn.done { background: #46c98c; }

/* leaderboard */
.rw-myrank { display: flex; align-items: center; gap: 10px; background: linear-gradient(135deg, rgba(91,140,255,.16), rgba(123,91,255,.1));
  border: 1px solid rgba(91,140,255,.3); border-radius: 13px; padding: 13px 16px; margin-bottom: 14px; }
.rw-myrank b { font-size: 19px; } .rw-myrank-pts { margin-inline-start: auto; color: var(--muted); font-weight: 700; }
.rw-board-row { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-bottom: 1px solid var(--accent-2); }
.rw-board-row.mine { background: rgba(91,140,255,.1); border-radius: 10px; }
.rw-rank { width: 30px; font-weight: 800; font-size: 15px; }
.rw-bname { flex: 1; min-width: 0; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rw-bpts { color: #ffd166; font-weight: 800; font-size: 13.5px; }

/* me */
.rw-me-head { text-align: center; padding: 10px 0 18px; }
.rw-me-name { font-size: 19px; font-weight: 800; }
.rw-me-stats { color: var(--muted); margin-top: 4px; font-size: 14px; }
.rw-me-pts { color: #ffd166; font-weight: 800; font-size: 17px; }
.rw-sec-title { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); font-weight: 800; margin: 14px 0 8px; }
.rw-red-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; background: var(--panel);
  border: 1px solid var(--accent-2); border-radius: 11px; padding: 11px 13px; margin-bottom: 7px; font-size: 14px; }
.rw-red-note { color: var(--muted); font-size: 11.5px; text-align: end; }
.rw-tx-row { display: flex; justify-content: space-between; padding: 9px 2px; border-bottom: 1px solid var(--accent-2); font-size: 14px; }
.rw-tx-row .pos { color: #46c98c; font-weight: 700; } .rw-tx-row .neg { color: #ff8a8a; font-weight: 700; }

/* جعبهٔ ویجتِ کپچا (Turnstile) */
.cf-box { margin: 4px auto 2px; display: flex; justify-content: center; }
.cf-box:empty { display: none; }

/* ردیفِ نام/فامیل و موبایلِ ثبت‌نامِ حضار */
.rw-2col { display: flex; gap: 8px; }
.rw-2col .rw-input { margin-bottom: 10px; }
.rw-phone { display: flex; gap: 8px; align-items: start; }
.rw-phone .rw-phone-num { flex: 1; }
/* منوی کشویی سفارشیِ کدِ کشور — هم‌سبکِ کارت‌های سایت */
.rw-cc { position: relative; flex: 0 0 auto; }
.rw-cc-btn { display: flex; align-items: center; gap: 6px; justify-content: space-between;
  min-width: 104px; background: var(--bg); border: 1px solid var(--accent-2); border-radius: 11px;
  padding: 12px 12px; color: var(--text); font: inherit; font-size: 15px; cursor: pointer; }
.rw-cc-btn:hover { border-color: var(--accent); }
.rw-cc-label { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 110px; }
.rw-cc-caret { color: var(--muted); font-size: 11px; flex: none; }
.rw-cc-pop { position: absolute; z-index: 60; top: calc(100% + 6px); left: 0; width: 280px; max-width: 76vw;
  background: var(--panel); border: 1px solid var(--accent-2); border-radius: 12px;
  box-shadow: 0 16px 44px rgba(0,0,0,.5); overflow: hidden; }
.rw-cc-search { width: 100%; box-sizing: border-box; background: var(--bg); border: none;
  border-bottom: 1px solid var(--accent-2); color: var(--text); font: inherit; font-size: 14px; padding: 11px 14px; }
.rw-cc-search:focus { outline: none; }
.rw-cc-list { list-style: none; margin: 0; padding: 5px; max-height: 240px; overflow-y: auto; }
.rw-cc-list li { display: flex; justify-content: space-between; gap: 10px; align-items: center;
  padding: 10px 12px; border-radius: 8px; cursor: pointer; font-size: 14px; }
.rw-cc-list li:hover { background: rgba(91,140,255,.15); }
.rw-cc-list li .cc-dial { color: var(--muted); flex: none; }

/* تغییر/بازنشانیِ رمزِ عضو */
.rw-cp { display: flex; flex-direction: column; gap: 8px; margin: 4px 0 14px; }
.rw-cp input { width: 100%; padding: 11px 12px; border: 1px solid var(--rw-border, #d8dee9); border-radius: 10px; font-size: 15px; background: var(--rw-input-bg, #fff); color: inherit; box-sizing: border-box; }
.rw-cp-msg { font-size: 13px; color: var(--rw-muted, #6b7280); min-height: 16px; }
.rw-forgot { display: inline-block; margin-top: 10px; font-size: 13px; color: var(--rw-accent, #2563eb); text-decoration: none; text-align: center; width: 100%; }
.rw-forgot.hidden { display: none; }
.rw-reset-overlay { position: fixed; inset: 0; z-index: 9999; background: rgba(15,23,42,.55); display: flex; align-items: center; justify-content: center; padding: 20px; }
.rw-reset-card { background: var(--rw-card, #fff); color: var(--rw-text, #0f172a); border-radius: 16px; padding: 22px; width: 100%; max-width: 360px; box-shadow: 0 20px 50px rgba(0,0,0,.3); display: flex; flex-direction: column; gap: 10px; }
.rw-reset-card h3 { margin: 0 0 4px; font-size: 18px; }
.rw-reset-card input { width: 100%; padding: 12px; border: 1px solid var(--rw-border, #d8dee9); border-radius: 10px; font-size: 15px; box-sizing: border-box; }

/* انتخابِ زبانِ کوییز در فرمِ ثبت‌نام */
.rw-lang-row { display: flex; flex-direction: column; gap: 4px; text-align: left; margin: 2px 0 2px; }
.rw-lang-row > span { font-size: 12px; color: var(--rw-muted, #6b7280); padding-left: 2px; }
.rw-lang-row.hidden { display: none; }
.rw-lang-row select.rw-input { width: 100%; }

/* کوییزِ ترتیبی: یک سوال در هر لحظه + تایمرِ ۹۰ ثانیه‌ایِ هر سوال */
.rw-q.locked { display: none; }                 /* سوالِ هنوز نرسیده پنهان است */
.rw-q.active { border-color: var(--brand, #4a8cff); box-shadow: 0 0 0 2px rgba(74,140,255,.22); }
.rw-q-head { display: flex; justify-content: flex-end; align-items: center; min-height: 16px; margin-bottom: 2px; }
.rw-q-timer { font-size: 13px; font-weight: 700; color: var(--muted, #9aa4b2); background: rgba(255,255,255,.06); border: 1px solid var(--accent-2, rgba(255,255,255,.12)); border-radius: 999px; padding: 3px 10px; }
.rw-q-timer.low { color: #ffd07a; background: rgba(255,176,32,.16); border-color: rgba(255,176,32,.45); animation: pulseTimer 1s infinite; }
.rw-q-timer.expired { color: #ff9a9a; background: rgba(255,107,107,.14); border-color: rgba(255,107,107,.4); }

/* دکمهٔ اتصالِ دوباره (رفرشِ ترجمه) */
#refreshBtn.spinning { animation: imtspin .7s linear; }
@keyframes imtspin { to { transform: rotate(360deg); } }

/* دکمهٔ صدا: وقتی روشن است سبز و کمی نورانی می‌شود */
#voiceBtn.voice-on { background: var(--green, #2ea567); color: #fff; box-shadow: 0 0 0 2px rgba(46,165,103,.35); }

/* ============================================================
   سایتِ عمومیِ کلیسا (?org=slug) — هدر/هیرو/درباره/وبلاگ/رویدادها/فوتر
   ============================================================ */
/* ── متغیرهای مشترکِ تمِ پریمیومِ تیره (روی هر سه صفحهٔ سایتِ کلیسا) ── */
#churchScreen, #postsArchiveScreen, #postEntryScreen {
  --cs-serif: 'Iowan Old Style', 'Palatino Linotype', Palatino, Georgia, 'Times New Roman', serif;
  --cs-card: linear-gradient(180deg, rgba(40,45,59,.92), rgba(23,26,34,.94));
  --cs-line: rgba(255,255,255,.09);
  --cs-line-2: rgba(255,255,255,.17);
  --cs-shadow: 0 18px 42px -20px rgba(0,0,0,.72);
}
#churchScreen { display: block; min-height: 100vh; color: var(--text);
  background: radial-gradient(1100px 560px at 50% -8%, #1b2233 0%, rgba(13,15,20,0) 58%), #0d0f14; }
#postsArchiveScreen, #postEntryScreen {
  background: radial-gradient(1100px 560px at 50% -8%, #1b2233 0%, rgba(13,15,20,0) 58%), #0d0f14; }

.cs-header { position: sticky; top: 0; z-index: 20; background: rgba(13,15,20,.72);
  backdrop-filter: blur(16px) saturate(1.2); -webkit-backdrop-filter: blur(16px) saturate(1.2);
  border-bottom: 1px solid var(--cs-line); }
.cs-header-in { max-width: 1120px; margin: 0 auto; padding: 14px 22px;
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.cs-brand { display: flex; align-items: center; gap: 11px; min-width: 0; margin-right: auto; }
.cs-logo { height: 36px; width: 36px; border-radius: 10px; object-fit: cover; flex: none;
  border: 1px solid var(--cs-line-2); box-shadow: 0 2px 8px rgba(0,0,0,.4); }
.cs-name { font-family: var(--cs-serif); font-weight: 700; font-size: 19px; letter-spacing: .2px;
  color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cs-nav { display: flex; gap: 4px; flex-wrap: wrap; }
.cs-nav-a { color: var(--muted); text-decoration: none; font-size: 13.5px; font-weight: 600; letter-spacing: .2px;
  padding: 8px 13px; border-radius: 9px; transition: color .15s, background .15s; }
.cs-nav-a:hover { color: #fff; background: rgba(255,255,255,.06); }

.cs-scroll { display: block; }

/* هیرو: تمام‌قد، سینمایی، با لایه‌های گرادیان روی عکسِ کاور */
.cs-hero { position: relative; isolation: isolate; overflow: hidden;
  background-color: #0e1016; background-image: linear-gradient(135deg, #202a3e, #0e1016);
  background-size: cover; background-position: center; }
.cs-hero-overlay { position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(13,15,20,.35) 0%, rgba(13,15,20,.74) 58%, #0d0f14 100%); }
.cs-hero::after { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(120% 78% at 50% 0%, rgba(91,140,255,.18), transparent 60%); }
.cs-hero-in { position: relative; z-index: 2; max-width: 920px; margin: 0 auto;
  padding: clamp(64px, 12vw, 112px) 22px clamp(52px, 8vw, 80px);
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 18px; }
.cs-hero-logo { height: 92px; width: 92px; border-radius: 20px; object-fit: cover;
  box-shadow: 0 16px 40px rgba(0,0,0,.55); border: 1px solid rgba(255,255,255,.16); }
.cs-hero-in h1 { font-family: var(--cs-serif); font-size: clamp(30px, 6vw, 52px); font-weight: 700;
  color: #fff; line-height: 1.08; letter-spacing: .3px; text-shadow: 0 2px 30px rgba(0,0,0,.5); }
.cs-hero-about { color: #cdd3e0; font-size: clamp(15px, 2.3vw, 17.5px); max-width: 600px; line-height: 1.65; }
.cs-cta { margin-top: 8px; background: linear-gradient(135deg, var(--accent), #7b5bff); color: #fff;
  border: none; padding: 14px 30px; border-radius: 999px; font-size: 15px; font-weight: 700; letter-spacing: .3px; cursor: pointer;
  box-shadow: 0 10px 30px rgba(91,140,255,.4), inset 0 1px 0 rgba(255,255,255,.25);
  transition: transform .12s, box-shadow .2s, filter .15s; }
.cs-cta:hover { filter: brightness(1.07); transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(91,140,255,.5), inset 0 1px 0 rgba(255,255,255,.25); }
.cs-cta:active { transform: translateY(0); }

.cs-main { max-width: 1120px; margin: 0 auto; padding: 10px 22px 56px; }
.cs-sec { padding: 44px 0; border-top: 1px solid var(--cs-line); }
.cs-sec:first-child { border-top: none; }
.cs-sec-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 22px; }
.cs-sec > h2, .cs-sec-head h2 { font-family: var(--cs-serif); font-size: clamp(22px, 3.2vw, 28px);
  font-weight: 700; color: #fff; letter-spacing: .2px; position: relative; padding-bottom: 10px; }
.cs-sec > h2 { margin-bottom: 22px; }
.cs-sec > h2::after, .cs-sec-head h2::after { content: ''; position: absolute; left: 0; bottom: 0;
  width: 44px; height: 3px; border-radius: 3px; background: linear-gradient(90deg, var(--accent), #7b5bff); }
.cs-seeall { background: none; border: none; color: var(--accent); font-size: 14px; font-weight: 600;
  cursor: pointer; padding: 6px 4px; white-space: nowrap; transition: color .15s; }
.cs-seeall:hover { color: #fff; }
.cs-empty { color: var(--muted); font-size: 14px; padding: 10px 0; }

.cs-about-text { color: #c8cedb; font-size: 16px; line-height: 1.8; white-space: pre-wrap; max-width: 760px; }
.cs-contact { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.cs-c { display: inline-flex; align-items: center; gap: 7px; background: rgba(255,255,255,.04);
  border: 1px solid var(--cs-line); color: #e7ebf3; text-decoration: none; padding: 9px 15px;
  border-radius: 999px; font-size: 13.5px; font-weight: 600; transition: border-color .15s, background .15s, transform .1s; }
.cs-c:hover { border-color: rgba(91,140,255,.6); background: rgba(91,140,255,.1); transform: translateY(-1px); }

/* کارتِ سخنرانی — با دیسکِ ▶ و افکتِ بلندشدنِ نرم */
.cs-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; }
.cs-card { position: relative; text-align: left; background: var(--cs-card); border: 1px solid var(--cs-line);
  border-radius: 16px; padding: 18px; cursor: pointer; color: var(--text); box-shadow: var(--cs-shadow);
  overflow: hidden; transition: border-color .18s, transform .12s, box-shadow .18s; }
.cs-card::before { content: ''; position: absolute; inset: 0 0 auto 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent); }
.cs-card:hover { border-color: rgba(91,140,255,.5); transform: translateY(-3px);
  box-shadow: 0 24px 50px -20px rgba(0,0,0,.82), 0 0 0 1px rgba(91,140,255,.15); }
.cs-card:active { transform: translateY(0); }
.cs-sermon { padding-left: 62px; }
.cs-sermon::after { content: '▶'; position: absolute; left: 16px; top: 50%; transform: translateY(-50%);
  width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-size: 11px;
  color: #cdd9ff; background: rgba(91,140,255,.16); border: 1px solid rgba(91,140,255,.4); }
.cs-card-t { font-weight: 700; font-size: 15.5px; line-height: 1.35; margin-bottom: 7px; color: #fff; }
.cs-card-m { color: var(--muted); font-size: 12.5px; letter-spacing: .2px; }

.cs-posts { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.cs-post { position: relative; background: var(--cs-card); border: 1px solid var(--cs-line);
  border-radius: 18px; overflow: hidden; cursor: pointer; box-shadow: var(--cs-shadow);
  transition: border-color .18s, transform .12s, box-shadow .18s; }
.cs-post:hover { border-color: rgba(91,140,255,.5); transform: translateY(-3px);
  box-shadow: 0 24px 50px -20px rgba(0,0,0,.82); }
.cs-post:active { transform: translateY(0); }
.cs-post-img { width: 100%; height: 190px; object-fit: cover; display: block; background: #0c0e13; }
.cs-post-body { padding: 18px 20px 22px; }
.cs-post-body h3 { font-family: var(--cs-serif); font-size: 19px; font-weight: 700; color: #fff; line-height: 1.3; }
.cs-post-date { color: var(--muted); font-size: 12px; letter-spacing: .4px; text-transform: uppercase; margin: 6px 0 11px; }
.cs-post-body p { color: #c4cad7; font-size: 14.5px; line-height: 1.7; }

.cs-events { display: flex; flex-direction: column; gap: 16px; }
.cs-event { position: relative; display: flex; gap: 18px; align-items: flex-start;
  background: var(--cs-card); border: 1px solid var(--cs-line); border-radius: 16px;
  padding: 20px 22px; box-shadow: var(--cs-shadow); overflow: hidden;
  transition: border-color .18s, transform .12s; }
.cs-event.up:hover { border-color: rgba(91,140,255,.4); transform: translateY(-2px); }
/* بلوکِ تقویمی (روز + ماه) */
.cs-ev-cal { flex: none; width: 66px; text-align: center; padding: 11px 0; border-radius: 13px;
  background: rgba(255,255,255,.04); border: 1px solid var(--cs-line); }
.cs-event.up .cs-ev-cal { background: linear-gradient(180deg, rgba(91,140,255,.22), rgba(91,140,255,.07));
  border-color: rgba(91,140,255,.4); }
.cs-ev-day { display: block; font-family: var(--cs-serif); font-size: 27px; font-weight: 700; color: #fff; line-height: 1; }
.cs-ev-mon { display: block; margin-top: 4px; font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1.2px; color: #9fb4ff; }
.cs-event:not(.up) .cs-ev-mon { color: var(--muted); }
.cs-ev-main { min-width: 0; flex: 1; }
.cs-ev-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cs-event h3 { font-family: var(--cs-serif); font-size: 18.5px; font-weight: 700; color: #fff; line-height: 1.3; }
.cs-event-badge { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px;
  color: #cdd9ff; background: rgba(91,140,255,.16); border: 1px solid rgba(91,140,255,.4); padding: 2px 9px; border-radius: 999px; }
.cs-ev-meta { color: var(--muted); font-size: 13px; margin-top: 8px; }
.cs-event p { color: #c4cad7; font-size: 14.5px; line-height: 1.7; margin-top: 12px; }

.cs-footer { border-top: 1px solid var(--cs-line);
  background: linear-gradient(180deg, rgba(255,255,255,.02), transparent);
  padding: 40px 22px 48px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.cs-foot-name { font-family: var(--cs-serif); font-weight: 700; font-size: 19px; color: #fff; }
.cs-foot-contact { display: flex; flex-wrap: wrap; justify-content: center; gap: 9px; }
.cs-powered { color: var(--muted); text-decoration: none; font-size: 12.5px; margin-top: 8px; opacity: .85; transition: opacity .15s; }
.cs-powered:hover { opacity: 1; }
.cs-powered b { color: #fff; font-weight: 700; }
.cs-powered i { color: var(--accent); font-style: normal; }

@media (max-width: 640px) {
  /* هدر: نام و دکمهٔ ورود در ردیفِ اول؛ منو در ردیفِ دومِ افقیِ قابل‌اسکرول */
  .cs-header-in { gap: 10px 12px; padding: 11px 15px; }
  .cs-nav { order: 3; width: 100%; overflow-x: auto; flex-wrap: nowrap; white-space: nowrap;
    gap: 2px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .cs-nav::-webkit-scrollbar { display: none; }
  .cs-nav-a { padding: 7px 12px; font-size: 13.5px; flex: none; }
  .cs-name { font-size: 17px; }
  .cs-main { padding: 6px 16px 40px; }
  .cs-sec { padding: 32px 0; }
  .cs-sermon { padding-left: 56px; }
  .cs-account { padding: 9px 15px; font-size: 13px; }
  .cs-event { padding: 16px; gap: 14px; }
  .cs-ev-cal { width: 58px; padding: 9px 0; }
  .cs-ev-day { font-size: 24px; }
  .cs-event h3 { font-size: 17px; }
}

/* --- سایتِ کلیسا: حساب/ورود + آرشیوِ وبلاگ + پستِ کامل --- */
.cs-account { background: linear-gradient(135deg, var(--accent), #7b5bff); color: #fff; border: none;
  border-radius: 999px; padding: 10px 18px; font-size: 13.5px; font-weight: 700; letter-spacing: .2px; cursor: pointer; white-space: nowrap; flex: none;
  box-shadow: 0 6px 18px rgba(91,140,255,.35), inset 0 1px 0 rgba(255,255,255,.25); transition: filter .15s, transform .12s; }
.cs-account:hover { filter: brightness(1.07); transform: translateY(-1px); }
.cs-account.in { background: rgba(255,255,255,.05); border: 1px solid var(--cs-line-2); color: var(--text); box-shadow: none;
  display: inline-flex; align-items: center; gap: 9px; padding: 5px 14px 5px 5px; }
.cs-acc-ava { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), #7b5bff);
  color: #fff; display: grid; place-items: center; font-size: 12.5px; font-weight: 800; flex: none; }
.cs-acc-name { max-width: 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 600; }

.cs-members-hint { display: inline-block; margin-top: 18px; background: rgba(91,140,255,.1);
  border: 1px solid rgba(91,140,255,.3); color: #aebfe8; border-radius: 12px; padding: 11px 17px;
  font-size: 13.5px; font-weight: 600; cursor: pointer; transition: background .15s; }
.cs-members-hint:hover { background: rgba(91,140,255,.18); }

.cs-loadmore { display: block; margin: 28px auto 8px; background: rgba(255,255,255,.04); border: 1px solid var(--cs-line-2);
  color: #fff; border-radius: 999px; padding: 12px 30px; font-size: 14px; font-weight: 600; cursor: pointer; transition: border-color .15s, background .15s; }
.cs-loadmore:hover { border-color: rgba(91,140,255,.6); background: rgba(91,140,255,.1); }

.cs-post-full { max-width: 740px; margin: 0 auto; padding: 10px 4px 56px; }
.cs-post-full-img { width: 100%; max-height: 420px; object-fit: cover; border-radius: 18px; margin-bottom: 26px; background: #0c0e13; }
.cs-post-full h1 { font-family: var(--cs-serif); font-size: clamp(26px, 5vw, 38px); font-weight: 700; color: #fff; line-height: 1.18; }
.cs-post-full .cs-post-date { margin: 10px 0 0; }
.cs-post-text { color: #cfd5e1; font-size: 17px; line-height: 1.85; margin-top: 22px; white-space: pre-wrap; }
#postsArchiveScreen .archive-body, #postEntryScreen .archive-body { max-width: 980px; margin: 0 auto; }
