/* ============================================================
   ATHAR — أثر · Design System
   Shared by index.html (EN · LTR) and ar.html (AR · RTL)
   Uses CSS logical properties so RTL works natively.
   ============================================================ */

:root {
  --ink: #14241c;
  --forest: #1d3a2c;
  --moss: #2e5944;
  --sage: #6f8c7a;
  --cream: #f6f0e2;
  --paper: #fdfaf2;
  --card: #fffdf8;
  --gold: #b8923c;
  --gold-deep: #96752a;
  --gold-soft: #ead9ae;
  --terra: #b06a52;
  --wa-green: #dcf3c8;
  --line: rgba(20, 36, 28, .12);
  --shadow-soft: 0 2px 24px rgba(20, 36, 28, .07);
  --shadow-lift: 0 18px 50px -18px rgba(20, 36, 28, .25);
  --radius: 20px;
  --font-display: "Fraunces", "Amiri", serif;
  --font-body: "Newsreader", "IBM Plex Sans Arabic", serif;
  --font-ui: "Outfit", "IBM Plex Sans Arabic", sans-serif;
  --font-ar: "IBM Plex Sans Arabic", sans-serif;
  --font-ar-display: "Amiri", serif;
}

html[lang="ar"] {
  --font-display: "Amiri", serif;
  --font-body: "IBM Plex Sans Arabic", sans-serif;
  --font-ui: "IBM Plex Sans Arabic", sans-serif;
}

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

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.65;
  font-size: 17px;
  overflow-x: hidden;
}

html[lang="ar"] body { line-height: 1.9; letter-spacing: 0; }

/* Grain overlay */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none; z-index: 9999;
  opacity: .35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection { background: var(--gold-soft); color: var(--ink); }

h1, h2, h3 { font-family: var(--font-display); font-weight: 600; line-height: 1.15; }
html[lang="ar"] h1, html[lang="ar"] h2 { line-height: 1.5; font-weight: 700; }

img { max-width: 100%; }
a { color: inherit; }

.wrap { max-width: 1140px; margin-inline: auto; padding-inline: 24px; }

/* ---------- Scroll progress bar ---------- */
.scroll-progress {
  position: fixed; inset-block-start: 0; inset-inline-start: 0; height: 3px; width: 0;
  background: linear-gradient(90deg, var(--moss), var(--gold)); z-index: 300;
  transition: width .1s linear;
}

/* ---------- Reveal on scroll (cinematic blur-in) ---------- */
.rv { opacity: 0; transform: translateY(30px) scale(.985); filter: blur(7px); transition: opacity .9s cubic-bezier(.2,.6,.2,1), transform .9s cubic-bezier(.2,.6,.2,1), filter .9s cubic-bezier(.2,.6,.2,1); }
.rv.in { opacity: 1; transform: none; filter: none; }
.rv-d1 { transition-delay: .08s; } .rv-d2 { transition-delay: .16s; }
.rv-d3 { transition-delay: .24s; } .rv-d4 { transition-delay: .32s; }

/* ---------- Nav ---------- */
nav {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: blur(14px);
  border-block-end: 1px solid var(--line);
}
.nav-inner { display: flex; align-items: center; gap: 28px; padding-block: 14px; }
.brand { display: flex; align-items: baseline; gap: 10px; text-decoration: none; }
.brand .b-en { font-family: "Fraunces", serif; font-size: 1.45rem; font-weight: 600; letter-spacing: .01em; }
.brand .b-ar { font-family: "Amiri", serif; font-size: 1.5rem; color: var(--gold-deep); }
.nav-links { display: flex; gap: 26px; margin-inline-start: auto; font-family: var(--font-ui); font-size: .92rem; }
.nav-links a { text-decoration: none; opacity: .75; transition: opacity .2s; }
.nav-links a:hover { opacity: 1; }
.lang-pill {
  font-family: var(--font-ui); font-size: .85rem; text-decoration: none;
  border: 1px solid var(--line); padding: 7px 16px; border-radius: 99px;
  transition: all .25s;
}
.lang-pill:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.nav-cta {
  font-family: var(--font-ui); font-size: .9rem; font-weight: 600; text-decoration: none;
  background: var(--forest); color: var(--paper);
  padding: 9px 22px; border-radius: 99px; transition: all .25s;
}
.nav-cta:hover { background: var(--moss); transform: translateY(-1px); }
@media (max-width: 860px) { .nav-links { display: none; } }

