/* ===========================================================
   Ajitanatha Bhagwan · Premium Spiritual Archive
   Shared Stylesheet
   =========================================================== */

:root{
  --ivory:#FBF8F1;
  --ivory-2:#F4EEDF;
  --paper:#F8F2E2;
  --sand:#E8DCC4;
  --sand-deep:#D6C49A;
  --gold:#B8893B;
  --gold-deep:#8C6420;
  --gold-soft:#D9B872;
  --gold-pale:#EFD9A6;
  --maroon:#5A1622;
  --maroon-deep:#3D0E16;
  --saffron:#D9722E;
  --saffron-soft:#E89464;
  --emerald:#2C5F4A;
  --ink:#22130F;
  --ink-soft:#3B2A22;
  --muted:#6B5A48;
  --line:rgba(140,100,32,0.22);
  --line-strong:rgba(140,100,32,0.4);

  --serif-d:'Cinzel', serif;
  --serif:'Cormorant Garamond', serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --r-shadow:0 20px 60px -30px rgba(58,18,12,0.35);
  --t-ease:cubic-bezier(.2,.7,.2,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  font-size:15.5px;
  line-height:1.7;
  color:var(--ink-soft);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

::selection{ background:var(--gold-pale); color:var(--maroon-deep); }

/* Type scale */
h1,h2,h3,h4{ font-family:var(--serif-d); color:var(--maroon-deep); font-weight:500; line-height:1.15; letter-spacing:0.02em; }
h1{ font-size:clamp(36px, 5.4vw, 64px); letter-spacing:0.04em; }
h2{ font-size:clamp(28px, 3.8vw, 44px); letter-spacing:0.03em; }
h3{ font-size:clamp(20px, 2.2vw, 26px); }
h4{ font-size:18px; letter-spacing:0.05em; }

.eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-size:11px; font-weight:500; letter-spacing:0.4em;
  text-transform:uppercase; color:var(--gold-deep);
}
.eyebrow::before, .eyebrow.center::after{
  content:""; display:block; width:30px; height:1px; background:var(--gold);
}
.eyebrow.center{ justify-content:center; }

.lead{
  font-family:var(--serif);
  font-size:clamp(18px, 2vw, 22px);
  line-height:1.55;
  color:var(--ink-soft);
  font-weight:400;
}

.italic{ font-family:var(--serif); font-style:italic; }

/* Layout helpers */
.wrap{ width:100%; max-width:1280px; margin-inline:auto; padding:0 32px; }
.wrap-narrow{ max-width:980px; margin-inline:auto; padding:0 32px; }
section{ position:relative; }
.section-pad{ padding:120px 0; }
.section-pad-sm{ padding:80px 0; }

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:80;
  background:rgba(251,248,241,0.86);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:background .3s, box-shadow .3s;
}
.topbar.scrolled{
  background:rgba(251,248,241,0.96);
  box-shadow:0 12px 30px -20px rgba(58,18,12,0.18);
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px;
  max-width:1440px; margin-inline:auto;
  gap:24px;
}
.brand{
  display:flex; align-items:center; gap:14px;
}
.brand-mark{
  width:42px; height:42px;
  display:grid; place-items:center;
  color:var(--gold-deep);
  border:1px solid var(--gold);
  border-radius:50%;
  position:relative;
  background:radial-gradient(circle, #FBEFD0 0%, var(--ivory) 70%);
}
.brand-mark svg{ width:24px; height:24px; }
.brand-name{
  font-family:var(--serif-d);
  font-size:14px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--maroon-deep);
  font-weight:500;
  line-height:1;
}
.brand-tag{
  font-family:var(--serif);
  font-style:italic;
  font-size:12px;
  color:var(--gold-deep);
  letter-spacing:0.04em;
  margin-top:3px;
  display:block;
}
.nav-list{
  display:flex; align-items:center; gap:34px;
  list-style:none;
}
.nav-list a{
  font-size:12px;
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  position:relative;
  padding:8px 0;
  transition:color .3s;
}
.nav-list a::after{
  content:"";
  position:absolute; left:50%; bottom:0;
  width:0; height:1px;
  background:var(--gold);
  transition:width .35s var(--t-ease), left .35s var(--t-ease);
}
.nav-list a:hover, .nav-list a.is-active{ color:var(--maroon-deep); }
.nav-list a:hover::after, .nav-list a.is-active::after{ width:100%; left:0; }

.nav-cta{
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg, var(--maroon), var(--maroon-deep));
  color:var(--ivory);
  padding:11px 22px;
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  border-radius:1px;
  border:1px solid var(--maroon-deep);
  transition:transform .3s, box-shadow .3s, background .3s;
}
.nav-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px -14px rgba(90,22,34,0.55);
}

.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--line-strong);
  width:42px; height:42px;
  align-items:center; justify-content:center;
  color:var(--maroon-deep);
}
.nav-toggle span{
  display:block; width:18px; height:1.4px;
  background:currentColor; position:relative;
  transition:.3s;
}
.nav-toggle span::before, .nav-toggle span::after{
  content:""; position:absolute; left:0;
  width:18px; height:1.4px; background:currentColor;
  transition:.3s;
}
.nav-toggle span::before{ top:-6px; }
.nav-toggle span::after{ top:6px; }
.nav-toggle.is-open span{ background:transparent; }
.nav-toggle.is-open span::before{ top:0; transform:rotate(45deg); }
.nav-toggle.is-open span::after{ top:0; transform:rotate(-45deg); }

@media (max-width:1080px){
  .nav-list{
    position:absolute; left:0; right:0; top:100%;
    flex-direction:column; gap:0;
    background:var(--ivory);
    border-bottom:1px solid var(--line);
    padding:8px 0 18px;
    max-height:0; overflow:hidden;
    transition:max-height .5s var(--t-ease);
  }
  .nav-list.is-open{ max-height:600px; }
  .nav-list li{ width:100%; }
  .nav-list a{
    display:block; padding:14px 32px;
    border-bottom:1px solid var(--line);
  }
  .nav-list a::after{ display:none; }
  .nav-toggle{ display:inline-flex; }
  .nav-cta{ display:none; }
}

