/* ════════════════════════════════════════════════════════
   MODERN YOGI · ॐ SACRED SUPPLY · CSS v5
   Sacred-Futuristic · Dark · Gold · Sanskrit
════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Noto+Serif+Devanagari:wght@300;400;500&display=swap');

/* ── TOKENS ── */
:root {
  --void:    #07080A;
  --deep:    #0D0F12;
  --surface: #131519;
  --raised:  #1A1D23;
  --rim:     #22262E;

  --gold:    #C8960A;
  --gold-lt: #E8B420;
  --gold-dim:#7A5C06;
  --gold-glow: rgba(200,150,10,0.18);
  --gold-glow-strong: rgba(200,150,10,0.45);

  --saffron: #D4620A;
  --lotus:   #A03070;
  --teal:    #1A8A7A;
  --teal-lt: #22B89E;
  --sage:    #5A8A3A;

  --text:    #E8E2D8;
  --text-mid:#A89E8E;
  --text-dim:#5A5248;

  --border:       rgba(200,150,10,0.12);
  --border-gold:  rgba(200,150,10,0.35);
  --border-bright:rgba(200,150,10,0.6);

  --fd: 'Cinzel', serif;
  --fb: 'Cormorant Garamond', serif;
  --fh: 'Noto Serif Devanagari', serif;

  --radius: 2px;
  --radius-l: 4px;
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; font-size:16px; }
body {
  background: var(--void);
  color: var(--text);
  font-family: var(--fb);
  font-size: 1rem;
  line-height: 1.75;
  overflow-x: hidden;
  cursor: none;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ── CUSTOM CURSOR ── */
#cur-dot {
  width: 6px; height: 6px;
  background: var(--gold);
  border-radius: 50%;
  position: fixed; pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  box-shadow: 0 0 12px var(--gold-glow-strong);
  transition: transform 0.05s;
}
#cur-ring {
  width: 32px; height: 32px;
  border: 1px solid rgba(200,150,10,0.4);
  border-radius: 50%;
  position: fixed; pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: width 0.35s, height 0.35s, border-color 0.35s;
}
body.hov #cur-ring { width: 52px; height: 52px; border-color: var(--gold); }

/* ── LOADER ── */
#loader {
  position: fixed; inset: 0; z-index: 8000;
  background: var(--void);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 20px;
  transition: opacity 0.9s, visibility 0.9s;
}
#loader.gone { opacity:0; visibility:hidden; pointer-events:none; }
.l-om {
  font-family: var(--fh); font-size: 72px; color: var(--gold); line-height:1;
  animation: omPulse 2s ease-in-out infinite alternate;
}
@keyframes omPulse {
  from { text-shadow: 0 0 20px rgba(200,150,10,0.3); }
  to   { text-shadow: 0 0 60px rgba(200,150,10,0.9), 0 0 120px rgba(200,150,10,0.3); }
}
.l-sub { font-family:var(--fd); font-size:.55rem; letter-spacing:.28em; text-transform:uppercase; color:var(--text-dim); }
.l-bar { width:160px; height:1px; background:var(--rim); overflow:hidden; }
.l-fill { height:100%; background: linear-gradient(to right, var(--gold-dim), var(--gold)); animation: lFill 2.2s ease-out forwards; width:0; }
@keyframes lFill { to { width:100%; } }

/* ── SACRED PARTICLE CANVAS ── */
#sacredCanvas { position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.6; }

/* ── NAV ── */
.site-nav {
  position: fixed; top:0; left:0; right:0; z-index:500;
  display: flex; align-items:center; justify-content:space-between;
  padding: 24px 60px;
  transition: all 0.4s;
}
.site-nav.scrolled {
  background: rgba(7,8,10,0.92);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  padding: 16px 60px;
}
.nav-logo { display:flex; align-items:center; gap:14px; }
.nav-om { font-family:var(--fh); font-size:26px; color:var(--gold); line-height:1; }
.nav-wordmark { display:flex; flex-direction:column; }
.nav-name { font-family:var(--fd); font-size:.65rem; letter-spacing:.2em; color:var(--text); }
.nav-tagline { font-family:var(--fh); font-size:.5rem; color:var(--gold-dim); letter-spacing:.12em; }

