/* =========================================================
   BANGLADESH SHAKTIPEETH — Sacred Heritage Portal
   Design system v2 · Saffron · Gold · Maroon · Ivory
   ========================================================= */

:root{
  /* Sacred palette */
  --maroon:#5a0a16;
  --maroon-deep:#3d0710;
  --maroon-soft:#7a1a26;
  --saffron:#e87722;
  --saffron-deep:#c45a16;
  --saffron-glow:#f5a04e;
  --gold:#c9a24a;
  --gold-light:#e8c876;
  --gold-deep:#9d7e34;
  --gold-shimmer:#f0d488;

  --ivory:#faf6ec;
  --ivory-warm:#f3ecd9;
  --ivory-deep:#ebe1c5;
  --sand:#d9c5a3;
  --sand-light:#ebd9b4;

  --ink:#2a1810;
  --ink-soft:#4a3528;
  --ink-muted:#8a7361;
  --line-gold:rgba(201,162,74,.32);
  --line-soft:rgba(90,10,22,.16);

  /* Type stack */
  --display:"Cinzel", "Cormorant Garamond", Georgia, serif;
  --serif:"Cormorant Garamond", "Cormorant", Georgia, serif;
  --sanskrit:"Eczar", "Cormorant Garamond", serif;
  --body:"Spectral", Georgia, serif;
  --ui:"Inter", system-ui, -apple-system, sans-serif;
  --bn-display:"Noto Serif Bengali", "Hind Siliguri", serif;
  --bn-body:"Noto Serif Bengali", "Hind Siliguri", "Cormorant Garamond", serif;

  --max:1340px;
  --pad:clamp(20px, 4vw, 56px);
  --r-sm:4px;
  --r-md:10px;
  --r-lg:18px;
  --r-pill:999px;

  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);

  --shadow-soft:0 18px 60px -28px rgba(13,8,4,.45);
  --shadow-deep:0 30px 80px -30px rgba(90,10,22,.55);
  --shadow-glow:0 0 50px -10px rgba(232,200,118,.5);
}

/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  scroll-padding-top:80px;
}
body{
  margin:0;
  font-family:var(--body);
  font-size:17px;
  line-height:1.75;
  color:var(--ink);
  background:var(--ivory);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;-webkit-appearance:none;appearance:none}
input,textarea,select{font:inherit;color:inherit}

h1,h2,h3,h4,h5{
  font-family:var(--display);
  font-weight:500;
  letter-spacing:.04em;
  line-height:1.2;
  color:var(--maroon-deep);
  margin:0 0 .6em;
}
h1{font-size:clamp(2.4rem,5.2vw,4.8rem);letter-spacing:.05em;font-weight:600}
h2{font-size:clamp(1.9rem,3.4vw,3rem);letter-spacing:.04em}
h3{font-size:clamp(1.3rem,2vw,1.7rem);letter-spacing:.03em}
h4{font-size:1.05rem;letter-spacing:.18em;text-transform:uppercase;font-family:var(--ui);font-weight:600;color:var(--gold-deep)}
p{margin:0 0 1em}
em{color:var(--saffron-deep);font-style:italic}
.sanskrit{font-family:var(--sanskrit);color:var(--maroon);font-style:italic}

/* ===== BILINGUAL SYSTEM =====
   We use `bn-mode` on the body (so it never collides with the .lang-bn span class
   which would cause `body.lang-bn { display: none }` to hide the entire page).
   Content lives in <span class="lang-en"> and <span class="lang-bn"> pairs. */
.lang-en, .lang-bn { display: inline; }
.lang-bn { display: none; }
body.bn-mode .lang-en { display: none !important; }
body.bn-mode .lang-bn { display: inline !important; }

/* When Bengali active, swap font for prose */
body.bn-mode,
body.bn-mode h1, body.bn-mode h2, body.bn-mode h3,
body.bn-mode p, body.bn-mode .lead, body.bn-mode blockquote,
body.bn-mode .nav-list a, body.bn-mode .btn,
body.bn-mode .brand-name, body.bn-mode .brand-sub {
  font-family: var(--bn-body);
}
body.bn-mode h1, body.bn-mode h2, body.bn-mode h3 {
  font-family: var(--bn-display);
  letter-spacing: 0;
  font-weight: 600;
}
body.bn-mode h4, body.bn-mode .eyebrow,
body.bn-mode .nav-list a, body.bn-mode .btn,
body.bn-mode .brand-sub {
  letter-spacing: .06em;
  text-transform: none;
  font-family: var(--bn-body);
}

/* ===== UTILITIES ===== */
.container{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding:clamp(70px,9vw,140px) 0;position:relative}
.section.tight{padding:clamp(50px,6vw,90px) 0}
.section.dark{background:var(--maroon-deep);color:var(--ivory)}
.section.dark h1,.section.dark h2,.section.dark h3{color:var(--ivory)}
.section.maroon{background:linear-gradient(160deg,var(--maroon-deep) 0%,var(--maroon) 60%,var(--maroon-deep) 100%);color:var(--ivory)}
.section.maroon h1,.section.maroon h2,.section.maroon h3{color:var(--ivory)}
.section.warm{background:linear-gradient(180deg,var(--ivory) 0%,var(--ivory-warm) 100%)}
.section.sand{background:var(--ivory-warm)}
.text-center{text-align:center}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--ui);
  font-size:.74rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--saffron-deep);
  font-weight:600;
  margin-bottom:1.4rem;
}
.eyebrow::before, .eyebrow::after{
  content:"";
  width:36px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold));
}
.eyebrow.left{justify-content:flex-start}
.eyebrow.left::before{display:none}
.eyebrow.left::after{background:linear-gradient(90deg,var(--gold),transparent)}
.eyebrow.center{justify-content:center}

.divider{
  display:flex;align-items:center;justify-content:center;
  gap:1.2rem;margin:1.8rem auto 2.4rem;color:var(--gold);
}
.divider::before,.divider::after{
  content:"";flex:1;max-width:120px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-light),var(--gold));
}
.divider::after{background:linear-gradient(90deg,var(--gold),var(--gold-light),transparent)}
.divider-glyph{font-size:1.4rem;letter-spacing:.5em;color:var(--saffron)}