/* ---------- Hero ---------- */
.hero { position: relative; padding-block: 84px 70px; overflow: hidden; }
.hero::after {
  content: ""; position: absolute; inset-inline-end: -180px; top: -120px;
  width: 560px; height: 560px; border-radius: 50%;
  background: radial-gradient(circle, rgba(184,146,60,.14), transparent 65%);
  pointer-events: none;
}
.hero::before {
  content: ""; position: absolute; inset-inline-start: -160px; bottom: -200px;
  width: 480px; height: 480px; border-radius: 50%;
  background: radial-gradient(circle, rgba(46,89,68,.10), transparent 65%);
  pointer-events: none;
}
.hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: center; position: relative; }
@media (max-width: 920px) { .hero-grid { grid-template-columns: 1fr; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font-ui); font-size: .82rem; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase; color: var(--gold-deep);
  border: 1px solid var(--gold-soft); background: rgba(234,217,174,.25);
  padding: 7px 16px; border-radius: 99px; margin-block-end: 26px;
}
html[lang="ar"] .eyebrow { letter-spacing: 0; font-size: .9rem; }
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); animation: pulse 2.4s infinite; }
@keyframes pulse { 50% { opacity: .35; transform: scale(.8); } }

.hero h1 { font-size: clamp(2.6rem, 5.4vw, 4.3rem); margin-block-end: 24px; }
.hero h1 em { font-style: italic; color: var(--gold-deep); }
html[lang="ar"] .hero h1 em { font-style: normal; }
.hero p.lede { font-size: 1.18rem; max-width: 34em; opacity: .85; margin-block-end: 34px; }

