/* ============================================
   PUSHPADANTA BHAGWAN — SANCTUM LUMEN
   A premium spiritual heritage portal
   ============================================ */

:root{
  --ivory:#F8F4ED;
  --ivory-2:#F2EBDD;
  --sand:#E5D9C4;
  --sand-2:#D8C9AC;
  --gold:#C9A964;
  --gold-deep:#A8893F;
  --gold-soft:#E8D5A8;
  --maroon:#6B1F2A;
  --maroon-deep:#4A1219;
  --sage:#8B9D7C;
  --charcoal:#2A2520;
  --charcoal-soft:#4A4138;
  --line:rgba(42,37,32,.12);
  --line-gold:rgba(201,169,100,.35);
  --shadow-sm:0 4px 14px rgba(42,37,32,.06);
  --shadow-md:0 12px 40px rgba(42,37,32,.10);
  --shadow-lg:0 30px 80px rgba(42,37,32,.16);
  --r-sm:6px;
  --r-md:14px;
  --r-lg:24px;
  --ease:cubic-bezier(.65,.05,.36,1);
  --serif:"Cormorant Garamond",Georgia,serif;
  --display:"Cinzel","Cormorant Garamond",Georgia,serif;
  --body:"Inter","Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  font-size:16px;
  line-height:1.65;
  color:var(--charcoal);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .35s var(--ease)}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}
input,textarea,select{font-family:inherit;color:inherit}
ul{list-style:none}

/* Selection */
::selection{background:var(--gold);color:var(--ivory)}

/* ===== TYPOGRAPHY ===== */
.eyebrow{
  font-family:var(--display);
  font-size:11px;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--gold-deep);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before,.eyebrow::after{
  content:"";display:block;width:34px;height:1px;background:var(--gold);
}
.eyebrow.left::after{display:none}
.eyebrow.left::before{width:24px}

h1,h2,h3,h4{font-family:var(--display);font-weight:500;color:var(--charcoal);line-height:1.15;letter-spacing:.01em}
.display{
  font-family:var(--serif);
  font-weight:400;
  font-style:italic;
  font-size:clamp(2.6rem,6.5vw,5.5rem);
  line-height:1.05;
  letter-spacing:-.005em;
}
.h-xl{font-size:clamp(2.4rem,5vw,4rem)}
.h-lg{font-size:clamp(1.9rem,3.6vw,2.85rem)}
.h-md{font-size:clamp(1.4rem,2.4vw,1.85rem)}

.lead{
  font-family:var(--serif);
  font-size:clamp(1.15rem,1.7vw,1.4rem);
  line-height:1.55;
  color:var(--charcoal-soft);
  font-weight:400;
}

p{color:var(--charcoal-soft)}

.sanskrit{
  font-family:var(--serif);
  font-style:italic;
  color:var(--maroon);
  letter-spacing:.02em;
}

/* ===== LAYOUT ===== */
.wrap{width:100%;max-width:1400px;margin:0 auto;padding:0 40px}
.wrap-narrow{max-width:1100px;margin:0 auto;padding:0 40px}
.wrap-tight{max-width:880px;margin:0 auto;padding:0 40px}
section{padding:120px 0;position:relative}
section.tight{padding:80px 0}

@media(max-width:768px){
  .wrap,.wrap-narrow,.wrap-tight{padding:0 22px}
  section{padding:80px 0}
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 34px;
  font-family:var(--display);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:500;
  border-radius:2px;
  transition:all .45s var(--ease);
  position:relative;
  overflow:hidden;
}
.btn-primary{background:var(--charcoal);color:var(--ivory)}
.btn-primary:hover{background:var(--maroon);transform:translateY(-2px);box-shadow:0 12px 28px rgba(107,31,42,.28)}
.btn-gold{background:var(--gold);color:var(--charcoal)}
.btn-gold:hover{background:var(--gold-deep);color:var(--ivory);transform:translateY(-2px)}
.btn-outline{border:1px solid var(--charcoal);color:var(--charcoal);background:transparent}
.btn-outline:hover{background:var(--charcoal);color:var(--ivory)}
.btn-ghost{padding:14px 0;border-bottom:1px solid var(--gold);color:var(--charcoal)}
.btn-ghost:hover{color:var(--maroon);border-color:var(--maroon)}
.btn .arrow{display:inline-block;transition:transform .4s var(--ease)}
.btn:hover .arrow{transform:translateX(6px)}

