/* ============================================================
   IqraSpace — Home / Hero redesign, Top bar, Language switcher
   Emerald + Gold modern Islamic theme
   ============================================================ */

/* ---------- App loader with PNG logo ---------- */
.app-loader .loader-logo {
  width: 88px; height: 88px;
  border-radius: 22px;
  object-fit: contain;
  box-shadow: 0 8px 30px rgba(12,124,89,.35);
}

/* ---------- Nav logo PNG ---------- */
.nav-logo-img {
  width: 52px; height: 52px;
  object-fit: contain;
  border-radius: 10px;
  transition: transform .25s var(--ease);
}
.nav-brand:hover .nav-logo-img { transform: scale(1.06); }
/* Remove old .brand-mark gradient on home-page transparent nav */
.home-page .site-nav:not(.is-scrolled) .nav-logo-img { filter: drop-shadow(0 2px 10px rgba(0,0,0,.35)); }

/* ---------- Drawer logo ---------- */
.drawer-logo { display: flex; justify-content: center; padding-bottom: .5rem; border-bottom: 1px solid var(--c-border); }
.drawer-logo img { width: 80px; height: 80px; object-fit: contain; }

/* ---------- Footer brand with PNG ---------- */
.footer-brand { display: flex; align-items: center; gap: .9rem; margin-bottom: .9rem; }
.footer-brand img { width: 64px; height: 64px; object-fit: contain; border-radius: 12px; }
.footer-brand-text { font-family: var(--ff-heading); font-size: 1.1rem; font-weight: 800; color: var(--c-text); }
[data-theme="dark"] .footer-brand img { filter: brightness(1.05); }