.lead{font-size:1.18rem;line-height:1.75;color:var(--ink-soft);font-family:var(--serif);font-style:italic}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.7rem;
  font-family:var(--ui);font-weight:600;font-size:.78rem;
  letter-spacing:.24em;text-transform:uppercase;
  padding:1.1rem 2.2rem;border-radius:var(--r-sm);
  transition:all .4s var(--ease);
  position:relative;overflow:hidden;cursor:pointer;
  border:1px solid transparent;
}
.btn-primary{
  background:linear-gradient(135deg,var(--saffron) 0%,var(--saffron-deep) 100%);
  color:var(--ivory);
  border-color:var(--saffron-deep);
  box-shadow:0 10px 30px -12px rgba(232,119,34,.55);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 42px -14px rgba(232,119,34,.7);
  background:linear-gradient(135deg,var(--saffron-deep) 0%,var(--saffron) 100%);
}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-light) 0%,var(--gold) 50%,var(--gold-deep) 100%);
  color:var(--maroon-deep);
  border:none;
  box-shadow:0 10px 30px -12px rgba(201,162,74,.55);
}
.btn-gold:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 42px -14px rgba(201,162,74,.7);
}
.btn-outline{
  background:transparent;
  color:var(--maroon);
  border-color:var(--maroon);
}
.btn-outline:hover{background:var(--maroon);color:var(--ivory)}
.btn-ghost{
  background:transparent;
  color:var(--ivory);
  border-color:rgba(248,243,232,.45);
}
.btn-ghost:hover{background:var(--ivory);color:var(--maroon)}
.btn .arrow{display:inline-block;transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(6px)}

/* ===== HEADER ===== */
.site-header{
  position:sticky;top:0;z-index:90;
  background:rgba(250,246,236,.92);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line-gold);
  transition:background .3s, box-shadow .3s, padding .3s;
}
.site-header.scrolled{
  background:rgba(250,246,236,.98);
  box-shadow:0 6px 30px -18px rgba(13,8,4,.18);
}
.nav-bar{
  display:flex;align-items:center;justify-content:space-between;gap:1.2rem;
  padding:14px var(--pad);max-width:var(--max);margin:0 auto;
}
.brand{
  display:flex;align-items:center;gap:.85rem;
  text-decoration:none;color:var(--maroon-deep);
  flex-shrink:0;
}
.brand .crest{
  width:46px;height:46px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--gold-shimmer),var(--gold) 50%,var(--gold-deep));
  display:grid;place-items:center;
  color:var(--maroon-deep);
  font-family:var(--sanskrit);font-size:1.45rem;font-weight:700;
  box-shadow:
    inset 0 0 0 2px rgba(255,255,255,.45),
    0 6px 16px -8px rgba(201,162,74,.6);
  flex-shrink:0;
}
.brand-text{display:flex;flex-direction:column;line-height:1;white-space:nowrap}
.brand-name{
  font-family:var(--display);font-size:1rem;
  letter-spacing:.18em;font-weight:600;
  color:var(--maroon-deep);text-transform:uppercase;
}
.brand-sub{
  font-family:var(--ui);font-size:.6rem;
  letter-spacing:.32em;color:var(--saffron-deep);
  font-weight:600;text-transform:uppercase;margin-top:5px;
}

.nav-list{
  display:flex;gap:1rem;list-style:none;margin:0;padding:0;
  align-items:center;flex-wrap:nowrap;
}
.nav-list a{
  font-family:var(--ui);font-size:.7rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:500;
  position:relative;padding:6px 0;
  transition:color .3s;
  white-space:nowrap;
}
@media (min-width:1280px){
  .nav-list{gap:1.3rem}
  .nav-list a{font-size:.74rem;letter-spacing:.18em}
}
.nav-list a::after{
  content:"";position:absolute;left:50%;bottom:-3px;
  width:0;height:2px;
  background:linear-gradient(90deg,var(--gold-light),var(--saffron));
  transition:all .35s var(--ease);
  transform:translateX(-50%);
}
.nav-list a:hover, .nav-list a.active{color:var(--maroon-deep)}
.nav-list a:hover::after, .nav-list a.active::after{width:100%}

.nav-cta{display:flex;align-items:center;gap:.7rem;flex-shrink:0;flex-wrap:nowrap}
.nav-cta .btn{padding:.9rem 1.5rem;font-size:.74rem;letter-spacing:.22em;white-space:nowrap}
/* Hide CTA button below 1600px — at narrower widths the 8-item nav already fills the bar.
   The Visit menu link still gets users to plan a pilgrimage. */
@media (max-width:1599px){.nav-cta .btn{display:none}}

/* Language toggle pill — two separate buttons */
.lang-toggle{
  display:inline-flex;align-items:center;gap:.1rem;
  padding:.3rem .35rem;
  border:1px solid var(--gold);border-radius:var(--r-pill);
  background:rgba(250,246,236,.6);
  flex-shrink:0;line-height:1;
}
.lang-toggle button{
  display:inline-block;
  font-family:var(--ui);font-size:.7rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.42rem .75rem;border:0;border-radius:var(--r-pill);
  background:transparent;color:var(--ink-muted);
  cursor:pointer;transition:all .3s var(--ease);
}
.lang-toggle button:hover{color:var(--maroon-deep)}
.lang-toggle button.active{
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:var(--maroon-deep);
  font-weight:700;
  box-shadow:0 2px 8px -3px rgba(201,162,74,.6);
}
.lang-toggle .lt-bn{
  font-family:var(--bn-body);
  font-size:.85rem;
  letter-spacing:0;
  text-transform:none;
}