/* ===== NAVIGATION ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:22px 40px;
  background:rgba(248,244,237,.85);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid transparent;
  transition:all .45s var(--ease);
}
.nav.scrolled{background:rgba(248,244,237,.96);border-bottom-color:var(--line);padding:14px 40px;box-shadow:0 4px 24px rgba(42,37,32,.06)}
.nav-inner{max-width:1500px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:14px}
.brand-mark{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));
  display:grid;place-items:center;
  position:relative;
  box-shadow:0 4px 14px rgba(201,169,100,.35);
}
.brand-mark svg{width:26px;height:26px;color:var(--maroon)}
.brand-mark::before{content:"";position:absolute;inset:-4px;border:1px solid var(--gold);border-radius:50%;opacity:.4}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-family:var(--display);font-size:14px;letter-spacing:.18em;color:var(--charcoal);font-weight:500;text-transform:uppercase}
.brand-sub{font-family:var(--serif);font-size:11px;letter-spacing:.22em;color:var(--gold-deep);margin-top:5px;text-transform:uppercase}

.nav-menu{display:flex;align-items:center;gap:36px}
.nav-link{
  font-family:var(--display);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--charcoal);
  position:relative;
  padding:6px 0;
}
.nav-link::after{
  content:"";position:absolute;left:50%;bottom:0;
  width:0;height:1px;background:var(--gold);
  transition:all .4s var(--ease);transform:translateX(-50%);
}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link.active{color:var(--maroon)}

.nav-toggle{display:none;width:30px;height:30px;flex-direction:column;justify-content:center;gap:6px}
.nav-toggle span{display:block;height:1.5px;background:var(--charcoal);transition:all .35s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

@media(max-width:1024px){
  .nav,.nav.scrolled{padding:18px 22px}
  .nav-toggle{display:flex}
  .nav-menu{
    position:fixed;top:0;right:-100%;
    width:min(360px,86vw);height:100vh;
    background:var(--ivory);
    flex-direction:column;justify-content:center;
    gap:22px;
    box-shadow:-30px 0 80px rgba(42,37,32,.18);
    transition:right .55s var(--ease);
    padding:60px 40px;
  }
  .nav-menu.open{right:0}
  .nav-link{font-size:14px;letter-spacing:.2em}
}

/* ===== PAGE HEADER (interior pages) ===== */
.page-header{
  padding:180px 0 90px;
  text-align:center;
  position:relative;
  background:linear-gradient(180deg,var(--ivory-2) 0%,var(--ivory) 100%);
  border-bottom:1px solid var(--line-gold);
  overflow:hidden;
}
.page-header::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'%3E%3Cg fill='none' stroke='%23C9A964' stroke-width='.5' opacity='.18'%3E%3Ccircle cx='300' cy='300' r='80'/%3E%3Ccircle cx='300' cy='300' r='140'/%3E%3Ccircle cx='300' cy='300' r='200'/%3E%3Ccircle cx='300' cy='300' r='260'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
  opacity:.6;pointer-events:none;
}
.page-header > *{position:relative}
.page-title{font-family:var(--serif);font-style:italic;font-size:clamp(2.8rem,6vw,5rem);font-weight:400;margin:24px 0 18px;line-height:1.05}
.page-sub{max-width:640px;margin:0 auto;color:var(--charcoal-soft);font-family:var(--serif);font-size:1.2rem;line-height:1.5}
.crumbs{font-family:var(--display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);margin-top:32px}
.crumbs a:hover{color:var(--maroon)}
.crumbs span{margin:0 12px;opacity:.5}

/* ===== FOOTER ===== */
.footer{
  background:var(--charcoal);
  color:var(--ivory);
  padding:90px 0 30px;
  position:relative;
  overflow:hidden;
}
.footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:60px;margin-bottom:70px}
.footer h4{font-family:var(--display);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;font-weight:500}
.footer p,.footer a{color:rgba(248,244,237,.72);font-size:14px;line-height:1.85}
.footer a:hover{color:var(--gold)}
.footer-brand .brand-mark{margin-bottom:20px}
.footer-brand-name{font-family:var(--display);font-size:18px;letter-spacing:.18em;color:var(--ivory);text-transform:uppercase;margin-bottom:6px}
.footer-brand-sub{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:14px;margin-bottom:16px}

.footer-links{display:flex;flex-direction:column;gap:12px}
.footer-contact a{display:block;margin-bottom:10px}