.cta-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-block-end: 26px; }
.btn {
  font-family: var(--font-ui); font-weight: 600; font-size: 1rem;
  text-decoration: none; border-radius: 99px; padding: 15px 32px;
  display: inline-flex; align-items: center; gap: 9px;
  transition: all .25s cubic-bezier(.2,.6,.2,1); cursor: pointer; border: none;
}
.btn-primary { background: var(--forest); color: var(--paper); box-shadow: var(--shadow-lift); }
.btn-primary:hover { background: var(--moss); transform: translateY(-2px); }
.btn-ghost { border: 1.5px solid var(--line); color: var(--ink); background: transparent; }
.btn-ghost:hover { border-color: var(--ink); }
.btn-gold { background: var(--gold); color: #fff; box-shadow: 0 14px 36px -12px rgba(184,146,60,.5); }
.btn-gold:hover { background: var(--gold-deep); transform: translateY(-2px); }

.hero-trust { display: flex; flex-wrap: wrap; gap: 18px; font-family: var(--font-ui); font-size: .88rem; opacity: .8; }
.hero-trust span { display: inline-flex; gap: 7px; align-items: center; }
.hero-trust .tick { color: var(--moss); font-weight: 700; }

/* ---------- Phone mockup ---------- */
.phone {
  position: relative; max-width: 360px; margin-inline: auto;
  background: #0d1f16; border-radius: 42px; padding: 14px;
  box-shadow: 0 40px 90px -30px rgba(20,36,28,.5);
  transform: rotate(2deg) translateY(calc(var(--py, 0) * 1px));
  animation: floaty 7s ease-in-out infinite;
  will-change: transform;
}
html[lang="ar"] .phone { transform: rotate(-2deg); }
@keyframes floaty { 50% { translate: 0 -10px; } }
.phone-screen { background: #ece5d8 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' opacity='0.05'%3E%3Cpath d='M30 5l5 10 10 2-7 8 2 10-10-5-10 5 2-10-7-8 10-2z' fill='%231d3a2c'/%3E%3C/svg%3E"); border-radius: 30px; overflow: hidden; }
.phone-head { background: var(--forest); color: var(--paper); padding: 16px 18px; display: flex; gap: 12px; align-items: center; }
.avatar { width: 42px; height: 42px; border-radius: 50%; background: var(--gold-soft); color: var(--ink); display: grid; place-items: center; font-family: "Amiri", serif; font-size: 1.2rem; font-weight: 700; }
.phone-head .who { font-family: var(--font-ui); font-size: .95rem; font-weight: 600; }
.phone-head .sub { font-size: .75rem; opacity: .75; }
.phone-body { padding: 18px 14px 22px; display: flex; flex-direction: column; gap: 12px; min-height: 330px; }
.bubble {
  background: #fff; border-radius: 14px; padding: 12px 15px;
  max-width: 88%; font-size: .92rem; line-height: 1.75;
  box-shadow: 0 1px 2px rgba(0,0,0,.08); position: relative;
  align-self: flex-start;
}
.bubble.them { background: var(--wa-green); }
.bubble .t { display: block; text-align: end; font-size: .68rem; opacity: .5; margin-block-start: 5px; font-family: var(--font-ui); }
.bubble .t .ticks { color: #4fa3d1; }
.bubble-note {
  align-self: center; font-family: var(--font-ui); font-size: .75rem;
  background: rgba(20,36,28,.07); border-radius: 99px; padding: 5px 14px; opacity: .8;
}

/* ---------- Decorative botanical branch (baked-in SVG) ---------- */
.hero .wrap::after {
  content: ""; position: absolute; inset-block-end: -40px; inset-inline-start: -30px;
  width: 300px; height: 300px; pointer-events: none; opacity: .14; z-index: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 300'%3E%3Cg fill='none' stroke='%232e5944' stroke-width='3'%3E%3Cpath d='M30 280 C 80 220, 120 160, 200 60'/%3E%3Cpath d='M95 200 C 120 195, 150 200, 168 218'/%3E%3Cpath d='M130 150 C 155 145, 185 150, 203 168'/%3E%3C/g%3E%3Cg fill='%232e5944'%3E%3Cellipse cx='90' cy='208' rx='26' ry='11' transform='rotate(-28 90 208)'/%3E%3Cellipse cx='128' cy='158' rx='26' ry='11' transform='rotate(-30 128 158)'/%3E%3Cellipse cx='166' cy='110' rx='24' ry='10' transform='rotate(-34 166 110)'/%3E%3C/g%3E%3Cg fill='%23b8923c'%3E%3Cellipse cx='178' cy='222' rx='22' ry='9' transform='rotate(20 178 222)'/%3E%3Cellipse cx='212' cy='172' rx='22' ry='9' transform='rotate(18 212 172)'/%3E%3Ccircle cx='205' cy='52' r='7'/%3E%3C/g%3E%3C/svg%3E") no-repeat center / contain;
}
html[dir="rtl"] .hero .wrap::after { transform: scaleX(-1); }
.hero .wrap { position: relative; }
.hero-grid > div { position: relative; z-index: 1; }

/* ---------- AI image slot (graceful when file missing) ---------- */
.art-slot { margin-block: 0 48px; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lift); }
.art-slot img { display: block; width: 100%; height: 280px; object-fit: cover; }

/* ---------- Stats / ticker ---------- */
.stats { padding-block: 44px 10px; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; text-align: center; }
@media (max-width: 760px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
.stat .n { font-family: var(--font-display); font-size: 2.6rem; font-weight: 600; color: var(--forest); }
.stat .n sup { font-size: 1.1rem; color: var(--gold-deep); }
.stat .l { font-family: var(--font-ui); font-size: .88rem; opacity: .7; }

.ticker-wrap {
  overflow: hidden; border-block: 1px solid var(--line);
  padding-block: 14px; margin-block: 40px 0;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.ticker { display: flex; gap: 38px; width: max-content; animation: tick 60s linear infinite; }
.ticker-wrap:hover .ticker { animation-play-state: paused; }
@keyframes tick { to { transform: translateX(-50%); } }
html[dir="rtl"] .ticker { animation-name: tick-rtl; }
@keyframes tick-rtl { to { transform: translateX(50%); } }
.ticker span { font-family: var(--font-ui); font-size: .92rem; opacity: .75; white-space: nowrap; display: inline-flex; align-items: center; gap: 38px; }
.ticker .sep { color: var(--gold); }

/* ---------- Sections ---------- */
section { padding-block: 116px; position: relative; }
.sect-head { max-width: 640px; margin-block-end: 64px; }
.sect-head.center { margin-inline: auto; text-align: center; }
.kicker {
  font-family: var(--font-ui); font-size: .8rem; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase; color: var(--gold-deep);
  margin-block-end: 14px; display: block;
}
html[lang="ar"] .kicker { letter-spacing: 0; font-size: .95rem; }
.sect-head h2 { font-size: clamp(1.9rem, 3.6vw, 2.9rem); margin-block-end: 16px; }
.sect-head p { opacity: .8; font-size: 1.08rem; }

.band { background: var(--cream); }
.band-dark { background: var(--ink); color: var(--cream); }
.band-dark .kicker { color: var(--gold-soft); }

/* ---------- Two paths ---------- */
.paths { display: grid; grid-template-columns: 1fr auto 1fr; gap: 22px; align-items: stretch; margin-block-end: 64px; }
@media (max-width: 860px) { .paths { grid-template-columns: 1fr; } .or-pill { margin-inline: auto; } }
.path-card {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 36px 32px; position: relative; transition: all .35s cubic-bezier(.2,.6,.2,1);
  box-shadow: var(--shadow-soft); display: flex; flex-direction: column;
}
.path-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lift); border-color: var(--gold-soft); }
.path-tag {
  position: absolute; inset-block-start: -13px; inset-inline-start: 28px;
  font-family: var(--font-ui); font-size: .75rem; font-weight: 700;
  background: var(--forest); color: var(--paper); padding: 5px 14px; border-radius: 99px;
}
.path-card.alt .path-tag { background: var(--gold); }
.path-emoji { font-size: 2.2rem; margin-block-end: 16px; }
.path-card h3 { font-size: 1.45rem; margin-block-end: 12px; }
.path-card p { opacity: .82; flex: 1; }
.path-meta { font-family: var(--font-ui); font-size: .84rem; color: var(--moss); margin-block-start: 18px; font-weight: 600; }
.path-link { margin-block-start: 14px; font-family: var(--font-ui); font-weight: 700; color: var(--gold-deep); text-decoration: none; }
.path-link:hover { text-decoration: underline; }
.or-pill {
  align-self: center; font-family: var(--font-ui); font-weight: 700; font-size: .9rem;
  background: var(--ink); color: var(--paper); width: 54px; height: 54px;
  border-radius: 50%; display: grid; place-items: center;
}

.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 860px) { .steps { grid-template-columns: 1fr; } }
.step { padding: 30px 28px; border-radius: var(--radius); background: var(--card); border: 1px solid var(--line); }
.step .num { font-family: var(--font-display); font-size: 2.4rem; color: var(--gold); font-weight: 600; }
.step h3 { font-size: 1.25rem; margin-block: 10px 10px; }
.step p { font-size: .98rem; opacity: .82; }

.privacy-note {
  margin-block-start: 56px; border-inline-start: 4px solid var(--gold);
  background: var(--card); border-radius: 0 var(--radius) var(--radius) 0;
  padding: 28px 32px; font-size: 1.02rem; box-shadow: var(--shadow-soft);
}
html[dir="rtl"] .privacy-note { border-radius: var(--radius) 0 0 var(--radius); }

/* ---------- Garden explainer ---------- */
.garden { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 980px) { .garden { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .garden { grid-template-columns: 1fr; } }
.garden-card {
  border-radius: var(--radius); padding: 30px 26px; position: relative; overflow: hidden;
  background: linear-gradient(165deg, rgba(46,89,68,.10), rgba(184,146,60,.08)), var(--card);
  border: 1px solid var(--line); transition: transform .35s;
}
.garden-card:hover { transform: translateY(-5px); }
.garden-card .g-ico { font-size: 2rem; margin-block-end: 14px; display: block; }
.garden-card h3 { font-size: 1.15rem; margin-block-end: 8px; }
.garden-card p { font-size: .94rem; opacity: .82; }
.garden-card .g-stage {
  position: absolute; inset-block-start: 18px; inset-inline-end: 20px;
  font-family: var(--font-display); font-size: 1.4rem; color: var(--gold); opacity: .6;
}
.garden-quote {
  text-align: center; margin-block-start: 48px; font-family: var(--font-display);
  font-size: clamp(1.3rem, 2.6vw, 1.8rem); font-style: italic; color: var(--forest); max-width: 32em; margin-inline: auto;
}
html[lang="ar"] .garden-quote { font-style: normal; }

/* ---------- Message cards ---------- */
.msgs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 980px) { .msgs { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .msgs { grid-template-columns: 1fr; } }
.msg {
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px 24px; display: flex; flex-direction: column;
  transition: all .35s cubic-bezier(.2,.6,.2,1); box-shadow: var(--shadow-soft);
}
.msg:hover { transform: translateY(-5px) rotate(-.4deg); box-shadow: var(--shadow-lift); }
.msg.featured { background: linear-gradient(165deg, #21402f, #14241c); color: var(--cream); border-color: transparent; }
.msg.featured .msg-when { color: var(--gold-soft); }
.msg-top { display: flex; justify-content: space-between; align-items: center; margin-block-end: 14px; font-family: var(--font-ui); }
.msg-cat { font-size: .8rem; font-weight: 700; color: var(--gold-deep); }
.msg.featured .msg-cat { color: var(--gold-soft); }
.msg-when { font-size: .75rem; opacity: .65; }
.msg-bubble { background: var(--wa-green); color: var(--ink); border-radius: 14px; padding: 16px 17px; font-size: .95rem; line-height: 1.8; flex: 1; box-shadow: 0 1px 2px rgba(0,0,0,.06); }
.msg-label { margin-block-start: 14px; font-family: var(--font-ui); font-size: .8rem; opacity: .65; }

/* ---------- Testimonials ---------- */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .quotes { grid-template-columns: 1fr; } }
.quote {
  background: var(--card); border-radius: var(--radius); padding: 34px 30px;
  border: 1px solid var(--line); position: relative; box-shadow: var(--shadow-soft);
}
.quote::before {
  content: "“"; font-family: "Fraunces", serif; font-size: 4.5rem; line-height: 1;
  color: var(--gold-soft); position: absolute; inset-block-start: 14px; inset-inline-start: 22px;
}
html[dir="rtl"] .quote::before { content: "”"; }
.quote p { position: relative; font-size: 1.0rem; margin-block-start: 28px; }
.quote-who { display: flex; gap: 12px; align-items: center; margin-block-start: 22px; }
.quote-who .qa { width: 42px; height: 42px; border-radius: 50%; background: var(--forest); color: var(--gold-soft); display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; }
.quote-who .qn { font-family: var(--font-ui); font-weight: 700; font-size: .92rem; }
.quote-who .qc { font-size: .8rem; opacity: .65; }
.quotes-note { text-align: center; font-size: .85rem; opacity: .6; margin-block-start: 28px; font-family: var(--font-ui); }

/* ---------- Foundation (hadith) ---------- */
.foundation { text-align: center; }
.hadith-ar {
  font-family: "Amiri", serif; font-size: clamp(1.5rem, 3.4vw, 2.3rem);
  line-height: 2.1; color: var(--gold-soft); max-width: 26em; margin-inline: auto; direction: rtl;
}
.hadith-en { font-style: italic; opacity: .85; max-width: 36em; margin: 26px auto 0; font-size: 1.1rem; }
.hadith-src { font-family: var(--font-ui); font-size: .85rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold); margin-block-start: 22px; }
html[lang="ar"] .hadith-src { letter-spacing: 0; }
.foundation-belief { max-width: 38em; margin: 44px auto 0; font-size: 1.08rem; opacity: .9; }
.foundation-belief strong { color: var(--gold-soft); }

/* ---------- Features ---------- */
.feats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .feats { grid-template-columns: 1fr; } }
.feat { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 28px; transition: all .3s; }
.feat:hover { border-color: var(--gold-soft); transform: translateY(-4px); box-shadow: var(--shadow-soft); }
.feat .f-ico { width: 46px; height: 46px; border-radius: 14px; background: rgba(46,89,68,.1); display: grid; place-items: center; font-size: 1.3rem; margin-block-end: 16px; }
.feat h3 { font-size: 1.12rem; margin-block-end: 8px; }
.feat p { font-size: .95rem; opacity: .8; }

/* ---------- Channels ---------- */
.chans { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 900px) { .chans { grid-template-columns: repeat(2, 1fr); } }
.chan { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 24px; text-align: center; transition: all .3s; }
.chan:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); }
.chan .c-ico { font-size: 2rem; margin-block-end: 12px; }
.chan h3 { font-size: 1.08rem; margin-block-end: 8px; }
.chan p { font-size: .88rem; opacity: .78; min-height: 3.2em; }
.chan .c-badge { display: inline-block; font-family: var(--font-ui); font-size: .72rem; font-weight: 700; padding: 4px 12px; border-radius: 99px; background: rgba(46,89,68,.12); color: var(--moss); margin-block-start: 10px; }
.chan .c-badge.soon { background: rgba(184,146,60,.14); color: var(--gold-deep); }

