/* ============================================================
   ISHQ — Landing styles (ishqtime.com)
   Tokens copied 1:1 from apps/web/src/theme/tokens.css so the
   landing is visually identical to the Telegram mini-app.
   Brand discipline: gold = accent only (≤10% of any surface,
   never a fill). Emerald = primary fill. Whitespace = silence.
   ============================================================ */

:root {
  /* ── Backgrounds ── */
  --ink:      #101a16;
  --ink-2:    #13241e;
  --ink-3:    #0a1813;
  --footer-ink: #060f0c;            /* black ⊕ ink-3: honors registered black wordmark */
  --glow-bg:  rgba(22, 48, 36, 0.35);

  /* ── Semantic accents ── */
  --accent:      #c9a24b;           /* gold — accent ONLY */
  --accent-soft: #e6c878;
  --brand:       #0e6b52;           /* emerald — brand fill */
  --brand-soft:  #157a5e;

  /* ── Gold palette ── */
  --gold-muted:  #a8823a;
  --gold-warm:   #d4963a;
  --gold-accent: #c8a96e;
  --gold-ghost:  rgba(201, 162, 75, 0.06);

  /* ── Compat aliases ── */
  --emerald:      var(--brand);
  --emerald-soft: var(--brand-soft);
  --turquoise:    #2fb6a0;
  --gold:         var(--accent);
  --gold-soft:    var(--accent-soft);

  /* ── Text ── */
  --cream:   #faf7f0;
  --white:   #ffffff;
  --muted:   rgba(250, 247, 240, 0.78);
  --muted-2: rgba(250, 247, 240, 0.55);
  --muted-3: rgba(250, 247, 240, 0.6);

  /* ── Atmospheric / sacred ── */
  --teal-deep:    #1a4a44;
  --teal-surface: rgba(47, 182, 160, 0.06);

  /* ── Elevation ── */
  --surface-0:        rgba(250, 247, 240, 0.05);
  --surface:          rgba(250, 247, 240, 0.11);
  --surface-2:        rgba(250, 247, 240, 0.15);
  --surface-3:        rgba(250, 247, 240, 0.20);
  --surface-elevated: rgba(250, 247, 240, 0.24);
  --surface-gold:     rgba(201, 162, 75,  0.06);
  --surface-teal:     rgba(47,  182, 160, 0.06);

  --line:      rgba(250, 247, 240, 0.12);
  --line-gold: rgba(201, 162, 75,  0.20);

  /* ── Shadows ── */
  --shadow-1: 0 1px 3px  rgba(0, 0, 0, 0.24),
              0 2px 8px  rgba(0, 0, 0, 0.16);
  --shadow-2: 0 4px 12px rgba(0, 0, 0, 0.28),
              0 8px 24px rgba(0, 0, 0, 0.20);
  --shadow-3: 0 8px 24px rgba(0, 0, 0, 0.36),
              0 16px 48px rgba(0, 0, 0, 0.28);
  --shadow:   var(--shadow-2);

  /* ── Glow ── */
  --glow-gold:   0 0 20px rgba(201, 162, 75, 0.22),
                 0 0 48px rgba(201, 162, 75, 0.10);
  --glow-subtle: 0 0 12px rgba(201, 162, 75, 0.12);

  /* ── Fonts ── */
  --font-head: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-ar:   'Reem Kufi', 'Noto Naskh Arabic', 'Arabic Typesetting', serif;
  --lh-ar:     2.1;

  /* ── Radii ── */
  --r-xs:   6px;
  --r-sm:   12px;
  --r:      18px;
  --r-lg:   26px;
  --r-pill: 999px;

  /* ── Spacing ── */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;

  --nav-h:          74px;
  --nav-h-scrolled: 60px;

  /* ── Motion ── */
  --dur-fast: 120ms;
  --dur:      200ms;
  --dur-slow: 440ms;
  --ease-out:    cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-settle: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-reveal: cubic-bezier(0.0, 0.0, 0.2, 1);
  --press-scale: 0.97;

  /* ── Type scale ── */
  --text-xs:  clamp(10px, 2.4vw, 12px);
  --text-sm:  clamp(12px, 3.2vw, 14px);
  --text-md:  clamp(14px, 3.8vw, 16px);
  --text-lg:  clamp(16px, 4.2vw, 18px);
  --text-xl:  clamp(20px, 5vw,   24px);
  --text-2xl: clamp(28px, 7vw,   36px);
  --text-3xl: clamp(36px, 10vw,  56px);
  --text-ar-body:    clamp(18px, 4.8vw, 22px);
  --text-ar-display: clamp(26px, 7vw,   34px);
  --text-ar-hero:    clamp(36px, 10vw,  52px);

  /* ── Atmospheric opacity ── */
  --opacity-pattern:   0.055;
  --opacity-watermark: 0.04;
  --opacity-glow-rim:  0.08;

  /* ── Typographic ── */
  --ls-display: -0.02em;
  --ls-eyebrow: 0.14em;
  --ls-wordmark: 0.18em;

  /* ── Gold rim system ── */
  --gold-rim-subtle: rgba(201, 162, 75, 0.18);
  --gold-rim:        rgba(201, 162, 75, 0.28);
  --gold-rim-strong: rgba(201, 162, 75, 0.45);

  /* ── Layout ── */
  --maxw:    1100px;
  --gutter:  clamp(20px, 5vw, 48px);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  background: var(--ink-2);
  color: var(--cream);
  font-family: var(--font-body);
  font-size: var(--text-md);
  line-height: 1.6;
  font-feature-settings: 'kern' 1, 'liga' 1, 'calt' 1;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

h1, h2, h3 { margin: 0; font-weight: 600; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img, svg { display: block; max-width: 100%; }

::selection { background: rgba(14, 107, 82, 0.4); color: var(--cream); }

:focus-visible {
  outline: 2px solid var(--gold-rim-strong);
  outline-offset: 3px;
  border-radius: var(--r-xs);
}

/* Arabic spans */
[lang="ar"] {
  font-family: var(--font-ar);
  line-height: var(--lh-ar);
}

/* ── Eyebrow shared look ── */
.isq-mission__eyebrow,
.isq-doctrine__eyebrow,
.isq-eco__eyebrow,
.isq-companion__eyebrow,
.isq-sadaqah__eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  color: var(--gold-muted);
  margin: 0 0 var(--space-4);
}

/* ── Section title shared ── */
.isq-eco__title,
.isq-companion__title,
.isq-sadaqah__title {
  font-family: var(--font-head);
  color: var(--cream);
  letter-spacing: var(--ls-display);
  line-height: 1.15;
}

/* ── Khatam star glyph (nav + footer) ── */
.isq-star__stroke { stroke: var(--emerald); stroke-width: 1.6; fill: none; }
.isq-star__dot    { fill: var(--accent); }

/* ── Reveal-on-scroll (toggled by app.js) ── */
.reveal {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity var(--dur-slow) var(--ease-reveal),
              transform var(--dur-slow) var(--ease-reveal);
}
.reveal.is-visible { opacity: 1; transform: none; }

/* ============================================================
   1. NAV
   ============================================================ */
.isq-nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  height: calc(var(--nav-h) + env(safe-area-inset-top, 0px));
  padding-top: env(safe-area-inset-top, 0px);
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: height var(--dur) var(--ease-out),
              background-color var(--dur) var(--ease-out),
              border-color var(--dur) var(--ease-out),
              backdrop-filter var(--dur) var(--ease-out);
}
.isq-nav--scrolled {
  height: calc(var(--nav-h-scrolled) + env(safe-area-inset-top, 0px));
  background: rgba(19, 36, 30, 0.72);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
}
.isq-nav__inner {
  height: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.isq-nav__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  min-height: 44px;
}
.isq-nav__star { display: inline-flex; }
.isq-nav__wordmark {
  font-family: var(--font-body);
  font-weight: 600;
  letter-spacing: var(--ls-wordmark);
  font-size: 17px;
  color: var(--cream);
}
.isq-nav__wordmark-ar {
  font-size: 18px;
  color: var(--gold-accent);
  opacity: 0.85;
  transform: translateY(-1px);
}
.isq-nav__spacer { flex: 1; }