.nav-links { display:flex; gap:32px; list-style:none; }
.nav-links a {
  font-family:var(--fd); font-size:.55rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--text-mid); transition:color 0.25s; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0; height:1px;
  background:var(--gold); transform:scaleX(0); transition:transform 0.25s;
}
.nav-links a:hover { color:var(--gold); }
.nav-links a:hover::after { transform:scaleX(1); }
.nav-links a.active { color:var(--gold); }
.nav-links a.active::after { transform:scaleX(1); }

.nav-end { display:flex; align-items:center; gap:16px; }
.nav-wa {
  font-family:var(--fd); font-size:.52rem; letter-spacing:.15em; text-transform:uppercase;
  color:var(--text-mid); padding:8px 14px; border:1px solid var(--rim);
  display:flex; align-items:center; gap:6px; transition:all 0.25s;
}
.nav-wa:hover { color:var(--gold); border-color:var(--border-gold); }
.btn-sacred {
  font-family:var(--fd); font-size:.52rem; letter-spacing:.18em; text-transform:uppercase;
  background:var(--gold); color:var(--void); padding:11px 26px;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  transition:all 0.3s; cursor:pointer; border:none;
}
.btn-sacred:hover { background:var(--gold-lt); box-shadow:0 0 40px var(--gold-glow-strong); }