/* ---------- Top utility bar ---------- */
.topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--top-h);
  z-index: 130;
  background: linear-gradient(90deg, var(--c-hero-2), var(--c-primary-700));
  color: #EAF6EF;
  font-size: 0.82rem;
  display: flex;
  align-items: center;
  transition: transform .35s var(--ease);
  box-shadow: inset 0 -1px 0 rgba(255,255,255,.06);
}
.topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; width: 100%; }
.topbar-left, .topbar-right { display: flex; align-items: center; gap: 1.25rem; }
.topbar-item { display: inline-flex; align-items: center; gap: .5rem; color: #EAF6EF; }
.topbar-item svg { width: 15px; height: 15px; color: var(--c-secondary); }
.topbar-item strong { font-weight: 600; }
a.topbar-item:hover { color: #fff; }
.topbar-social { display: inline-flex; gap: .35rem; }
.topbar-social a {
  width: 26px; height: 26px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.10); color: #fff; transition: background .2s, transform .2s;
}
.topbar-social a svg { width: 13px; height: 13px; }
.topbar-social a:hover { background: var(--c-secondary); transform: translateY(-1px); }

/* ---------- Language switcher ---------- */
.lang-switch { position: relative; }
.lang-current {
  display: inline-flex; align-items: center; gap: .45rem;
  background: rgba(255,255,255,.12); color: #fff;
  border: 1px solid rgba(255,255,255,.18);
  padding: .3rem .7rem; border-radius: var(--r-full);
  font: inherit; font-size: .82rem; cursor: pointer; transition: background .2s;
}
.lang-current:hover { background: rgba(255,255,255,.22); }
.lang-current .globe { display: inline-flex; }
.lang-current .globe svg { width: 15px; height: 15px; color: var(--c-secondary); }
.lang-current .chev { width: 14px; height: 14px; transition: transform .25s; }
.lang-switch.is-open .chev { transform: rotate(180deg); }
.lang-menu {
  position: absolute; top: calc(100% + 8px); right: 0;
  min-width: 190px; list-style: none; margin: 0; padding: .4rem;
  background: var(--c-card); color: var(--c-text);
  border: 1px solid var(--c-border); border-radius: var(--r);
  box-shadow: var(--sh-lg); z-index: 140;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity .2s, transform .2s, visibility .2s;
}
.lang-switch.is-open .lang-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-menu a {
  display: flex; align-items: center; gap: .6rem;
  padding: .55rem .7rem; border-radius: var(--r-sm);
  color: var(--c-text); font-size: .9rem; transition: background .15s;
}
.lang-menu a small { color: var(--c-text-soft); font-size: .72rem; margin-inline-start: auto; }
.lang-menu a .flag { font-size: 1.05rem; }
.lang-menu a:hover { background: var(--c-accent-soft); }
.lang-menu a.is-active { background: var(--c-primary); color: #fff; }
.lang-menu a.is-active small { color: rgba(255,255,255,.75); }
[dir="rtl"] .lang-menu { right: auto; left: 0; }

/* ---------- Nav offset for the top bar ---------- */
.site-nav { top: var(--top-h); transition: top .35s var(--ease), background .28s, box-shadow .28s; }
body.is-scrolled .topbar { transform: translateY(-100%); }
body.is-scrolled .site-nav { top: 0; }

/* Inner pages: clear the fixed top bar + nav */
body:not(.home-page) .page-hero { padding-top: calc(var(--nav-h) + var(--top-h) + var(--sp-8)); }

/* ---------- Transparent nav over the dark hero (home only) ---------- */
.home-page .site-nav:not(.is-scrolled) .nav-brand,
.home-page .site-nav:not(.is-scrolled) .nav-links a,
.home-page .site-nav:not(.is-scrolled) .theme-toggle { color: #fff; }
.home-page .site-nav:not(.is-scrolled) .nav-links a:hover { color: var(--c-secondary); }
.home-page .site-nav:not(.is-scrolled) .nav-links a.is-active { color: var(--c-secondary); }
.home-page .site-nav:not(.is-scrolled) .nav-burger span,
.home-page .site-nav:not(.is-scrolled) .nav-burger span::before,
.home-page .site-nav:not(.is-scrolled) .nav-burger span::after { background: #fff; }

/* ============================================================
   HERO
   ============================================================ */
.hero-x {
  position: relative;
  padding: calc(var(--top-h) + var(--nav-h) + 2.5rem) 0 7rem;
  background:
    radial-gradient(1200px 500px at 85% -5%, rgba(230,169,56,.18), transparent 60%),
    radial-gradient(900px 600px at 0% 100%, rgba(12,124,89,.5), transparent 55%),
    linear-gradient(155deg, var(--c-hero-1), var(--c-hero-2) 70%);
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.hero-x-ornament {
  position: absolute; inset: 0; z-index: -1; opacity: .5;
  background-image:
    radial-gradient(circle at 12% 30%, rgba(255,255,255,.05) 0 2px, transparent 3px),
    radial-gradient(circle at 78% 60%, rgba(255,255,255,.05) 0 2px, transparent 3px);
  background-size: 120px 120px, 160px 160px;
  -webkit-mask-image: linear-gradient(180deg, #000, transparent);
          mask-image: linear-gradient(180deg, #000, transparent);
}
.hero-x-inner {
  display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; gap: 2.5rem;
}

.hero-x-eyebrow {
  display: inline-flex; align-items: center; gap: .55rem;
  background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18);
  color: #FBEFD2; padding: .45rem .9rem; border-radius: var(--r-full);
  font-size: .82rem; font-weight: 600; letter-spacing: .02em; backdrop-filter: blur(4px);
}
.hero-x-eyebrow .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c-secondary); box-shadow: 0 0 0 4px rgba(230,169,56,.25); }

.hero-x-title {
  font-family: var(--ff-display);
  font-weight: 400;
  font-size: clamp(2.4rem, 1.6rem + 4vw, 4.4rem);
  line-height: 1.06;
  letter-spacing: .01em;
  margin: 1.1rem 0 1rem;
  text-shadow: 0 2px 24px rgba(0,0,0,.25);
}
.hero-x-title .gold {
  color: var(--c-secondary);
  background: linear-gradient(90deg, #F4C95B, #E6A938);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.hero-x-lead {
  font-size: clamp(1rem, .95rem + .4vw, 1.18rem);
  color: rgba(255,255,255,.86);
  max-width: 33rem; margin: 0 0 1.8rem;
}

.hero-x-cta { display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; }
.btn-listen {
  display: inline-flex; align-items: center; gap: .8rem;
  padding: .55rem 1.5rem .55rem .55rem;
  border-radius: var(--r-full);
  background: linear-gradient(90deg, var(--c-secondary), var(--c-secondary-700));
  color: #2A1B00; font-weight: 700; font-size: .98rem;
  box-shadow: 0 12px 30px rgba(230,169,56,.35);
  transition: transform .2s, box-shadow .2s;
}
.btn-listen:hover { transform: translateY(-2px); box-shadow: 0 16px 38px rgba(230,169,56,.45); color: #2A1B00; }
.btn-listen .play {
  width: 42px; height: 42px; border-radius: 50%;
  background: #fff; color: var(--c-primary-700);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.btn-listen .play svg { width: 18px; height: 18px; margin-inline-start: 2px; }

.hero-x-stats { display: flex; gap: 2rem; margin-top: 2.4rem; flex-wrap: wrap; }
.hero-x-stats .stat { display:flex; align-items:center; gap:.6rem; }
.hero-x-stats .stat-icon { display:flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.15); flex-shrink:0; }
.hero-x-stats .stat-icon svg { width:17px; height:17px; stroke:#fff; }
.hero-x-stats .lbl { font-size: .82rem; color: rgba(255,255,255,.85); font-weight:500; }

/* ---- Quatrefoil visual ---- */
.hero-x-visual { position: relative; display: flex; justify-content: center; }
.quatrefoil { position: relative; width: min(440px, 86%); filter: drop-shadow(0 26px 50px rgba(0,0,0,.35)); animation: floatY 6s ease-in-out infinite; }
.quatrefoil svg { display: block; width: 100%; height: auto; }
@keyframes floatY { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }

.hx-badge {
  position: absolute; z-index: 3;
  display: flex; align-items: center; gap: .6rem;
  background: rgba(255,255,255,.96); color: var(--c-text);
  padding: .6rem .85rem; border-radius: var(--r); box-shadow: var(--sh-lg);
  backdrop-filter: blur(6px);
}
.hx-badge .ic {
  width: 34px; height: 34px; border-radius: 9px; flex: none;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--c-primary), var(--c-secondary)); color: #fff;
}
.hx-badge .ic svg { width: 18px; height: 18px; }
.hx-badge strong { display: block; font-size: .9rem; line-height: 1.1; }
.hx-badge span.sub { font-size: .74rem; color: var(--c-text-soft); }
.hx-badge.top { top: 8%; inset-inline-start: -4%; animation: floatY 5s ease-in-out infinite; }
.hx-badge.bottom { bottom: 10%; inset-inline-end: -4%; animation: floatY 5.5s ease-in-out .4s infinite; }

/* ---- Scallop divider at hero bottom ---- */
.hero-x-scallop { position: absolute; left: 0; right: 0; bottom: -1px; width: 100%; height: clamp(60px, 9vw, 130px); display: block; z-index: 2; }
.hero-x-scallop path { fill: var(--c-bg); }

/* ============================================================
   WELCOME / VISION / MISSION
   ============================================================ */
.welcome-x { padding-top: 1rem; }
.welcome-x-head { text-align: center; max-width: 880px; margin: 0 auto 3rem; }
.welcome-x-star {
  width: 56px; height: 56px; margin: 0 auto 1rem;
  display: grid; place-items: center; color: var(--c-secondary);
}
.welcome-x-star svg { width: 100%; height: 100%; }
.welcome-x-eyebrow {
  display: inline-block; font-family: var(--ff-display); letter-spacing: .22em;
  text-transform: uppercase; font-size: .9rem; color: var(--c-secondary-700);
}
.welcome-x-title {
  font-family: var(--ff-display); font-weight: 400;
  font-size: clamp(1.8rem, 1.3rem + 2.4vw, 3rem); line-height: 1.12;
  color: var(--c-primary-900); margin: .5rem 0 0;
}
.welcome-x-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; align-items: center; }
.welcome-x-text p { color: var(--c-text-muted); font-size: 1.04rem; margin: 0 0 1.6rem; }

.vm-list { display: grid; gap: 1.4rem; }
.vm-item { display: flex; gap: 1.1rem; align-items: flex-start; padding: 1.3rem; border-radius: var(--r-lg); background: var(--c-card); border: 1px solid var(--c-border); box-shadow: var(--sh-sm); transition: transform .25s, box-shadow .25s, border-color .25s; }
.vm-item:hover { transform: translateY(-4px); box-shadow: var(--sh-lg); border-color: var(--c-secondary); }
.vm-icon {
  flex: none; width: 64px; height: 64px; border-radius: 50%;
  display: grid; place-items: center; color: var(--c-primary);
  border: 2px dashed var(--c-secondary);
  background: var(--c-accent-soft);
}
.vm-icon svg { width: 30px; height: 30px; }
.vm-item h4 { font-family: var(--ff-display); font-size: 1.3rem; color: var(--c-primary-900); margin: .1rem 0 .4rem; }
.vm-item p { margin: 0; color: var(--c-text-muted); font-size: .95rem; }

/* Courses section — clean neutral background instead of gold */
.courses-section {
  background: linear-gradient(180deg, transparent, rgba(12,124,89,0.05) 50%, transparent);
}

/* ============================================================
   Image cards (courses / gallery) — modern polish
   ============================================================ */
.course-card .thumb { position: relative; overflow: hidden; }
.course-card .thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease); }
.course-card:hover .thumb img { transform: scale(1.07); }
/* Dark gradient scrim so Arabic text is always readable over images */
.course-card .thumb::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4,44,30,.1) 0%, rgba(4,30,20,.6) 100%); z-index: 1; }
.course-card .thumb .level, .course-card .thumb .arabic { position: relative; z-index: 2; }