.isq-nav__lang {
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  border-radius: var(--r-pill);
  background: var(--surface-0);
}
.isq-nav__lang-btn {
  min-width: 36px;
  min-height: 32px;
  padding: 0 var(--space-3);
  border: 0;
  background: transparent;
  color: var(--muted-2);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  border-radius: var(--r-pill);
  transition: color var(--dur-fast) var(--ease-out),
              background-color var(--dur-fast) var(--ease-out);
}
.isq-nav__lang-btn:hover { color: var(--cream); }
.isq-nav__lang-btn--active {
  color: var(--cream);
  background: var(--surface);
}

.isq-nav__cta {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  padding: 0 var(--space-5);
  background: var(--emerald);
  color: var(--cream);
  font-size: var(--text-sm);
  font-weight: 600;
  border-radius: var(--r-pill);
  white-space: nowrap;
  transition: background-color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.isq-nav__cta:hover { background: var(--emerald-soft); box-shadow: var(--glow-subtle); }
.isq-nav__cta:active { transform: scale(var(--press-scale)); }

/* ============================================================
   2. HERO
   ============================================================ */
.isq-hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--nav-h) + var(--space-8)) var(--gutter) var(--space-8);
  background: linear-gradient(180deg, var(--ink-3) 0%, var(--ink-2) 100%);
  overflow: hidden;
  text-align: center;
}
.isq-hero__glow {
  position: absolute;
  top: 38%;
  left: 50%;
  width: min(720px, 120vw);
  height: min(720px, 120vw);
  transform: translate(-50%, -50%);
  pointer-events: none;
  background:
    radial-gradient(circle at 50% 45%, rgba(14, 107, 82, 0.34) 0%, transparent 58%),
    radial-gradient(circle at 50% 50%, rgba(201, 162, 75, 0.14) 0%, transparent 50%);
  opacity: 0.3;
  filter: blur(8px);
}
.isq-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 620px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
}
.isq-hero__ar-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.isq-hero__pattern {
  position: absolute;
  top: 50%;
  left: 50%;
  width: clamp(220px, 60vw, 340px);
  height: clamp(220px, 60vw, 340px);
  transform: translate(-50%, -50%);
  color: var(--gold-accent);
  opacity: var(--opacity-pattern);
  pointer-events: none;
}
.isq-hero__ar {
  position: relative;
  font-family: var(--font-ar);
  font-size: clamp(72px, 22vw, 140px);
  font-weight: 600;
  line-height: 1;
  color: var(--cream);
  text-shadow: 0 0 28px rgba(201, 162, 75, 0.30),
               0 0 64px rgba(201, 162, 75, 0.14),
               0 2px 18px rgba(14, 107, 82, 0.40);
  animation: isq-breathe 6s var(--ease-out) infinite;
}
@keyframes isq-breathe {
  0%, 100% { opacity: 0.92; }
  50%      { opacity: 1; }
}