/* Mobile hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.hamburger span { width:22px; height:1px; background:var(--text-mid); transition:all 0.3s; display:block; }

.mobile-nav {
  display:none; position:fixed; inset:0; z-index:490;
  background:rgba(7,8,10,0.97); backdrop-filter:blur(20px);
  flex-direction:column; align-items:center; justify-content:center; gap:32px;
}
.mobile-nav.open { display:flex; }
.mobile-nav a { font-family:var(--fd); font-size:1.2rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-mid); transition:color 0.25s; }
.mobile-nav a:hover { color:var(--gold); }

/* ── MODAL ── */
.modal-overlay {
  display:none; position:fixed; inset:0; z-index:600;
  background:rgba(0,0,0,0.85); backdrop-filter:blur(8px);
  align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal-box {
  background:var(--surface); border:1px solid var(--border-gold);
  max-width:540px; width:90%; padding:48px; position:relative;
  clip-path: polygon(0 0, calc(100% - 20px) 0, 100% 20px, 100% 100%, 20px 100%, 0 calc(100% - 20px));
}
.modal-close {
  position:absolute; top:20px; right:20px; background:none; border:none;
  color:var(--text-dim); font-size:1.2rem; cursor:pointer; transition:color 0.2s;
}
.modal-close:hover { color:var(--gold); }
.modal-box h3 { font-family:var(--fd); font-size:1rem; letter-spacing:.15em; text-transform:uppercase; color:var(--gold); margin-bottom:6px; }
.modal-deva { font-family:var(--fh); font-size:.8rem; color:var(--text-dim); margin-bottom:28px; }
.modal-box label { display:block; font-family:var(--fd); font-size:.52rem; letter-spacing:.15em; text-transform:uppercase; color:var(--text-dim); margin-bottom:6px; margin-top:16px; }
.modal-box input, .modal-box textarea, .modal-box select {
  width:100%; background:var(--raised); border:1px solid var(--border);
  color:var(--text); padding:11px 14px; font-family:var(--fb); font-size:.95rem;
  transition:border-color 0.25s; outline:none;
}
.modal-box input:focus, .modal-box textarea:focus, .modal-box select:focus { border-color:var(--border-gold); }
.modal-box textarea { resize:vertical; min-height:90px; }
.modal-box select { cursor:pointer; }
.modal-box select option { background:var(--surface); }
.modal-submit {
  width:100%; margin-top:24px; padding:14px;
  background:var(--gold); color:var(--void); border:none; cursor:pointer;
  font-family:var(--fd); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  transition:all 0.3s;
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.modal-submit:hover { background:var(--gold-lt); box-shadow:0 0 30px var(--gold-glow-strong); }
.modal-alt { margin-top:16px; text-align:center; font-size:.78rem; color:var(--text-dim); }
.modal-alt a { color:var(--gold); }

/* ── SECTION PRIMITIVES ── */
.section { padding:100px 0; position:relative; z-index:1; }
.section-dark { background:var(--deep); }
.section-surface { background:var(--surface); }
.section-raised { background:var(--raised); }
.container { max-width:1260px; margin:0 auto; padding:0 40px; }
.text-center { text-align:center; }
.mb-16 { margin-bottom:16px; }
.mb-32 { margin-bottom:32px; }
.mb-48 { margin-bottom:48px; }
.mb-64 { margin-bottom:64px; }

/* ── SACRED DIVIDER ── */
.sacred-divider {
  display:flex; align-items:center; gap:16px; margin:0 auto;
  max-width:300px; justify-content:center;
}
.sacred-divider .line { flex:1; height:1px; background:linear-gradient(to right, transparent, var(--border-gold)); }
.sacred-divider .line.r { background:linear-gradient(to left, transparent, var(--border-gold)); }
.sacred-divider .om { font-family:var(--fh); color:var(--gold); font-size:1.1rem; }

/* ── EYEBROW / LABELS ── */
.eyebrow-sacred {
  font-family:var(--fh); font-size:.75rem; color:var(--gold); letter-spacing:.1em;
  display:block; margin-bottom:8px;
}
.eyebrow {
  font-family:var(--fd); font-size:.52rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--text-dim); display:block; margin-bottom:10px;
}
h1, h2 { font-family:var(--fd); line-height:1.1; }
h1 { font-size:clamp(2.5rem, 5vw, 4.5rem); font-weight:400; color:var(--text); }
h2 { font-size:clamp(1.8rem, 3vw, 2.8rem); font-weight:400; color:var(--text); }
h3 { font-family:var(--fd); font-size:1.1rem; font-weight:600; color:var(--text); }
h1 em, h2 em { color:var(--gold); font-style:italic; font-family:'Cormorant Garamond', serif; }
.section-subtitle { font-size:1rem; color:var(--text-mid); max-width:580px; margin:12px auto 0; line-height:1.85; }

/* ── PAGE HERO ── */
.page-hero {
  padding: 160px 0 80px;
  background: var(--deep);
  position: relative; overflow:hidden; z-index:1;
}
.page-hero::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at 30% 50%, rgba(200,150,10,0.06) 0%, transparent 60%);
}
.page-hero .container { position:relative; z-index:2; }
.page-hero h1 { margin-bottom:16px; }
.page-hero p { max-width:580px; color:var(--text-mid); font-size:1rem; line-height:1.85; }
.hero-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:28px; }

/* ── BUTTONS ── */
.btn {
  font-family:var(--fd); font-size:.52rem; letter-spacing:.18em; text-transform:uppercase;
  padding:12px 28px; display:inline-block; transition:all 0.3s; cursor:pointer;
  border:none; text-align:center;
}
.btn-gold {
  background:var(--gold); color:var(--void);
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.btn-gold:hover { background:var(--gold-lt); box-shadow:0 0 40px var(--gold-glow-strong); }
.btn-outline {
  background:transparent; color:var(--text-mid);
  border:1px solid var(--border-gold);
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.btn-outline:hover { color:var(--gold); border-color:var(--border-bright); }
.btn-ghost { background:transparent; color:var(--gold); border:1px solid rgba(200,150,10,0.3); }
.btn-ghost:hover { border-color:var(--gold); background:var(--gold-glow); }
.btn-sm { padding:8px 18px; font-size:.48rem; }
.btn-lg { padding:15px 36px; font-size:.58rem; }
.btn-full { width:100%; }

/* ── TRUST STRIP ── */
.trust-strip {
  background:var(--raised); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:14px 0; overflow:hidden;
}
.trust-ticker {
  display:flex; gap:0; width:max-content;
  animation: trustScroll 30s linear infinite;
}
@keyframes trustScroll { to { transform:translateX(-50%); } }
.trust-item {
  display:inline-flex; align-items:center; gap:12px; padding:0 32px;
  font-family:var(--fd); font-size:.52rem; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim);
  white-space:nowrap;
}
.trust-item .t-deva { font-family:var(--fh); font-size:.75rem; color:var(--gold); }
.trust-sep { color:var(--gold-dim); }

/* ── TICKER ── */
.ticker-wrap { overflow:hidden; padding:16px 0; }
.ticker-track {
  display:flex; white-space:nowrap;
  animation: tickerMove 40s linear infinite;
}
@keyframes tickerMove { to { transform:translateX(-50%); } }
.ticker-item {
  font-family:var(--fd); font-size:.55rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--text-dim); padding:0 36px; display:inline-flex; align-items:center; gap:16px;
}
.ticker-item .t-sep { color:var(--gold); font-family:var(--fh); font-size:.9rem; }