.socials{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.social{
  width:40px;height:40px;
  min-width:40px;min-height:40px;
  border-radius:50%;
  border:1px solid rgba(201,169,100,.35);
  display:inline-block;
  transition:background .35s var(--ease),border-color .35s var(--ease),transform .35s var(--ease);
  flex:0 0 auto;
  padding:0;
  box-sizing:border-box;
  background-color:transparent;
  background-repeat:no-repeat;
  background-position:center center;
  background-size:15px 15px;
  font-size:0;
  line-height:0;
  text-indent:-9999px;
}
.social:hover{background-color:var(--gold);border-color:var(--gold);transform:translateY(-3px)}
.social svg{display:none !important}

.social-fb{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23C9A964'%3E%3Cpath d='M13.5 21.5v-8.4h2.8l.4-3.3h-3.2V7.7c0-.95.3-1.6 1.65-1.6h1.75V3.2c-.3-.04-1.3-.13-2.5-.13-2.5 0-4.2 1.52-4.2 4.32v2.4H7.4v3.3h2.7v8.4h3.4z'/%3E%3C/svg%3E")}
.social-ig{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C9A964' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='4' width='16' height='16' rx='4'/%3E%3Ccircle cx='12' cy='12' r='3.5'/%3E%3Ccircle cx='17' cy='7' r='0.7' fill='%23C9A964' stroke='none'/%3E%3C/svg%3E")}
.social-li{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23C9A964'%3E%3Cpath d='M5.4 3.5a2 2 0 110 4 2 2 0 010-4zM3.7 9h3.4v11.5H3.7V9zM9.4 9h3.2v1.6c.5-.85 1.55-1.75 3.2-1.75 3.4 0 4 2.25 4 5.15v6.5h-3.4v-5.75c0-1.4-.05-3.15-1.95-3.15-1.95 0-2.25 1.5-2.25 3.05v5.85H9.4V9z'/%3E%3C/svg%3E")}
.social-yt{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23C9A964'%3E%3Cpath d='M21.5 7.5c-.2-1.1-1-2-2.1-2.2C17.4 5 12 5 12 5s-5.4 0-7.4.3c-1.1.2-1.9 1.1-2.1 2.2C2.2 9.4 2.2 12 2.2 12s0 2.6.3 4.5c.2 1.1 1 2 2.1 2.2 2 .3 7.4.3 7.4.3s5.4 0 7.4-.3c1.1-.2 1.9-1.1 2.1-2.2.3-1.9.3-4.5.3-4.5s0-2.6-.3-4.5zM10 15.2V8.8L15.5 12 10 15.2z'/%3E%3C/svg%3E")}
.social-x{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23C9A964'%3E%3Cpath d='M17.4 3.5h2.6l-5.7 6.5L21 20.5h-5.2l-4.1-5.3-4.7 5.3H4.4l6.1-7L3.4 3.5h5.4l3.7 4.9 4.9-4.9zm-.9 15.4h1.4L7.6 5h-1.5l10.4 13.9z'/%3E%3C/svg%3E")}

.social-fb:hover{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232A2520'%3E%3Cpath d='M13.5 21.5v-8.4h2.8l.4-3.3h-3.2V7.7c0-.95.3-1.6 1.65-1.6h1.75V3.2c-.3-.04-1.3-.13-2.5-.13-2.5 0-4.2 1.52-4.2 4.32v2.4H7.4v3.3h2.7v8.4h3.4z'/%3E%3C/svg%3E")}
.social-ig:hover{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232A2520' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='4' width='16' height='16' rx='4'/%3E%3Ccircle cx='12' cy='12' r='3.5'/%3E%3Ccircle cx='17' cy='7' r='0.7' fill='%232A2520' stroke='none'/%3E%3C/svg%3E")}
.social-li:hover{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232A2520'%3E%3Cpath d='M5.4 3.5a2 2 0 110 4 2 2 0 010-4zM3.7 9h3.4v11.5H3.7V9zM9.4 9h3.2v1.6c.5-.85 1.55-1.75 3.2-1.75 3.4 0 4 2.25 4 5.15v6.5h-3.4v-5.75c0-1.4-.05-3.15-1.95-3.15-1.95 0-2.25 1.5-2.25 3.05v5.85H9.4V9z'/%3E%3C/svg%3E")}
.social-yt:hover{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232A2520'%3E%3Cpath d='M21.5 7.5c-.2-1.1-1-2-2.1-2.2C17.4 5 12 5 12 5s-5.4 0-7.4.3c-1.1.2-1.9 1.1-2.1 2.2C2.2 9.4 2.2 12 2.2 12s0 2.6.3 4.5c.2 1.1 1 2 2.1 2.2 2 .3 7.4.3 7.4.3s5.4 0 7.4-.3c1.1-.2 1.9-1.1 2.1-2.2.3-1.9.3-4.5.3-4.5s0-2.6-.3-4.5zM10 15.2V8.8L15.5 12 10 15.2z'/%3E%3C/svg%3E")}
.social-x:hover{background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%232A2520'%3E%3Cpath d='M17.4 3.5h2.6l-5.7 6.5L21 20.5h-5.2l-4.1-5.3-4.7 5.3H4.4l6.1-7L3.4 3.5h5.4l3.7 4.9 4.9-4.9zm-.9 15.4h1.4L7.6 5h-1.5l10.4 13.9z'/%3E%3C/svg%3E")}

.footer-bottom{
  padding-top:30px;border-top:1px solid rgba(248,244,237,.1);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;
}
.footer-bottom p{font-size:12px;letter-spacing:.06em}
.creaa-link{font-family:var(--display);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold)}
.creaa-link:hover{color:var(--ivory)}

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

/* ===== PASSCODE GATE ===== */
html.authed .gate{display:none !important}
html.locked{overflow:hidden}
.gate{
  position:fixed;inset:0;z-index:9999;
  background:radial-gradient(ellipse at center,#1a1410 0%,#0a0805 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s var(--ease),visibility .8s var(--ease);
}
.gate.hidden{opacity:0;visibility:hidden;pointer-events:none}
.gate-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(201,169,100,.08),transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(107,31,42,.10),transparent 50%);
  overflow:hidden;
}
.gate-bg::before,.gate-bg::after{
  content:"";position:absolute;border-radius:50%;
  border:1px solid rgba(201,169,100,.08);
}
.gate-bg::before{width:600px;height:600px;top:50%;left:50%;transform:translate(-50%,-50%);animation:slowSpin 80s linear infinite}
.gate-bg::after{width:900px;height:900px;top:50%;left:50%;transform:translate(-50%,-50%);animation:slowSpin 120s linear infinite reverse}

@keyframes slowSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}

.gate-mandala{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:min(80vmin,800px);height:min(80vmin,800px);
  opacity:.18;pointer-events:none;
  animation:slowSpin 240s linear infinite;
}

.gate-card{
  position:relative;z-index:2;
  text-align:center;
  width:min(520px,90vw);
  padding:60px 50px;
  background:rgba(248,244,237,.04);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(201,169,100,.18);
  border-radius:4px;
  box-shadow:0 60px 120px rgba(0,0,0,.5);
}
.gate-mark{
  width:78px;height:78px;
  margin:0 auto 30px;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(201,169,100,.25),rgba(201,169,100,.08));
  display:grid;place-items:center;
  position:relative;
}
.gate-mark::before,.gate-mark::after{
  content:"";position:absolute;border-radius:50%;border:1px solid rgba(201,169,100,.3);
}
.gate-mark::before{inset:-8px}
.gate-mark::after{inset:-18px;opacity:.5;animation:pulseRing 3s var(--ease) infinite}
@keyframes pulseRing{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:0;transform:scale(1.15)}}
.gate-mark svg{width:42px;height:42px;color:var(--gold)}

.gate-eyebrow{
  font-family:var(--display);font-size:10px;letter-spacing:.5em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;
}
.gate-title{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(2rem,4vw,2.8rem);
  color:var(--ivory);line-height:1.1;margin-bottom:14px;
}
.gate-sub{color:rgba(248,244,237,.6);font-size:14px;margin-bottom:36px;line-height:1.6}

.gate-field{position:relative;margin-bottom:22px}
.gate-input{
  width:100%;
  padding:18px 20px;
  background:rgba(0,0,0,.25);
  border:1px solid rgba(201,169,100,.3);
  color:var(--ivory);
  font-size:15px;
  letter-spacing:.4em;text-align:center;
  border-radius:2px;
  transition:all .35s var(--ease);
  font-family:var(--body);
}
.gate-input:focus{outline:none;border-color:var(--gold);background:rgba(0,0,0,.4);box-shadow:0 0 0 4px rgba(201,169,100,.1)}
.gate-input::placeholder{color:rgba(248,244,237,.3);letter-spacing:.3em}

.gate-label{
  font-family:var(--display);font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);margin-bottom:14px;display:block;
}

.gate-btn{
  width:100%;padding:18px;
  background:linear-gradient(135deg,var(--gold),var(--gold-deep));
  color:var(--charcoal);
  font-family:var(--display);font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:600;
  border-radius:2px;
  transition:all .35s var(--ease);
  position:relative;overflow:hidden;
}
.gate-btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(201,169,100,.35)}

.gate-error{
  margin-top:18px;
  font-size:13px;color:#E68A8A;
  font-family:var(--serif);font-style:italic;
  opacity:0;transform:translateY(-4px);
  transition:all .35s var(--ease);
  min-height:20px;
}
.gate-error.show{opacity:1;transform:translateY(0)}
.gate-input.shake{animation:shake .55s var(--ease)}
@keyframes shake{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-8px)}
  40%,80%{transform:translateX(8px)}
}

.gate-foot{
  margin-top:32px;
  font-family:var(--display);font-size:9px;letter-spacing:.42em;text-transform:uppercase;
  color:rgba(201,169,100,.5);
}

/* ===== HOME — HERO ===== */
.hero{
  min-height:100vh;
  position:relative;
  background:var(--ivory);
  display:flex;align-items:center;
  padding:140px 0 80px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:80px;align-items:center;
  position:relative;z-index:2;
}
.hero-text .display{margin:24px 0 28px}
.hero-text .display em{font-style:italic;color:var(--maroon);display:block}
.hero-text .lead{margin-bottom:40px;max-width:520px}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}

.hero-visual{
  position:relative;
  aspect-ratio:4/5;
  max-height:78vh;
}
.hero-visual::before{
  content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;
  border:1px solid var(--gold);border-radius:50%;opacity:.6;
}
.hero-visual::after{
  content:"";position:absolute;bottom:-30px;left:-30px;width:90px;height:90px;
  background:var(--maroon);border-radius:50%;opacity:.08;
}
.hero-frame{
  position:relative;width:100%;height:100%;
  border-radius:300px 300px 8px 8px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero-frame img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.hero-frame::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(42,37,32,.15) 100%);
  pointer-events:none;
}

