/* ══════════════════════════════════════════════════════════════
   HUSAMI — style.css v3.0
   Spiritual · Elegant · Islamic · Premium · Mobile-First
   Deep Green · Gold · Black · Beige · White
   ══════════════════════════════════════════════════════════════ */

/* ── GOOGLE FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Noto+Nastaliq+Urdu:wght@400;500;600;700&family=Lato:wght@300;400;700;900&family=Noto+Serif+Arabic:wght@400;500;600&display=swap');

/* ══════════════════════════════════════════════════════════════
   1. DESIGN TOKENS
   ══════════════════════════════════════════════════════════════ */
:root {
  /* Colours */
  --gold:         #C9A84C;
  --gold-lt:      #E8C96F;
  --gold-pale:    #F5E9C8;
  --green:        #0E3B2A;
  --green-mid:    #1A5C3D;
  --green-soft:   #2D7A52;
  --green-pale:   #E8F4EE;
  --black:        #080808;
  --off-white:    #FAF8F3;
  --beige:        #F2EDE0;
  --beige-dk:     #E8DFC8;
  --white:        #FFFFFF;
  --text:         #1A1A1A;
  --text-muted:   #6B6B6B;
  --text-light:   #A0A0A0;
  --border:       rgba(201,168,76,0.18);
  --border-mid:   rgba(201,168,76,0.35);

  /* Shadows */
  --sh-sm: 0 2px 14px rgba(14,59,42,0.09);
  --sh-md: 0 8px 32px rgba(14,59,42,0.14);
  --sh-lg: 0 20px 60px rgba(14,59,42,0.20);

  /* Radii */
  --r-sm:   8px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --r-pill:999px;

  /* Layout */
  --nav-h:  72px;
  --max-w: 1180px;
  --gap:    28px;

  /* Motion */
  --ease:   cubic-bezier(0.4,0,0.2,1);
  --t:      0.28s;
}

/* ══════════════════════════════════════════════════════════════
   2. RESET
   ══════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html  { scroll-behavior: smooth; font-size: 16px; -webkit-text-size-adjust: 100%; }
body  { font-family: 'Lato', sans-serif; background: var(--off-white); color: var(--text); line-height: 1.75; overflow-x: hidden; -webkit-font-smoothing: antialiased; }
img   { max-width: 100%; display: block; }
a     { text-decoration: none; color: inherit; }
ul    { list-style: none; }
button{ cursor: pointer; border: none; background: none; font-family: inherit; }
input, textarea, select { font-family: inherit; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
::selection { background: var(--gold); color: var(--black); }

/* ══════════════════════════════════════════════════════════════
   3. TYPOGRAPHY
   ══════════════════════════════════════════════════════════════ */
h1,h2,h3,h4,h5 { font-family:'Playfair Display',serif; font-weight:600; line-height:1.28; color:var(--green); }
h1 { font-size: clamp(2rem,  5vw, 3.4rem); }
h2 { font-size: clamp(1.5rem,3vw, 2.2rem); }
h3 { font-size: clamp(1.1rem,2vw, 1.5rem); }

.urdu  { font-family:'Noto Nastaliq Urdu',serif; direction:rtl; line-height:2.2; unicode-bidi:isolate; }
.arabic{ font-family:'Noto Serif Arabic',serif; direction:rtl; line-height:2; }
.serif { font-family:'Playfair Display',serif; }

/* ══════════════════════════════════════════════════════════════
   4. LAYOUT HELPERS
   ══════════════════════════════════════════════════════════════ */
.wrap     { max-width:var(--max-w); margin-inline:auto; padding-inline:24px; }
.section  { padding-block:80px; }
.s-beige  { background:var(--beige); }
.s-white  { background:var(--white); }
.s-dark   { background:var(--green); }
.s-black  { background:var(--black); }

.grid-2   { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); }
.grid-3   { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
.grid-4   { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); }
.auto-sm  { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:var(--gap); }
.auto-md  { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:var(--gap); }
.auto-lg  { display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:var(--gap); }
.flex     { display:flex; align-items:center; }
.flex-c   { display:flex; align-items:center; justify-content:center; }
.flex-b   { display:flex; align-items:center; justify-content:space-between; }
.gap-8    { gap:8px; }
.gap-12   { gap:12px; }
.gap-16   { gap:16px; }
.gap-24   { gap:24px; }
.tc       { text-align:center; }
.tr       { text-align:right; }

/* ══════════════════════════════════════════════════════════════
   5. DECORATIVE
   ══════════════════════════════════════════════════════════════ */