/* ---------- FAQ ---------- */
.faq { max-width: 760px; margin-inline: auto; }
.faq details { border-block-end: 1px solid var(--line); padding-block: 4px; }
.faq summary {
  cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-display); font-size: 1.18rem; font-weight: 600; padding-block: 20px; gap: 16px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--font-ui); font-size: 1.5rem; color: var(--gold); transition: transform .3s; flex-shrink: 0; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq .a { padding-block-end: 22px; opacity: .85; max-width: 60ch; }

/* ---------- Waitlist ---------- */
.waitlist-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
@media (max-width: 920px) { .waitlist-grid { grid-template-columns: 1fr; } }
.wl-points { display: flex; flex-direction: column; gap: 20px; margin-block-start: 30px; }
.wl-point { display: flex; gap: 16px; }
.wl-point .ico { width: 42px; height: 42px; flex-shrink: 0; border-radius: 13px; background: rgba(184,146,60,.16); display: grid; place-items: center; font-size: 1.15rem; }
.wl-point h4 { font-family: var(--font-ui); font-size: 1rem; }
.wl-point p { font-size: .92rem; opacity: .78; }

.form-card {
  background: var(--card); border-radius: 26px; padding: 40px 36px;
  box-shadow: var(--shadow-lift); border: 1px solid var(--line); position: relative;
}
.form-card::before {
  content: ""; position: absolute; inset-inline: 24px; inset-block-start: 0; height: 4px;
  background: linear-gradient(90deg, var(--gold), var(--moss)); border-radius: 0 0 6px 6px;
}
.form-card h3 { font-size: 1.5rem; margin-block-end: 8px; }
.form-card .fc-sub { font-size: .92rem; opacity: .75; margin-block-end: 26px; }
.field { margin-block-end: 18px; }
.field label { display: block; font-family: var(--font-ui); font-size: .85rem; font-weight: 600; margin-block-end: 8px; }
.field input[type=text], .field input[type=email], .field input[type=tel], .field textarea, .field select {
  width: 100%; padding: 13px 16px; border: 1.5px solid var(--line); border-radius: 13px;
  font-family: var(--font-body); font-size: 1rem; background: var(--paper); color: var(--ink);
  transition: border-color .25s;
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--gold); }
.chips { display: flex; flex-wrap: wrap; gap: 9px; }
.chip {
  font-family: var(--font-ui); font-size: .87rem; padding: 9px 17px; border-radius: 99px;
  border: 1.5px solid var(--line); cursor: pointer; user-select: none; transition: all .2s; background: var(--paper);
}
.chip:hover { border-color: var(--gold); }
.chip.on { background: var(--forest); color: var(--paper); border-color: var(--forest); }
.nudge {
  display: none; margin-block-start: 14px; background: rgba(184,146,60,.1);
  border: 1px dashed var(--gold); border-radius: 13px; padding: 14px 16px; font-size: .9rem;
}
.nudge.show { display: block; animation: nudgein .4s; }
@keyframes nudgein { from { opacity: 0; transform: translateY(6px); } }
.nudge a { color: var(--gold-deep); font-weight: 700; }
.form-foot { font-size: .8rem; opacity: .6; text-align: center; margin-block-start: 14px; }
.form-ok { display: none; text-align: center; padding: 30px 10px; }
.form-ok.show { display: block; animation: nudgein .5s; }
.form-ok .big { font-size: 2.6rem; }
.form-ok h4 { font-family: var(--font-display); font-size: 1.4rem; margin-block: 12px 8px; }