/* Mobile menu button */
.menu-toggle{
  display:none;
  width:42px;height:42px;
  background:transparent;border:0;
  position:relative;cursor:pointer;
  flex-shrink:0;
}
.menu-toggle span{
  position:absolute;left:10px;right:10px;height:2px;
  background:var(--maroon-deep);
  transition:all .3s var(--ease);
}
.menu-toggle span:nth-child(1){top:14px}
.menu-toggle span:nth-child(2){top:20px}
.menu-toggle span:nth-child(3){top:26px}
.menu-toggle.open span:nth-child(1){top:20px;transform:rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){top:20px;transform:rotate(-45deg)}

@media (max-width:1180px){
  .nav-list{
    position:fixed;top:74px;right:0;
    background:var(--ivory);
    flex-direction:column;
    padding:2rem 2.5rem;gap:1.4rem;
    border-left:1px solid var(--line-gold);
    box-shadow:var(--shadow-deep);
    transform:translateX(100%);
    transition:transform .4s var(--ease);
    height:calc(100vh - 74px);
    overflow-y:auto;
    width:min(80vw,360px);
    z-index:80;
  }
  .nav-list.open{transform:translateX(0)}
  .nav-list a{font-size:.85rem;padding:.4rem 0;letter-spacing:.18em}
  .menu-toggle{display:block}
  .nav-cta .btn{display:none}
}
@media (max-width:520px){
  .brand-text{display:none}
  .lang-toggle button{padding:.32rem .55rem;font-size:.62rem}
  .lang-toggle .lt-bn{font-size:.7rem}
}

/* ===== HERO ===== */
.hero{
  position:relative;
  min-height:88vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;isolation:isolate;
  padding:6rem 0 4rem;
}
.hero-bg{
  position:absolute;inset:0;z-index:-2;
}
.hero-bg img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 40%;
}
.hero-veil{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(90,10,22,.6), transparent 60%),
    linear-gradient(180deg, rgba(13,8,4,.45) 0%, rgba(90,10,22,.55) 70%, rgba(13,8,4,.85) 100%);
}
.hero-content{
  position:relative;
  text-align:center;
  max-width:920px;
  padding:0 var(--pad);
  color:var(--ivory);
}
.hero-content .eyebrow{color:var(--gold-light)}
.hero-content .eyebrow::before, .hero-content .eyebrow::after{
  background:linear-gradient(90deg,transparent,var(--gold-light));
}
.hero-content h1{
  color:var(--ivory);
  text-shadow:0 4px 30px rgba(0,0,0,.4);
  margin-bottom:1.2rem;
}
.hero-content h1 em{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  color:var(--gold-light);
  font-weight:400;
  margin-top:.3rem;
  letter-spacing:.02em;
}
.hero-sub{
  font-size:1.18rem;
  font-family:var(--serif);font-style:italic;
  color:rgba(250,246,236,.92);
  max-width:680px;margin:0 auto 2.2rem;
  line-height:1.7;
}
.hero-actions{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  margin-top:1rem;
}
.hero-meta{
  position:absolute;bottom:2rem;left:0;right:0;
  display:flex;justify-content:space-between;
  padding:0 var(--pad);
  font-family:var(--ui);font-size:.7rem;letter-spacing:.3em;
  text-transform:uppercase;
  color:rgba(250,246,236,.65);
}
.hero-meta .dot{color:var(--gold-light)}

@media (max-width:720px){
  .hero{min-height:80vh}
  .hero-meta{flex-direction:column;gap:.6rem;text-align:center}
}

/* ===== SUBHERO (page banners) ===== */
.subhero{
  position:relative;
  min-height:54vh;
  display:flex;align-items:center;
  overflow:hidden;isolation:isolate;
  padding:5rem 0 3rem;
}
.subhero .hero-bg{position:absolute;inset:0;z-index:-2}
.subhero .hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.subhero .hero-veil{
  position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg, rgba(13,8,4,.4) 0%, rgba(90,10,22,.6) 100%);
}
.subhero-inner{
  position:relative;color:var(--ivory);
  max-width:var(--max);margin:0 auto;
  padding:0 var(--pad);width:100%;
}
.subhero h1{
  color:var(--ivory);
  font-size:clamp(2rem,4vw,3.6rem);
}
.subhero h1 em{
  display:block;
  font-family:var(--serif);font-style:italic;
  color:var(--gold-light);font-weight:400;
}
.subhero p{
  color:rgba(250,246,236,.88);
  max-width:680px;font-size:1.1rem;
  font-family:var(--serif);font-style:italic;
}
.subhero .eyebrow{color:var(--gold-light)}
.subhero .eyebrow::before, .subhero .eyebrow::after{background:linear-gradient(90deg,transparent,var(--gold-light))}
.crumb{
  display:flex;align-items:center;gap:.6rem;
  font-family:var(--ui);font-size:.7rem;letter-spacing:.25em;
  text-transform:uppercase;color:rgba(250,246,236,.7);
  margin-bottom:1.5rem;
}
.crumb a{color:var(--gold-light);transition:color .3s}
.crumb a:hover{color:var(--ivory)}

/* ===== STATS ===== */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:2rem;
  padding:2rem 0;
}
.stat{
  text-align:center;
  padding:2rem 1rem;
  border:1px solid var(--line-gold);
  background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-warm) 100%);
  border-radius:var(--r-md);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.stat:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
}
.stat-num{
  font-family:var(--display);
  font-size:clamp(2.2rem, 4vw, 3.4rem);
  color:var(--maroon-deep);
  font-weight:600;
  letter-spacing:.04em;
}
.stat-num em{
  font-family:var(--sanskrit);
  font-size:.5em;
  color:var(--saffron);
  font-style:normal;
}
.stat-label{
  margin-top:.5rem;
  font-family:var(--ui);font-size:.7rem;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-muted);font-weight:600;
}
@media (max-width:880px){
  .stats{grid-template-columns:repeat(2,1fr);gap:1rem}
}