.hero-meta{
  position:absolute;bottom:60px;left:0;right:0;
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--display);font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);
  z-index:3;
}
.hero-meta .line{flex:1;height:1px;background:var(--gold);margin:0 24px;opacity:.5}

.hero-bg-mark{
  position:absolute;top:50%;left:-150px;transform:translateY(-50%);
  width:600px;height:600px;
  opacity:.04;pointer-events:none;
  animation:slowSpin 200s linear infinite;
}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-visual{max-height:none;aspect-ratio:3/4}
  .hero-meta{position:static;margin-top:30px}
}

/* ===== INTRO / WELCOME ===== */
.intro{background:var(--ivory-2);text-align:center}
.intro .lead{max-width:760px;margin:30px auto 0}
.intro-quote{
  margin-top:50px;font-family:var(--serif);font-style:italic;
  font-size:clamp(1.4rem,2.4vw,2rem);color:var(--maroon);line-height:1.45;
  position:relative;padding:0 40px;
}
.intro-quote::before,.intro-quote::after{
  content:"";position:absolute;top:50%;width:60px;height:1px;background:var(--gold);
}
.intro-quote::before{left:-30px}
.intro-quote::after{right:-30px}

@media(max-width:640px){
  .intro-quote::before,.intro-quote::after{display:none}
}