/* ---------- Footer ---------- */
footer { background: var(--ink); color: var(--cream); padding-block: 64px 36px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-block-end: 48px; }
@media (max-width: 860px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
.foot-brand p { font-size: .92rem; opacity: .7; max-width: 28em; margin-block-start: 12px; }
footer h4 { font-family: var(--font-ui); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gold-soft); margin-block-end: 16px; }
html[lang="ar"] footer h4 { letter-spacing: 0; }
footer ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
footer ul a { text-decoration: none; font-size: .92rem; opacity: .75; font-family: var(--font-ui); }
footer ul a:hover { opacity: 1; }
.foot-base { border-block-start: 1px solid rgba(246,240,226,.12); padding-block-start: 26px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px; font-size: .85rem; opacity: .65; font-family: var(--font-ui); }
.foot-dua { font-family: "Amiri", serif; font-size: 1.15rem; color: var(--gold-soft); opacity: .9; direction: rtl; }

/* ============================================================
   QUESTIONNAIRE
   ============================================================ */
.q-page { min-height: 100vh; display: flex; flex-direction: column; }
.q-shell { max-width: 720px; margin: 0 auto; padding: 40px 22px 90px; width: 100%; flex: 1; }
.q-progress { position: sticky; top: 0; z-index: 50; background: var(--paper); padding-block: 18px 10px; }
.q-bar { height: 6px; border-radius: 99px; background: rgba(20,36,28,.1); overflow: hidden; }
.q-bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--moss), var(--gold)); border-radius: 99px; transition: width .5s cubic-bezier(.2,.6,.2,1); }
.q-meta { display: flex; justify-content: space-between; font-family: var(--font-ui); font-size: .8rem; opacity: .65; margin-block-start: 8px; }
.q-step { display: none; animation: qin .45s cubic-bezier(.2,.6,.2,1); }
.q-step.on { display: block; }
@keyframes qin { from { opacity: 0; transform: translateY(18px); } }
.q-step .q-kick { font-family: var(--font-ui); font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--gold-deep); }
html[lang="ar"] .q-step .q-kick { letter-spacing: 0; }
.q-step h2 { font-size: clamp(1.6rem, 3.4vw, 2.2rem); margin-block: 10px 8px; }
.q-step .q-sub { opacity: .75; margin-block-end: 30px; }
.q-nav { display: flex; justify-content: space-between; gap: 14px; margin-block-start: 38px; }
.sliders { display: flex; flex-direction: column; gap: 26px; }
.slider-row label { display: flex; justify-content: space-between; font-family: var(--font-ui); font-size: .9rem; font-weight: 600; margin-block-end: 10px; }
.slider-row input[type=range] { width: 100%; accent-color: var(--gold); }
.slider-ends { display: flex; justify-content: space-between; font-size: .78rem; opacity: .6; margin-block-start: 4px; font-family: var(--font-ui); }
.q-wl-banner {
  background: linear-gradient(120deg, rgba(46,89,68,.1), rgba(184,146,60,.12));
  border: 1px solid var(--gold-soft); border-radius: var(--radius);
  padding: 18px 22px; margin-block-end: 34px; font-size: .95rem; display: flex; gap: 12px; align-items: center;
}
.q-wl-banner .b-ico { font-size: 1.4rem; }
.q-done { text-align: center; padding-block: 60px; }
.q-done .big { font-size: 3.4rem; }
.q-done h2 { margin-block: 18px 12px; }
.q-done p { max-width: 32em; margin-inline: auto; opacity: .8; }