/* ===== SPLIT (two-column) ===== */
.split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:center;
}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split-media{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  border-radius:var(--r-md);
  background:var(--sand);
  box-shadow:var(--shadow-deep);
}
.split-media::before{
  content:"";
  position:absolute;inset:6px;
  border:1px solid rgba(201,162,74,.4);
  border-radius:var(--r-md);
  z-index:1;pointer-events:none;
}
.split-media img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .9s var(--ease);
}
.split-media:hover img{transform:scale(1.05)}
.split-text h2{margin-bottom:1.4rem}
.split-text .lead{margin-bottom:1.2rem}

@media (max-width:880px){
  .split{grid-template-columns:1fr}
  .split.reverse{direction:ltr}
  .split-media{aspect-ratio:5/4;max-height:480px}
}

/* ===== PILLARS (4-up icon cards) ===== */
.pillars{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;
  margin-top:3rem;
}
.pillar{
  text-align:center;padding:2.2rem 1.4rem;
  background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-warm) 100%);
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
  transition:all .4s var(--ease);position:relative;
  overflow:hidden;
}
.pillar::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(232,200,118,.15),transparent 70%);
  opacity:0;transition:opacity .5s;
}
.pillar:hover::before{opacity:1}
.pillar:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-soft);
  border-color:var(--gold);
}
.pillar-icon{
  width:64px;height:64px;
  margin:0 auto 1.2rem;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--gold-shimmer),var(--gold) 60%,var(--gold-deep));
  color:var(--maroon-deep);
  display:grid;place-items:center;
  font-family:var(--sanskrit);font-size:1.8rem;font-weight:700;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.4),0 8px 20px -8px rgba(201,162,74,.6);
  position:relative;z-index:1;
}
.pillar h3{font-size:1.15rem;margin-bottom:.7rem;letter-spacing:.05em;position:relative;z-index:1}
.pillar p{font-size:.95rem;color:var(--ink-soft);line-height:1.7;margin:0;position:relative;z-index:1}

@media (max-width:1000px){.pillars{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.pillars{grid-template-columns:1fr}}

/* ===== TEMPLE CARDS (peethas grid) ===== */
.peetha-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:2rem;
  margin-top:3rem;
}
.peetha-card{
  position:relative;
  background:var(--ivory);
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:all .5s var(--ease);
  display:flex;flex-direction:column;
}
.peetha-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-deep);
  border-color:var(--gold);
}
.peetha-card .img{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--sand);
}
.peetha-card .img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .9s var(--ease);
}
.peetha-card:hover .img img{transform:scale(1.06)}
.peetha-card .img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(13,8,4,.5));
}
.peetha-card .number{
  position:absolute;top:1rem;left:1rem;z-index:2;
  width:42px;height:42px;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:var(--maroon-deep);
  display:grid;place-items:center;
  font-family:var(--display);font-size:1.05rem;font-weight:700;
  border-radius:50%;
  box-shadow:0 4px 14px -4px rgba(201,162,74,.6);
}
.peetha-card .ornament{
  position:absolute;top:1rem;right:1rem;z-index:2;
  color:var(--gold-light);font-size:1rem;letter-spacing:.3em;
  text-shadow:0 2px 8px rgba(0,0,0,.5);
}
.peetha-card .body{
  padding:1.6rem 1.4rem 1.8rem;
  flex:1;display:flex;flex-direction:column;
}
.peetha-card .tag{
  font-family:var(--ui);font-size:.65rem;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--saffron-deep);font-weight:600;
  margin-bottom:.6rem;
}
.peetha-card h3{
  font-size:1.4rem;margin-bottom:.4rem;
  letter-spacing:.04em;
}
.peetha-card .deity{
  font-family:var(--serif);font-style:italic;
  color:var(--gold-deep);font-size:.98rem;
  margin-bottom:.9rem;line-height:1.5;
}
.peetha-card .desc{
  color:var(--ink-soft);font-size:.95rem;
  line-height:1.7;flex:1;margin-bottom:1.2rem;
}
.peetha-card .read-more{
  font-family:var(--ui);font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--maroon);font-weight:600;
  display:inline-flex;align-items:center;gap:.5rem;
  transition:gap .3s var(--ease), color .3s;
}
.peetha-card:hover .read-more{gap:.8rem;color:var(--saffron-deep)}

/* Detailed Peetha entries */
.peetha-detail{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:3rem;
  margin-bottom:5rem;
  padding-bottom:5rem;
  border-bottom:1px solid var(--line-gold);
}
.peetha-detail:last-child{border-bottom:0;margin-bottom:0;padding-bottom:0}
.peetha-detail.reverse{grid-template-columns:1fr 1.2fr}
.peetha-detail.reverse .pd-img{order:2}
.pd-img{
  position:relative;aspect-ratio:4/3;
  overflow:hidden;border-radius:var(--r-md);
  box-shadow:var(--shadow-deep);
}
.pd-img img{width:100%;height:100%;object-fit:cover;object-position:center}
.pd-img .badge{
  position:absolute;bottom:1rem;left:1rem;
  padding:.5rem 1rem;
  background:rgba(250,246,236,.95);
  color:var(--maroon-deep);
  font-family:var(--ui);font-size:.65rem;letter-spacing:.24em;
  text-transform:uppercase;font-weight:700;
  border-radius:var(--r-pill);
}
.pd-body h2{margin-bottom:.4rem;font-size:clamp(1.6rem,2.6vw,2.2rem)}
.pd-body .pd-deity{
  font-family:var(--serif);font-style:italic;
  color:var(--saffron-deep);font-size:1.05rem;
  margin-bottom:1.2rem;
}
.pd-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
  margin-top:1.6rem;list-style:none;padding:0;
}
.pd-grid li{
  padding:1rem 1.2rem;
  background:var(--ivory-warm);
  border-left:3px solid var(--gold);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
}
.pd-grid dt{
  font-family:var(--ui);font-size:.65rem;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-bottom:.3rem;
}
.pd-grid dd{
  margin:0;font-family:var(--serif);
  font-size:1rem;color:var(--ink);line-height:1.5;
}
@media (max-width:880px){
  .peetha-detail, .peetha-detail.reverse{grid-template-columns:1fr;gap:1.6rem}
  .peetha-detail.reverse .pd-img{order:0}
  .pd-grid{grid-template-columns:1fr}
}