/* Hero common */
.hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:12px;
  padding:14px 28px;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  font-weight:500;
  border:1px solid transparent;
  border-radius:1px;
  cursor:pointer;
  transition:transform .3s, box-shadow .3s, background .3s, color .3s, border-color .3s;
}
.btn svg{ width:14px; height:14px; }
.btn--primary{
  background:linear-gradient(135deg, var(--maroon), var(--maroon-deep));
  color:var(--ivory);
  border-color:var(--maroon-deep);
}
.btn--primary:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 36px -12px rgba(90,22,34,0.5);
}
.btn--ghost{
  background:transparent;
  color:var(--maroon-deep);
  border-color:var(--gold);
}
.btn--ghost:hover{
  background:var(--gold);
  color:var(--ivory);
  border-color:var(--gold);
  transform:translateY(-3px);
}
.btn--gold{
  background:linear-gradient(135deg, var(--gold-soft), var(--gold-deep));
  color:var(--ivory);
  border-color:var(--gold-deep);
}
.btn--gold:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 36px -12px rgba(140,100,32,0.5);
}

/* Decorative motifs */
.divider{
  display:flex; align-items:center; justify-content:center;
  gap:16px;
  margin:18px 0 28px;
}
.divider::before, .divider::after{
  content:""; height:1px; flex:1; max-width:80px;
  background:linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
}
.divider-mark{
  width:18px; height:18px;
  border:1px solid var(--gold);
  transform:rotate(45deg);
  position:relative;
}
.divider-mark::before{
  content:""; position:absolute; inset:3px;
  background:var(--gold);
  transform:rotate(0deg);
}

.ornament{
  position:relative;
  width:60px; height:60px;
  margin:0 auto 24px;
}
.ornament svg{ width:100%; height:100%; color:var(--gold-deep); }