/* ── PRODUCT CARDS ── */
.product-card {
  background:var(--surface); border:1px solid var(--border);
  transition:all 0.35s; position:relative; overflow:hidden;
}
.product-card::before {
  content:''; position:absolute; inset:0; opacity:0;
  background:radial-gradient(ellipse at top left, var(--gold-glow), transparent 60%);
  transition:opacity 0.4s;
}
.product-card:hover { border-color:var(--border-gold); transform:translateY(-4px); }
.product-card:hover::before { opacity:1; }
.product-card-img {
  aspect-ratio:4/3; background:var(--raised); position:relative; overflow:hidden;
}
.product-card-img img { width:100%; height:100%; object-fit:cover; }
.card-badge {
  position:absolute; top:14px; left:14px;
  font-family:var(--fd); font-size:.45rem; letter-spacing:.18em; text-transform:uppercase;
  background:var(--gold); color:var(--void); padding:4px 12px;
}
.card-badge-saffron { background:var(--saffron); color:#fff; }
.product-card-body { padding:24px; }
.product-card-cat { font-family:var(--fh); font-size:.7rem; color:var(--gold-dim); margin-bottom:4px; }
.product-card-name { font-family:var(--fd); font-size:1.05rem; color:var(--text); margin-bottom:8px; letter-spacing:.05em; }
.product-card-spec { font-size:.7rem; color:var(--teal-lt); letter-spacing:.06em; margin-bottom:10px; font-family:var(--fd); }
.product-card-desc { font-size:.87rem; color:var(--text-mid); line-height:1.78; margin-bottom:16px; }
.product-card-price { font-family:var(--fd); font-size:1.3rem; color:var(--gold); margin-bottom:14px; }
.product-card-price span { font-size:.6rem; color:var(--text-dim); font-family:var(--fb); }

/* ── COLOUR CARDS ── */
.colour-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.colour-card { background:var(--surface); border:1px solid var(--border); transition:all 0.3s; }
.colour-card:hover { border-color:var(--border-gold); }
.colour-swatch { aspect-ratio:1/1; position:relative; overflow:hidden; }
.colour-swatch img { width:100%; height:100%; object-fit:cover; }
.swatch-badge {
  position:absolute; bottom:8px; left:8px;
  font-family:var(--fd); font-size:.4rem; letter-spacing:.14em; text-transform:uppercase;
  padding:3px 10px;
}
.swatch-anchor { background:var(--gold); color:var(--void); }
.swatch-seasonal { background:var(--saffron); color:#fff; }
.colour-info { padding:16px; }
.colour-name { font-family:var(--fd); font-size:.78rem; color:var(--text); margin-bottom:4px; letter-spacing:.06em; }
.colour-desc { font-size:.78rem; color:var(--text-dim); line-height:1.6; margin-bottom:12px; }

/* ── TIER ROWS ── */
.tier-row { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.tier-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.tier-label { font-family:var(--fd); font-size:.5rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); }
.tier-anchor .tier-dot { background:var(--gold); box-shadow:0 0 8px var(--gold); }
.tier-seasonal .tier-dot { background:var(--saffron); }

/* ── SPECS TABLE ── */
.specs-table { width:100%; border-collapse:collapse; }
.specs-table tr { border-bottom:1px solid var(--border); }
.specs-table tr:last-child { border-bottom:none; }
.specs-table td { padding:10px 0; font-size:.85rem; vertical-align:top; line-height:1.6; }
.specs-table td:first-child { font-family:var(--fd); font-size:.5rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-dim); width:40%; padding-right:16px; padding-top:12px; }
.specs-table td:last-child { color:var(--text-mid); }

/* ── VARIANT CARDS ── */
.variant-card { border:1px solid var(--border); padding:28px; position:relative; transition:border-color 0.3s; }
.variant-card:hover { border-color:var(--border-gold); }
.variant-label { font-family:var(--fd); font-size:.52rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:8px; }
.variant-name { font-family:var(--fd); font-size:1.25rem; color:var(--text); margin-bottom:14px; }
.variant-features { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.variant-features li { font-size:.85rem; color:var(--text-mid); display:flex; gap:10px; align-items:flex-start; }
.variant-features .check { flex-shrink:0; font-family:var(--fh); font-size:.7rem; }
.variant-price { font-family:var(--fd); font-size:1.8rem; color:var(--gold); }
.variant-price span { font-size:.65rem; color:var(--text-dim); font-family:var(--fb); }

/* ── KIT CARDS ── */
.kit-card {
  background:var(--surface); border:1px solid var(--border);
  position:relative; overflow:hidden; transition:all 0.35s;
}
.kit-card:hover { border-color:var(--border-gold); transform:translateY(-4px); }
.kit-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
  opacity:0; transition:opacity 0.4s;
}
.kit-card:hover::after { opacity:1; }
.kit-header { padding:32px 28px 24px; border-bottom:1px solid var(--border); }
.kit-header-gold { background:linear-gradient(135deg, rgba(200,150,10,0.08), transparent); }
.kit-header-saffron { background:linear-gradient(135deg, rgba(212,98,10,0.08), transparent); }
.kit-header-teal { background:linear-gradient(135deg, rgba(26,138,122,0.08), transparent); }
.kit-eyebrow { font-family:var(--fh); font-size:.7rem; color:var(--gold); margin-bottom:4px; }
.kit-name { font-family:var(--fd); font-size:1.3rem; color:var(--text); letter-spacing:.05em; margin-bottom:8px; }
.kit-tagline { font-size:.87rem; color:var(--text-mid); line-height:1.7; }
.kit-badge {
  position:absolute; top:20px; right:20px;
  font-family:var(--fd); font-size:.42rem; letter-spacing:.15em; text-transform:uppercase;
  padding:4px 12px; background:var(--gold); color:var(--void);
}
.kit-body { padding:24px 28px; }
.kit-items { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:20px; }
.kit-items li { font-size:.87rem; color:var(--text-mid); display:flex; gap:10px; align-items:flex-start; }
.kit-items .ki-mark { color:var(--gold); font-family:var(--fh); font-size:.8rem; flex-shrink:0; }
.kit-price-row { display:flex; align-items:baseline; gap:8px; margin-bottom:16px; }
.kit-price { font-family:var(--fd); font-size:1.6rem; color:var(--gold); }
.kit-per { font-size:.7rem; color:var(--text-dim); font-family:var(--fb); }

/* ── CALLOUT BOX ── */
.callout-gold {
  border-left:2px solid var(--gold); padding:16px 20px;
  background:rgba(200,150,10,0.05); font-size:.87rem; color:var(--text-mid); line-height:1.85;
}
.callout-gold strong { color:var(--gold); }

/* ── FAQ ── */
.faq-group { margin-bottom:48px; }
.faq-group-title { font-family:var(--fd); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; display:flex; align-items:center; gap:14px; }
.faq-group-title::after { content:''; flex:1; height:1px; background:var(--border); }
.faq-item { border-bottom:1px solid var(--border); }
.faq-btn {
  width:100%; background:none; border:none; cursor:pointer;
  padding:18px 0; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:16px;
  font-family:var(--fd); font-size:.75rem; letter-spacing:.08em; color:var(--text); transition:color 0.25s;
}
.faq-btn:hover { color:var(--gold); }
.faq-btn.open { color:var(--gold); }
.faq-icon { color:var(--gold-dim); font-size:1.2rem; flex-shrink:0; transition:transform 0.3s; }
.faq-btn.open .faq-icon { transform:rotate(45deg); }
.faq-body { display:none; padding:0 0 20px; font-size:.9rem; color:var(--text-mid); line-height:1.85; max-width:680px; }
.faq-body.open { display:block; }

/* ── CTA BAND ── */
.cta-band {
  padding:80px 0; text-align:center; position:relative; overflow:hidden;
  background:var(--deep); border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.cta-band::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse at center, rgba(200,150,10,0.08) 0%, transparent 65%);
}
.cta-band .container { position:relative; z-index:1; }
.cta-band h2 { margin-bottom:12px; }
.cta-band p { color:var(--text-mid); margin-bottom:28px; font-size:.95rem; }
.cta-band .cta-deva { font-family:var(--fh); font-size:1rem; color:var(--gold-dim); margin-bottom:8px; display:block; }
.cta-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ── FOOTER ── */
.site-footer { background:var(--void); border-top:1px solid var(--border); padding:60px 0 0; }
.footer-inner { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; }
.footer-om { font-family:var(--fh); font-size:2.5rem; color:var(--gold); line-height:1; margin-bottom:10px; display:block; }
.footer-brand { font-family:var(--fd); font-size:.7rem; letter-spacing:.16em; color:var(--text); margin-bottom:6px; }
.footer-tagline { font-size:.87rem; color:var(--text-dim); line-height:1.75; margin-bottom:20px; max-width:260px; }
.footer-flags { font-family:var(--fd); font-size:.48rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); margin-bottom:16px; display:flex; gap:8px; align-items:center; }
.footer-flags .f-sep { color:var(--gold-dim); }
.footer-social { display:flex; flex-direction:column; gap:8px; }
.footer-social a {
  font-family:var(--fd); font-size:.5rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--text-dim); transition:color 0.25s; display:inline-block;
}
.footer-social a:hover { color:var(--gold); }
.footer-col h4 { font-family:var(--fd); font-size:.55rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-dim); margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col a { font-size:.87rem; color:var(--text-dim); transition:color 0.25s; }
.footer-col a:hover { color:var(--gold); }
.footer-bottom {
  border-top:1px solid var(--border); padding:20px 0;
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--fd); font-size:.45rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim);
}
.footer-bottom a { color:var(--text-dim); transition:color 0.25s; }
.footer-bottom a:hover { color:var(--gold); }