/* ============================================================
   RTL tweaks (Urdu)
   ============================================================ */
[dir="rtl"] body { font-family: 'Amiri', var(--ff-body); }
[dir="rtl"] .hero-x-lead, [dir="rtl"] .vm-item p, [dir="rtl"] .welcome-x-text p { line-height: 1.9; }
[dir="rtl"] .btn-listen { padding: .55rem .55rem .55rem 1.5rem; }
[dir="rtl"] .btn-listen .play svg { transform: scaleX(-1); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 960px) {
  .hero-x-inner { grid-template-columns: 1fr; text-align: center; gap: 2rem; }
  .hero-x-eyebrow { margin: 0 auto; }
  .hero-x-lead { margin-inline: auto; }
  .hero-x-cta { justify-content: center; }
  .hero-x-stats { justify-content: center; }
  .welcome-x-grid { grid-template-columns: 1fr; }
  .hero-x-visual { order: -1; }
  .quatrefoil { width: min(360px, 78%); }
}

@media (max-width: 760px) {
  .topbar-loc, .topbar-social { display: none; }
  .topbar { font-size: .78rem; }
  .topbar-item span { white-space: nowrap; }
  .hx-badge.top { inset-inline-start: 0; }
  .hx-badge.bottom { inset-inline-end: 0; }
}

@media (max-width: 480px) {
  .hero-x-stats { gap: 1.3rem; }
  .lang-current span:not(.globe) { display: none; }
}