/* Footer */
.footer{
  background:linear-gradient(180deg, #1F0810 0%, #2A0E18 100%);
  color:#E2D6BE;
  padding:80px 0 32px;
  position:relative;
  overflow:hidden;
}
.footer::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(184,137,59,0.18) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(217,114,46,0.14) 0%, transparent 55%);
  pointer-events:none;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:60px;
  position:relative;
}
.footer h4{
  color:#F4DDA4;
  font-family:var(--serif-d);
  font-size:13px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  margin-bottom:22px;
  font-weight:500;
}
.footer-brand-mark{
  display:flex; align-items:center; gap:14px;
  margin-bottom:22px;
}
.footer-brand-mark svg{ width:46px; height:46px; color:#F4DDA4; }
.footer-brand-mark .name{
  font-family:var(--serif-d);
  font-size:16px;
  color:#F4DDA4;
  letter-spacing:0.18em;
  text-transform:uppercase;
}
.footer-brand-mark .tag{
  font-family:var(--serif);
  font-style:italic;
  font-size:13px;
  color:rgba(244,221,164,0.7);
  display:block;
  margin-top:2px;
}
.footer p{ font-size:14px; color:rgba(226,214,190,0.78); line-height:1.7; }
.footer-list{ list-style:none; }
.footer-list li{ margin-bottom:11px; font-size:14px; }
.footer-list a{
  color:rgba(226,214,190,0.78);
  transition:color .3s;
  display:inline-block;
  position:relative;
}
.footer-list a:hover{ color:#F4DDA4; }
.footer-contact a{
  display:flex; align-items:center; gap:10px;
  color:rgba(226,214,190,0.85);
  transition:color .3s;
  margin-bottom:10px;
  font-size:14px;
}
.footer-contact a:hover{ color:#F4DDA4; }
.footer-contact svg{ width:14px; height:14px; flex-shrink:0; color:#D9B872; }

.social{
  display:flex; gap:10px;
  margin-top:18px;
}
.social a{
  display:grid; place-items:center;
  width:40px; height:40px;
  border:1px solid rgba(244,221,164,0.25);
  color:rgba(244,221,164,0.85);
  transition:all .3s var(--t-ease);
  border-radius:50%;
}
.social a:hover{
  background:#F4DDA4;
  color:var(--maroon-deep);
  border-color:#F4DDA4;
  transform:translateY(-3px);
}
.social svg{ width:16px; height:16px; }

.footer-bottom{
  margin-top:60px;
  padding-top:26px;
  border-top:1px solid rgba(244,221,164,0.18);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:14px;
  font-size:12.5px;
  color:rgba(226,214,190,0.6);
  letter-spacing:0.05em;
  position:relative;
}
.footer-bottom a{
  color:#F4DDA4;
  border-bottom:1px solid rgba(244,221,164,0.4);
  transition:opacity .3s;
}
.footer-bottom a:hover{ opacity:0.8; }

@media (max-width:980px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:40px; }
}
@media (max-width:560px){
  .footer-grid{ grid-template-columns:1fr; gap:32px; }
  .footer-bottom{ flex-direction:column; text-align:center; }
}

/* Card primitives */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:32px;
  position:relative;
  transition:transform .4s var(--t-ease), box-shadow .4s, border-color .3s;
}
.card:hover{
  transform:translateY(-6px);
  border-color:var(--gold);
  box-shadow:var(--r-shadow);
}
.card-img{
  position:relative;
  width:100%; aspect-ratio:4/3;
  overflow:hidden;
  margin-bottom:20px;
}
.card-img img{
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  transition:transform 1.2s var(--t-ease);
}
.card:hover .card-img img{ transform:scale(1.06); }

/* Reveal */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity 1s var(--t-ease), transform 1s var(--t-ease); }
.reveal.in{ opacity:1; transform:translateY(0); }
.reveal-stagger > *{ opacity:0; transform:translateY(20px); transition:opacity .9s var(--t-ease), transform .9s var(--t-ease); }
.reveal-stagger.in > *:nth-child(1){ transition-delay:.05s; }
.reveal-stagger.in > *:nth-child(2){ transition-delay:.15s; }
.reveal-stagger.in > *:nth-child(3){ transition-delay:.25s; }
.reveal-stagger.in > *:nth-child(4){ transition-delay:.35s; }
.reveal-stagger.in > *:nth-child(5){ transition-delay:.45s; }
.reveal-stagger.in > *:nth-child(6){ transition-delay:.55s; }
.reveal-stagger.in > *{ opacity:1; transform:translateY(0); }

/* Background motifs */
.bg-paper{ background:var(--paper); }
.bg-ivory{ background:var(--ivory); }
.bg-sand{ background:linear-gradient(180deg, var(--ivory) 0%, var(--sand) 100%); }
.bg-rich{
  background:linear-gradient(180deg, #1F0810 0%, #3D0E16 100%);
  color:#E2D6BE;
}
.bg-rich h2, .bg-rich h3, .bg-rich h4{ color:#F4DDA4; }
.bg-rich .eyebrow{ color:#D9B872; }

/* SVG patterns/etc */
.bg-grid{
  position:absolute; inset:0;
  pointer-events:none;
  opacity:0.4;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, black 30%, transparent 75%);
}

/* ============== HOME PAGE ============== */
.home-hero{
  min-height:92vh;
  display:grid;
  grid-template-columns:1.05fr 1fr;
  align-items:stretch;
  background:linear-gradient(180deg, #FBF8F1 0%, #F4EAD0 100%);
}
.home-hero-text{
  padding:120px 80px 80px;
  display:flex; flex-direction:column; justify-content:center;
  position:relative;
}
.home-hero-text::before{
  content:""; position:absolute; left:80px; top:80px;
  width:40px; height:40px;
  border:1px solid var(--gold);
  border-right:none; border-bottom:none;
}
.home-hero h1{
  font-size:clamp(40px, 5.6vw, 78px);
  margin-top:18px;
  margin-bottom:8px;
  line-height:0.98;
}
.home-hero h1 .ital{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  color:var(--gold-deep);
  font-size:0.6em;
  letter-spacing:0.02em;
  margin-top:8px;
}
.home-hero .lead{ margin:24px 0 36px; max-width:520px; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero-meta{
  display:flex; gap:36px;
  margin-top:54px;
  padding-top:30px;
  border-top:1px solid var(--line);
}
.hero-meta div{
  font-family:var(--serif);
}
.hero-meta strong{
  display:block;
  font-family:var(--serif-d);
  font-size:24px;
  color:var(--maroon-deep);
  letter-spacing:0.08em;
  margin-bottom:4px;
  font-weight:500;
}
.hero-meta span{
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
}
.home-hero-image{
  position:relative;
  background:var(--sand);
  overflow:hidden;
}
.home-hero-image::before{
  content:"";
  position:absolute; inset:36px;
  border:1px solid rgba(255,255,255,0.5);
  z-index:2;
  pointer-events:none;
}
.home-hero-image::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 0%, transparent 60%, rgba(61,14,22,0.5) 100%);
  z-index:1;
  pointer-events:none;
}
.home-hero-image img{
  width:100%; height:100%;
  object-fit:cover; object-position:center 18%;
}
.home-hero-image .badge{
  position:absolute;
  bottom:50px; left:50px;
  z-index:3;
  background:rgba(251,248,241,0.92);
  padding:18px 22px;
  border:1px solid rgba(184,137,59,0.4);
  backdrop-filter:blur(8px);
  font-family:var(--serif);
  font-style:italic;
  color:var(--maroon-deep);
  font-size:14px;
  max-width:300px;
}
.home-hero-image .badge strong{
  display:block;
  font-family:var(--serif-d);
  font-style:normal;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:6px;
  font-weight:500;
}

@media (max-width:980px){
  .home-hero{ grid-template-columns:1fr; }
  .home-hero-text{ padding:80px 32px 60px; }
  .home-hero-text::before{ left:32px; top:50px; }
  .home-hero-image{ min-height:520px; }
}

/* Welcome section */
.welcome-grid{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:80px;
  align-items:center;
}
.welcome-image{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
}
.welcome-image::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(160deg, transparent 50%, rgba(217,114,46,0.1) 100%);
  pointer-events:none;
}
.welcome-image img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.welcome-image .seal{
  position:absolute; bottom:24px; right:24px;
  width:90px; height:90px;
  border-radius:50%;
  background:rgba(251,248,241,0.95);
  display:grid; place-items:center;
  border:1px solid var(--gold);
  font-family:var(--serif-d);
  font-size:10px;
  text-align:center;
  color:var(--maroon-deep);
  letter-spacing:0.18em;
  text-transform:uppercase;
  line-height:1.3;
  padding:14px;
}
.welcome-text h2{ margin:18px 0 22px; }
.welcome-text p{ margin-bottom:20px; }
.welcome-quote{
  margin-top:32px;
  padding:24px 28px;
  border-left:2px solid var(--gold);
  background:rgba(184,137,59,0.06);
  font-family:var(--serif);
  font-style:italic;
  font-size:18px;
  color:var(--maroon-deep);
}
.welcome-quote span{
  display:block;
  margin-top:10px;
  font-family:var(--sans);
  font-style:normal;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
}

@media (max-width:880px){
  .welcome-grid{ grid-template-columns:1fr; gap:50px; }
}

/* Highlight pillars */
.pillars{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  border:1px solid var(--line);
  background:var(--paper);
}
.pillar{
  padding:42px 32px;
  border-right:1px solid var(--line);
  position:relative;
  transition:background .4s;
}
.pillar:last-child{ border-right:none; }
.pillar:hover{ background:var(--ivory); }
.pillar-num{
  font-family:var(--serif-d);
  font-size:14px;
  letter-spacing:0.3em;
  color:var(--gold-deep);
  margin-bottom:18px;
}
.pillar svg{
  width:38px; height:38px;
  color:var(--maroon);
  margin-bottom:18px;
}
.pillar h4{
  font-size:17px;
  margin-bottom:8px;
  letter-spacing:0.04em;
}
.pillar p{ font-size:14px; color:var(--muted); }

@media (max-width:880px){
  .pillars{ grid-template-columns:1fr 1fr; }
  .pillar{ border-right:1px solid var(--line); border-bottom:1px solid var(--line); }
  .pillar:nth-child(2){ border-right:none; }
  .pillar:nth-child(3), .pillar:nth-child(4){ border-bottom:none; }
  .pillar:nth-child(4){ border-right:none; }
}
@media (max-width:520px){
  .pillars{ grid-template-columns:1fr; }
  .pillar{ border-right:none !important; border-bottom:1px solid var(--line); }
  .pillar:last-child{ border-bottom:none; }
}

/* Featured teaching feature */
.feature-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  background:var(--maroon-deep);
  color:var(--ivory);
  overflow:hidden;
}
.feature-row .imgcol{
  position:relative;
  min-height:560px;
}
.feature-row .imgcol img{
  width:100%; height:100%; object-fit:cover; object-position:center top;
  position:absolute; inset:0;
}
.feature-row .imgcol::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(61,14,22,0.6) 0%, transparent 60%);
}
.feature-row .txtcol{
  padding:80px 60px;
  display:flex; flex-direction:column; justify-content:center;
}
.feature-row h2{ color:#F4DDA4; }
.feature-row .lead{ color:rgba(244,221,164,0.85); }
.feature-row .eyebrow{ color:#D9B872; }
.feature-row .eyebrow::before{ background:#D9B872; }
.feature-row p{ color:rgba(226,214,190,0.85); margin:18px 0 26px; }

.teach-list{ list-style:none; margin-top:24px; }
.teach-list li{
  display:flex; align-items:flex-start; gap:14px;
  padding:14px 0;
  border-bottom:1px solid rgba(244,221,164,0.18);
  font-size:14px;
}
.teach-list li:last-child{ border:none; }
.teach-list li svg{ width:18px; height:18px; color:#D9B872; flex-shrink:0; margin-top:3px; }
.teach-list li strong{ color:#F4DDA4; font-family:var(--serif-d); font-size:13px; letter-spacing:0.18em; text-transform:uppercase; font-weight:500; display:block; margin-bottom:2px; }

@media (max-width:880px){
  .feature-row{ grid-template-columns:1fr; }
  .feature-row .imgcol{ min-height:380px; }
  .feature-row .txtcol{ padding:54px 32px; }
}

/* Heritage preview */
.heritage-preview{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.h-card{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  border:1px solid var(--line);
}
.h-card img{ width:100%; height:100%; object-fit:cover; object-position:center; transition:transform 1.2s var(--t-ease); }
.h-card:hover img{ transform:scale(1.06); }
.h-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(31,8,16,0.85) 100%);
}
.h-card-meta{
  position:absolute; bottom:0; left:0; right:0;
  padding:28px;
  z-index:2;
  color:var(--ivory);
}
.h-card-meta strong{
  display:block;
  font-family:var(--serif-d);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:#D9B872;
  margin-bottom:6px;
  font-weight:500;
}
.h-card-meta h3{ color:#F4DDA4; font-size:20px; }
.h-card-meta span{
  display:inline-block;
  margin-top:10px;
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:rgba(244,221,164,0.8);
  border-bottom:1px solid rgba(244,221,164,0.4);
  padding-bottom:2px;
}

@media (max-width:880px){
  .heritage-preview{ grid-template-columns:1fr; }
  .h-card{ aspect-ratio:16/10; }
}

/* CTA banner */
.cta-band{
  position:relative;
  padding:90px 0;
  text-align:center;
  background:
    linear-gradient(rgba(31,8,16,0.84), rgba(31,8,16,0.92)),
    url('../../images/Lord_Ajitnath_Tirthankar.jpg') center 20%/cover no-repeat;
  color:var(--ivory);
}
.cta-band h2{ color:#F4DDA4; max-width:760px; margin:14px auto 18px; }
.cta-band p{ color:rgba(244,221,164,0.85); max-width:580px; margin:0 auto 32px; font-family:var(--serif); font-size:18px; font-style:italic; }
.cta-band .actions{ display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }

/* ============== ABOUT PAGE ============== */
.page-hero{
  position:relative;
  padding:120px 0 100px;
  background:linear-gradient(180deg, var(--ivory) 0%, var(--sand) 100%);
  text-align:center;
  overflow:hidden;
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background-image:url('../../images/171644746553.jpg');
  background-size:cover;
  background-position:center 30%;
  opacity:0.12;
  filter:saturate(0.5);
}
.page-hero-content{ position:relative; max-width:780px; margin:0 auto; padding:0 32px; }
.page-hero h1{ margin:18px 0 18px; }
.page-hero .lead{ font-size:clamp(18px, 2vw, 22px); color:var(--ink-soft); }
.page-hero-crumb{
  display:flex; justify-content:center; gap:10px;
  margin-top:36px;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
}
.page-hero-crumb a{ color:var(--maroon-deep); transition:opacity .3s; }
.page-hero-crumb a:hover{ opacity:0.7; }
.page-hero-crumb span.sep{ color:var(--gold); }

.about-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:80px;
  align-items:start;
}
.about-image-stack{
  position:relative;
}
.about-image-stack .a{
  width:100%; aspect-ratio:3/4;
  overflow:hidden;
  border:1px solid var(--line);
}
.about-image-stack .a img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.about-image-stack .b{
  position:absolute; bottom:-50px; right:-30px;
  width:60%; aspect-ratio:1;
  overflow:hidden;
  border:6px solid var(--ivory);
  box-shadow:var(--r-shadow);
  z-index:2;
}
.about-image-stack .b img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.about-image-stack .gold-frame{
  position:absolute; top:-18px; left:-18px;
  width:60px; height:60px;
  border:2px solid var(--gold);
  border-right:none; border-bottom:none;
}
.about-text h2{ margin:18px 0 22px; }
.about-text p{ margin-bottom:20px; font-size:16px; }
.about-text p strong{ color:var(--maroon-deep); }
.about-stats{
  margin-top:40px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border:1px solid var(--line);
}
.about-stats div{
  padding:24px;
  border-right:1px solid var(--line);
}
.about-stats div:last-child{ border-right:none; }
.about-stats strong{
  display:block;
  font-family:var(--serif-d);
  font-size:32px;
  color:var(--maroon-deep);
  font-weight:500;
  letter-spacing:0.04em;
  margin-bottom:6px;
}
.about-stats span{
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold-deep);
}

@media (max-width:980px){
  .about-grid{ grid-template-columns:1fr; gap:80px; }
  .about-image-stack .b{ width:50%; right:0; bottom:-30px; }
}

.lineage-band{
  background:linear-gradient(180deg, var(--paper) 0%, var(--ivory) 100%);
}
.lineage-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
  margin-top:48px;
}
.lineage-card{
  background:var(--ivory);
  padding:38px 30px;
  border:1px solid var(--line);
  position:relative;
  transition:.4s var(--t-ease);
}
.lineage-card::before{
  content:"";
  position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--gold-soft), var(--gold), var(--gold-soft));
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--t-ease);
}
.lineage-card:hover{ transform:translateY(-6px); box-shadow:var(--r-shadow); }
.lineage-card:hover::before{ transform:scaleX(1); }
.lineage-card svg{ width:42px; height:42px; color:var(--gold-deep); margin-bottom:18px; }
.lineage-card h3{ font-size:20px; margin-bottom:12px; }
.lineage-card p{ font-size:14.5px; color:var(--muted); line-height:1.7; }