.isq-hero__slogan {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}
.isq-hero__slogan-ru {
  font-family: var(--font-head);
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--cream);
  line-height: 1.1;
  letter-spacing: var(--ls-display);
}
.isq-hero__breath-rule {
  display: block;
  width: 40px;
  height: 1px;
  background: var(--accent);
  opacity: 0.7;
}
.isq-hero__slogan-en {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  color: var(--muted-2);
}

.isq-hero__breath {
  font-family: var(--font-body);
  font-size: var(--text-md);
  color: var(--muted);
  max-width: 30ch;
  line-height: 1.85;
}

.isq-hero__cta-btn {
  display: inline-flex;
  align-items: center;
  min-height: 50px;
  padding: 0 var(--space-7);
  background: var(--emerald);
  color: var(--cream);
  font-size: var(--text-md);
  font-weight: 600;
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-2);
  transition: background-color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.isq-hero__cta-btn:hover { background: var(--emerald-soft); box-shadow: var(--shadow-2), var(--glow-subtle); }
.isq-hero__cta-btn:active { transform: scale(var(--press-scale)); }

.isq-hero__ayah {
  margin: var(--space-5) 0 0;
  max-width: 36ch;
}
.isq-hero__ayah-text {
  margin: 0;
  font-family: var(--font-head);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--muted-2);
  line-height: 1.7;
}
.isq-hero__ayah-ref {
  margin-top: var(--space-2);
  font-size: var(--text-xs);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--gold-muted);
}

.isq-hero__scroll-hint {
  position: absolute;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--muted-3);
  font-size: var(--text-xs);
  letter-spacing: 0.04em;
}
.isq-hero__scroll-hint svg { animation: isq-bob 2.6s var(--ease-out) infinite; }
@keyframes isq-bob {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(5px); }
}

/* ============================================================
   3. MISSION
   ============================================================ */