/* ===== QUOTE BAND ===== */
.quote-band{
  background:linear-gradient(160deg,var(--maroon-deep) 0%,var(--maroon) 60%,var(--maroon-deep) 100%);
  color:var(--ivory);
  padding:clamp(60px, 8vw, 100px) var(--pad);
  text-align:center;
  position:relative;overflow:hidden;
}
.quote-band::before, .quote-band::after{
  content:"";position:absolute;
  width:480px;height:480px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(232,200,118,.15),transparent 70%);
  pointer-events:none;
}
.quote-band::before{top:-200px;left:-100px}
.quote-band::after{bottom:-200px;right:-100px}
.quote-band .lotus{
  color:var(--gold-light);font-size:1.2rem;
  letter-spacing:.5em;margin-bottom:1.5rem;
  position:relative;
}
.quote-band blockquote{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(1.3rem, 2.4vw, 1.9rem);
  line-height:1.6;
  max-width:900px;margin:0 auto 1.4rem;
  color:var(--ivory);
  position:relative;
}
.quote-band cite{
  font-family:var(--ui);font-size:.75rem;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-light);font-style:normal;
}

/* ===== CAROUSEL ===== */
.carousel-wrap{
  margin-top:3rem;
  overflow:hidden;
}
.carousel{
  display:grid;grid-auto-flow:column;
  grid-auto-columns:minmax(290px, 1fr);
  gap:1.6rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:.5rem .25rem 2rem;
  scrollbar-width:thin;scrollbar-color:var(--gold) transparent;
}
.carousel::-webkit-scrollbar{height:8px}
.carousel::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}
.carousel-card{
  scroll-snap-align:start;
  background:var(--ivory);
  border-radius:var(--r-md);
  border:1px solid var(--line-gold);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:all .4s var(--ease);
}
.carousel-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.carousel-card .img{aspect-ratio:4/3;overflow:hidden}
.carousel-card .img img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s var(--ease)}
.carousel-card:hover .img img{transform:scale(1.05)}
.carousel-card .body{padding:1.4rem;flex:1}
.carousel-card .tag{
  font-family:var(--ui);font-size:.65rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--saffron-deep);
  font-weight:600;display:block;margin-bottom:.6rem;
}
.carousel-card h3{font-size:1.15rem;margin-bottom:.5rem}
.carousel-card p{font-size:.92rem;color:var(--ink-soft);line-height:1.6;margin:0}

/* ===== TESTIMONIALS ===== */
.testimonials{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  margin-top:3rem;
}
.testimonial{
  padding:2rem 1.6rem;
  background:var(--ivory);
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
  position:relative;
  transition:all .4s var(--ease);
}
.testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.testimonial::before{
  content:"\201C";
  position:absolute;top:-15px;left:24px;
  font-family:var(--display);font-size:5rem;line-height:1;
  color:var(--gold);opacity:.4;
}
.testimonial blockquote{
  font-family:var(--serif);font-style:italic;
  font-size:1.02rem;color:var(--ink-soft);
  margin:0 0 1.4rem;line-height:1.7;
  position:relative;
}
.testimonial .who{
  display:flex;align-items:center;gap:.9rem;
}
.testimonial .who-avatar{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
  color:var(--maroon-deep);
  display:grid;place-items:center;
  font-family:var(--display);font-weight:700;font-size:1.1rem;
  flex-shrink:0;
}
.testimonial .who-meta{font-family:var(--ui);font-size:.85rem}
.testimonial .who-name{font-weight:600;color:var(--maroon-deep)}
.testimonial .who-loc{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-muted);margin-top:2px}

@media (max-width:1000px){.testimonials{grid-template-columns:1fr 1fr;gap:1.2rem}}
@media (max-width:680px){.testimonials{grid-template-columns:1fr}}

/* ===== TEAM (management) ===== */
.team-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem;
  margin-top:3rem;max-width:980px;margin-left:auto;margin-right:auto;
}
.team-card{
  background:var(--ivory);
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
  overflow:hidden;
  cursor:pointer;
  transition:all .4s var(--ease);
}
.team-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-deep);
  border-color:var(--gold);
}
.team-photo{
  aspect-ratio:4/5;overflow:hidden;
  background:var(--sand);
  position:relative;
}
.team-photo img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 25%;
  transition:transform .8s var(--ease);
}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(90,10,22,.4));
}
.team-body{
  padding:1.8rem 1.6rem 2rem;
  text-align:center;
}
.team-body h3{
  font-size:1.45rem;margin-bottom:.4rem;
}
.team-role{
  font-family:var(--serif);font-style:italic;
  color:var(--saffron-deep);font-size:.95rem;
  margin:0 0 1rem;line-height:1.5;
}
.view-profile{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ui);font-size:.7rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--maroon);font-weight:600;
  border:1px solid var(--gold);border-radius:var(--r-pill);
  padding:.5rem 1.1rem;transition:all .3s var(--ease);
}
.team-card:hover .view-profile{
  background:var(--gold);color:var(--maroon-deep);
}
@media (max-width:720px){.team-grid{grid-template-columns:1fr;gap:1.6rem}}