/* ===== PILLARS ===== */
.pillars-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;border-top:1px solid var(--line-gold);border-bottom:1px solid var(--line-gold);
}
.pillar{
  padding:50px 36px;text-align:center;
  border-right:1px solid var(--line-gold);
  transition:background .4s var(--ease);
}
.pillar:last-child{border-right:none}
.pillar:hover{background:var(--ivory-2)}
.pillar-icon{
  width:60px;height:60px;margin:0 auto 22px;
  display:grid;place-items:center;color:var(--gold-deep);
  border:1px solid var(--gold);border-radius:50%;
  transition:all .4s var(--ease);
}
.pillar:hover .pillar-icon{background:var(--gold);color:var(--ivory);transform:rotate(45deg)}
.pillar:hover .pillar-icon svg{transform:rotate(-45deg)}
.pillar-icon svg{width:26px;height:26px;transition:transform .4s var(--ease)}
.pillar h3{font-family:var(--display);font-size:13px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:12px}
.pillar p{font-size:14px;line-height:1.7;color:var(--charcoal-soft)}

@media(max-width:900px){.pillars-grid{grid-template-columns:1fr 1fr}.pillar:nth-child(2){border-right:none}.pillar:nth-child(1),.pillar:nth-child(2){border-bottom:1px solid var(--line-gold)}}
@media(max-width:560px){.pillars-grid{grid-template-columns:1fr}.pillar{border-right:none;border-bottom:1px solid var(--line-gold)}.pillar:last-child{border-bottom:none}}

/* ===== SPLIT (image + text) ===== */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
.split-img{
  position:relative;aspect-ratio:4/5;
  border-radius:8px;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.split-img img{width:100%;height:100%;object-fit:cover;object-position:center 25%}
.split-img::after{
  content:"";position:absolute;inset:14px;border:1px solid rgba(248,244,237,.35);
  border-radius:4px;pointer-events:none;
}
.split-text h2{margin:24px 0 22px}
.split-text p{margin-bottom:18px;font-size:16.5px;line-height:1.85}
.split-tag{
  position:absolute;bottom:24px;left:24px;
  background:rgba(248,244,237,.94);
  padding:14px 22px;font-family:var(--display);font-size:10px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--maroon);border-radius:2px;
}

@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:50px}
  .split.reverse{direction:ltr}
}

/* ===== HIGHLIGHTS ===== */
.highlights-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;gap:40px;flex-wrap:wrap}
.highlights-head h2{max-width:560px}
.highlights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.highlight{
  background:var(--ivory-2);
  border:1px solid var(--line);
  border-radius:6px;
  padding:0;
  overflow:hidden;
  transition:all .5s var(--ease);
  display:flex;flex-direction:column;
}
.highlight:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.highlight-img{aspect-ratio:4/3;overflow:hidden;position:relative}
.highlight-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%;transition:transform .8s var(--ease)}
.highlight:hover .highlight-img img{transform:scale(1.06)}
.highlight-body{padding:34px 30px}
.highlight-num{
  font-family:var(--display);font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold-deep);margin-bottom:14px;
}
.highlight h3{font-size:1.4rem;margin-bottom:12px;font-family:var(--serif);font-style:italic;font-weight:400}
.highlight p{font-size:14.5px;line-height:1.75}

@media(max-width:900px){.highlights-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.highlights-grid{grid-template-columns:1fr}}

/* ===== TEACHING PREVIEW ===== */
.teach-preview{background:linear-gradient(180deg,var(--ivory) 0%,var(--sand) 100%)}
.teach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-gold);border:1px solid var(--line-gold);border-radius:4px;overflow:hidden}
.teach{background:var(--ivory);padding:44px 36px;transition:background .4s var(--ease)}
.teach:hover{background:var(--ivory-2)}
.teach-num{font-family:var(--display);font-size:42px;color:var(--gold);font-weight:400;font-style:italic;line-height:1;margin-bottom:14px;font-family:var(--serif)}
.teach h3{font-size:1.2rem;margin-bottom:12px;font-family:var(--display);letter-spacing:.06em}
.teach p{font-size:14.5px}

@media(max-width:900px){.teach-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.teach-grid{grid-template-columns:1fr}}

/* ===== CTA STRIPE ===== */
.cta-stripe{
  background:var(--charcoal);color:var(--ivory);
  padding:90px 0;position:relative;overflow:hidden;
}
.cta-stripe::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(201,169,100,.10),transparent 70%);
}
.cta-stripe .wrap{position:relative;display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.cta-stripe h2{color:var(--ivory);font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.8rem,3.5vw,3rem);max-width:680px;line-height:1.15}
.cta-stripe .btn-gold{flex-shrink:0}

/* ===== ABOUT PAGE ===== */
.about-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:90px;align-items:start}
.about-grid .split-img{position:sticky;top:120px}
.about-text h2{margin-bottom:28px}
.about-text p{margin-bottom:20px;font-size:16.5px;line-height:1.85}
.about-text p:first-of-type{font-family:var(--serif);font-size:1.35rem;line-height:1.65;color:var(--charcoal);font-style:italic}