/* ============================================================
   PRICING
   ============================================================ */
.pricing { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; max-width: 880px; margin-inline: auto; align-items: stretch; }
.pricing.three { grid-template-columns: repeat(3, 1fr); max-width: 1100px; }
@media (max-width: 920px) { .pricing.three { grid-template-columns: 1fr; max-width: 560px; } }
@media (max-width: 760px) { .pricing { grid-template-columns: 1fr; } }
.trial-note {
  text-align: center; font-family: var(--font-ui); font-size: .95rem; font-weight: 600;
  color: var(--moss); margin: -28px auto 44px; max-width: 40em;
}
.trial-note .pill { background: rgba(46,89,68,.1); border-radius: 99px; padding: 8px 20px; display: inline-block; }
.price-card {
  background: var(--card); border: 1px solid var(--line); border-radius: 26px;
  padding: 40px 36px; display: flex; flex-direction: column; position: relative;
  box-shadow: var(--shadow-soft); transition: transform .3s;
}
.price-card:hover { transform: translateY(-4px); }
.price-card.gold { border: 2px solid var(--gold); box-shadow: var(--shadow-lift); }
.price-badge {
  position: absolute; inset-block-start: -14px; inset-inline-start: 50%; transform: translateX(-50%);
  font-family: var(--font-ui); font-size: .75rem; font-weight: 700; white-space: nowrap;
  background: var(--gold); color: #fff; padding: 6px 18px; border-radius: 99px;
}
html[dir="rtl"] .price-badge { transform: translateX(50%); }
.price-card h3 { font-size: 1.35rem; margin-block-end: 6px; }
.price-card .p-sub { font-size: .92rem; opacity: .7; margin-block-end: 22px; }
.price-card .p-amount { font-family: var(--font-display); font-size: 2.7rem; font-weight: 600; color: var(--forest); line-height: 1; }
.price-card .p-amount small { font-size: 1rem; font-family: var(--font-ui); font-weight: 500; opacity: .6; }
.price-card .p-note { font-family: var(--font-ui); font-size: .8rem; color: var(--gold-deep); font-weight: 600; margin-block-start: 6px; }
.price-card ul { list-style: none; margin-block: 26px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.price-card ul li { display: flex; gap: 10px; font-size: .96rem; align-items: flex-start; }
.price-card ul li::before { content: "✓"; color: var(--moss); font-weight: 700; flex-shrink: 0; }
.price-card ul li.muted { opacity: .55; }
.price-card ul li.muted::before { content: "—"; color: var(--sage); }
.pricing-why {
  max-width: 680px; margin: 44px auto 0; text-align: center; font-size: .98rem; opacity: .85;
  background: var(--cream); border-radius: var(--radius); padding: 24px 30px; border: 1px solid var(--line);
}
.pricing-why strong { color: var(--gold-deep); }

/* ============================================================
   STICKY MOBILE CTA
   ============================================================ */
.sticky-cta {
  position: fixed; inset-block-end: 0; inset-inline: 0; z-index: 95;
  display: none; align-items: center; justify-content: space-between; gap: 14px;
  background: color-mix(in srgb, var(--ink) 97%, transparent);
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  color: var(--cream); padding: 12px 18px calc(12px + env(safe-area-inset-bottom));
  transform: translateY(110%); transition: transform .4s cubic-bezier(.2,.6,.2,1);
}
.sticky-cta.show { transform: none; }
.sticky-cta .s-txt { font-family: var(--font-ui); font-size: .85rem; line-height: 1.4; }
.sticky-cta .s-txt strong { color: var(--gold-soft); }
.sticky-cta .btn { padding: 11px 22px; font-size: .9rem; flex-shrink: 0; }
@media (max-width: 760px) { .sticky-cta { display: flex; } }

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.chip:focus-visible, .btn:focus-visible, .lang-pill:focus-visible, .nav-cta:focus-visible {
  outline: 3px solid var(--gold); outline-offset: 2px;
}
.faq summary:focus-visible { outline: 3px solid var(--gold); outline-offset: 2px; border-radius: 8px; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .rv { opacity: 1; transform: none; filter: none; transition: none; }
  .phone { transform: none !important; }
  .scroll-progress { display: none; }
  .ticker { animation: none; flex-wrap: wrap; width: auto; }
  .phone { animation: none; }
  .eyebrow .dot { animation: none; }
  .sticky-cta { transition: none; }
  .q-step, .nudge.show, .form-ok.show { animation: none; }
}