.isq-mission { background: var(--ink); padding: var(--space-8) var(--gutter); }
.isq-mission__inner { max-width: 56ch; margin: 0 auto; text-align: center; }
.isq-mission__body { display: flex; flex-direction: column; align-items: center; }
.isq-mission__p {
  font-family: var(--font-body);
  font-size: var(--text-md);
  color: var(--muted);
  line-height: 1.85;
  margin-bottom: var(--space-5);
  max-width: 54ch;
}
.isq-mission__p--lead {
  font-family: var(--font-head);
  font-size: var(--text-xl);
  color: var(--cream);
  line-height: 1.3;
  margin-bottom: var(--space-6);
}
.isq-mission__rule {
  width: 56px;
  height: 1px;
  background: var(--line-gold);
  margin: var(--space-4) 0 var(--space-6);
}
.isq-mission__p--ar {
  color: var(--muted);
  margin-bottom: 0;
}
.isq-mission__p--ar [lang="ar"] {
  display: inline-block;
  margin-top: var(--space-3);
  font-size: var(--text-ar-body);
  color: var(--gold-accent);
}

/* ============================================================
   4. DOCTRINE
   ============================================================ */
.isq-doctrine { background: var(--ink-2); padding: var(--space-8) var(--gutter); }
.isq-doctrine__inner { max-width: var(--maxw); margin: 0 auto; text-align: center; }
.isq-doctrine__row {
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: var(--space-5);
  margin: var(--space-6) 0;
}
.isq-doctrine__node {
  flex: 1;
  max-width: 320px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-5);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--surface-0);
}
.isq-doctrine__node-ar {
  font-family: var(--font-ar);
  font-size: var(--text-ar-hero);
  font-weight: 600;
  line-height: 1.1;
  color: var(--cream);
}
.isq-doctrine__node--dest {
  border-color: var(--gold-rim-subtle);
  background: var(--surface-gold);
}
.isq-doctrine__node--dest .isq-doctrine__node-ar {
  color: var(--gold-accent);
  text-shadow: 0 0 20px rgba(201, 162, 75, 0.22);
}
.isq-doctrine__node-label {
  font-family: var(--font-head);
  font-size: var(--text-lg);
  color: var(--cream);
}
.isq-doctrine__node-sub {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--muted-2);
  max-width: 22ch;
  line-height: 1.6;
}

.isq-doctrine__arrow {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-width: 130px;
}
.isq-doctrine__arrow-label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  color: var(--gold-muted);
  white-space: nowrap;
}
.isq-doctrine__arrow-line {
  position: relative;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent) 50%, transparent);
  opacity: 0.7;
}
.isq-doctrine__arrow-diamond {
  position: absolute;
  bottom: calc(50% - 4px);
  left: 50%;
  width: 8px;
  height: 8px;
  transform: translateX(-50%) rotate(45deg);
  background: var(--accent);
  box-shadow: 0 0 10px rgba(201, 162, 75, 0.4);
}
.isq-doctrine__note {
  font-family: var(--font-head);
  font-style: italic;
  font-size: var(--text-md);
  color: var(--muted);
  max-width: 44ch;
  margin: var(--space-4) auto 0;
}

/* ============================================================
   5. ECOSYSTEM
   ============================================================ */
.isq-eco { background: var(--ink); padding: var(--space-8) var(--gutter); }
.isq-eco__inner { max-width: var(--maxw); margin: 0 auto; text-align: center; }
.isq-eco__title { font-size: var(--text-2xl); margin-bottom: var(--space-7); }
.isq-eco__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  text-align: left;
}
.isq-eco__card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
  transition: transform var(--dur) var(--ease-out),
              border-color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
.isq-eco__card:hover {
  transform: translateY(-4px);
  border-color: var(--gold-rim-subtle);
  box-shadow: var(--shadow-2);
}
.isq-eco__card-ring { color: var(--emerald); margin-bottom: var(--space-2); }
.isq-eco__card-dot { fill: var(--accent); }
.isq-eco__card-title { font-family: var(--font-head); font-size: var(--text-lg); color: var(--cream); }
.isq-eco__card-desc { font-family: var(--font-body); font-size: var(--text-sm); color: var(--muted); line-height: 1.7; }

/* Companion = the live ring: subtle teal tint + emerald/gold ring */
.isq-eco__card--companion {
  background: linear-gradient(180deg, var(--teal-surface), var(--surface));
  border-color: rgba(14, 107, 82, 0.3);
}
.isq-eco__card--companion .isq-eco__card-ring { color: var(--emerald-soft); }