@media (max-width:880px){
  .lineage-grid{ grid-template-columns:1fr; }
}

/* Quote block */
.quote-block{
  text-align:center;
  max-width:880px;
  margin:0 auto;
  padding:64px 32px;
  position:relative;
}
.quote-block::before, .quote-block::after{
  content:"";
  position:absolute;
  width:40px; height:40px;
  border:1px solid var(--gold);
}
.quote-block::before{ top:0; left:0; border-right:none; border-bottom:none; }
.quote-block::after{ bottom:0; right:0; border-left:none; border-top:none; }
.quote-block p{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(22px, 2.6vw, 30px);
  line-height:1.5;
  color:var(--maroon-deep);
  margin-bottom:18px;
}
.quote-block cite{
  display:block;
  font-family:var(--serif-d);
  font-style:normal;
  font-size:12px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  font-weight:500;
}

/* ============== JOURNEY PAGE ============== */
.journey-intro{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:80px;
  align-items:end;
  padding-bottom:60px;
}
.journey-intro h2{ margin:18px 0 22px; }
.journey-intro img{
  aspect-ratio:4/5;
  width:100%;
  object-fit:cover;
  object-position:center top;
  border:1px solid var(--line);
}

@media (max-width:980px){
  .journey-intro{ grid-template-columns:1fr; gap:48px; }
}