.geo {
  background-image: url("data:image/svg+xml,%3Csvg width='90' height='90' viewBox='0 0 90 90' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23C9A84C' stroke-width='0.5' opacity='0.12'%3E%3Cpolygon points='45 5 85 25 85 65 45 85 5 65 5 25'/%3E%3Cpolygon points='45 18 72 31 72 59 45 72 18 59 18 31'/%3E%3Cline x1='45' y1='5' x2='45' y2='85'/%3E%3Cline x1='5' y1='25' x2='85' y2='65'/%3E%3Cline x1='5' y1='65' x2='85' y2='25'/%3E%3C/g%3E%3C/svg%3E");
}

.divider { display:flex; align-items:center; gap:14px; margin-block:14px; }
.divider::before,.divider::after { content:''; flex:1; height:1px; background:linear-gradient(to right,transparent,var(--gold),transparent); opacity:.6; }
.divider i { font-size:16px; color:var(--gold); }

.eyebrow { display:block; font-size:10.5px; font-weight:700; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }

.sec-hd { text-align:center; margin-bottom:52px; }
.sec-hd p { font-size:15px; color:var(--text-muted); max-width:500px; margin:12px auto 0; line-height:1.75; }

/* ══════════════════════════════════════════════════════════════
   6. BUTTONS
   ══════════════════════════════════════════════════════════════ */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 30px; border-radius:var(--r-pill); font-size:12.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; transition:all var(--t) var(--ease); white-space:nowrap; cursor:pointer; }
.btn-gold  { background:var(--gold);  color:var(--black);  border:2px solid var(--gold); }
.btn-gold:hover { background:var(--gold-lt); border-color:var(--gold-lt); transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,168,76,.3); }
.btn-dark  { background:var(--green); color:var(--gold);   border:2px solid var(--green); }
.btn-dark:hover { background:var(--green-mid); border-color:var(--green-mid); transform:translateY(-2px); }
.btn-out   { background:transparent; color:rgba(255,255,255,.82); border:1.5px solid rgba(255,255,255,.28); }
.btn-out:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
.btn-out-dk{ background:transparent; color:var(--green); border:1.5px solid var(--border-mid); }
.btn-out-dk:hover { border-color:var(--gold); color:var(--gold); }
.btn-sm    { padding:8px 18px; font-size:11px; }

.pill      { display:inline-flex; align-items:center; gap:4px; padding:4px 12px; border-radius:var(--r-pill); font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; cursor:pointer; transition:all .18s var(--ease); }
.pill-gr   { background:var(--green-pale); color:var(--green-mid); }
.pill-gr:hover { background:var(--green-mid); color:#fff; }
.pill-go   { background:var(--gold-pale); color:#7A5C10; }
.pill-go:hover { background:var(--gold); color:var(--black); }

.badge     { display:inline-block; padding:3px 10px; border-radius:var(--r-pill); font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; }
.bdg-cat   { background:var(--green-pale); color:var(--green-mid); }
.bdg-vol   { background:var(--gold); color:var(--black); }
.bdg-yr    { background:var(--beige-dk); color:var(--text-muted); }

/* ══════════════════════════════════════════════════════════════
   7. NAVIGATION
   ══════════════════════════════════════════════════════════════ */
.navbar {
  position:fixed; inset-block-start:0; inset-inline:0;
  z-index:1000; height:var(--nav-h);
  background:rgba(8,8,8,.96);
  backdrop-filter:blur(18px) saturate(1.4);
  border-bottom:1px solid var(--border);
  transition:box-shadow var(--t) var(--ease);
}
.navbar.scrolled { box-shadow:0 4px 24px rgba(0,0,0,.4); }
.nav-inner { max-width:var(--max-w); margin-inline:auto; padding-inline:24px; height:100%; display:flex; align-items:center; justify-content:space-between; gap:32px; }

.nav-logo { display:flex; flex-direction:column; line-height:1; gap:2px; }
.nav-logo .ar { font-family:'Noto Serif Arabic',serif; font-size:22px; color:var(--gold); direction:rtl; }
.nav-logo .en { font-size:9px; letter-spacing:.3em; text-transform:uppercase; color:rgba(255,255,255,.35); }

.nav-links { display:flex; align-items:center; gap:26px; }
.nav-links a { font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.6); transition:color var(--t) var(--ease); position:relative; padding-bottom:3px; }
.nav-links a::after { content:''; position:absolute; bottom:0; left:0; right:0; height:1px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform var(--t) var(--ease); }
.nav-links a:hover,.nav-links a.active { color:var(--gold); }
.nav-links a:hover::after,.nav-links a.active::after { transform:scaleX(1); }

.nav-right { display:flex; align-items:center; gap:10px; }
.nav-search { width:36px; height:36px; border-radius:50%; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); font-size:15px; transition:all var(--t) var(--ease); background:transparent; }
.nav-search:hover { border-color:var(--gold); color:var(--gold); }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.hamburger span { display:block; width:22px; height:2px; background:rgba(255,255,255,.7); border-radius:2px; transition:all var(--t) var(--ease); }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.nav-mobile { display:none; position:fixed; top:var(--nav-h); inset-inline:0; background:rgba(8,8,8,.98); border-bottom:1px solid var(--border); padding:24px; z-index:999; flex-direction:column; gap:4px; }
.nav-mobile.open { display:flex; }
.nav-mobile a { font-size:14px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.6); padding:12px 0; border-bottom:1px solid rgba(255,255,255,.04); transition:color .18s; }
.nav-mobile a:last-child { border-bottom:none; }
.nav-mobile a:hover,.nav-mobile a.active { color:var(--gold); }