.facts{
  background:var(--ivory-2);
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-radius:6px;overflow:hidden;border:1px solid var(--line-gold);
}
.fact{padding:38px 28px;text-align:center;border-right:1px solid var(--line-gold)}
.fact:last-child{border-right:none}
.fact-label{font-family:var(--display);font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:10px}
.fact-value{font-family:var(--serif);font-style:italic;font-size:1.45rem;color:var(--charcoal);line-height:1.2}

@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:50px}
  .about-grid .split-img{position:static}
  .facts{grid-template-columns:1fr 1fr}
  .fact:nth-child(2){border-right:none}
  .fact:nth-child(1),.fact:nth-child(2){border-bottom:1px solid var(--line-gold)}
}

/* ===== JOURNEY / TIMELINE ===== */
.timeline{
  position:relative;max-width:1100px;margin:0 auto;padding:20px 0;
}
.timeline::before{
  content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;
  background:linear-gradient(180deg,transparent,var(--gold) 8%,var(--gold) 92%,transparent);
  transform:translateX(-50%);
}
.tl-item{
  position:relative;width:50%;padding:30px 60px;
  display:flex;flex-direction:column;
}
.tl-item:nth-child(odd){left:0;text-align:right;align-items:flex-end}
.tl-item:nth-child(even){left:50%;text-align:left}
.tl-dot{
  position:absolute;top:46px;
  width:18px;height:18px;border-radius:50%;
  background:var(--ivory);border:2px solid var(--gold);
  z-index:2;
}
.tl-dot::after{content:"";position:absolute;inset:3px;background:var(--gold);border-radius:50%}
.tl-item:nth-child(odd) .tl-dot{right:-9px}
.tl-item:nth-child(even) .tl-dot{left:-9px}
.tl-num{font-family:var(--display);font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:12px}
.tl-card{
  background:var(--ivory-2);border:1px solid var(--line-gold);border-radius:6px;
  padding:32px 30px;
  box-shadow:var(--shadow-sm);
  transition:all .4s var(--ease);
  width:100%;
}
.tl-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--gold)}
.tl-card h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.6rem;margin-bottom:12px;color:var(--maroon)}
.tl-card p{font-size:15px;line-height:1.75}

@media(max-width:900px){
  .timeline::before{left:18px}
  .tl-item,.tl-item:nth-child(odd),.tl-item:nth-child(even){
    width:100%;left:0;text-align:left;align-items:flex-start;
    padding:20px 0 20px 50px;
  }
  .tl-item:nth-child(odd) .tl-dot,.tl-item:nth-child(even) .tl-dot{left:9px;right:auto}
}

/* ===== TEACHINGS PAGE ===== */
.principles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.principle{
  position:relative;
  padding:50px 38px;
  background:var(--ivory-2);
  border:1px solid var(--line);
  border-radius:6px;
  transition:all .5s var(--ease);
  overflow:hidden;
}
.principle::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--maroon));
  transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease);
}
.principle:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);background:var(--ivory)}
.principle:hover::before{transform:scaleX(1)}
.principle-icon{
  width:64px;height:64px;
  background:var(--ivory);border:1px solid var(--gold);
  border-radius:50%;
  display:grid;place-items:center;
  color:var(--maroon);
  margin-bottom:24px;
}
.principle-icon svg{width:28px;height:28px}
.principle-sanskrit{font-family:var(--serif);font-style:italic;color:var(--gold-deep);font-size:1.05rem;margin-bottom:6px}
.principle h3{font-family:var(--display);font-size:1.15rem;letter-spacing:.06em;margin-bottom:14px}
.principle p{font-size:15px;line-height:1.75}

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

/* Wisdom callout */
.wisdom{
  background:var(--maroon);color:var(--ivory);padding:120px 0;text-align:center;position:relative;overflow:hidden;
}
.wisdom::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800' height='800' viewBox='0 0 800 800'%3E%3Cg fill='none' stroke='%23C9A964' stroke-width='.4' opacity='.18'%3E%3Ccircle cx='400' cy='400' r='100'/%3E%3Ccircle cx='400' cy='400' r='180'/%3E%3Ccircle cx='400' cy='400' r='260'/%3E%3Ccircle cx='400' cy='400' r='340'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
}
.wisdom .wrap-tight{position:relative}
.wisdom .eyebrow{color:var(--gold)}
.wisdom .eyebrow::before,.wisdom .eyebrow::after{background:var(--gold)}
.wisdom blockquote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(1.6rem,3vw,2.4rem);
  line-height:1.45;color:var(--ivory);
  margin:30px 0 22px;
}
.wisdom cite{
  font-family:var(--display);font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);font-style:normal;
}

/* ===== HERITAGE PAGE ===== */
.heritage-tabs{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;
}
.heritage-card{
  background:var(--ivory-2);border:1px solid var(--line-gold);border-radius:6px;
  padding:50px 44px;
  position:relative;overflow:hidden;
}
.heritage-card::before{
  content:"";position:absolute;top:-30px;right:-30px;width:140px;height:140px;
  border:1px solid var(--gold);border-radius:50%;opacity:.4;
}
.heritage-card .badge{
  display:inline-block;padding:6px 16px;background:var(--gold);color:var(--charcoal);
  font-family:var(--display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  border-radius:2px;margin-bottom:20px;
}
.heritage-card h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:2rem;margin-bottom:14px;color:var(--maroon)}
.heritage-card p{font-size:15.5px;line-height:1.85;margin-bottom:14px}