/* Timeline */
.timeline{
  position:relative;
  margin-top:60px;
  padding:40px 0 20px;
}
.timeline::before{
  content:"";
  position:absolute; left:50%; top:0; bottom:0;
  width:1px;
  background:linear-gradient(180deg, transparent, var(--gold) 5%, var(--gold) 95%, transparent);
  transform:translateX(-50%);
}
.t-item{
  position:relative;
  display:grid;
  grid-template-columns:1fr 80px 1fr;
  gap:0;
  margin-bottom:60px;
  align-items:center;
}
.t-item:last-child{ margin-bottom:0; }
.t-marker{
  grid-column:2;
  width:80px; height:80px;
  display:grid; place-items:center;
  position:relative; z-index:2;
}
.t-marker-inner{
  width:54px; height:54px;
  background:var(--ivory);
  border:1px solid var(--gold);
  border-radius:50%;
  display:grid; place-items:center;
  position:relative;
  font-family:var(--serif-d);
  font-size:14px;
  color:var(--maroon-deep);
  letter-spacing:0.05em;
  font-weight:500;
}
.t-marker-inner::before{
  content:"";
  position:absolute; inset:-8px;
  border:1px solid rgba(184,137,59,0.3);
  border-radius:50%;
  animation:pulseRing 3s ease-in-out infinite;
}
@keyframes pulseRing{
  0%,100%{ transform:scale(1); opacity:0.8; }
  50%{ transform:scale(1.2); opacity:0; }
}

.t-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:32px 36px;
  position:relative;
  transition:.4s var(--t-ease);
}
.t-card:hover{
  border-color:var(--gold);
  transform:translateY(-4px);
  box-shadow:var(--r-shadow);
}
.t-card .epoch{
  font-family:var(--serif-d);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:8px;
  font-weight:500;
}
.t-card h3{ font-size:22px; margin-bottom:12px; }
.t-card p{ font-size:14.5px; color:var(--muted); line-height:1.75; }
.t-card .img-mini{
  width:100%; aspect-ratio:16/9;
  margin-top:18px;
  overflow:hidden;
}
.t-card .img-mini img{ width:100%; height:100%; object-fit:cover; object-position:center 25%; }