.isq-eco__card-phase {
  align-self: flex-start;
  margin-top: var(--space-2);
  padding: 3px var(--space-3);
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  color: var(--gold-muted);
  background: var(--surface-gold);
  border-radius: var(--r-pill);
}

/* ============================================================
   5b. VISION — куда мы идём (50-летнее видение)
   ============================================================ */
.isq-vision { background: var(--ink-2); padding: var(--space-8) var(--gutter); }
.isq-vision__inner { max-width: var(--maxw); margin: 0 auto; text-align: center; }
.isq-vision__eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  color: var(--gold-muted);
  margin: 0 0 var(--space-4);
}
.isq-vision__title {
  font-family: var(--font-head);
  color: var(--cream);
  letter-spacing: var(--ls-display);
  line-height: 1.15;
  font-size: var(--text-2xl);
  margin-bottom: var(--space-4);
}
.isq-vision__lead {
  font-family: var(--font-head);
  font-size: var(--text-lg);
  color: var(--muted);
  max-width: 52ch;
  margin: 0 auto var(--space-7);
  line-height: 1.5;
}
.isq-vision__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  text-align: left;
}
.isq-vision__card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
  transition: transform var(--dur) var(--ease-out),
              border-color var(--dur) var(--ease-out);
}
.isq-vision__card:hover { transform: translateY(-2px); border-color: rgba(14, 107, 82, 0.3); }
.isq-vision__card-icon { color: var(--emerald-soft); }
.isq-vision__card-title { font-family: var(--font-head); font-size: var(--text-lg); color: var(--cream); }
.isq-vision__card-desc { font-family: var(--font-body); font-size: var(--text-sm); color: var(--muted); line-height: 1.7; }
.isq-vision__note {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--gold-muted);
  margin-top: var(--space-7);
  font-style: italic;
}

/* ============================================================
   6. COMPANION
   ============================================================ */
.isq-companion { background: var(--ink-2); padding: var(--space-8) var(--gutter); }
.isq-companion__inner { max-width: var(--maxw); margin: 0 auto; text-align: center; }
.isq-companion__title { font-size: var(--text-2xl); margin-bottom: var(--space-4); }
.isq-companion__lead {
  font-family: var(--font-head);
  font-size: var(--text-lg);
  color: var(--muted);
  max-width: 44ch;
  margin: 0 auto var(--space-7);
  line-height: 1.5;
}
.isq-companion__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  text-align: left;
}
.isq-companion__tile {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5);
  background: var(--surface-0);
  border: 1px solid var(--line);
  border-radius: var(--r);
  transition: border-color var(--dur) var(--ease-out),
              transform var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out);
}
.isq-companion__tile:hover {
  border-color: var(--gold-rim-subtle);
  transform: translateY(-3px);
  box-shadow: var(--shadow-1);
}
.isq-companion__tile-icon {
  color: var(--emerald);
  margin-bottom: var(--space-1);
}
.isq-companion__tile-icon--heart { filter: drop-shadow(0 0 8px rgba(201, 162, 75, 0.18)); }
.isq-companion__dot { fill: var(--accent); }
.isq-companion__tile-title { font-family: var(--font-head); font-size: var(--text-md); color: var(--cream); }
.isq-companion__tile-desc { font-family: var(--font-body); font-size: var(--text-sm); color: var(--muted-2); line-height: 1.7; }

