/* ============================================================
   China Trip 2026 — QUESTS / FAMILY MODE v8.0
   Arabic gamified layer with challenges + prizes for the kids
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cairo+Play:wght@400;500;600;700;900&family=Cairo:wght@400;500;600;700;900&display=swap');

:root {
  --ar-display: 'Cairo Play', 'Cairo', system-ui, sans-serif;
  --ar-body:    'Cairo Play', 'Cairo', system-ui, sans-serif;

  --q-fares:    #ff7a3d;
  --q-youssef:  #4ec78f;
  --q-yassin:   #b48bff;
  --q-dina:     #ff5e8a;
  --q-mfz:      #f5b94a;

  --q-gold:     linear-gradient(135deg, #f5b94a, #ffd28a);
  --q-pop:      linear-gradient(135deg, #ff5e3a, #ff8c5a);
}

/* ──────────────────────────────────────────
   ARABIC HERO REWRITE
   ────────────────────────────────────────── */
[lang="ar"], [dir="rtl"] {
  font-family: var(--ar-body);
  letter-spacing: 0;
}

/* ──────────────────────────────────────────
   QUESTS SECTION
   ────────────────────────────────────────── */
.quests {
  padding: 5rem 1.5rem;
  position: relative;
  background: transparent;
  overflow: hidden;
  direction: rtl;
}
.quests::before {
  content: '';
  position: absolute;
  inset: -1px;
  background:
    radial-gradient(800px 400px at 80% 30%, rgba(255,94,58,0.18), transparent 60%),
    radial-gradient(700px 400px at 20% 70%, rgba(245,185,74,0.16), transparent 60%);
  pointer-events: none;
  z-index: 0;
}
.quests__inner { max-width: 1240px; margin: 0 auto; position: relative; z-index: 2; }

.quests__head {
  text-align: center;
  margin-bottom: 2.5rem;
}
.quests__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--q-gold);
  color: #1a0e00;
  padding: 6px 16px;
  border-radius: 999px;
  font-family: var(--ar-body);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 8px 24px rgba(245,185,74,0.4);
  margin-bottom: 1rem;
}
.quests__title {
  font-family: var(--ar-display) !important;
  font-size: clamp(2.4rem, 6vw, 4.4rem);
  font-weight: 400;
  line-height: 1.05;
  margin-bottom: 0.6rem;
  background: linear-gradient(180deg, #fff, #f5b94a 80%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 80px rgba(255,255,255,0.15);
}
.quests__sub {
  font-family: var(--ar-body);
  color: rgba(255,255,255,0.78);
  font-size: clamp(0.95rem, 2vw, 1.15rem);
  font-weight: 500;
  max-width: 640px;
  margin: 0 auto 1.2rem;
  line-height: 1.6;
}

/* ──────────────────────────────────────────
   FAMILY LEADERBOARD
   ────────────────────────────────────────── */
.leaderboard {
  background: rgba(20,18,28,0.55);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 24px;
  padding: 1.8rem 1.4rem;
  margin-bottom: 3rem;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.18) inset,
    0 24px 70px rgba(0,0,0,0.5);
  position: relative;
}
.leaderboard__title {
  font-family: var(--ar-display) !important;
  font-size: 1.6rem;
  color: #fff;
  text-align: center;
  margin-bottom: 1.4rem;
  letter-spacing: 0.01em;
}
.leaderboard__title::before { content: '🏆 '; margin-left: 6px; }