/* ── SCROLL REVEAL ── */
.rev { opacity:0; transform:translateY(28px); transition:opacity 0.7s, transform 0.7s; }
.rev.in { opacity:1; transform:translateY(0); }
.rev-delay-1 { transition-delay:0.1s; }
.rev-delay-2 { transition-delay:0.2s; }
.rev-delay-3 { transition-delay:0.3s; }
.rev-delay-4 { transition-delay:0.4s; }

/* ── MANDALA CANVAS ── */
.mandala-canvas { opacity:.08; position:absolute; pointer-events:none; }

/* ── SACRED GRID ── */
.sacred-grid-bg {
  position:absolute; inset:0; pointer-events:none; opacity:.03;
  background-image:
    linear-gradient(var(--gold) 1px, transparent 1px),
    linear-gradient(90deg, var(--gold) 1px, transparent 1px);
  background-size:80px 80px;
}

/* ── RESPONSIVE ── */
@media (max-width:1100px) {
  .colour-grid { grid-template-columns:repeat(3,1fr); }
  .footer-inner { grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:900px) {
  .site-nav { padding:20px 28px; }
  .site-nav.scrolled { padding:14px 28px; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .page-hero { padding:130px 0 60px; }
  .section { padding:70px 0; }
  .container { padding:0 24px; }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px) {
  h1 { font-size:2rem; }
  h2 { font-size:1.5rem; }
  .colour-grid { grid-template-columns:repeat(2,1fr); }
  .footer-inner { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .cta-actions { flex-direction:column; align-items:center; }
}