.isq-companion__cta { margin-top: var(--space-7); }
.isq-companion__cta-btn {
  display: inline-flex;
  align-items: center;
  min-height: 48px;
  padding: 0 var(--space-6);
  background: transparent;
  color: var(--cream);
  font-size: var(--text-md);
  font-weight: 600;
  border: 1px solid var(--emerald);
  border-radius: var(--r-pill);
  transition: border-color var(--dur) var(--ease-out),
              background-color var(--dur) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.isq-companion__cta-btn:hover { background: rgba(14, 107, 82, 0.16); border-color: var(--emerald-soft); }
.isq-companion__cta-btn:active { transform: scale(var(--press-scale)); }

/* ============================================================
   7. SADAQAH
   ============================================================ */
.isq-sadaqah {
  background: var(--ink-3);
  padding: var(--space-8) var(--gutter);
  display: flex;
  justify-content: center;
}
.isq-sadaqah__inner {
  position: relative;
  max-width: 60ch;
  width: 100%;
  padding: var(--space-7);
  background: var(--surface-0);
  border: 1px solid var(--line-gold);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-2);
  text-align: center;
  overflow: hidden;
}
.isq-sadaqah__watermark {
  position: absolute;
  top: -40px;
  left: 50%;
  width: 260px;
  height: 260px;
  transform: translateX(-50%);
  color: var(--accent);
  opacity: var(--opacity-watermark);
  pointer-events: none;
}
.isq-sadaqah__eyebrow,
.isq-sadaqah__title,
.isq-sadaqah__lead,
.isq-sadaqah__ayah,
.isq-sadaqah__grid,
.isq-sadaqah__note,
.isq-sadaqah__basmala { position: relative; z-index: 1; }
.isq-sadaqah__title { font-size: var(--text-xl); margin-bottom: var(--space-4); }
.isq-sadaqah__lead {
  font-family: var(--font-body);
  font-size: var(--text-md);
  color: var(--muted);
  line-height: 1.75;
  max-width: 50ch;
  margin: 0 auto var(--space-5);
}
.isq-sadaqah__ayah { margin: 0 0 var(--space-6); }
.isq-sadaqah__ayah blockquote {
  margin: 0;
  font-family: var(--font-head);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--muted-2);
  line-height: 1.7;
}
.isq-sadaqah__ayah figcaption {
  margin-top: var(--space-2);
  font-size: var(--text-xs);
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--gold-muted);
}

.isq-sadaqah__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  text-align: left;
}
.isq-sadaqah__btn {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-height: 56px;
  padding: var(--space-3) var(--space-4);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  color: var(--cream);
  text-align: left;
  transition: border-color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.isq-sadaqah__btn:hover { border-color: var(--gold-rim); box-shadow: var(--shadow-1); }
.isq-sadaqah__btn:active { transform: scale(var(--press-scale)); }
.isq-sadaqah__btn-icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--r-pill);
  background: rgba(14, 107, 82, 0.18);
  color: var(--gold-soft);
  font-size: 17px;
  line-height: 1;
}
.isq-sadaqah__btn-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.isq-sadaqah__btn-label { font-size: var(--text-md); font-weight: 600; color: var(--cream); }
.isq-sadaqah__btn-hint  { font-size: var(--text-xs); color: var(--muted-2); }

.isq-sadaqah__note {
  font-size: var(--text-xs);
  color: var(--muted-3);
  line-height: 1.7;
  max-width: 46ch;
  margin: 0 auto var(--space-4);
}
.isq-sadaqah__basmala {
  font-family: var(--font-ar);
  font-size: var(--text-ar-body);
  color: var(--gold-accent);
}

/* ============================================================
   8. FINAL CTA
   ============================================================ */
.isq-final {
  position: relative;
  padding: var(--space-8) var(--gutter);
  background: linear-gradient(180deg, var(--ink-3) 0%, #050b08 100%);
  text-align: center;
  overflow: hidden;
}
.isq-final__glow {
  position: absolute;
  top: 40%;
  left: 50%;
  width: min(560px, 110vw);
  height: min(560px, 110vw);
  transform: translate(-50%, -50%);
  pointer-events: none;
  background: radial-gradient(circle, rgba(14, 107, 82, 0.30) 0%, transparent 60%);
  opacity: 0.25;
  filter: blur(6px);
}
.isq-final__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}
.isq-final__ar {
  font-family: var(--font-ar);
  font-size: clamp(48px, 12vw, 80px);
  font-weight: 600;
  line-height: 1;
  color: var(--cream);
  text-shadow: 0 0 24px rgba(201, 162, 75, 0.26), 0 0 56px rgba(201, 162, 75, 0.12);
  animation: isq-breathe 6s var(--ease-out) infinite;
}
.isq-final__tagline {
  font-family: var(--font-head);
  font-size: var(--text-xl);
  color: var(--cream);
  letter-spacing: var(--ls-display);
}
.isq-final__cta-btn {
  display: inline-flex;
  align-items: center;
  min-height: 50px;
  padding: 0 var(--space-7);
  background: var(--emerald);
  color: var(--cream);
  font-size: var(--text-md);
  font-weight: 600;
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-2);
  transition: background-color var(--dur) var(--ease-out),
              box-shadow var(--dur) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
}
.isq-final__cta-btn:hover { background: var(--emerald-soft); box-shadow: var(--shadow-2), var(--glow-subtle); }
.isq-final__cta-btn:active { transform: scale(var(--press-scale)); }
.isq-final__mantra {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ls-eyebrow);
  color: var(--muted-2);
}