.t-item:nth-child(odd) .t-card{ grid-column:1; text-align:right; margin-right:32px; }
.t-item:nth-child(odd) .t-card::after{
  content:"";
  position:absolute; right:-9px; top:32px;
  width:16px; height:16px;
  background:var(--paper);
  border-top:1px solid var(--line);
  border-right:1px solid var(--line);
  transform:rotate(45deg);
}
.t-item:nth-child(even) .t-card{ grid-column:3; margin-left:32px; }
.t-item:nth-child(even) .t-card::after{
  content:"";
  position:absolute; left:-9px; top:32px;
  width:16px; height:16px;
  background:var(--paper);
  border-bottom:1px solid var(--line);
  border-left:1px solid var(--line);
  transform:rotate(45deg);
}

@media (max-width:880px){
  .timeline::before{ left:32px; }
  .t-item{ grid-template-columns:64px 1fr; gap:0; }
  .t-marker{ grid-column:1; width:64px; }
  .t-card, .t-item:nth-child(odd) .t-card, .t-item:nth-child(even) .t-card{
    grid-column:2; text-align:left; margin:0 0 0 16px;
  }
  .t-item:nth-child(odd) .t-card::after, .t-item:nth-child(even) .t-card::after{
    left:-9px; right:auto; top:24px;
    border:none;
    border-bottom:1px solid var(--line);
    border-left:1px solid var(--line);
  }
}

/* ============== TEACHINGS PAGE ============== */
.teachings-intro{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.teachings-intro h2{ margin:18px 0 22px; }
.teachings-intro img{
  aspect-ratio:1;
  width:100%; object-fit:cover; object-position:center top;
  border:1px solid var(--line);
}
@media (max-width:980px){
  .teachings-intro{ grid-template-columns:1fr; gap:48px; }
}

.principles{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
  margin-top:48px;
}
.principle{
  position:relative;
  padding:36px 28px;
  background:var(--ivory);
  border:1px solid var(--line);
  transition:.4s var(--t-ease);
  overflow:hidden;
}
.principle::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(184,137,59,0.08), transparent 60%);
  opacity:0; transition:opacity .4s;
}
.principle:hover{
  transform:translateY(-6px);
  border-color:var(--gold);
  box-shadow:var(--r-shadow);
}
.principle:hover::before{ opacity:1; }
.principle-icon{
  width:56px; height:56px;
  margin-bottom:24px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--gold-pale), var(--gold-soft));
  border:1px solid var(--gold);
  color:var(--maroon-deep);
  border-radius:50%;
  position:relative;
}
.principle-icon svg{ width:24px; height:24px; }
.principle h3{ font-size:18px; margin-bottom:8px; }
.principle .sanskrit{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--gold-deep);
  margin-bottom:10px;
  display:block;
}
.principle p{ font-size:14px; color:var(--muted); line-height:1.7; }