.players {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}
.player {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 18px;
  padding: 14px 10px;
  text-align: center;
  position: relative;
  transition: all .3s cubic-bezier(.32,.72,0,1);
  overflow: hidden;
}
.player::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), transparent 40%);
  pointer-events: none;
}
.player.leader {
  background: linear-gradient(180deg, rgba(245,185,74,0.18), rgba(245,185,74,0.04));
  border-color: rgba(245,185,74,0.55);
  box-shadow: 0 0 32px rgba(245,185,74,0.35), 0 1px 0 rgba(255,255,255,0.3) inset;
}
.player.leader::after {
  content: '👑';
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 22px;
  filter: drop-shadow(0 4px 12px rgba(245,185,74,0.6));
}
.player__avatar {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  margin: 0 auto 8px;
  background: var(--q-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 6px 20px rgba(0,0,0,0.4);
  position: relative;
  z-index: 2;
}
.player[data-key="fares"]   .player__avatar { background: linear-gradient(135deg, var(--q-fares), #ffaa78); }
.player[data-key="youssef"] .player__avatar { background: linear-gradient(135deg, var(--q-youssef), #6bdbb0); }
.player[data-key="yassin"]  .player__avatar { background: linear-gradient(135deg, var(--q-yassin), #d4b3ff); }
.player[data-key="dina"]    .player__avatar { background: linear-gradient(135deg, var(--q-dina), #ff8aab); }
.player[data-key="mfz"]     .player__avatar { background: linear-gradient(135deg, var(--q-mfz), #ffd28a); }

.player__name {
  font-family: var(--ar-display) !important;
  color: #fff;
  font-size: 1.1rem;
  font-weight: 400;
  margin-bottom: 4px;
  position: relative;
  z-index: 2;
}
.player__age {
  font-size: 0.65rem;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0.08em;
  margin-bottom: 8px;
  position: relative;
  z-index: 2;
}
.player__points {
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  font-size: 1.6rem;
  color: var(--q-mfz);
  line-height: 1;
  font-weight: 400;
  position: relative;
  z-index: 2;
}
.player__label {
  font-size: 0.62rem;
  color: rgba(255,255,255,0.50);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-top: 2px;
  position: relative;
  z-index: 2;
}

/* Pulsing animation when points increase */
.player.bumped { animation: bump 0.6s cubic-bezier(.34,1.56,.64,1); }
@keyframes bump {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.08) translateY(-4px); }
  100% { transform: scale(1) translateY(0); }
}

/* ──────────────────────────────────────────
   CITY GROUPS + QUEST CARDS
   ────────────────────────────────────────── */
.quest-group {
  margin-bottom: 2.5rem;
}
.quest-group__head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 1.2rem;
  padding-bottom: 0.7rem;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.quest-group__icon {
  font-size: 28px;
  filter: drop-shadow(0 4px 10px rgba(245,185,74,0.4));
}
.quest-group__title {
  font-family: var(--ar-display) !important;
  font-size: clamp(1.4rem, 3vw, 2rem);
  color: #fff;
  font-weight: 400;
  letter-spacing: 0;
  flex: 1;
}
.quest-group__progress {
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  color: var(--q-mfz);
  font-size: 1.05rem;
  white-space: nowrap;
}

.quest-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}

.quest-card {
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 20px;
  padding: 1.2rem 1.2rem 1.4rem;
  position: relative;
  overflow: hidden;
  transition: all .35s cubic-bezier(.32,.72,0,1);
  box-shadow: 0 1px 0 rgba(255,255,255,0.14) inset, 0 12px 40px rgba(0,0,0,0.3);
}
.quest-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), transparent 50%);
  pointer-events: none;
  border-radius: inherit;
}
.quest-card:hover {
  transform: translateY(-4px);
  border-color: rgba(245,185,74,0.55);
  box-shadow: 0 1px 0 rgba(255,255,255,0.22) inset, 0 18px 50px rgba(0,0,0,0.45), 0 0 40px rgba(245,185,74,0.18);
}
.quest-card.done {
  background: linear-gradient(135deg, rgba(78,199,143,0.18), rgba(78,199,143,0.05));
  border-color: rgba(78,199,143,0.5);
}
.quest-card.done::after {
  content: '✓';
  position: absolute;
  top: 12px;
  left: 12px;
  width: 32px;
  height: 32px;
  background: var(--q-youssef);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 18px;
  box-shadow: 0 6px 20px rgba(78,199,143,0.5);
}

.quest-card__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
  position: relative;
  z-index: 2;
}
.quest-card__icon {
  font-size: 32px;
  line-height: 1;
}
.quest-card__owner {
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  font-family: var(--ar-body);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  color: #fff;
  white-space: nowrap;
}
.quest-card[data-owner="fares"]   .quest-card__owner { background: rgba(255,122,61,0.22); border-color: var(--q-fares); }
.quest-card[data-owner="youssef"] .quest-card__owner { background: rgba(78,199,143,0.22); border-color: var(--q-youssef); }
.quest-card[data-owner="yassin"]  .quest-card__owner { background: rgba(180,139,255,0.22); border-color: var(--q-yassin); }
.quest-card[data-owner="dina"]    .quest-card__owner { background: rgba(255,94,138,0.22); border-color: var(--q-dina); }
.quest-card[data-owner="mfz"]     .quest-card__owner { background: rgba(245,185,74,0.22); border-color: var(--q-mfz); }
.quest-card[data-owner="all"]     .quest-card__owner { background: rgba(255,255,255,0.18); }

.quest-card__title {
  font-family: var(--ar-display) !important;
  font-size: 1.25rem;
  color: #fff;
  margin-bottom: 6px;
  font-weight: 400;
  line-height: 1.25;
  position: relative;
  z-index: 2;
}
.quest-card__desc {
  font-family: var(--ar-body);
  font-size: 0.85rem;
  color: rgba(255,255,255,0.78);
  line-height: 1.55;
  font-weight: 500;
  margin-bottom: 14px;
  position: relative;
  z-index: 2;
}
.quest-card__prize {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(245,185,74,0.10);
  border: 1px dashed rgba(245,185,74,0.45);
  border-radius: 12px;
  padding: 8px 12px;
  margin-bottom: 14px;
  font-family: var(--ar-body);
  font-size: 0.82rem;
  color: var(--q-mfz);
  font-weight: 700;
  position: relative;
  z-index: 2;
}
.quest-card__prize::before { content: '🎁'; font-size: 18px; }

.quest-btn {
  width: 100%;
  background: var(--q-gold);
  color: #1a0e00;
  border: none;
  border-radius: 14px;
  padding: 12px 16px;
  font-family: var(--ar-body);
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 8px 22px rgba(245,185,74,0.4);
  transition: all .25s cubic-bezier(.32,.72,0,1);
  position: relative;
  z-index: 2;
  -webkit-tap-highlight-color: transparent;
}
.quest-btn:hover { transform: translateY(-2px); box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset, 0 12px 32px rgba(245,185,74,0.6); }
.quest-btn:active { transform: scale(0.97); }
.quest-card.done .quest-btn {
  background: rgba(78,199,143,0.20);
  color: var(--q-youssef);
  box-shadow: 0 1px 0 rgba(255,255,255,0.18) inset;
}
.quest-card.done .quest-btn::before { content: '✓ '; }

/* Reset all button */
.quests__reset {
  display: block;
  margin: 2rem auto 0;
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.7);
  border: 1px solid rgba(255,255,255,0.16);
  padding: 10px 20px;
  border-radius: 999px;
  font-family: var(--ar-body);
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
}
.quests__reset:hover { background: rgba(255,255,255,0.12); color: #fff; }

/* ──────────────────────────────────────────
   PRIZE POPUP — celebration
   ────────────────────────────────────────── */
.prize-popup {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(8,7,10,0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 1000;
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s;
}
.prize-popup.show {
  opacity: 1;
  pointer-events: auto;
}
.prize-popup__card {
  background: linear-gradient(180deg, #1f1c2a, #15121e);
  border: 2px solid rgba(245,185,74,0.55);
  border-radius: 28px;
  padding: 2.4rem 2rem 2rem;
  max-width: 380px;
  width: 90vw;
  text-align: center;
  position: relative;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.25) inset,
    0 30px 90px rgba(0,0,0,0.7),
    0 0 80px rgba(245,185,74,0.4);
  transform: scale(0.85);
  transition: transform .45s cubic-bezier(.34,1.56,.64,1);
  direction: rtl;
}
.prize-popup.show .prize-popup__card { transform: scale(1); }
.prize-popup__icon {
  font-size: 64px;
  line-height: 1;
  margin-bottom: 12px;
  filter: drop-shadow(0 8px 24px rgba(245,185,74,0.6));
  animation: prizeBounce 1s cubic-bezier(.34,1.56,.64,1) infinite alternate;
}
@keyframes prizeBounce {
  from { transform: translateY(0) rotate(-3deg); }
  to   { transform: translateY(-8px) rotate(3deg); }
}
.prize-popup__title {
  font-family: var(--ar-display) !important;
  font-size: 2rem;
  color: var(--q-mfz);
  margin-bottom: 8px;
  font-weight: 400;
}
.prize-popup__sub {
  font-family: var(--ar-body);
  color: #fff;
  font-size: 1.05rem;
  font-weight: 500;
  margin-bottom: 6px;
}
.prize-popup__prize {
  font-family: var(--ar-body);
  color: var(--q-youssef);
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 18px;
  padding: 10px 14px;
  background: rgba(78,199,143,0.10);
  border: 1px dashed rgba(78,199,143,0.5);
  border-radius: 14px;
}
.prize-popup__close {
  background: var(--q-gold);
  color: #1a0e00;
  border: none;
  border-radius: 14px;
  padding: 12px 28px;
  font-family: var(--ar-body);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(245,185,74,0.4);
}

/* Confetti pieces */
.q-confetti {
  position: fixed;
  width: 10px;
  height: 14px;
  pointer-events: none;
  z-index: 1100;
  border-radius: 2px;
}

/* ──────────────────────────────────────────
   Mobile
   ────────────────────────────────────────── */
@media (max-width: 768px) {
  .players { grid-template-columns: repeat(5, 1fr); gap: 6px; }
  .player { padding: 10px 4px; }
  .player__avatar { width: 38px; height: 38px; font-size: 18px; margin-bottom: 4px; }
  .player__name { font-size: 0.78rem; margin-bottom: 0; }
  .player__age { font-size: 0.55rem; margin-bottom: 4px; }
  .player__points { font-size: 1.15rem; }
  .player__label { font-size: 0.5rem; letter-spacing: 0.1em; }
  .leaderboard { padding: 1.2rem 0.9rem; }
  .leaderboard__title { font-size: 1.25rem; }
  .quest-grid { grid-template-columns: 1fr; }
  .quests { padding: 3.5rem 1rem; }
  .quest-card { padding: 1rem 1rem 1.1rem; }
  .quest-card__title { font-size: 1.1rem; }
  .quest-card__desc { font-size: 0.8rem; }
  .prize-popup__card { padding: 2rem 1.4rem 1.6rem; }
  .prize-popup__title { font-size: 1.6rem; }
}

/* ──────────────────────────────────────────
   GLOBAL ARABIC FONT — apply to all readable text
   ────────────────────────────────────────── */
body,
.day-content,
.day-title,
.day-date,
.timeline,
.timeline li,
.stop,
.stop__name,
.stop__desc,
.info-card,
.info-card__label,
.info-card__title,
.info-card__detail,
.tip-box,
.cities-section,
.cities-section__title,
.cities-section__sub,
.events-section,
.event-card,
.event-card__title,
.event-card__desc,
.extras,
.extras h2,
.extras p,
.tips-list li,
.checklist label,
.phrase,
.app-tile,
.btn-maps,
.site-header__sub {
  font-family: 'Cairo Play', 'Cairo', system-ui, sans-serif !important;
}

/* RTL on Arabic content blocks */
[dir="rtl"] .day-content,
[dir="rtl"] .timeline,
[dir="rtl"] .stop,
[dir="rtl"] .info-card,
[dir="rtl"] .tip-box,
[dir="rtl"] .stops {
  direction: rtl;
  text-align: right;
}

[dir="rtl"] .timeline { padding: 1.4rem 2.6rem 1.4rem 1.4rem !important; }
[dir="rtl"] .timeline::before { left: auto !important; right: 1.5rem !important; }
[dir="rtl"] .timeline li::before { left: auto !important; right: -1.05rem !important; }
[dir="rtl"] .timeline .time { margin-right: 0; margin-left: 8px; }

[dir="rtl"] .info-card { border-left: none !important; border-right: 3px solid var(--accent-xian) !important; }
[dir="rtl"] .stop { flex-direction: row-reverse; }

/* Numbers + Latin tokens stay LTR within RTL */
[dir="rtl"] .ltr {
  direction: ltr;
  display: inline-block;
  unicode-bidi: isolate;
}

/* ──────────────────────────────────────────
   INLINE QUEST CARDS — placed inside day sections
   ────────────────────────────────────────── */
.day-quests {
  margin: 1.5rem 0 0.8rem !important;
  direction: rtl;
}
.day-quests__head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0.8rem;
  padding: 8px 14px;
  background: linear-gradient(135deg, rgba(245,185,74,0.18), rgba(255,94,58,0.10));
  border: 1px solid rgba(245,185,74,0.35);
  border-radius: 999px;
  font-family: 'Cairo Play', sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--q-mfz);
  width: max-content;
  box-shadow: 0 4px 16px rgba(245,185,74,0.18);
}
.day-quests__head::before { content: '🏆'; font-size: 18px; }

.day-quests__list {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .day-quests__list { grid-template-columns: repeat(2, 1fr); } }

.quest-inline {
  background: rgba(245,185,74,0.06);
  border: 1px solid rgba(245,185,74,0.30);
  border-radius: 16px;
  padding: 12px 14px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px 12px;
  align-items: center;
  font-family: 'Cairo Play', sans-serif;
  position: relative;
  transition: all .25s cubic-bezier(.32,.72,0,1);
  cursor: pointer;
}
.quest-inline:hover {
  background: rgba(245,185,74,0.10);
  border-color: rgba(245,185,74,0.55);
  transform: translateY(-2px);
}
.quest-inline.done {
  background: rgba(78,199,143,0.12);
  border-color: rgba(78,199,143,0.45);
}
.quest-inline.done::after {
  content: '✓';
  position: absolute;
  top: 8px;
  left: 8px;
  width: 22px;
  height: 22px;
  background: var(--q-youssef);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 13px;
  box-shadow: 0 4px 12px rgba(78,199,143,0.5);
}
.quest-inline__icon {
  font-size: 28px;
  line-height: 1;
}
.quest-inline__body { min-width: 0; }
.quest-inline__title {
  font-size: 0.9rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 2px;
  line-height: 1.3;
}
.quest-inline__meta {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.72);
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
}
.quest-inline__meta span::before { margin-left: 4px; }
.quest-inline__when::before { content: '🕒 '; }
.quest-inline__prize::before { content: '🎁 '; }
.quest-inline__points::before { content: '⭐'; }

.quest-inline__btn {
  background: var(--q-gold);
  color: #1a0e00;
  border: none;
  border-radius: 999px;
  padding: 8px 14px;
  font-family: 'Cairo Play', sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 4px 14px rgba(245,185,74,0.4);
  transition: all .2s;
}
.quest-inline__btn:hover { transform: translateY(-1px); }
.quest-inline.done .quest-inline__btn {
  background: rgba(78,199,143,0.20);
  color: var(--q-youssef);
  box-shadow: 0 1px 0 rgba(255,255,255,0.18) inset;
}
.quest-inline.done .quest-inline__btn::before { content: '✓ '; }

@media (max-width: 600px) {
  .quest-inline { grid-template-columns: auto 1fr; gap: 8px; padding: 10px 12px; }
  .quest-inline__btn { grid-column: 1 / -1; width: 100%; padding: 10px; }
  .quest-inline__icon { font-size: 24px; }
  .quest-inline__title { font-size: 0.85rem; }
  .quest-inline__meta { font-size: 0.7rem; }
}

/* ──────────────────────────────────────────
   QUEST-DAY (grouped by day with header)
   ────────────────────────────────────────── */
.quest-day {
  margin-bottom: 2.4rem;
  position: relative;
}
.quest-day__head {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 1.2rem;
  padding: 14px 18px;
  background: rgba(20,18,28,0.55);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.14) inset, 0 8px 24px rgba(0,0,0,0.3);
}
.quest-day__num {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: var(--q-gold);
  color: #1a0e00;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  font-size: 1.7rem;
  font-weight: 400;
  box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset, 0 8px 22px rgba(245,185,74,0.4);
}
.quest-day--bonus .quest-day__num {
  background: linear-gradient(135deg, #b48bff, #d4b3ff);
  color: #fff;
  box-shadow: 0 1px 0 rgba(255,255,255,0.4) inset, 0 8px 22px rgba(180,139,255,0.4);
}
.quest-day__info { flex: 1; min-width: 0; }
.quest-day__label {
  font-family: var(--ar-display) !important;
  font-size: 1.15rem;
  color: #fff;
  font-weight: 700;
  margin: 0 0 2px;
  line-height: 1.2;
}
.quest-day__sub {
  font-family: var(--ar-body);
  font-size: 0.82rem;
  color: rgba(255,255,255,0.7);
  margin: 0;
  font-weight: 500;
}
.quest-day__progress {
  font-family: 'Instrument Serif', Georgia, serif;
  font-style: italic;
  color: var(--q-mfz);
  font-size: 1.15rem;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Quest card — when chip */
.quest-card__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}
.quest-card__when {
  font-family: var(--ar-body);
  font-size: 0.68rem;
  color: var(--q-mfz);
  background: rgba(245,185,74,0.10);
  border: 1px solid rgba(245,185,74,0.3);
  padding: 3px 8px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

@media (max-width: 600px) {
  .quest-day__head { padding: 11px 14px; gap: 12px; }
  .quest-day__num { width: 40px; height: 40px; font-size: 1.4rem; border-radius: 12px; }
  .quest-day__label { font-size: 1rem; }
  .quest-day__sub { font-size: 0.75rem; }
  .quest-day__progress { font-size: 0.95rem; }
}