/* ============================================================
   9. FOOTER
   ============================================================ */
.isq-footer {
  position: relative;
  background: var(--footer-ink);
  padding: var(--space-7) var(--gutter)
           calc(var(--space-7) + env(safe-area-inset-bottom, 0px));
}
.isq-footer__rule {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: var(--line-gold);
}
.isq-footer__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  text-align: center;
}
.isq-footer__brand { display: inline-flex; align-items: center; gap: var(--space-3); min-height: 44px; }
.isq-footer__wordmark {
  font-family: var(--font-body);
  font-weight: 600;
  letter-spacing: var(--ls-wordmark);
  font-size: 16px;
  color: var(--cream);
}
.isq-footer__praise {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-family: var(--font-head);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--muted);
}
.isq-footer__praise-ar {
  font-family: var(--font-ar);
  font-style: normal;
  font-size: var(--text-sm);
  color: var(--gold-muted);
}
.isq-footer__tm { font-size: var(--text-xs); color: var(--muted-3); max-width: 44ch; line-height: 1.6; }

.isq-footer__links { display: inline-flex; gap: var(--space-5); }
.isq-footer__link {
  font-size: var(--text-sm);
  color: var(--muted);
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  transition: color var(--dur-fast) var(--ease-out);
}
.isq-footer__link:hover { color: var(--cream); }

.isq-footer__lang {
  display: inline-flex;
  gap: 2px;
  padding: 3px;
  border-radius: var(--r-pill);
  background: var(--surface-0);
}
.isq-footer__lang-btn {
  min-width: 36px;
  min-height: 32px;
  padding: 0 var(--space-3);
  border: 0;
  background: transparent;
  color: var(--muted-2);
  font-size: var(--text-xs);
  font-weight: 600;
  border-radius: var(--r-pill);
  transition: color var(--dur-fast) var(--ease-out),
              background-color var(--dur-fast) var(--ease-out);
}
.isq-footer__lang-btn:hover { color: var(--cream); }
.isq-footer__lang-btn--active { color: var(--cream); background: var(--surface); }

.isq-footer__year {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--muted-3);
}

/* ============================================================
   SECTION ORDER — Спутник вынесен на 2-й экран (магнит + помощник первых шагов)
   ============================================================ */
main { display: flex; flex-direction: column; }
.isq-hero      { order: 1; }
.isq-companion { order: 2; }
.isq-mission   { order: 3; }
.isq-vision    { order: 4; }
.isq-doctrine  { order: 5; }
.isq-eco       { order: 6; }
.isq-sadaqah   { order: 7; }
.isq-final     { order: 8; }

/* ============================================================
   PAYMENT MODAL — реквизиты садаки (номер + получатель + копирование)
   ============================================================ */