/* ===== PROFILE MODAL ===== */
.profile-modal{
  position:fixed;inset:0;z-index:200;
  background:rgba(13,8,4,.85);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  display:none;align-items:flex-start;justify-content:center;
  padding:2rem 1rem;overflow-y:auto;
  opacity:0;transition:opacity .3s ease;
}
.profile-modal.open{display:flex;opacity:1}
.profile-panel{
  background:var(--ivory);
  max-width:920px;width:100%;
  border:1px solid var(--gold);
  border-radius:var(--r-md);
  position:relative;
  box-shadow:var(--shadow-deep);
  margin:2rem auto;
  overflow:hidden;
  transform:translateY(20px);
  transition:transform .4s var(--ease-out);
}
.profile-modal.open .profile-panel{transform:translateY(0)}
.profile-close{
  position:absolute;top:1rem;right:1rem;
  width:40px;height:40px;border-radius:50%;
  background:rgba(250,246,236,.95);
  border:1px solid var(--line-gold);
  font-size:1.2rem;color:var(--maroon-deep);
  display:grid;place-items:center;cursor:pointer;
  z-index:5;transition:all .3s;
}
.profile-close:hover{background:var(--maroon);color:var(--ivory);border-color:var(--maroon)}
.profile-hero{
  display:grid;grid-template-columns:280px 1fr;
  gap:2rem;padding:2.4rem;
  background:linear-gradient(135deg,var(--maroon-deep) 0%,var(--maroon) 100%);
  color:var(--ivory);
  align-items:center;
}
.profile-portrait{
  aspect-ratio:1;border-radius:50%;
  overflow:hidden;border:3px solid var(--gold);
  box-shadow:0 12px 40px -10px rgba(0,0,0,.5);
}
.profile-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 25%}
.profile-head .eyebrow{color:var(--gold-light)}
.profile-head .eyebrow::before, .profile-head .eyebrow::after{background:linear-gradient(90deg,transparent,var(--gold-light))}
.profile-head h2{color:var(--ivory);margin:.4rem 0 .8rem;font-size:clamp(1.6rem, 2.4vw, 2.2rem)}
.profile-titles{
  font-family:var(--serif);font-style:italic;
  color:var(--gold-light);font-size:1.05rem;
  margin-bottom:1rem;line-height:1.5;
}
.profile-roles{display:flex;flex-wrap:wrap;gap:.5rem}
.profile-roles span{
  padding:.3rem .8rem;
  background:rgba(250,246,236,.12);
  border:1px solid rgba(232,200,118,.3);
  border-radius:var(--r-pill);
  font-family:var(--ui);font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold-light);
}
.profile-body{padding:2.4rem 2.6rem}
.profile-intro{
  font-family:var(--serif);font-size:1.05rem;
  line-height:1.85;color:var(--ink-soft);
  margin-bottom:2rem;
  padding-bottom:1.6rem;border-bottom:1px solid var(--line-gold);
}
.profile-intro a{color:var(--maroon);border-bottom:1px solid var(--gold);font-weight:600}
.profile-section{margin-bottom:1.8rem}
.profile-section h3{
  font-size:1.05rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold-deep);font-family:var(--ui);font-weight:700;
  margin-bottom:1rem;
}
.profile-bullets{list-style:none;padding:0;margin:0;display:grid;gap:.9rem}
.profile-bullets li{
  padding:.9rem 1.1rem;
  border-left:3px solid var(--gold);
  background:var(--ivory-warm);border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-size:.96rem;line-height:1.65;color:var(--ink);
}
.profile-bullets li strong{color:var(--maroon-deep);font-weight:600}
.torus-table{display:grid;grid-template-columns:200px 1fr;gap:.7rem 1.4rem;font-size:.92rem}
.torus-table .domain{
  font-family:var(--ui);font-weight:700;font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--saffron-deep);align-self:start;padding-top:.2rem;
}
.torus-table .entities{color:var(--ink-soft);line-height:1.6}
.profile-foot{
  padding:1.6rem 2.6rem;
  background:var(--ivory-warm);
  border-top:1px solid var(--line-gold);
  text-align:center;
}
.profile-foot .nm{font-family:var(--display);font-size:1.1rem;color:var(--maroon-deep);font-weight:600}
.profile-foot .ti{font-family:var(--serif);font-style:italic;color:var(--ink-soft);margin:.4rem 0 .8rem}
.profile-foot .links{font-family:var(--ui);font-size:.85rem;color:var(--ink-soft);display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem}
.profile-foot .links a{color:var(--maroon);font-weight:600}
.profile-foot .links a:hover{color:var(--saffron-deep)}

@media (max-width:720px){
  .profile-hero{grid-template-columns:1fr;text-align:center;padding:1.8rem}
  .profile-portrait{max-width:200px;margin:0 auto}
  .profile-roles{justify-content:center}
  .profile-body{padding:1.8rem}
  .torus-table{grid-template-columns:1fr;gap:.3rem}
  .torus-table .domain{padding-top:.8rem}
}

/* ===== MAP PREVIEW (interactive) ===== */
.map-preview{
  background:linear-gradient(160deg,var(--maroon-deep) 0%,var(--maroon) 100%);
  border-radius:var(--r-md);overflow:hidden;
  display:grid;grid-template-columns:1.5fr 1fr;
  min-height:520px;
  margin-top:3rem;
}
.map-svg{position:relative;background:radial-gradient(ellipse at center,#1c2c47 0%,#0d1a2e 100%)}
.map-svg svg{width:100%;height:100%;display:block}
.map-pin{cursor:pointer}
.map-pin .pulse{fill:var(--gold);opacity:0;animation:pulse 2.4s infinite}
.map-pin .ring{fill:none;stroke:var(--gold);stroke-width:1;opacity:.55;transition:all .3s}
.map-pin .core{fill:var(--saffron);transition:all .3s}
.map-pin:hover .ring, .map-pin.active .ring{stroke:var(--gold-light);opacity:1;stroke-width:2}
.map-pin:hover .core, .map-pin.active .core{fill:var(--gold-light);transform-origin:center}
.map-svg .label{
  font-family:'Inter',sans-serif;font-size:9px;
  fill:rgba(232,200,118,.55);
  letter-spacing:1.5px;text-transform:uppercase;
  pointer-events:none;
}
@keyframes pulse{0%{opacity:.55;r:8}100%{opacity:0;r:36}}

.map-info{
  padding:2.5rem 2rem;color:var(--ivory);
  display:flex;flex-direction:column;
}
.map-info .tag{
  font-family:var(--ui);font-size:.7rem;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold-light);font-weight:600;
  margin-bottom:.7rem;
}
.map-info h3{color:var(--ivory);font-size:1.6rem;margin-bottom:.4rem}
.map-info .sub{
  font-family:var(--serif);font-style:italic;
  color:var(--gold-light);font-size:1rem;margin-bottom:1.2rem;
}
.map-info dl{display:grid;grid-template-columns:auto 1fr;gap:.6rem 1rem;font-size:.92rem}
.map-info dt{
  font-family:var(--ui);font-size:.65rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold-light);font-weight:600;
}
.map-info dd{margin:0;color:rgba(250,246,236,.92);line-height:1.5}
.pin-list{
  display:flex;flex-wrap:wrap;gap:.5rem;
  margin-top:auto;padding-top:1.4rem;
  border-top:1px solid rgba(232,200,118,.2);
}
.pin-list button{
  font-family:var(--ui);font-size:.7rem;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.5rem .9rem;
  background:transparent;color:rgba(250,246,236,.7);
  border:1px solid rgba(232,200,118,.3);
  border-radius:var(--r-pill);cursor:pointer;
  transition:all .3s;
}
.pin-list button:hover, .pin-list button.active{
  background:var(--gold);color:var(--maroon-deep);border-color:var(--gold);
}
@media (max-width:880px){
  .map-preview{grid-template-columns:1fr;min-height:auto}
  .map-svg{aspect-ratio:6/7}
}