/* ══════════════════════════════════════════════════════════════
   8. PAGE HERO (inner pages)
   ══════════════════════════════════════════════════════════════ */
.page-hero {
  padding-top:calc(var(--nav-h) + 60px); padding-bottom:64px;
  background:var(--green); text-align:center; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23C9A84C' stroke-width='0.5' opacity='0.08'%3E%3Cpolygon points='40 4 76 20 76 60 40 76 4 60 4 20'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px;
}
.page-hero .inner { position:relative; z-index:1; max-width:680px; margin-inline:auto; padding-inline:24px; }
.page-hero h1 { color:#fff; margin-bottom:12px; }
.page-hero p  { color:rgba(255,255,255,.52); font-size:15px; }

/* ══════════════════════════════════════════════════════════════
   9. HERO SLIDER
   ══════════════════════════════════════════════════════════════ */
.hero { position:relative; height:100vh; min-height:580px; overflow:hidden; background:var(--black); }
.hero-slides { position:relative; width:100%; height:100%; }

.slide { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity 1.1s ease; pointer-events:none; }
.slide.active { opacity:1; pointer-events:all; }
.slide-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(.3) saturate(.8); transition:transform 8s ease; }
.slide.active .slide-bg { transform:scale(1.04); }
.slide-pattern { position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23C9A84C' stroke-width='0.4' opacity='0.1'%3E%3Cpolygon points='50 5 95 27.5 95 72.5 50 95 5 72.5 5 27.5'/%3E%3Cpolygon points='50 20 80 35 80 65 50 80 20 65 20 35'/%3E%3C/g%3E%3C/svg%3E"); background-size:100px; }
.slide-content { position:relative; z-index:2; text-align:center; max-width:760px; padding-inline:24px; }
.slide-badge { display:inline-block; padding:6px 22px; border:1px solid rgba(201,168,76,.5); border-radius:var(--r-pill); font-size:10.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:24px; }
.slide-title-ur { font-family:'Noto Nastaliq Urdu',serif; font-size:clamp(2.2rem,6vw,4rem); color:#fff; direction:rtl; line-height:1.9; margin-bottom:6px; }
.slide-title-en { font-family:'Playfair Display',serif; font-size:clamp(1rem,2.2vw,1.45rem); color:var(--gold-lt); font-style:italic; margin-bottom:22px; }
.slide-desc { font-size:15px; color:rgba(255,255,255,.6); line-height:1.85; max-width:460px; margin-inline:auto; margin-bottom:36px; }
.slide-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

.hero-arrows { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:100%; display:flex; justify-content:space-between; padding-inline:20px; pointer-events:none; }
.hero-arrow { width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14); color:rgba(255,255,255,.65); display:flex; align-items:center; justify-content:center; font-size:18px; cursor:pointer; pointer-events:all; transition:all var(--t) var(--ease); }
.hero-arrow:hover { background:rgba(201,168,76,.18); border-color:var(--gold); color:var(--gold); }

.hero-dots { position:absolute; bottom:36px; left:50%; transform:translateX(-50%); z-index:10; display:flex; gap:10px; }
.dot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.3); border:none; cursor:pointer; transition:all var(--t) var(--ease); }
.dot.active { background:var(--gold); width:24px; border-radius:4px; }

/* ══════════════════════════════════════════════════════════════
   10. STATS ROW
   ══════════════════════════════════════════════════════════════ */
.stats-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:20px; }
.stat-card { text-align:center; padding:28px 16px; border:1px solid var(--border); border-radius:var(--r-md); background:#fff; transition:all var(--t) var(--ease); }
.stat-card:hover { box-shadow:var(--sh-sm); border-color:var(--border-mid); }
.stat-num { font-family:'Playfair Display',serif; font-size:2.4rem; font-weight:700; color:var(--green); line-height:1; margin-bottom:6px; }
.stat-num span { color:var(--gold); }
.stat-lbl { font-size:10.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); }

/* ══════════════════════════════════════════════════════════════
   11. ALBUM CARDS
   ══════════════════════════════════════════════════════════════ */