@media(max-width:900px){.heritage-tabs{grid-template-columns:1fr}}

/* Lineage grid */
.lineage-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:30px}
@media(max-width:900px){.lineage-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:560px){.lineage-grid{grid-template-columns:repeat(3,1fr);gap:10px}}
.lineage-cell{aspect-ratio:1;background:var(--ivory);border:1px solid var(--line);border-radius:6px;display:grid;place-items:center;text-align:center;padding:10px}
.lineage-cell.highlighted{background:linear-gradient(135deg,var(--maroon),var(--maroon-deep));color:var(--ivory);border:none;box-shadow:var(--shadow-md)}
.lineage-num{font-family:var(--display);font-size:11px;letter-spacing:.24em;color:var(--gold-deep)}
.lineage-cell.highlighted .lineage-num{color:var(--gold)}
.lineage-name{font-family:var(--serif);font-style:italic;font-size:14px;margin-top:4px}
.lineage-cell.highlighted .lineage-name{color:var(--ivory)}
.lineage-tag{font-family:var(--display);font-size:8px;letter-spacing:.24em;color:var(--gold);margin-top:4px}

/* Iconography panel */
.icono{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.icono-img{aspect-ratio:1/1;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-lg)}
.icono-img img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.icono-list{display:flex;flex-direction:column;gap:24px;margin-top:30px}
.icono-item{display:flex;gap:20px;padding:20px;background:var(--ivory-2);border-radius:6px;border:1px solid var(--line)}
.icono-item-icon{
  flex-shrink:0;width:48px;height:48px;border-radius:50%;
  background:var(--gold);color:var(--charcoal);
  display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:14px;
}
.icono-item h4{font-family:var(--display);font-size:13px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}
.icono-item p{font-size:14.5px;line-height:1.65;margin:0}

@media(max-width:900px){.icono{grid-template-columns:1fr}}

/* ===== GALLERY ===== */
.gallery-filter{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin-bottom:50px}
.gal-tab{
  padding:12px 22px;
  font-family:var(--display);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--charcoal-soft);
  border:1px solid transparent;border-radius:2px;
  transition:all .35s var(--ease);
}
.gal-tab:hover{color:var(--maroon)}
.gal-tab.active{background:var(--charcoal);color:var(--ivory)}

.masonry{
  columns:3;column-gap:20px;
}
.masonry-item{
  break-inside:avoid;margin-bottom:20px;
  position:relative;border-radius:6px;overflow:hidden;
  box-shadow:var(--shadow-sm);cursor:pointer;
  transition:all .5s var(--ease);
}
.masonry-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.masonry-item img{width:100%;display:block;transition:transform .8s var(--ease)}
.masonry-item:hover img{transform:scale(1.05)}
.masonry-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(42,37,32,.6) 100%);
  opacity:0;transition:opacity .4s var(--ease);
}
.masonry-item:hover::after{opacity:1}
.masonry-cap{
  position:absolute;left:20px;right:20px;bottom:18px;color:var(--ivory);z-index:2;
  opacity:0;transform:translateY(10px);transition:all .45s var(--ease);
}
.masonry-item:hover .masonry-cap{opacity:1;transform:translateY(0)}
.masonry-cap span{font-family:var(--display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:4px}
.masonry-cap h4{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.15rem;color:var(--ivory)}

@media(max-width:900px){.masonry{columns:2}}
@media(max-width:560px){.masonry{columns:1}}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(10,8,5,.95);
  display:none;align-items:center;justify-content:center;
  padding:40px;
}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:88vh;object-fit:contain;border-radius:4px;box-shadow:0 30px 100px rgba(0,0,0,.6)}
.lightbox-close{
  position:absolute;top:30px;right:30px;
  width:48px;height:48px;border-radius:50%;
  border:1px solid rgba(201,169,100,.5);color:var(--gold);
  display:grid;place-items:center;
  transition:all .35s var(--ease);
}
.lightbox-close:hover{background:var(--gold);color:var(--charcoal)}

/* ===== ARTICLES ===== */
.articles-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:start}
.article-feature{
  background:var(--ivory-2);border-radius:8px;overflow:hidden;
  border:1px solid var(--line);
  transition:all .5s var(--ease);
}
.article-feature:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.article-feature .feature-img{aspect-ratio:5/4;overflow:hidden}
.article-feature .feature-img img{width:100%;height:100%;object-fit:cover;object-position:center 25%;transition:transform .8s var(--ease)}
.article-feature:hover .feature-img img{transform:scale(1.05)}
.article-feature .feature-body{padding:40px 36px}
.article-tag{font-family:var(--display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:14px}
.article-feature h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:2rem;margin-bottom:14px;line-height:1.2}
.article-feature p{font-size:15.5px;line-height:1.7;margin-bottom:20px}
.article-meta{display:flex;align-items:center;gap:16px;color:var(--charcoal-soft);font-size:12px;font-family:var(--display);letter-spacing:.18em;text-transform:uppercase}
.article-meta span{display:inline-flex;align-items:center;gap:8px}

