/* ============================================================
   Dārul Qur'ān Leicester — Design System
   Emerald / Gold / Cream · Amiri (display) · Cairo (UI/body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Amiri:ital,wght@0,400;0,700;1,400&family=Amiri+Quran&family=Cairo:wght@400;500;600;700;800&family=Montserrat:wght@400;500;600;700&display=swap');

:root{
  /* Brand */
  --emerald:        #06574C;
  --emerald-deep:   #043D35;
  --emerald-night:  #022a24;
  --emerald-soft:   #0B4B42;
  --gold:           #946F07;
  --gold-bright:    #C99A33;
  --gold-warm:      #D28E3D;
  --sage:           #8CA3A0;
  --sage-light:     #BBCCCA;
  --mint:           #C9DEDB;

  /* Neutrals */
  --cream:          #FAF0EC;
  --cream-deep:     #F3E4DB;
  --blush:          #FFEEE6;
  --paper:          #FFFFFF;
  --ink:            #2B2B2B;
  --ink-soft:       #545454;
  --line:           rgba(6,87,76,.14);
  --line-gold:      rgba(148,111,7,.28);

  /* Type */
  --display: 'Amiri', 'Amiri Quran', Georgia, serif;
  --arabic:  'Amiri Quran', 'Amiri', serif;
  --ui:      'Cairo', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --label:   'Montserrat', 'Cairo', sans-serif;

  /* Shape */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 26px;
  --r-xl: 38px;
  --shadow-sm: 0 2px 10px rgba(2,42,36,.06);
  --shadow-md: 0 14px 38px rgba(2,42,36,.10);
  --shadow-lg: 0 30px 70px rgba(2,42,36,.18);
  --maxw: 1240px;
  --header-h: 96px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--ui);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--gold-warm); color:#fff; }

/* ---------- Typography ---------- */
.display{ font-family:var(--display); font-weight:700; line-height:1.08; letter-spacing:.01em; }
.arabic{ font-family:var(--arabic); direction:rtl; }
h1,h2,h3{ font-family:var(--display); font-weight:700; color:var(--emerald); margin:0; line-height:1.1; }
h1{ font-size:clamp(40px,6vw,72px); }
h2{ font-size:clamp(30px,4.4vw,52px); }
h3{ font-size:clamp(22px,2.6vw,30px); }
p{ margin:0 0 1em; }
.lead{ font-size:clamp(18px,2.1vw,21px); color:var(--ink-soft); }