/* ===== TIMELINE ===== */
.timeline{
  position:relative;padding-left:2rem;
  margin-top:2rem;
}
.timeline::before{
  content:"";position:absolute;top:0;bottom:0;left:7px;
  width:2px;background:linear-gradient(180deg,var(--gold-light),var(--gold),transparent);
}
.tl-item{
  position:relative;padding-bottom:1.8rem;
}
.tl-item::before{
  content:"";position:absolute;top:.4rem;left:-2rem;
  width:16px;height:16px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
  box-shadow:0 0 0 4px var(--ivory);
}
.tl-item .day{
  display:inline-block;
  font-family:var(--ui);font-size:.65rem;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--saffron-deep);font-weight:700;margin-bottom:.3rem;
}
.tl-item h4{
  font-family:var(--display);font-size:1.1rem;
  letter-spacing:.04em;text-transform:none;
  color:var(--maroon-deep);margin:0 0 .5rem;
}
.tl-item p{font-size:.95rem;color:var(--ink-soft);line-height:1.65;margin:0}

/* ===== ESSENTIALS / NUMBERED CARDS ===== */
.essentials{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;
  margin-top:2.4rem;
}
.essential{
  position:relative;
  padding:2rem 1.6rem 1.8rem;
  background:linear-gradient(180deg,var(--ivory),var(--ivory-warm));
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
  transition:all .4s var(--ease);
}
.essential:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--gold)}
.essential .num{
  font-family:var(--display);
  font-size:2.4rem;font-weight:700;
  color:var(--gold);
  background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:.5rem;line-height:1;
}
.essential h3{font-size:1.15rem;margin-bottom:.6rem;letter-spacing:.04em}
.essential p{font-size:.95rem;color:var(--ink-soft);line-height:1.65;margin:0}
@media (max-width:880px){.essentials{grid-template-columns:1fr}}

/* ===== FAQ ===== */
.faq{display:grid;gap:.8rem;margin-top:2rem;max-width:880px;margin-left:auto;margin-right:auto}
.faq-item{
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);overflow:hidden;
  background:var(--ivory);
}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:1.2rem 1.4rem;
  background:transparent;border:0;
  text-align:left;cursor:pointer;
  font-family:var(--display);font-size:1.05rem;font-weight:500;
  color:var(--maroon-deep);letter-spacing:.03em;
}
.faq-q .plus{
  font-size:1.4rem;color:var(--gold);transition:transform .3s;
  flex-shrink:0;margin-left:1rem;
}
.faq-item.open .faq-q .plus{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .5s var(--ease);
}
.faq-item.open .faq-a{max-height:600px}
.faq-a-inner{
  padding:0 1.4rem 1.4rem;
  color:var(--ink-soft);font-size:.98rem;line-height:1.75;
}

/* ===== GALLERY ===== */
.gallery-filters{
  display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
  margin-bottom:2.4rem;
}
.gallery-filters button{
  font-family:var(--ui);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;font-weight:600;
  padding:.6rem 1.2rem;
  border:1px solid var(--gold);border-radius:var(--r-pill);
  background:transparent;color:var(--ink-soft);
  cursor:pointer;transition:all .3s;
}
.gallery-filters button:hover, .gallery-filters button.active{
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:var(--maroon-deep);
  border-color:var(--gold);
}
.gallery{
  columns:4 220px;
  column-gap:1rem;
  margin-top:1rem;
}
.gallery-item{
  break-inside:avoid;
  margin:0 0 1rem;
  border-radius:var(--r-md);overflow:hidden;
  position:relative;cursor:pointer;
  background:var(--sand);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.gallery-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.gallery-item img{
  width:100%;height:auto;display:block;
  transition:transform .9s var(--ease), filter .4s;
}
.gallery-item:hover img{transform:scale(1.04);filter:brightness(.85)}
.gallery-item .cap{
  position:absolute;left:0;right:0;bottom:0;
  padding:.9rem 1rem .8rem;
  background:linear-gradient(180deg,transparent,rgba(13,8,4,.78));
  color:var(--ivory);
  font-family:var(--ui);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;font-weight:600;
  opacity:0;transform:translateY(8px);
  transition:all .4s var(--ease);pointer-events:none;
}
.gallery-item:hover .cap{opacity:1;transform:translateY(0)}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:300;
  background:rgba(13,8,4,.94);
  display:none;align-items:center;justify-content:center;
  padding:5vh 4vw;
}
.lightbox.open{display:flex}
.lightbox img{max-width:100%;max-height:90vh;border-radius:var(--r-md);box-shadow:0 30px 80px -10px rgba(0,0,0,.6)}
.lightbox-close{
  position:absolute;top:1.2rem;right:1.2rem;
  width:48px;height:48px;border-radius:50%;
  background:rgba(250,246,236,.95);
  color:var(--maroon-deep);font-size:1.5rem;
  border:0;cursor:pointer;
  display:grid;place-items:center;
  transition:all .3s;
}
.lightbox-close:hover{background:var(--maroon);color:var(--ivory)}