.album-card { position:relative; border-radius:var(--r-md); overflow:hidden; cursor:pointer; transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease); box-shadow:var(--sh-sm); background:var(--black); }
.album-card:hover { transform:translateY(-6px); box-shadow:var(--sh-lg); }
.album-card img { width:100%; aspect-ratio:1/1; object-fit:cover; display:block; transition:transform .7s var(--ease); }
.album-card:hover img { transform:scale(1.06); }
.album-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(8,8,8,.92) 0%,rgba(8,8,8,.12) 55%,transparent 100%); display:flex; flex-direction:column; justify-content:flex-end; padding:20px; }
.album-vol { position:absolute; top:14px; left:14px; background:var(--gold); color:var(--black); font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:4px 10px; border-radius:4px; }
.album-title-ur { font-family:'Noto Nastaliq Urdu',serif; font-size:18px; color:#fff; direction:rtl; line-height:1.9; margin-bottom:3px; }
.album-title-en { font-size:11px; color:rgba(255,255,255,.45); font-style:italic; margin-bottom:10px; }
.album-meta { display:flex; align-items:center; justify-content:space-between; }
.album-count { font-size:11px; color:rgba(255,255,255,.45); }
.album-play { width:38px; height:38px; border-radius:50%; background:rgba(201,168,76,.88); color:var(--black); display:flex; align-items:center; justify-content:center; font-size:14px; transition:all .18s var(--ease); }
.album-card:hover .album-play { background:var(--gold-lt); transform:scale(1.08); }

/* ══════════════════════════════════════════════════════════════
   12. KALAAM CARDS
   ══════════════════════════════════════════════════════════════ */
.k-card { background:#fff; border-radius:var(--r-md); border:1px solid var(--border); overflow:hidden; cursor:pointer; transition:transform var(--t) var(--ease),box-shadow var(--t) var(--ease),border-color var(--t) var(--ease); }
.k-card:hover { transform:translateY(-4px); box-shadow:var(--sh-md); border-color:var(--border-mid); }
.k-card-top { display:flex; align-items:stretch; }
.k-thumb { width:88px; height:88px; flex-shrink:0; object-fit:cover; }
.k-thumb-ph { width:88px; height:88px; flex-shrink:0; background:var(--green); display:flex; align-items:center; justify-content:center; font-family:'Noto Serif Arabic',serif; font-size:22px; color:var(--gold); }
.k-head { padding:12px 14px; flex:1; }
.k-code { font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:4px; }
.k-title-ur { font-family:'Noto Nastaliq Urdu',serif; font-size:16px; color:var(--green); direction:rtl; line-height:1.9; }
.k-title-en { font-size:11px; color:var(--text-muted); font-style:italic; margin-top:2px; }
.k-foot { padding:9px 14px 13px; display:flex; align-items:center; justify-content:space-between; border-top:1px solid var(--border); }
.k-play { width:30px; height:30px; border-radius:50%; background:var(--green); color:var(--gold); display:flex; align-items:center; justify-content:center; font-size:11px; flex-shrink:0; transition:all .18s var(--ease); }
.k-card:hover .k-play { background:var(--gold); color:var(--black); transform:scale(1.1); }

/* ══════════════════════════════════════════════════════════════
   13. SEARCH BAR
   ══════════════════════════════════════════════════════════════ */
.search-band { background:var(--green); padding-block:40px; padding-inline:24px; }
.search-band .inner { max-width:700px; margin-inline:auto; text-align:center; }
.search-band h2 { font-family:'Playfair Display',serif; font-size:20px; color:var(--gold-lt); margin-bottom:18px; }
.search-bar { display:flex; border-radius:var(--r-pill); overflow:hidden; border:1px solid var(--border); background:rgba(255,255,255,.05); }
.search-bar input { flex:1; padding:13px 22px; background:transparent; border:none; outline:none; color:#fff; font-size:14px; }
.search-bar input::placeholder { color:rgba(255,255,255,.3); }
.search-bar button { padding:13px 26px; background:var(--gold); color:var(--black); font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; border:none; transition:background .18s; }
.search-bar button:hover { background:var(--gold-lt); }
.filter-chips { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin-top:16px; }
.chip { padding:5px 16px; border-radius:var(--r-pill); border:1px solid rgba(201,168,76,.28); font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.45); cursor:pointer; transition:all .18s; background:transparent; }
.chip:hover,.chip.active { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,.08); }

/* ══════════════════════════════════════════════════════════════
   14. AUDIO PLAYER
   ══════════════════════════════════════════════════════════════ */
.audio-player { background:var(--green); border-radius:var(--r-md); padding:22px 24px; border:1px solid rgba(201,168,76,.18); }
.ap-label { font-size:10px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:14px; }
.ap-name { font-family:'Noto Nastaliq Urdu',serif; font-size:16px; color:#fff; direction:rtl; text-align:right; line-height:1.9; margin-bottom:3px; }
.ap-sub  { font-size:11px; color:rgba(255,255,255,.35); font-style:italic; margin-bottom:16px; }
.ap-seek { height:4px; background:rgba(255,255,255,.08); border-radius:4px; cursor:pointer; margin-bottom:8px; overflow:hidden; }
.ap-fill { height:100%; background:linear-gradient(to right,var(--gold),var(--gold-lt)); width:0%; transition:width .12s linear; }
.ap-times { display:flex; justify-content:space-between; font-size:10px; color:rgba(255,255,255,.25); margin-bottom:18px; }
.ap-controls { display:flex; align-items:center; justify-content:center; gap:20px; }
.ap-btn { background:none; border:none; color:rgba(255,255,255,.55); font-size:18px; cursor:pointer; padding:4px; transition:color .18s; }
.ap-btn:hover { color:var(--gold); }
.ap-play { width:52px; height:52px; border-radius:50%; background:var(--gold); color:var(--black); display:flex; align-items:center; justify-content:center; font-size:20px; cursor:pointer; border:none; transition:all .18s; flex-shrink:0; }
.ap-play:hover { background:var(--gold-lt); transform:scale(1.06); }
.ap-list { margin-top:18px; border-top:1px solid rgba(255,255,255,.06); padding-top:14px; }
.ap-item { display:flex; align-items:center; gap:12px; padding:9px 10px; border-radius:var(--r-sm); cursor:pointer; transition:background .18s; text-decoration:none; }
.ap-item:hover { background:rgba(255,255,255,.04); }
.ap-item.active { background:rgba(201,168,76,.09); }
.ap-num  { font-size:10px; color:rgba(255,255,255,.2); min-width:20px; }
.ap-ititle { font-family:'Noto Nastaliq Urdu',serif; font-size:13px; color:rgba(255,255,255,.7); direction:rtl; flex:1; text-align:right; line-height:1.85; }
.ap-item.active .ap-ititle { color:var(--gold-lt); }
.ap-imeta { font-size:10px; color:rgba(255,255,255,.22); white-space:nowrap; }

/* Audio highlight row (individual page) */
.audio-hl-row { display:flex; align-items:center; gap:16px; padding:14px 18px; background:#fff; border:1px solid var(--border); border-radius:var(--r-md); }
.ahl-num { font-size:13px; font-weight:700; color:var(--text-light); min-width:32px; }
.ahl-info { flex:1; }
.ahl-title { font-family:'Noto Nastaliq Urdu',serif; font-size:15px; direction:rtl; text-align:right; color:var(--green); line-height:2; }
.ahl-meta  { font-size:11px; color:var(--text-muted); }
.ahl-actions { display:flex; gap:6px; flex-wrap:wrap; }

/* ══════════════════════════════════════════════════════════════
   15. VIDEO EMBED
   ══════════════════════════════════════════════════════════════ */
.video-wrap { position:relative; border-radius:var(--r-md); overflow:hidden; aspect-ratio:16/9; background:#111; }
.video-wrap iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.video-ph { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; color:rgba(255,255,255,.35); font-size:14px; }
.video-ph .icon { font-size:52px; }

/* ══════════════════════════════════════════════════════════════
   16. KALAAM LIBRARY TABLE
   ══════════════════════════════════════════════════════════════ */
.table-wrap { overflow-x:auto; border-radius:var(--r-md); border:1px solid var(--border); }
.lib-table { width:100%; border-collapse:collapse; background:#fff; min-width:900px; }
.lib-table th { padding:11px 14px; text-align:left; font-size:10px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--text-light); background:var(--beige); border-bottom:1px solid var(--border); white-space:nowrap; }
.lib-table td { padding:12px 14px; font-size:13px; border-bottom:1px solid var(--border); vertical-align:middle; }
.lib-table tr:last-child td { border-bottom:none; }
.lib-table tr:hover td { background:var(--green-pale); }
.lib-table td.ur { font-family:'Noto Nastaliq Urdu',serif; font-size:15px; direction:rtl; text-align:right; line-height:2; }
.lib-tabs { display:flex; gap:4px; background:rgba(0,0,0,.06); padding:4px; border-radius:var(--r-md); width:fit-content; margin-bottom:24px; }
.lib-tab { padding:8px 22px; border-radius:var(--r-sm); font-size:11px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); cursor:pointer; transition:all .18s; border:none; background:none; }
.lib-tab.active { background:var(--green); color:var(--gold); }

/* ══════════════════════════════════════════════════════════════
   17. PDF VIEWER
   ══════════════════════════════════════════════════════════════ */
.pdf-wrap { background:#fff; border-radius:var(--r-md); border:1px solid var(--border); overflow:hidden; }
.pdf-head { padding:13px 20px; background:var(--beige); border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.pdf-head-title { font-size:13px; font-weight:700; color:var(--green); }
.pdf-body { aspect-ratio:4/5; background:#f0f0f0; display:flex; align-items:center; justify-content:center; }
.pdf-ph { text-align:center; color:var(--text-muted); padding:32px; }
.pdf-ph .icon { font-size:48px; color:var(--gold); margin-bottom:12px; }
.pdf-ph p { font-size:13px; line-height:1.7; }

/* ══════════════════════════════════════════════════════════════
   18. INSTAGRAM REELS
   ══════════════════════════════════════════════════════════════ */
.reels-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:14px; }
.reel { position:relative; aspect-ratio:9/16; border-radius:var(--r-md); overflow:hidden; cursor:pointer; background:#111; }
.reel img { width:100%; height:100%; object-fit:cover; transition:transform var(--t) var(--ease),opacity var(--t) var(--ease); opacity:.78; }
.reel:hover img { opacity:.55; transform:scale(1.05); }
.reel-ov { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:14px; background:linear-gradient(to top,rgba(0,0,0,.82) 0%,transparent 60%); }
.reel-play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,.12); border:2px solid rgba(255,255,255,.4); display:flex; align-items:center; justify-content:center; font-size:16px; color:#fff; transition:all .18s; }
.reel:hover .reel-play { background:rgba(201,168,76,.65); border-color:var(--gold); }
.reel-title { font-family:'Noto Nastaliq Urdu',serif; font-size:12px; color:#fff; direction:rtl; line-height:1.8; }

/* ══════════════════════════════════════════════════════════════
   19. LIKES, SHARE, ENGAGE
   ══════════════════════════════════════════════════════════════ */
.engage-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.engage-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 18px; border-radius:var(--r-pill); font-size:12px; font-weight:700; cursor:pointer; transition:all .18s; border:1px solid var(--border-mid); background:#fff; color:var(--text-muted); }
.engage-btn:hover,.engage-btn.liked { border-color:var(--gold); color:#7A5C10; background:var(--gold-pale); }
.engage-btn.share:hover { border-color:var(--green-mid); color:var(--green-mid); background:var(--green-pale); }

/* ══════════════════════════════════════════════════════════════
   20. META CARD (sidebar)
   ══════════════════════════════════════════════════════════════ */
.meta-card { background:#fff; border-radius:var(--r-md); border:1px solid var(--border); overflow:hidden; }
.meta-head { padding:12px 18px; background:var(--beige); border-bottom:1px solid var(--border); font-size:10.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--text-muted); }
.meta-body { padding:14px 18px; display:flex; flex-direction:column; gap:10px; }
.meta-row  { display:flex; justify-content:space-between; align-items:flex-start; font-size:13px; padding-bottom:10px; border-bottom:1px solid var(--border); gap:16px; }
.meta-row:last-child { border-bottom:none; padding-bottom:0; }
.meta-key  { color:var(--text-muted); font-size:12px; flex-shrink:0; }
.meta-val  { color:var(--text); font-weight:600; text-align:right; line-height:1.5; }

/* ══════════════════════════════════════════════════════════════
   21. COMMENTS
   ══════════════════════════════════════════════════════════════ */
.comments { background:#fff; border-radius:var(--r-md); border:1px solid var(--border); overflow:hidden; }
.comments-head { padding:14px 20px; background:var(--beige); border-bottom:1px solid var(--border); font-size:14px; font-weight:600; color:var(--green); }
.comments-body { padding:20px; }
.comment-form { margin-bottom:24px; display:flex; flex-direction:column; gap:10px; }
.comment-form input,.comment-form textarea { width:100%; padding:11px 14px; border:1px solid var(--border-mid); border-radius:var(--r-sm); font-size:13.5px; background:var(--off-white); color:var(--text); outline:none; transition:border-color .18s; }
.comment-form input:focus,.comment-form textarea:focus { border-color:var(--gold); }
.comment-form textarea { resize:vertical; line-height:1.7; min-height:90px; }
.comment-item { display:flex; gap:12px; padding-bottom:18px; margin-bottom:18px; border-bottom:1px solid var(--border); }
.comment-item:last-child { border-bottom:none; margin-bottom:0; padding-bottom:0; }
.comment-av { width:36px; height:36px; border-radius:50%; background:var(--green-pale); display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; color:var(--green-mid); flex-shrink:0; }
.comment-name { font-size:13px; font-weight:700; color:var(--text); }
.comment-time { font-size:11px; color:var(--text-light); margin-left:8px; }
.comment-text { font-size:13px; color:var(--text-muted); line-height:1.65; margin-top:4px; }

/* ══════════════════════════════════════════════════════════════
   22. ALBUM DETAIL HERO
   ══════════════════════════════════════════════════════════════ */
.album-hero { padding-top:var(--nav-h); background:var(--black); position:relative; overflow:hidden; }
.album-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:blur(40px) brightness(.22); transform:scale(1.12); }
.album-hero-inner { position:relative; z-index:2; max-width:var(--max-w); margin-inline:auto; padding:60px 24px; display:grid; grid-template-columns:260px 1fr; gap:52px; align-items:start; }
.album-cover-wrap { position:relative; }
.album-cover-wrap img { width:100%; border-radius:var(--r-md); box-shadow:0 24px 64px rgba(0,0,0,.65); }
.album-cover-badge { position:absolute; top:-10px; right:-10px; background:var(--gold); color:var(--black); font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:var(--r-sm); }
.album-info-title-ur { font-family:'Noto Nastaliq Urdu',serif; font-size:clamp(2rem,4vw,2.8rem); color:#fff; direction:rtl; text-align:right; line-height:1.75; margin-bottom:4px; }
.album-info-title-en { font-family:'Playfair Display',serif; font-size:1.25rem; color:var(--gold-lt); font-style:italic; margin-bottom:20px; }
.album-info-meta { display:flex; flex-wrap:wrap; gap:18px; margin-bottom:22px; }
.album-info-meta-item { display:flex; align-items:center; gap:6px; font-size:13px; color:rgba(255,255,255,.45); }
.album-info-meta-item strong { color:var(--gold-lt); }
.album-info-desc { font-size:14px; color:rgba(255,255,255,.5); line-height:1.85; margin-bottom:28px; max-width:460px; }
.album-info-actions { display:flex; gap:12px; flex-wrap:wrap; }

/* ══════════════════════════════════════════════════════════════
   23. KALAAM DETAIL
   ══════════════════════════════════════════════════════════════ */
.k-header { background:var(--green); padding:48px 24px; text-align:center; position:relative; overflow:hidden; }
.k-header::before { content:''; position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23C9A84C' stroke-width='0.4' opacity='0.09'%3E%3Cpolygon points='30 3 57 18 57 42 30 57 3 42 3 18'/%3E%3C/g%3E%3C/svg%3E"); background-size:60px; }
.k-header-inner { position:relative; z-index:1; max-width:660px; margin-inline:auto; }
.k-breadcrumb { font-size:11.5px; color:rgba(255,255,255,.3); margin-bottom:20px; letter-spacing:.08em; }
.k-breadcrumb a { color:var(--gold); }
.k-header-title-ur { font-family:'Noto Nastaliq Urdu',serif; font-size:clamp(1.7rem,4vw,2.8rem); color:#fff; direction:rtl; line-height:1.85; margin-bottom:6px; }
.k-header-title-en { font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--gold-lt); font-style:italic; margin-bottom:22px; }
.k-tags { display:flex; gap:8px; flex-wrap:wrap; justify-content:center; }
.k-tag { padding:4px 12px; border-radius:var(--r-pill); border:1px solid rgba(201,168,76,.28); font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.38); }
.k-body { max-width:var(--max-w); margin-inline:auto; padding:48px 24px; display:grid; grid-template-columns:1fr 340px; gap:44px; align-items:start; }
.k-main { display:flex; flex-direction:column; gap:32px; }
.k-sidebar { display:flex; flex-direction:column; gap:22px; }

/* ══════════════════════════════════════════════════════════════
   24. SIGNUP / CTA
   ══════════════════════════════════════════════════════════════ */
.signup { background:var(--green); position:relative; overflow:hidden; padding-block:80px; }
.signup::before { content:''; position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23C9A84C' fill-opacity='0.04'%3E%3Cpolygon points='30 2 58 16 58 44 30 58 2 44 2 16'/%3E%3C/g%3E%3C/svg%3E"); background-size:60px; }
.signup-inner { position:relative; z-index:1; max-width:500px; margin-inline:auto; text-align:center; padding-inline:24px; }
.signup-title { font-family:'Playfair Display',serif; font-size:clamp(1.5rem,3vw,2rem); color:#fff; margin-bottom:8px; }
.signup-sub { font-size:14px; color:rgba(255,255,255,.48); margin-bottom:30px; line-height:1.75; }
.signup-form { display:flex; border-radius:var(--r-pill); overflow:hidden; border:1px solid rgba(201,168,76,.28); max-width:420px; margin-inline:auto; }
.signup-form input { flex:1; padding:13px 20px; background:rgba(255,255,255,.06); border:none; outline:none; color:#fff; font-size:13.5px; }
.signup-form input::placeholder { color:rgba(255,255,255,.28); }
.signup-form button { padding:13px 24px; background:var(--gold); color:var(--black); font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; border:none; flex-shrink:0; transition:background .18s; }
.signup-form button:hover { background:var(--gold-lt); }
.signup-note { margin-top:12px; font-size:11px; color:rgba(255,255,255,.25); }

/* ══════════════════════════════════════════════════════════════
   25. CONTACT FORM
   ══════════════════════════════════════════════════════════════ */
.form-group { display:flex; flex-direction:column; gap:7px; margin-bottom:18px; }
.form-label { font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); }
.form-input,.form-textarea,.form-select { width:100%; padding:12px 16px; border:1px solid var(--border-mid); border-radius:var(--r-sm); font-size:14px; background:var(--off-white); color:var(--text); outline:none; transition:border-color .18s; }
.form-input:focus,.form-textarea:focus,.form-select:focus { border-color:var(--gold); background:#fff; }
.form-textarea { resize:vertical; line-height:1.75; min-height:130px; }

/* ══════════════════════════════════════════════════════════════
   26. FOOTER
   ══════════════════════════════════════════════════════════════ */
.footer { background:var(--black); color:rgba(255,255,255,.55); padding:64px 24px 32px; }
.footer-inner { max-width:var(--max-w); margin-inline:auto; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.05); margin-bottom:28px; }
.footer-logo { font-family:'Noto Serif Arabic',serif; font-size:28px; color:var(--gold); direction:rtl; margin-bottom:14px; }
.footer-desc { font-size:13px; line-height:1.85; color:rgba(255,255,255,.35); max-width:230px; }
.footer-col-title { font-size:10.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:13px; color:rgba(255,255,255,.38); transition:color .18s; }
.footer-links a:hover { color:var(--gold); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:11.5px; color:rgba(255,255,255,.22); }
.footer-copy a { color:var(--gold); }
.footer-social { display:flex; gap:10px; }
.soc-btn { width:34px; height:34px; border-radius:50%; border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.35); font-size:14px; transition:all .18s; }
.soc-btn:hover { border-color:var(--gold); color:var(--gold); }

/* ══════════════════════════════════════════════════════════════
   27. TOAST
   ══════════════════════════════════════════════════════════════ */
.toast { position:fixed; bottom:24px; right:24px; z-index:9999; background:var(--green); color:var(--gold-lt); padding:12px 24px; border-radius:var(--r-md); border:1px solid rgba(201,168,76,.28); font-size:13px; box-shadow:var(--sh-lg); transform:translateY(80px); opacity:0; transition:all .38s cubic-bezier(0,0,.2,1); pointer-events:none; }
.toast.show { transform:translateY(0); opacity:1; }

/* ══════════════════════════════════════════════════════════════
   28. ANIMATIONS
   ══════════════════════════════════════════════════════════════ */
@keyframes fadeUp { from { opacity:0; transform:translateY(28px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

.anim-up   { animation:fadeUp .6s var(--ease) both; }
.anim-in   { animation:fadeIn .5s var(--ease) both; }

.reveal { opacity:0; transform:translateY(24px); transition:opacity .55s cubic-bezier(0,0,.2,1),transform .55s cubic-bezier(0,0,.2,1); }
.reveal.visible { opacity:1; transform:translateY(0); }
[data-d="1"] { transition-delay:.08s; }
[data-d="2"] { transition-delay:.16s; }
[data-d="3"] { transition-delay:.24s; }
[data-d="4"] { transition-delay:.32s; }
[data-d="5"] { transition-delay:.40s; }

/* Screen reader only */
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border-width:0; }

/* ══════════════════════════════════════════════════════════════
   29. RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
@media (max-width:960px) {
  .grid-4       { grid-template-columns:repeat(2,1fr); }
  .grid-3       { grid-template-columns:repeat(2,1fr); }
  .footer-top   { grid-template-columns:1fr 1fr; gap:32px; }
  .album-hero-inner { grid-template-columns:1fr; }
  .k-body       { grid-template-columns:1fr; }
  .k-sidebar    { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
}
@media (max-width:640px) {
  :root { --nav-h:64px; }
  .section { padding-block:56px; }
  .grid-2 { grid-template-columns:1fr; }
  .grid-3 { grid-template-columns:1fr; }
  .nav-links { display:none; }
  .nav-right .nav-search { display:none; }
  .hamburger { display:flex; }
  .footer-top { grid-template-columns:1fr; gap:28px; }
  .stats-row  { grid-template-columns:repeat(2,1fr); }
  .reels-grid { grid-template-columns:repeat(2,1fr); }
  .hero-arrows { display:none; }
  .k-sidebar  { grid-template-columns:1fr; }
  .album-hero-inner { padding:36px 20px; }
  .search-bar { flex-direction:column; border-radius:var(--r-md); }
  .search-bar button { border-radius:0 0 var(--r-md) var(--r-md); }
}

/* ══════════════════════════════════════════════════════════════
   30. SCROLLBAR
   ══════════════════════════════════════════════════════════════ */
::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:var(--beige); }
::-webkit-scrollbar-thumb { background:var(--gold); border-radius:3px; }