.article-list{display:flex;flex-direction:column;gap:24px}
.article-item{
  display:grid;grid-template-columns:140px 1fr;gap:24px;
  background:var(--ivory-2);border:1px solid var(--line);border-radius:6px;
  padding:18px;transition:all .4s var(--ease);
}
.article-item:hover{border-color:var(--gold);transform:translateX(4px);box-shadow:var(--shadow-sm)}
.article-item .item-img{aspect-ratio:1/1;border-radius:4px;overflow:hidden}
.article-item .item-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.article-item h4{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.15rem;margin:6px 0 8px;line-height:1.3}
.article-item p{font-size:13.5px;line-height:1.5;color:var(--charcoal-soft);margin:0}

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

.articles-row{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:80px}
.article-card{
  background:var(--ivory-2);border:1px solid var(--line);border-radius:6px;
  overflow:hidden;transition:all .5s var(--ease);
}
.article-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.article-card .card-img{aspect-ratio:5/3;overflow:hidden}
.article-card .card-img img{width:100%;height:100%;object-fit:cover;object-position:center 22%;transition:transform .8s var(--ease)}
.article-card:hover .card-img img{transform:scale(1.05)}
.article-card .card-body{padding:28px 26px}
.article-card h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.4rem;margin:10px 0 10px;line-height:1.25}
.article-card p{font-size:14px;line-height:1.65;margin-bottom:14px}

@media(max-width:900px){.articles-row{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.articles-row{grid-template-columns:1fr}}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
.contact-info{position:sticky;top:120px}
.contact-info h2{margin-bottom:24px}
.contact-info > p{font-size:16px;line-height:1.75;margin-bottom:36px}

.contact-list{display:flex;flex-direction:column;gap:24px;margin-top:30px}
.contact-row{display:flex;gap:18px;align-items:flex-start}
.contact-row-icon{
  flex-shrink:0;width:46px;height:46px;border-radius:50%;
  background:var(--ivory-2);color:var(--maroon);
  display:grid;place-items:center;border:1px solid var(--line-gold);
}
.contact-row-icon svg{width:18px;height:18px}
.contact-row-label{font-family:var(--display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:4px}
.contact-row a,.contact-row-text{font-size:16px;color:var(--charcoal);font-family:var(--serif)}
.contact-row a:hover{color:var(--maroon)}

.contact-form{
  background:var(--ivory-2);border:1px solid var(--line-gold);border-radius:8px;
  padding:50px 44px;
}
.contact-form h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.8rem;margin-bottom:8px;color:var(--maroon)}
.contact-form .lead-sm{color:var(--charcoal-soft);margin-bottom:30px;font-size:15px}

.field{margin-bottom:22px;position:relative}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{display:block;font-family:var(--display);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:10px}
.field input,.field textarea{
  width:100%;padding:14px 16px;
  background:var(--ivory);border:1px solid var(--line);
  border-radius:3px;font-size:15px;color:var(--charcoal);
  transition:all .35s var(--ease);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px rgba(201,169,100,.12)}
.field textarea{min-height:130px;resize:vertical;font-family:inherit}

.form-success{
  background:var(--sage);color:var(--ivory);
  padding:18px 22px;border-radius:4px;
  font-family:var(--serif);font-style:italic;
  text-align:center;display:none;margin-bottom:20px;
}
.form-success.show{display:block;animation:fadeIn .5s var(--ease)}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:50px}
  .contact-info{position:static}
  .field-row{grid-template-columns:1fr}
  .contact-form{padding:40px 28px}
}

/* Map / temple visual */
.map-banner{
  margin-top:80px;padding:80px 0;
  background:linear-gradient(135deg,var(--maroon) 0%,var(--maroon-deep) 100%);
  color:var(--ivory);text-align:center;border-radius:8px;
  position:relative;overflow:hidden;
}
.map-banner::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'%3E%3Cg fill='none' stroke='%23C9A964' stroke-width='.4' opacity='.2'%3E%3Ccircle cx='300' cy='300' r='80'/%3E%3Ccircle cx='300' cy='300' r='150'/%3E%3Ccircle cx='300' cy='300' r='220'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat;
}
.map-banner > *{position:relative}
.map-banner h3{font-family:var(--serif);font-style:italic;font-weight:400;font-size:2rem;color:var(--ivory);margin-bottom:12px}
.map-banner p{color:rgba(248,244,237,.8);max-width:600px;margin:0 auto}

/* ===== UTILS / ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(30px);transition:all .9s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

/* Sacred divider */
.divider{
  display:flex;align-items:center;justify-content:center;gap:18px;margin:40px 0;
}
.divider .l{flex:1;max-width:120px;height:1px;background:var(--line-gold)}
.divider .d{width:8px;height:8px;background:var(--gold);transform:rotate(45deg);border-radius:1px}

/* Section header centered */
.section-head{text-align:center;max-width:760px;margin:0 auto 70px}
.section-head h2{margin:24px 0 18px}
.section-head p{font-size:16.5px;line-height:1.7}

/* Hide scrollbar where appropriate */
.no-scroll{overflow:hidden}