/* ===== CONTACT ===== */
.contact-grid{
  display:grid;grid-template-columns:1fr 1.3fr;gap:2.5rem;
  margin-top:3rem;
}
.contact-info{
  padding:2.4rem 2rem;
  background:linear-gradient(160deg,var(--maroon-deep),var(--maroon));
  color:var(--ivory);
  border-radius:var(--r-md);
  position:relative;overflow:hidden;
}
.contact-info::before{
  content:"";position:absolute;top:-100px;right:-100px;
  width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,200,118,.18),transparent 70%);
}
.contact-info .eyebrow{color:var(--gold-light);position:relative}
.contact-info .eyebrow::before, .contact-info .eyebrow::after{background:linear-gradient(90deg,transparent,var(--gold-light))}
.contact-info h3{color:var(--ivory);position:relative}
.contact-info > p{color:rgba(250,246,236,.9);font-family:var(--serif);font-style:italic;line-height:1.7;margin-bottom:2rem;position:relative}
.contact-row{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1rem 0;
  border-top:1px solid rgba(232,200,118,.2);
  position:relative;
}
.contact-row:first-of-type{border-top:0}
.contact-row .ic{
  width:36px;height:36px;border-radius:50%;
  background:rgba(232,200,118,.15);
  color:var(--gold-light);
  display:grid;place-items:center;font-size:1rem;
  flex-shrink:0;
}
.contact-row .lbl{
  font-family:var(--ui);font-size:.65rem;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold-light);font-weight:600;margin-bottom:.2rem;
}
.contact-row a, .contact-row span{color:var(--ivory);font-family:var(--serif);font-size:1.02rem}
.contact-row a:hover{color:var(--gold-light)}

.contact-form{
  padding:2.4rem 2rem;
  background:var(--ivory);
  border:1px solid var(--line-gold);
  border-radius:var(--r-md);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{
  font-family:var(--ui);font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;
}
.field input, .field select, .field textarea{
  width:100%;
  padding:.95rem 1rem;
  border:1px solid var(--line-gold);
  border-radius:var(--r-sm);
  background:var(--ivory-warm);
  font-family:var(--serif);font-size:1rem;
  color:var(--ink);
  transition:border-color .3s, background .3s;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none;border-color:var(--gold);
  background:var(--ivory);
}
.field textarea{min-height:140px;resize:vertical}
.form-msg{
  margin-top:1.2rem;padding:1rem 1.2rem;
  background:rgba(201,162,74,.16);
  border-left:3px solid var(--gold);
  color:var(--maroon-deep);font-style:italic;
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  display:none;
}
.form-msg.show{display:block;animation:slideDown .4s var(--ease)}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:820px){
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}

/* ===== FOOTER ===== */
.site-footer{
  background:linear-gradient(180deg,var(--maroon-deep) 0%,#2a0508 100%);
  color:rgba(250,246,236,.85);
  padding:5rem 0 0;
  position:relative;
  overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--gold-deep) 0%,var(--gold-light) 50%,var(--gold-deep) 100%);
}
.footer-top{
  display:grid;grid-template-columns:1.3fr .9fr .9fr 1.1fr;gap:2.5rem;
  padding-bottom:3rem;
}
.footer-brand .brand{margin-bottom:1.2rem}
.footer-brand .brand-name{color:var(--ivory)}
.footer-brand .brand-sub{color:var(--gold-light)}
.footer-brand p{color:rgba(250,246,236,.7);font-size:.95rem;line-height:1.7;margin-bottom:1.6rem}
.socials{display:flex;gap:.7rem}
.socials a{
  width:40px;height:40px;border-radius:50%;
  background:rgba(232,200,118,.1);
  border:1px solid rgba(232,200,118,.25);
  display:grid;place-items:center;
  color:var(--gold-light);
  transition:all .3s;
}
.socials a:hover{
  background:var(--gold);color:var(--maroon-deep);
  border-color:var(--gold);transform:translateY(-2px);
}
.socials svg{width:18px;height:18px;fill:currentColor}

.footer-col h4{
  color:var(--gold-light);
  font-family:var(--ui);font-size:.78rem;
  letter-spacing:.28em;text-transform:uppercase;
  margin-bottom:1.2rem;
}
.footer-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
.footer-col a{
  color:rgba(250,246,236,.7);font-family:var(--serif);font-size:1rem;
  transition:color .3s, padding .3s;
}
.footer-col a:hover{color:var(--gold-light);padding-left:6px}
.footer-contact div, .footer-contact a{
  display:block;font-family:var(--serif);font-size:1rem;
  margin-bottom:.5rem;color:rgba(250,246,236,.7);
}
.footer-contact a:hover{color:var(--gold-light)}

.footer-bottom{
  padding:1.6rem 0;
  border-top:1px solid rgba(232,200,118,.18);
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
  font-family:var(--ui);font-size:.78rem;
  color:rgba(250,246,236,.55);
}
.footer-credit a{color:var(--gold-light);font-weight:600}
.footer-credit a:hover{color:var(--ivory)}

@media (max-width:980px){.footer-top{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:540px){
  .footer-top{grid-template-columns:1fr;gap:1.6rem}
  .footer-bottom{flex-direction:column;text-align:center}
}

/* ===== SCROLL REVEAL ===== */
/* Reveal elements are always visible. JS adds an enter animation as enhancement only. */
.reveal{opacity:1;transform:translateY(0);transition:opacity .9s var(--ease),transform .9s var(--ease)}
@keyframes revealUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.reveal.animating{animation:revealUp .9s var(--ease) both}
.delay-1{animation-delay:.08s;transition-delay:.08s}
.delay-2{animation-delay:.16s;transition-delay:.16s}
.delay-3{animation-delay:.24s;transition-delay:.24s}
.delay-4{animation-delay:.32s;transition-delay:.32s}

/* ===== ACCESSIBILITY ===== */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
}

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