@media (max-width:1080px){
  .principles{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .principles{ grid-template-columns:1fr; }
}

.philosophy-band{
  background:var(--maroon-deep);
  color:var(--ivory);
  padding:100px 0;
  position:relative;
  overflow:hidden;
}
.philosophy-band::before{
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(circle at 20% 50%, rgba(217,184,114,0.18), transparent 50%);
  pointer-events:none;
}
.philosophy-band h2{ color:#F4DDA4; }
.philosophy-band .eyebrow{ color:#D9B872; }
.philosophy-band .eyebrow::before{ background:#D9B872; }
.philosophy-band p{ color:rgba(226,214,190,0.85); }

.path-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:32px;
  margin-top:48px;
}
.path-step{
  text-align:center;
  padding:32px 28px;
  border:1px solid rgba(244,221,164,0.18);
  background:rgba(0,0,0,0.18);
  transition:.4s var(--t-ease);
}
.path-step:hover{
  background:rgba(244,221,164,0.06);
  border-color:#D9B872;
  transform:translateY(-4px);
}
.path-step .num{
  display:inline-block;
  font-family:var(--serif-d);
  font-size:11px;
  letter-spacing:0.32em;
  color:#D9B872;
  font-weight:500;
  border:1px solid rgba(217,184,114,0.4);
  padding:6px 14px;
  margin-bottom:18px;
}
.path-step h3{ color:#F4DDA4; font-size:20px; margin-bottom:10px; }
.path-step p{ font-size:14.5px; line-height:1.7; }

@media (max-width:880px){
  .path-grid{ grid-template-columns:1fr; }
}

/* ============== HERITAGE PAGE ============== */
.heritage-hero-img{
  width:100%; aspect-ratio:21/9;
  overflow:hidden;
  margin-top:0;
}
.heritage-hero-img img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; }

.heritage-grid{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:80px;
  align-items:center;
}
.heritage-grid img{
  aspect-ratio:4/5;
  width:100%;
  object-fit:cover; object-position:center top;
  border:1px solid var(--line);
}
.heritage-grid h2{ margin:18px 0 22px; }
.heritage-grid p{ margin-bottom:18px; }

@media (max-width:980px){
  .heritage-grid{ grid-template-columns:1fr; gap:48px; }
}

.heritage-cards{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
  margin-top:48px;
}
.heritage-card{
  background:var(--ivory);
  border:1px solid var(--line);
  overflow:hidden;
  transition:.4s var(--t-ease);
}
.heritage-card:hover{ transform:translateY(-6px); border-color:var(--gold); box-shadow:var(--r-shadow); }
.heritage-card .img-wrap{ aspect-ratio:4/3; overflow:hidden; }
.heritage-card .img-wrap img{ width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform 1.2s var(--t-ease); }
.heritage-card:hover .img-wrap img{ transform:scale(1.05); }
.heritage-card-body{ padding:28px 30px; }
.heritage-card-body .label{
  font-family:var(--serif-d);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:8px;
  display:block;
  font-weight:500;
}
.heritage-card-body h3{ font-size:20px; margin-bottom:10px; }
.heritage-card-body p{ font-size:14.5px; color:var(--muted); }

@media (max-width:980px){
  .heritage-cards{ grid-template-columns:1fr; }
}

.position-band{
  background:linear-gradient(180deg, var(--paper) 0%, var(--ivory) 100%);
}
.position-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  margin-top:48px;
  border:1px solid var(--line);
  background:var(--ivory);
}
.position-cell{
  padding:36px 28px;
  border-right:1px solid var(--line);
  text-align:center;
  position:relative;
}
.position-cell:last-child{ border-right:none; }
.position-cell .num{
  font-family:var(--serif-d);
  font-size:42px;
  color:var(--maroon-deep);
  font-weight:500;
  letter-spacing:0.05em;
  margin-bottom:6px;
}
.position-cell h4{ font-size:13px; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold-deep); margin-bottom:8px; font-weight:500; }
.position-cell p{ font-size:13.5px; color:var(--muted); }

@media (max-width:980px){
  .position-grid{ grid-template-columns:1fr 1fr; }
  .position-cell{ border-bottom:1px solid var(--line); }
  .position-cell:nth-child(2){ border-right:none; }
  .position-cell:nth-child(3), .position-cell:nth-child(4){ border-bottom:none; }
}
@media (max-width:520px){
  .position-grid{ grid-template-columns:1fr; }
  .position-cell{ border-right:none !important; border-bottom:1px solid var(--line); }
  .position-cell:last-child{ border-bottom:none; }
}

/* ============== GALLERY PAGE ============== */
.gallery-tabs{
  display:flex; justify-content:center; gap:10px;
  flex-wrap:wrap;
  margin-bottom:48px;
}
.gallery-tabs button{
  background:transparent;
  border:1px solid var(--line);
  padding:10px 22px;
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
  transition:.3s var(--t-ease);
}
.gallery-tabs button:hover{ border-color:var(--gold); color:var(--maroon-deep); }
.gallery-tabs button.is-active{
  background:var(--maroon-deep);
  color:var(--ivory);
  border-color:var(--maroon-deep);
}

/* True column-based masonry — preserves natural aspect ratio,
   no face cropping, no gaps. Images sit edge-to-edge inside their cells. */
.masonry{
  column-count:4;
  column-gap:18px;
}
.masonry .tile{
  position:relative;
  display:block;
  width:100%;
  margin:0 0 18px;
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  page-break-inside:avoid;
  cursor:pointer;
  border:1px solid var(--line);
  background:var(--paper);
  overflow:hidden;
}
.masonry .tile img{
  display:block;
  width:100%;
  height:auto;
  object-fit:contain;
  transition:transform 1.2s var(--t-ease), filter .6s;
}
.masonry .tile::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(31,8,16,0.78) 100%);
  opacity:0; transition:opacity .4s;
  pointer-events:none;
}
.masonry .tile .cap{
  position:absolute; bottom:0; left:0; right:0;
  padding:18px 22px;
  color:var(--ivory);
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  z-index:2;
  opacity:0;
  transform:translateY(10px);
  transition:opacity .4s, transform .4s;
}
.masonry .tile:hover img{ transform:scale(1.04); }
.masonry .tile:hover::after{ opacity:1; }
.masonry .tile:hover .cap{ opacity:1; transform:translateY(0); }

@media (max-width:1180px){
  .masonry{ column-count:3; }
}
@media (max-width:760px){
  .masonry{ column-count:2; column-gap:14px; }
  .masonry .tile{ margin-bottom:14px; }
}
@media (max-width:480px){
  .masonry{ column-count:1; }
}

/* Lightbox */
.lightbox{
  position:fixed; inset:0;
  background:rgba(15,5,8,0.94);
  z-index:200;
  display:none;
  align-items:center; justify-content:center;
  padding:30px;
}
.lightbox.active{ display:flex; }
.lightbox img{
  max-width:90vw; max-height:84vh;
  object-fit:contain;
  border:1px solid rgba(244,221,164,0.3);
}
.lightbox .close{
  position:absolute; top:24px; right:30px;
  background:transparent; border:1px solid rgba(244,221,164,0.4);
  width:46px; height:46px;
  display:grid; place-items:center;
  color:#F4DDA4;
  font-size:20px;
  border-radius:50%;
  transition:.3s;
}
.lightbox .close:hover{ background:#F4DDA4; color:var(--maroon-deep); }
.lightbox .nav{
  position:absolute; top:50%; transform:translateY(-50%);
  background:transparent; border:1px solid rgba(244,221,164,0.4);
  color:#F4DDA4;
  width:50px; height:50px;
  display:grid; place-items:center;
  border-radius:50%;
  transition:.3s;
}
.lightbox .nav:hover{ background:#F4DDA4; color:var(--maroon-deep); }
.lightbox .nav svg{ width:20px; height:20px; }
.lightbox .prev{ left:30px; }
.lightbox .next{ right:30px; }

/* ============== ARTICLES PAGE ============== */
.articles-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:32px;
}
.article{
  background:var(--ivory);
  border:1px solid var(--line);
  overflow:hidden;
  display:flex; flex-direction:column;
  transition:.4s var(--t-ease);
}
.article:hover{ transform:translateY(-6px); border-color:var(--gold); box-shadow:var(--r-shadow); }
.article-img{ aspect-ratio:5/3; overflow:hidden; position:relative; }
.article-img img{ width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform 1.2s var(--t-ease); }
.article:hover .article-img img{ transform:scale(1.05); }
.article-img .tag{
  position:absolute; top:14px; left:14px;
  background:rgba(251,248,241,0.94);
  color:var(--maroon-deep);
  font-family:var(--serif-d);
  font-size:10px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  padding:6px 12px;
  font-weight:500;
}
.article-body{ padding:30px; flex:1; display:flex; flex-direction:column; }
.article-meta{
  display:flex; gap:14px; align-items:center;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:14px;
  font-weight:500;
}
.article-meta span.dot{ width:4px; height:4px; background:var(--gold); border-radius:50%; }
.article-body h3{ font-size:22px; margin-bottom:12px; line-height:1.3; }
.article-body p{ font-size:14.5px; color:var(--muted); margin-bottom:20px; flex:1; }
.article-body .more{
  display:inline-flex; align-items:center; gap:8px;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--maroon-deep);
  font-weight:500;
  border-bottom:1px solid var(--gold);
  padding-bottom:4px;
  align-self:flex-start;
  transition:gap .3s;
}
.article-body .more:hover{ gap:14px; }