.isq-pay-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(0, 0, 0, 0.62);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  animation: isq-pay-fade 200ms ease;
}
@keyframes isq-pay-fade { from { opacity: 0; } to { opacity: 1; } }
.isq-pay-modal {
  width: 100%;
  max-width: 520px;
  max-height: 86vh;
  overflow-y: auto;
  background: var(--ink-2);
  color: var(--cream);
  border-top: 1px solid var(--gold-muted, rgba(201, 162, 75, 0.4));
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  padding: 18px 16px calc(24px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.45);
}
.isq-pay-head { display: flex; align-items: center; justify-content: space-between; }
.isq-pay-title { font-family: var(--font-head); font-size: var(--text-lg); color: var(--accent); }
.isq-pay-x { background: none; border: none; color: var(--muted, rgba(250,247,240,0.7)); font-size: 20px; cursor: pointer; padding: 4px 8px; line-height: 1; }
.isq-pay-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  text-align: left;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 12px 14px;
  cursor: pointer;
  color: var(--cream);
  font-family: inherit;
  transition: border-color 140ms ease;
}
.isq-pay-row:hover { border-color: var(--gold-muted, rgba(201, 162, 75, 0.4)); }
.isq-pay-info { display: flex; flex-direction: column; gap: 3px; min-width: 0; flex: 1; }
.isq-pay-label { font-size: var(--text-xs); color: var(--muted, rgba(250,247,240,0.7)); }
.isq-pay-value { font-size: var(--text-md); color: var(--cream); word-break: break-all; }
.isq-pay-copy { flex-shrink: 0; font-size: var(--text-xs); color: var(--accent); white-space: nowrap; }
.isq-pay-recipient { font-size: var(--text-sm); color: var(--muted, rgba(250,247,240,0.7)); padding: 8px 4px 0; line-height: 1.5; }
.isq-pay-recipient b { color: var(--cream); }
.isq-pay-basmala { text-align: center; font-family: var(--font-ar, 'Reem Kufi', serif); color: var(--accent); font-size: 18px; margin-top: 6px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 860px) {
  .isq-eco__grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
  .isq-vision__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 680px) {
  /* Nav on mobile: keep compact lang pills visible; hide the nav CTA so the
     bar fits 360px (hero/companion/final CTAs remain on the page). */
  .isq-nav__lang { display: flex; gap: 2px; }
  .isq-nav__lang-btn { min-width: 38px; padding: 6px 6px; }
  .isq-nav__cta { display: none; }

  .isq-companion__grid { grid-template-columns: 1fr; }
  .isq-sadaqah__grid { grid-template-columns: 1fr; }
  .isq-vision__grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
  .isq-sadaqah__inner { padding: var(--space-6) var(--space-5); }

  /* Doctrine stacks; arrow rotates to point downward */
  .isq-doctrine__row { flex-direction: column; align-items: center; }
  .isq-doctrine__node { width: 100%; max-width: 380px; }
  .isq-doctrine__arrow { min-width: 0; width: 100%; height: 64px; }
  .isq-doctrine__arrow-line {
    width: 1px;
    height: 100%;
    background: linear-gradient(180deg, transparent, var(--accent) 50%, transparent);
  }
  .isq-doctrine__arrow-label {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    background: var(--ink-2);
    padding: 0 var(--space-2);
  }
  .isq-doctrine__arrow-diamond { bottom: auto; top: calc(50% - 4px); }

  .isq-footer__inner { gap: var(--space-5); }
}

/* Mobile lang sheet (built by app.js) */
.isq-lang-sheet {
  position: fixed;
  inset: auto 0 0 0;
  z-index: 200;
  padding: var(--space-5) var(--gutter)
           calc(var(--space-6) + env(safe-area-inset-bottom, 0px));
  background: rgba(19, 36, 30, 0.94);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  border-top: 1px solid var(--line-gold);
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  transform: translateY(100%);
  transition: transform var(--dur) var(--ease-out);
}
.isq-lang-sheet.is-open { transform: translateY(0); }
.isq-lang-sheet__btn {
  min-height: 48px;
  border: 1px solid var(--line);
  background: var(--surface-0);
  color: var(--cream);
  border-radius: var(--r);
  font-size: var(--text-md);
}
.isq-lang-sheet__btn--active { border-color: var(--gold-rim); background: var(--surface); }

@media (min-width: 681px) {
  .isq-lang-sheet { display: none; }
}

/* Mobile-only current-lang trigger inserted by app.js */
.isq-nav__lang-mobile {
  display: none;
  min-width: 44px;
  min-height: 36px;
  padding: 0 var(--space-3);
  border: 1px solid var(--line);
  background: var(--surface-0);
  color: var(--cream);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  border-radius: var(--r-pill);
}
@media (max-width: 680px) {
  .isq-nav__lang-mobile { display: inline-flex; align-items: center; justify-content: center; }
}

/* ============================================================
   TOAST (clipboard / status — created by app.js)
   ============================================================ */
.isq-toast {
  position: fixed;
  left: 50%;
  bottom: calc(24px + env(safe-area-inset-bottom, 0px));
  transform: translate(-50%, 12px);
  z-index: 300;
  max-width: min(90vw, 360px);
  padding: 12px 18px;
  background: rgba(19, 36, 30, 0.96);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  border: 1px solid var(--gold-rim);
  border-radius: var(--r-pill);
  color: var(--cream);
  font-size: var(--text-sm);
  letter-spacing: 0.01em;
  text-align: center;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur) var(--ease-out),
              transform var(--dur) var(--ease-out);
}
.isq-toast--show { opacity: 1; transform: translate(-50%, 0); }

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .isq-hero__ar,
  .isq-final__ar { animation: none; opacity: 1; }
  .isq-hero__scroll-hint svg { animation: none; }
  .reveal { opacity: 1; transform: none; }
}