.eyebrow{
  font-family:var(--label); font-weight:600; text-transform:uppercase;
  letter-spacing:.34em; font-size:12.5px; color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before,.eyebrow.center::after{
  content:""; width:34px; height:1px; background:var(--gold); opacity:.6;
}
.eyebrow.center{ justify-content:center; }

/* section title block */
.sec-head{ text-align:center; max-width:720px; margin:0 auto 56px; }
.sec-head .eyebrow{ margin-bottom:18px; }
.sec-head p{ margin-top:14px; }

/* ---------- Layout ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 32px; }
.section{ padding:104px 0; position:relative; }
.section.tight{ padding:72px 0; }
.bg-cream{ background:var(--cream); }
.bg-paper{ background:var(--paper); }
.bg-blush{ background:linear-gradient(180deg,var(--blush),var(--cream)); }
.bg-emerald{ background:var(--emerald); color:#fff; }
.bg-emerald h1,.bg-emerald h2,.bg-emerald h3{ color:#fff; }
.bg-emerald .lead{ color:rgba(255,255,255,.82); }

/* calligraphy texture overlay (light) */
.tex-light{ position:relative; }
.tex-light::before{
  content:""; position:absolute; inset:0;
  background:url('assets/img/img-e9f38.png') center/620px repeat;
  opacity:.5; mix-blend-mode:multiply; pointer-events:none;
}
.tex-light > *{ position:relative; z-index:1; }
.tex-emerald{ position:relative; }
.tex-emerald::before{
  content:""; position:absolute; inset:0;
  background:url('assets/img/img-e9f38.png') center/620px repeat;
  opacity:.05; pointer-events:none;
}
.tex-emerald > *{ position:relative; z-index:1; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  font-family:var(--ui); font-weight:600; font-size:15.5px;
  padding:15px 30px; border-radius:999px; border:1.5px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:18px; height:18px; }
.btn-gold{ background:linear-gradient(135deg,var(--gold-warm),var(--gold)); color:#fff; box-shadow:0 10px 24px rgba(148,111,7,.28); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 16px 34px rgba(148,111,7,.36); }
.btn-emerald{ background:var(--emerald); color:#fff; }
.btn-emerald:hover{ transform:translateY(-2px); background:var(--emerald-deep); box-shadow:var(--shadow-md); }
.btn-ghost{ background:transparent; color:var(--emerald); border-color:var(--line-gold); }
.btn-ghost:hover{ background:var(--emerald); color:#fff; border-color:var(--emerald); }
.btn-on-dark{ background:rgba(255,255,255,.10); color:#fff; border-color:rgba(255,255,255,.4); backdrop-filter:blur(6px); }
.btn-on-dark:hover{ background:#fff; color:var(--emerald); }
.btn-light{ background:var(--cream); color:var(--emerald); }
.btn-light:hover{ background:#fff; transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.btn-sm{ padding:11px 22px; font-size:14px; }
.btn-block{ width:100%; }

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:120;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding:18px 0;
}
.site-header.solid{ background:rgba(4,61,53,.96); backdrop-filter:blur(14px); box-shadow:0 8px 30px rgba(2,42,36,.22); padding:10px 0; }
.nav{
  display:flex; align-items:center; gap:22px;
  background:rgba(4,61,53,.34); border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(14px); border-radius:999px;
  padding:10px 12px 10px 22px; box-shadow:0 8px 30px rgba(2,42,36,.18);
}
.site-header.solid .nav{ background:transparent; border-color:transparent; box-shadow:none; backdrop-filter:none; }
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand img{ height:50px; width:auto; }
.nav-links{ display:flex; align-items:center; gap:5px; }
.nav-links a{
  color:rgba(255,255,255,.86); font-size:14.5px; font-weight:500;
  padding:9px 13px; border-radius:999px; transition:.2s; white-space:nowrap;
}
.nav-links a:hover{ color:#fff; background:rgba(255,255,255,.10); }
.nav-links a.active{ color:#fff; background:rgba(201,154,51,.26); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-login{ color:#fff!important; font-weight:600; padding:9px 14px!important; }
.nav-toggle{ display:none; background:transparent; border:0; padding:8px; color:#fff; }
.nav-toggle svg{ width:28px; height:28px; }

/* mobile drawer */
.mobile-menu{
  position:fixed; inset:0; z-index:130; background:var(--emerald-deep);
  display:flex; flex-direction:column; padding:28px;
  transform:translateX(100%); transition:transform .35s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu .mm-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:30px; }
.mobile-menu .mm-top img{ height:54px; }
.mobile-menu a{ color:#fff; font-family:var(--display); font-size:26px; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.10); }
.mobile-menu .mm-actions{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }
.mm-close{ background:transparent; border:0; color:#fff; }
.mm-close svg{ width:30px; height:30px; }

/* ---------- Page hero (interior pages) ---------- */
.page-hero{ position:relative; background:var(--emerald-deep); color:#fff; overflow:hidden; padding:calc(var(--header-h) + 56px) 0 76px; }
.page-hero .ph-pat{ position:absolute; inset:0; background:url('assets/img/hero-pattern.png') right center/cover; opacity:.14; }
.page-hero .ph-fade{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(2,42,36,.4),var(--emerald-deep)); }
.page-hero-inner{ position:relative; z-index:2; max-width:780px; }
.page-hero h1{ color:#fff; margin:14px 0 14px; }
.page-hero p{ color:rgba(255,255,255,.82); font-size:clamp(17px,2vw,20px); margin:0; max-width:600px; }
.breadcrumb{ display:flex; gap:8px; align-items:center; font-size:13.5px; color:rgba(255,255,255,.6); margin-bottom:6px; }
.breadcrumb a:hover{ color:#fff; }
.page-hero .ph-wave{ position:absolute; bottom:-1px; left:0; right:0; z-index:3; line-height:0; }

/* ---------- Cards ---------- */
.card{
  background:var(--paper); border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-md); border:1px solid var(--line);
  transition:transform .3s ease, box-shadow .3s ease;
  display:flex; flex-direction:column;
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-lg); }

/* course card */
.course-card .cc-media{ position:relative; aspect-ratio:4/3.1; overflow:hidden; }
.course-card .cc-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.course-card:hover .cc-media img{ transform:scale(1.05); }
.course-card .cc-body{ padding:24px 24px 26px; display:flex; flex-direction:column; gap:12px; flex:1; }
.course-card h3{ font-size:25px; }
.course-card .cc-desc{ color:var(--ink-soft); font-size:15px; flex:1; }
.course-card .cc-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:6px; gap:12px; }
.cc-price{ font-family:var(--display); font-size:26px; color:var(--emerald); font-weight:700; }
.cc-price small{ font-family:var(--ui); font-size:13px; color:var(--ink-soft); font-weight:500; }

/* badge / chip */
.chip{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--label); font-size:11.5px; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; padding:6px 12px; border-radius:999px;
}
.chip-gold{ background:rgba(201,154,51,.16); color:var(--gold); }
.chip-emerald{ background:rgba(6,87,76,.10); color:var(--emerald); }
.chip-enquiry{ background:rgba(210,142,61,.16); color:var(--gold-warm); }
.chip-online{ background:rgba(24,167,185,.14); color:#1493a3; }
.chip-inperson{ background:rgba(39,83,4,.12); color:#3a6a1a; }
.chip-on-media{ position:absolute; top:14px; left:14px; background:rgba(4,61,53,.82); color:#fff; backdrop-filter:blur(4px); z-index:2; }

/* ---------- Forms ---------- */
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-size:13.5px; font-weight:600; color:var(--emerald); }
.input, .field input, .field select, .field textarea{
  font-family:var(--ui); font-size:15.5px; color:var(--ink);
  background:var(--paper); border:1.5px solid var(--line);
  border-radius:var(--r-sm); padding:13px 16px; width:100%; transition:.2s;
}
.input:focus, .field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--gold-warm); box-shadow:0 0 0 4px rgba(210,142,61,.14);
}
.field textarea{ resize:vertical; min-height:120px; }

/* arch / mihrab frame */
.arch{ border-radius:50% 50% var(--r-lg) var(--r-lg) / 32% 32% var(--r-lg) var(--r-lg); }

/* divider with ornament */
.ornament{ display:flex; align-items:center; justify-content:center; gap:16px; color:var(--gold); margin:0 auto; }
.ornament::before,.ornament::after{ content:""; height:1px; width:60px; background:linear-gradient(90deg,transparent,var(--gold)); }
.ornament::after{ background:linear-gradient(90deg,var(--gold),transparent); }

/* ---------- Footer ---------- */
.site-footer{ background:var(--emerald); color:#fff; padding:70px 0 38px; position:relative; }
.footer-top{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding-bottom:30px; border-bottom:1px solid rgba(255,255,255,.16); flex-wrap:wrap; }
.footer-nav{ display:flex; gap:30px; flex-wrap:wrap; }
.footer-nav a{ color:rgba(255,255,255,.85); font-size:15px; }
.footer-nav a:hover{ color:#fff; }
.footer-social{ display:flex; gap:14px; }
.soc{ width:48px; height:48px; border-radius:50%; border:1.5px solid rgba(201,154,51,.7); display:grid; place-items:center; color:#fff; transition:.2s; }
.soc:hover{ background:var(--gold-warm); border-color:var(--gold-warm); transform:translateY(-3px); }
.soc svg{ width:22px; height:22px; }
.footer-mid{ padding:48px 0 36px; display:grid; grid-template-columns:1.4fr 1fr; gap:50px; align-items:center; }
.footer-mid h2{ color:#fff; font-size:clamp(28px,3.6vw,46px); }
.subscribe{ }
.subscribe .sub-row{ display:flex; gap:10px; margin-top:14px; }
.subscribe input{ flex:1; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.28); color:#fff; border-radius:999px; padding:14px 20px; font-family:var(--ui); }
.subscribe input::placeholder{ color:rgba(255,255,255,.6); }
.subscribe input:focus{ outline:none; border-color:var(--gold-warm); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; padding-top:26px; border-top:1px solid rgba(255,255,255,.14); flex-wrap:wrap; color:rgba(255,255,255,.7); font-size:14px; }

/* ---------- WhatsApp float + Appointment ---------- */
.wa-float{
  position:fixed; right:24px; bottom:24px; z-index:90;
  width:60px; height:60px; border-radius:50%; background:#25D366;
  display:grid; place-items:center; color:#fff; box-shadow:0 12px 30px rgba(37,211,102,.45);
  transition:transform .2s ease;
}
.wa-float:hover{ transform:scale(1.08); }
.wa-float svg{ width:32px; height:32px; }

/* ---------- Toast ---------- */
.toast{
  position:fixed; left:50%; bottom:34px; transform:translateX(-50%) translateY(140%);
  background:var(--emerald-deep); color:#fff; padding:15px 26px; border-radius:999px;
  box-shadow:var(--shadow-lg); z-index:200; transition:transform .4s cubic-bezier(.2,.8,.2,1);
  display:flex; align-items:center; gap:12px; font-size:15px; max-width:90vw;
  border:1px solid rgba(201,154,51,.5);
}
.toast.show{ transform:translateX(-50%) translateY(0); }
.toast svg{ width:20px; height:20px; color:var(--gold-bright); flex:none; }

/* ---------- Modal ---------- */
.modal-overlay{
  position:fixed; inset:0; z-index:160; background:rgba(2,42,36,.6); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center; padding:24px;
  opacity:0; pointer-events:none; transition:opacity .25s ease;
}
.modal-overlay.open{ opacity:1; pointer-events:auto; }
.modal{
  background:var(--cream); border-radius:var(--r-lg); width:min(560px,100%);
  max-height:90vh; overflow:auto; box-shadow:var(--shadow-lg);
  transform:translateY(20px) scale(.98); transition:transform .3s ease;
}
.modal-overlay.open .modal{ transform:none; }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---------- Utilities ---------- */
.center{ text-align:center; }
.grid{ display:grid; gap:28px; }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }
.mt-0{ margin-top:0; } .mb-0{ margin-bottom:0; }
.page-top-pad{ padding-top:var(--header-h); }

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .nav-links, .nav-cta .nav-login, .nav-cta .btn:not(.always){ display:none; }
  .nav-toggle{ display:inline-flex; }
  .cols-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:860px){
  .section{ padding:72px 0; }
  .footer-mid{ grid-template-columns:1fr; gap:30px; }
  .cols-3{ grid-template-columns:1fr; }
  .cols-2{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .wrap{ padding:0 20px; }
  .cols-4{ grid-template-columns:1fr; }
  .footer-top{ flex-direction:column; align-items:flex-start; }
  body{ font-size:16px; }
}