@media (max-width:980px){
  .articles-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .articles-grid{ grid-template-columns:1fr; }
}

.events-band{
  background:linear-gradient(180deg, var(--paper), var(--ivory));
}
.event-row{
  display:grid;
  grid-template-columns:160px 1fr auto;
  gap:32px;
  align-items:center;
  padding:30px 32px;
  background:var(--ivory);
  border:1px solid var(--line);
  margin-bottom:18px;
  transition:.4s var(--t-ease);
}
.event-row:hover{ border-color:var(--gold); transform:translateX(6px); box-shadow:var(--r-shadow); }
.event-date{
  text-align:center;
  border-right:1px solid var(--line);
  padding-right:32px;
}
.event-date strong{
  display:block;
  font-family:var(--serif-d);
  font-size:38px;
  color:var(--maroon-deep);
  letter-spacing:0.04em;
  font-weight:500;
  line-height:1;
}
.event-date span{
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-top:6px;
  display:block;
  font-weight:500;
}
.event-body h3{ font-size:20px; margin-bottom:6px; }
.event-body .meta{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--muted);
}
.event-body p{ font-size:14px; color:var(--muted); margin-top:8px; }
.event-row .arrow{
  width:46px; height:46px;
  border:1px solid var(--gold);
  display:grid; place-items:center;
  color:var(--maroon-deep);
  border-radius:50%;
  transition:.3s;
}
.event-row:hover .arrow{ background:var(--gold); color:var(--ivory); }
.event-row .arrow svg{ width:16px; height:16px; }

@media (max-width:680px){
  .event-row{ grid-template-columns:1fr; gap:14px; padding:24px; }
  .event-date{ border-right:none; padding-right:0; padding-bottom:14px; border-bottom:1px solid var(--line); display:flex; gap:12px; align-items:center; justify-content:flex-start; text-align:left; }
  .event-date strong{ font-size:28px; }
  .event-row .arrow{ justify-self:flex-start; }
}

/* ============== CONTACT PAGE ============== */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:80px;
  align-items:start;
}
.contact-info{
  position:sticky;
  top:120px;
}
.contact-info h2{ margin:18px 0 22px; }
.contact-info p{ margin-bottom:24px; font-size:16px; }

.contact-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:32px;
  margin-bottom:18px;
  transition:.3s;
}
.contact-card:hover{ border-color:var(--gold); }
.contact-card .label{
  font-family:var(--serif-d);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:10px;
  display:block;
  font-weight:500;
}
.contact-card .name{
  font-family:var(--serif-d);
  font-size:22px;
  color:var(--maroon-deep);
  font-weight:500;
  letter-spacing:0.05em;
  margin-bottom:10px;
}
.contact-card a{
  display:flex; align-items:center; gap:12px;
  color:var(--ink-soft);
  margin-bottom:8px;
  font-size:15px;
  transition:color .3s;
}
.contact-card a:hover{ color:var(--maroon-deep); }
.contact-card a:last-child{ margin-bottom:0; }
.contact-card a svg{ width:16px; height:16px; color:var(--gold-deep); flex-shrink:0; }

.contact-form{
  background:var(--ivory);
  border:1px solid var(--line);
  padding:48px;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-bottom:22px; }
.form-row.single{ grid-template-columns:1fr; }
.form-field label{
  display:block;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:10px;
  font-weight:500;
}
.form-field input, .form-field textarea, .form-field select{
  width:100%;
  background:transparent;
  border:none;
  border-bottom:1px solid var(--line-strong);
  padding:12px 0 14px;
  font-family:var(--sans);
  font-size:15px;
  color:var(--ink);
  outline:none;
  transition:border-color .3s;
}
.form-field input:focus, .form-field textarea:focus, .form-field select:focus{
  border-bottom-color:var(--gold-deep);
}
.form-field textarea{ resize:vertical; min-height:120px; padding-top:14px; }

.form-actions{
  display:flex; gap:16px; align-items:center; flex-wrap:wrap;
  margin-top:14px;
}
.form-status{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--emerald);
  display:none;
}
.form-status.show{ display:block; }

@media (max-width:980px){
  .contact-grid{ grid-template-columns:1fr; gap:48px; }
  .contact-info{ position:static; }
  .contact-form{ padding:36px 28px; }
  .form-row{ grid-template-columns:1fr; gap:18px; }
}

/* Final CTA */
.final-cta{
  text-align:center;
  background:
    linear-gradient(rgba(31,8,16,0.86), rgba(31,8,16,0.94)),
    url('../../images/Idol_of_Ajitnatha_at_Taranga.jpg') center 20%/cover no-repeat;
  color:var(--ivory);
  padding:120px 32px;
}
.final-cta .ornament svg{ color:#D9B872; }
.final-cta h2{ color:#F4DDA4; max-width:780px; margin:14px auto 18px; }
.final-cta p{ color:rgba(244,221,164,0.85); font-family:var(--serif); font-style:italic; font-size:18px; max-width:560px; margin:0 auto 30px; }

/* Helpers */
.text-center{ text-align:center; }
.center-stack{ max-width:780px; margin:0 auto 60px; text-align:center; }
.center-stack h2{ margin:14px 0 14px; }
.center-stack p{ font-size:16px; }
