/* ========================================================
   NEMINATH BHAGWAN — Luxury Digital Experience
   Design System & Global Stylesheet
   ======================================================== */

/* ---------- ROOT TOKENS ---------- */
:root{
  /* Palette */
  --ivory:#F6F1E7;
  --cream:#FAF6EE;
  --paper:#FDFBF6;
  --sand:#E6D6B8;
  --sand-soft:#EFE3CB;
  --gold:#B08A4A;
  --gold-light:#C9A961;
  --gold-deep:#8B6A2E;
  --charcoal:#1A1611;
  --ink:#231D15;
  --soft-ink:#5C5246;
  --muted:#8B8170;
  --line:rgba(26,22,17,0.12);
  --line-soft:rgba(26,22,17,0.06);

  /* Type */
  --f-serif:"Cormorant Garamond", "Playfair Display", Georgia, serif;
  --f-display:"Fraunces", "Cormorant Garamond", Georgia, serif;
  --f-sans:"Inter", "Manrope", -apple-system, BlinkMacSystemFont, sans-serif;
  --f-mono:"JetBrains Mono", "IBM Plex Mono", monospace;

  /* Motion */
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-luxe:cubic-bezier(.65,.05,.36,1);

  /* Layout */
  --max:1440px;
  --gut:clamp(20px,4vw,72px);
  --radius:2px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-sans);
  font-size:16px;
  line-height:1.7;
  color:var(--ink);
  background:var(--paper);
  font-weight:400;
  letter-spacing:0.005em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:opacity .4s var(--ease), color .4s var(--ease)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}

/* ---------- TYPOGRAPHY ---------- */
.eyebrow{
  font-family:var(--f-sans);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--gold-deep);
  display:inline-flex;
  align-items:center;
  gap:14px;
}
.eyebrow::before{
  content:"";
  width:36px;height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.center{justify-content:center}
.eyebrow.solo::before{display:none}

h1,h2,h3,h4{
  font-family:var(--f-display);
  font-weight:300;
  color:var(--charcoal);
  letter-spacing:-0.012em;
  line-height:1.05;
}
h1{font-size:clamp(44px,7vw,108px);font-weight:300}
h2{font-size:clamp(34px,5vw,68px);font-weight:300}
h3{font-size:clamp(24px,2.6vw,38px);font-weight:400}
h4{font-size:clamp(18px,1.4vw,22px);font-weight:500;font-family:var(--f-sans);letter-spacing:0;}

p{font-size:16px;line-height:1.8;color:var(--soft-ink)}
.lead{font-size:clamp(17px,1.4vw,21px);line-height:1.65;color:var(--ink);font-weight:300}
.italic-serif{font-family:var(--f-serif);font-style:italic}

/* ---------- LAYOUT ---------- */
.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gut)}
.wrap-narrow{max-width:980px;margin:0 auto;padding:0 var(--gut)}
.section{padding:clamp(80px,10vw,160px) 0;position:relative}
.section-tight{padding:clamp(60px,7vw,110px) 0}

.gold-rule{
  width:60px;height:1px;background:var(--gold);
  display:block;margin:24px 0;
}
.gold-rule.center{margin-left:auto;margin-right:auto}

/* ---------- NAVIGATION ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:100;
  padding:22px var(--gut);
  display:flex;align-items:center;justify-content:space-between;
  transition:background .5s var(--ease), padding .4s var(--ease), border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.solid{
  background:rgba(253,251,246,.94);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom-color:var(--line-soft);
  padding:16px var(--gut);
}
.nav.on-dark .brand,
.nav.on-dark .nav-toggle span,
.nav.on-dark .nav-links a{color:var(--paper)}
.nav.on-dark.solid .brand,
.nav.on-dark.solid .nav-toggle span,
.nav.on-dark.solid .nav-links a{color:var(--ink)}

.brand{
  font-family:var(--f-display);
  font-size:18px;
  font-weight:500;
  letter-spacing:.05em;
  color:var(--ink);
  display:flex;align-items:center;gap:12px;
  z-index:101;
}
.brand-mark{
  width:34px;height:34px;
  display:grid;place-items:center;
  border:1px solid var(--gold);
  border-radius:50%;
  font-family:var(--f-display);
  font-size:13px;color:var(--gold-deep);
  font-style:italic;
}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text small{font-family:var(--f-sans);font-size:9px;letter-spacing:.3em;color:var(--muted);font-weight:500;text-transform:uppercase;margin-top:4px}

.nav-links{
  display:flex;align-items:center;gap:38px;
}
.nav-links a{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink);
  font-weight:500;
  position:relative;
  padding:6px 0;
}
.nav-links a::after{
  content:"";
  position:absolute;left:0;bottom:0;
  width:0;height:1px;background:var(--gold);
  transition:width .5s var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--gold-deep)}

.nav-toggle{display:none;flex-direction:column;gap:6px;z-index:101;width:30px}
.nav-toggle span{display:block;height:1px;width:100%;background:var(--ink);transition:transform .4s var(--ease), opacity .3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:980px){
  .nav-links{
    position:fixed;inset:0;
    background:var(--paper);
    flex-direction:column;justify-content:center;
    gap:28px;
    transform:translateY(-100%);
    transition:transform .6s var(--ease-luxe);
    padding:0 var(--gut);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:18px;letter-spacing:.12em}
  .nav-toggle{display:flex}
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 34px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  font-weight:500;
  border:1px solid var(--ink);
  color:var(--ink);
  background:transparent;
  transition:all .5s var(--ease-luxe);
  position:relative;overflow:hidden;
}
.btn .arrow{display:inline-block;transition:transform .5s var(--ease)}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn:hover .arrow{transform:translateX(6px)}
.btn-gold{border-color:var(--gold);color:var(--gold-deep)}
.btn-gold:hover{background:var(--gold);color:var(--paper)}
.btn-light{border-color:var(--paper);color:var(--paper)}
.btn-light:hover{background:var(--paper);color:var(--ink)}
.btn-solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn-solid:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
.btn-text{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  color:var(--ink);
  border-bottom:1px solid var(--gold);
  padding:0 0 6px;
}
.btn-text:hover{color:var(--gold-deep)}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:flex-end;
  overflow:hidden;
  color:var(--paper);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;object-position:center 25%;
  filter:saturate(.92) contrast(1.02);
  animation:slowZoom 18s var(--ease) forwards;
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,12,8,.45) 0%,rgba(15,12,8,.15) 35%,rgba(15,12,8,.85) 100%);
}
@keyframes slowZoom{
  from{transform:scale(1.08)}
  to{transform:scale(1)}
}
.hero-inner{
  position:relative;z-index:2;
  width:100%;
  padding:0 var(--gut) clamp(60px,8vw,120px);
  max-width:var(--max);
  margin:0 auto;
}
.hero h1{color:var(--paper);max-width:14ch;margin-bottom:24px}
.hero .lead{color:rgba(255,255,255,.85);max-width:540px;margin-bottom:44px}
.hero .eyebrow{color:var(--gold-light);margin-bottom:32px}
.hero .eyebrow::before{background:var(--gold-light)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:18px}

.hero-meta{
  position:absolute;left:var(--gut);bottom:30px;z-index:3;
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
  display:none;
}
@media (min-width:1100px){
  .hero-meta{display:block}
}

.scroll-cue{
  position:absolute;right:var(--gut);bottom:30px;z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.scroll-cue::after{
  content:"";width:1px;height:48px;background:rgba(255,255,255,.4);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.3;transform:scaleY(.6)}
  50%{opacity:1;transform:scaleY(1)}
}

/* ---------- HIGHLIGHT STRIP ---------- */
.highlights{
  background:var(--ink);color:var(--paper);
  padding:46px var(--gut);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.highlights-grid{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.highlight{
  text-align:center;
  padding:18px 24px;
  border-right:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.highlight:last-child{border-right:none}
.highlight .num{
  font-family:var(--f-display);
  font-size:clamp(28px,3vw,44px);
  font-weight:300;
  color:var(--gold-light);
  line-height:1;
}
.highlight .label{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
  font-weight:500;
}
@media (max-width:780px){
  .highlights-grid{grid-template-columns:repeat(2,1fr)}
  .highlight{border-bottom:1px solid rgba(255,255,255,.08);padding:24px 16px}
  .highlight:nth-child(even){border-right:none}
  .highlight:nth-child(n+3){border-bottom:none}
}

/* ---------- INTRO / SPLIT ---------- */
.split{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,100px);
  align-items:center;
}
.split.reverse{direction:rtl}
.split.reverse > *{direction:ltr}
@media (max-width:880px){.split{grid-template-columns:1fr}}

.split-img{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--sand-soft);
}
.split-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s var(--ease-luxe);
}
.split-img:hover img{transform:scale(1.04)}
.split-img .corner-mark{
  position:absolute;top:20px;left:20px;
  font-family:var(--f-display);font-style:italic;
  color:var(--paper);font-size:14px;
  background:rgba(0,0,0,.3);
  padding:8px 14px;
  letter-spacing:.1em;
  backdrop-filter:blur(4px);
}

.split-text h2{margin-bottom:24px}
.split-text p{margin-bottom:18px}
.split-text .signature{
  display:block;margin-top:30px;
  font-family:var(--f-display);font-style:italic;
  color:var(--gold-deep);font-size:18px;
}

/* ---------- PILLARS / GRID ---------- */
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.pillar{
  padding:clamp(36px,4vw,60px) clamp(28px,3vw,48px);
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:var(--paper);
  transition:background .5s var(--ease);
  position:relative;
}
.pillar:hover{background:var(--cream)}
.pillar .num{
  font-family:var(--f-display);
  font-style:italic;font-weight:300;
  color:var(--gold);
  font-size:14px;
  margin-bottom:24px;
  display:block;
}
.pillar h3{margin-bottom:18px;font-size:24px;font-weight:400}
.pillar p{font-size:15px;line-height:1.7}
.pillar-icon{
  width:42px;height:42px;
  margin-bottom:24px;
  display:grid;place-items:center;
  color:var(--gold-deep);
}
@media (max-width:880px){.pillars{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.pillars{grid-template-columns:1fr}}

/* ---------- TIMELINE ---------- */
.timeline{
  position:relative;padding:60px 0;
  max-width:1100px;margin:0 auto;
}
.timeline::before{
  content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;
  background:linear-gradient(180deg,transparent 0,var(--gold) 8%,var(--gold) 92%,transparent 100%);
}
.tl-item{
  display:grid;grid-template-columns:1fr 80px 1fr;
  gap:0;
  margin-bottom:80px;align-items:center;
}
.tl-item:last-child{margin-bottom:0}
.tl-content{padding:0 40px}
.tl-item > .tl-content:first-child{text-align:right}
.tl-item > .tl-content:last-child{text-align:left}

.tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--paper);
  border:1px solid var(--gold);
  margin:0 auto;
  position:relative;
  z-index:2;
}
.tl-dot::after{
  content:"";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);
}
.tl-num{
  font-family:var(--f-display);font-style:italic;
  color:var(--gold);font-size:14px;
  margin-bottom:8px;display:block;
}
.tl-content h3{font-size:28px;margin-bottom:16px;font-weight:400}
.tl-content .place{
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:18px;
}
.tl-content p{font-size:15px}

@media (max-width:780px){
  .timeline::before{left:24px}
  .tl-item{display:flex;align-items:flex-start;gap:24px}
  .tl-item > div:empty{display:none}
  .tl-item > .tl-dot{order:1;margin:8px 0 0 17px;flex:0 0 14px}
  .tl-item > .tl-content{order:2;padding:0;text-align:left!important;flex:1}
}

/* ---------- QUOTE BLOCK ---------- */
.quote{
  background:var(--ink);
  color:var(--paper);
  padding:clamp(70px,8vw,140px) var(--gut);
  text-align:center;
  position:relative;overflow:hidden;
}
.quote::before{
  content:"\201C";
  position:absolute;top:30px;left:50%;transform:translateX(-50%);
  font-family:var(--f-display);font-size:140px;
  color:var(--gold);opacity:.4;line-height:1;
}
.quote blockquote{
  font-family:var(--f-display);
  font-weight:300;
  font-size:clamp(24px,3vw,42px);
  line-height:1.4;
  font-style:italic;
  max-width:920px;
  margin:0 auto 32px;
  color:var(--paper);
}
.quote cite{
  font-style:normal;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-light);font-weight:500;
}

/* ---------- CARD GRID ---------- */
.cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:0;
  position:relative;
  overflow:hidden;
  transition:transform .6s var(--ease-luxe), box-shadow .6s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(26,22,17,.25)}
.card-img{aspect-ratio:4/5;overflow:hidden;background:var(--sand-soft)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease-luxe)}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:30px 28px}
.card-body .meta{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:500;margin-bottom:14px;display:block;
}
.card-body h3{font-size:24px;margin-bottom:12px;font-weight:400}
.card-body p{font-size:14px}
@media (max-width:880px){.cards{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.cards{grid-template-columns:1fr}}

/* ---------- FULL-BLEED IMAGE BAND ---------- */
.bleed-band{
  position:relative;
  height:clamp(360px,55vh,620px);
  overflow:hidden;
}
.bleed-band img{
  width:100%;height:100%;object-fit:cover;object-position:center 30%;
  transform:scale(1.02);
  transition:transform 8s var(--ease);
}
.bleed-band.parallax img{transform:scale(1.15)}
.bleed-band::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.5));
}
.bleed-band-text{
  position:absolute;inset:0;z-index:2;
  display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--paper);
  padding:0 var(--gut);
}
.bleed-band-text h2{color:var(--paper);max-width:18ch;margin:0 auto;font-size:clamp(32px,5vw,60px)}
.bleed-band-text .eyebrow{color:var(--gold-light);margin-bottom:24px}
.bleed-band-text .eyebrow::before{background:var(--gold-light)}

/* ---------- SECTION HEADER ---------- */
.sec-head{
  display:grid;grid-template-columns:1fr 1.6fr;
  gap:60px;
  margin-bottom:80px;
  align-items:end;
}
.sec-head h2{margin-bottom:0}
.sec-head p{font-size:17px;line-height:1.7;max-width:60ch}
@media (max-width:880px){.sec-head{grid-template-columns:1fr;gap:24px}}

/* ---------- ICON LIST ---------- */
.icon-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line);
}
.icon-row{
  display:grid;grid-template-columns:80px 1fr;
  align-items:center;gap:24px;
  padding:36px 28px;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
}
.icon-row:nth-child(2n){border-right:none}
.icon-row .ic{
  width:54px;height:54px;
  display:grid;place-items:center;
  border:1px solid var(--gold);
  border-radius:50%;
  color:var(--gold-deep);
}
.icon-row h4{margin-bottom:6px;font-size:17px;font-weight:500;color:var(--ink)}
.icon-row p{font-size:14px;line-height:1.6}
@media (max-width:780px){
  .icon-list{grid-template-columns:1fr}
  .icon-row{border-right:none}
}

/* ---------- GALLERY (Masonry via CSS columns) ---------- */
.gallery-grid{
  column-count:4;
  column-gap:16px;
}
.gallery-item{
  display:block;
  width:100%;
  margin:0 0 16px;
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  page-break-inside:avoid;
  overflow:hidden;
  position:relative;
  background:var(--sand-soft);
  cursor:pointer;
  transition:transform .6s var(--ease-luxe), box-shadow .6s var(--ease);
}
.gallery-item img{
  width:100%;
  height:auto;
  display:block;
  object-fit:cover;
  transition:transform 1.1s var(--ease-luxe), filter .6s var(--ease);
}
.gallery-item:hover{box-shadow:0 24px 50px -28px rgba(26,22,17,.45)}
.gallery-item:hover img{transform:scale(1.04)}
.gallery-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.55) 100%);
  opacity:0;transition:opacity .5s var(--ease);
  pointer-events:none;
}
.gallery-item:hover::after{opacity:1}
.gallery-item .cap{
  position:absolute;left:18px;bottom:16px;
  color:var(--paper);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  z-index:2;opacity:0;transform:translateY(8px);
  transition:all .5s var(--ease);
  font-weight:500;
}
.gallery-item:hover .cap{opacity:1;transform:translateY(0)}

/* Span classes are decorative only in masonry — no-op */
.gi-1,.gi-2,.gi-3,.gi-4,.gi-5,.gi-6,.gi-7,.gi-8,.gi-9,.gi-10,.gi-11,.gi-12,.gi-tall,.gi-wide,.gi-sq{}

@media (max-width:1100px){.gallery-grid{column-count:3}}
@media (max-width:760px){.gallery-grid{column-count:2;column-gap:12px}.gallery-item{margin-bottom:12px}}
@media (max-width:460px){.gallery-grid{column-count:1}}

/* ---------- LIGHTBOX ---------- */
.lightbox{
  position:fixed;inset:0;z-index:999;
  background:rgba(15,12,8,.95);
  display:none;align-items:center;justify-content:center;
  padding:40px;
  backdrop-filter:blur(8px);
}
.lightbox.open{display:flex;animation:fadeIn .4s var(--ease)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lightbox .lb-close{
  position:absolute;top:24px;right:30px;
  color:var(--paper);font-size:14px;letter-spacing:.2em;
  text-transform:uppercase;cursor:pointer;
  display:flex;align-items:center;gap:12px;
}
.lightbox .lb-close::before{
  content:"";width:20px;height:1px;background:var(--paper);
  transform:rotate(45deg);position:absolute;left:-30px;top:50%;
}
.lightbox .lb-close::after{
  content:"";width:20px;height:1px;background:var(--paper);
  transform:rotate(-45deg);position:absolute;left:-30px;top:50%;
}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  color:var(--paper);font-family:var(--f-display);font-size:32px;
  cursor:pointer;padding:18px;opacity:.7;transition:opacity .3s;
  user-select:none;
}
.lb-nav:hover{opacity:1}
.lb-prev{left:30px}.lb-next{right:30px}

/* ---------- FORM ---------- */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:50px}}

.form{
  display:grid;gap:0;
}
.field{
  position:relative;border-bottom:1px solid var(--line);
  padding:14px 0;
}
.field label{
  display:block;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--muted);font-weight:500;margin-bottom:8px;
}
.field input,.field textarea{
  width:100%;background:transparent;border:none;outline:none;
  font-family:var(--f-sans);font-size:16px;color:var(--ink);
  padding:6px 0 14px;
  resize:vertical;
}
.field textarea{min-height:120px;line-height:1.6}
.field input:focus,.field textarea:focus{border-color:var(--gold)}
.form .btn{margin-top:30px;justify-self:start}

.contact-info{padding-top:8px}
.contact-info h3{font-size:30px;margin-bottom:24px;font-weight:400}
.contact-info .gold-rule{margin-bottom:30px}
.info-row{
  display:grid;grid-template-columns:120px 1fr;
  gap:24px;padding:20px 0;
  border-bottom:1px solid var(--line);
}
.info-row .lbl{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--muted);font-weight:500;padding-top:6px;
}
.info-row .val{
  font-family:var(--f-display);font-size:22px;font-weight:300;color:var(--ink);
}
.info-row a:hover{color:var(--gold-deep)}
.map-wrap{
  height:340px;
  background:var(--sand-soft);
  position:relative;
  overflow:hidden;
  margin-top:50px;
}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(.6) contrast(.95)}

/* ---------- LEGACY/EDITORIAL ---------- */
.editorial{
  display:grid;grid-template-columns:1fr;gap:60px;
}
.ed-block{
  display:grid;grid-template-columns:280px 1fr;
  gap:60px;align-items:start;
  padding:50px 0;border-top:1px solid var(--line);
}
.ed-block:last-child{border-bottom:1px solid var(--line)}
.ed-num{
  font-family:var(--f-display);
  font-size:80px;font-weight:200;font-style:italic;
  color:var(--gold);line-height:1;
}
.ed-num small{display:block;font-size:11px;letter-spacing:.3em;color:var(--muted);font-style:normal;font-family:var(--f-sans);font-weight:500;text-transform:uppercase;margin-top:8px}
.ed-content h3{font-size:30px;margin-bottom:18px;font-weight:400}
.ed-content p{margin-bottom:14px}
@media (max-width:780px){
  .ed-block{grid-template-columns:1fr;gap:24px;padding:40px 0}
  .ed-num{font-size:60px}
}

/* ---------- KRISHNA STORY ---------- */
.story-section{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;align-items:stretch;
}
.story-section.reverse{grid-template-columns:1fr 1fr}
.story-img{
  aspect-ratio:auto;
  min-height:560px;
  overflow:hidden;
  background:var(--sand-soft);
  position:relative;
}
.story-img img{width:100%;height:100%;object-fit:cover}
.story-text{
  padding:clamp(40px,6vw,100px);
  display:flex;flex-direction:column;justify-content:center;
  background:var(--cream);
}
.story-text h3{font-size:clamp(28px,3vw,40px);margin-bottom:24px;font-weight:400}
.story-text p{margin-bottom:16px}
.story-section.dark .story-text{background:var(--ink);color:rgba(255,255,255,.85)}
.story-section.dark .story-text h3{color:var(--paper)}
.story-section.dark .story-text p{color:rgba(255,255,255,.75)}
@media (max-width:780px){.story-section,.story-section.reverse{grid-template-columns:1fr}.story-img{min-height:380px}}

/* ---------- FOOTER ---------- */
.footer{
  background:var(--charcoal);color:rgba(255,255,255,.7);
  padding:80px var(--gut) 30px;
  position:relative;
}
.footer-top{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;
  padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-brand h4{
  font-family:var(--f-display);font-size:28px;color:var(--paper);
  font-weight:300;margin-bottom:14px;letter-spacing:.02em;
}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.55);max-width:32ch;line-height:1.7}
.footer-col h5{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-light);margin-bottom:24px;font-weight:500;
}
.footer-col a,.footer-col p{
  display:block;font-size:13px;color:rgba(255,255,255,.7);
  margin-bottom:10px;line-height:1.6;
}
.footer-col a:hover{color:var(--gold-light)}

.footer-bottom{
  max-width:var(--max);margin:30px auto 0;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;
  font-size:12px;color:rgba(255,255,255,.4);letter-spacing:.03em;
}
.footer-bottom a{color:rgba(255,255,255,.6)}
.footer-bottom a:hover{color:var(--gold-light)}
.footer-credit{font-style:italic;font-family:var(--f-display);}

.socials{display:flex;gap:14px}
.socials a{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  display:grid;place-items:center;
  color:rgba(255,255,255,.7);
  transition:all .4s var(--ease);
}
.socials a:hover{background:var(--gold);border-color:var(--gold);color:var(--paper)}
.socials svg{width:14px;height:14px}

@media (max-width:880px){
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr}
}

/* ---------- PAGE INTRO HEADER ---------- */
.page-intro{
  position:relative;
  min-height:60vh;
  padding:160px var(--gut) 80px;
  display:flex;align-items:flex-end;
  overflow:hidden;
  color:var(--paper);
}
.page-intro-bg{position:absolute;inset:0;z-index:0}
.page-intro-bg img{width:100%;height:100%;object-fit:cover;object-position:center 25%}
.page-intro-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,12,8,.4) 0%,rgba(15,12,8,.85) 100%);
}
.page-intro-inner{
  position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto;
}
.page-intro h1{color:var(--paper);max-width:18ch;margin-bottom:16px;font-size:clamp(44px,6vw,84px)}
.page-intro .lead{color:rgba(255,255,255,.85);max-width:560px}
.page-intro .eyebrow{color:var(--gold-light);margin-bottom:28px}
.page-intro .eyebrow::before{background:var(--gold-light)}
.breadcrumb{
  position:absolute;top:90px;left:var(--gut);z-index:2;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.7);font-weight:500;
}
.breadcrumb a:hover{color:var(--gold-light)}

/* ---------- SYMBOLISM ---------- */
.sym-hero{
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:80px;
  padding:clamp(60px,8vw,140px) var(--gut);
  background:linear-gradient(180deg,var(--cream),var(--paper));
}
.sym-circle{
  aspect-ratio:1;
  border:1px solid var(--gold);
  border-radius:50%;
  position:relative;
  display:grid;place-items:center;
  background:radial-gradient(circle at 30% 30%,var(--paper),var(--sand-soft));
  max-width:520px;margin:0 auto;width:100%;
}
.sym-circle::before{
  content:"";position:absolute;inset:30px;
  border:1px solid var(--gold);border-radius:50%;
  opacity:.4;
}
.sym-circle::after{
  content:"";position:absolute;inset:60px;
  border:1px solid var(--gold);border-radius:50%;
  opacity:.2;
}
.sym-circle img{
  width:62%;height:62%;object-fit:contain;
  filter:drop-shadow(0 12px 30px rgba(0,0,0,.15));
  position:relative;z-index:2;
}
@media (max-width:880px){.sym-hero{grid-template-columns:1fr;gap:40px}}

/* ---------- DEFINITION LIST ---------- */
.def-list{
  display:grid;grid-template-columns:1fr 1fr;
  gap:0;border-top:1px solid var(--line);
}
.def-item{
  padding:30px 0;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  padding-right:40px;padding-left:0;
}
.def-item:nth-child(odd){padding-left:0;padding-right:40px}
.def-item:nth-child(even){padding-left:40px;border-right:none}
.def-item dt{
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:500;margin-bottom:10px;
}
.def-item dd{
  font-family:var(--f-display);font-size:22px;font-weight:300;color:var(--ink);
}
@media (max-width:780px){
  .def-list{grid-template-columns:1fr}
  .def-item,.def-item:nth-child(odd),.def-item:nth-child(even){padding:24px 0;border-right:none}
}

/* ---------- ASPECT-CONTROLLED IMAGE ---------- */
.figure-frame{
  position:relative;overflow:hidden;
  background:var(--sand-soft);
}
.figure-frame img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center top;
}
.figure-frame.face-safe img{object-position:center 18%}
.figure-frame.face-mid img{object-position:center 28%}

/* ---------- REVEAL ANIMATION ---------- */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 1.1s var(--ease-luxe), transform 1.1s var(--ease-luxe);
}
.reveal.in{opacity:1;transform:none}
.reveal.delay-1{transition-delay:.1s}
.reveal.delay-2{transition-delay:.2s}
.reveal.delay-3{transition-delay:.3s}

/* ---------- PASSWORD GATE ---------- */
.gate{
  position:fixed;inset:0;z-index:1000;
  background:radial-gradient(ellipse at 50% 30%,#2a2118 0%,#0d0a06 70%);
  display:grid;place-items:center;
  overflow:hidden;
  color:var(--paper);
}
.gate::before{
  content:"";position:absolute;inset:-40%;
  background:
    radial-gradient(circle at 25% 30%,rgba(176,138,74,.18),transparent 30%),
    radial-gradient(circle at 75% 60%,rgba(201,169,97,.12),transparent 35%),
    radial-gradient(circle at 50% 90%,rgba(176,138,74,.08),transparent 40%);
  animation:gateFloat 18s ease-in-out infinite alternate;
}
.gate::after{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(180deg,transparent 0 80px,rgba(255,255,255,.012) 80px 81px);
  pointer-events:none;
}
@keyframes gateFloat{
  from{transform:translate(-2%,-1%) scale(1)}
  to{transform:translate(2%,1%) scale(1.05)}
}

.gate-particles{
  position:absolute;inset:0;overflow:hidden;
  pointer-events:none;
}
.particle{
  position:absolute;width:2px;height:2px;
  background:var(--gold-light);border-radius:50%;
  opacity:0;
  animation:rise linear infinite;
}
@keyframes rise{
  0%{opacity:0;transform:translateY(0) scale(.5)}
  10%{opacity:.6}
  90%{opacity:.4}
  100%{opacity:0;transform:translateY(-100vh) scale(1.4)}
}

.gate-rays{
  position:absolute;top:-10%;left:50%;
  transform:translateX(-50%);
  width:90vw;height:120vh;
  background:conic-gradient(from 80deg at 50% 0,transparent 0deg,rgba(201,169,97,.08) 30deg,transparent 60deg,rgba(201,169,97,.06) 100deg,transparent 130deg,rgba(201,169,97,.05) 160deg,transparent 200deg);
  filter:blur(24px);
  animation:rayDrift 22s ease-in-out infinite alternate;
}
@keyframes rayDrift{
  from{transform:translateX(-50%) rotate(-4deg)}
  to{transform:translateX(-50%) rotate(4deg)}
}

.gate-card{
  position:relative;z-index:5;
  width:min(92vw,540px);
  padding:clamp(40px,5vw,70px) clamp(28px,4vw,60px);
  text-align:center;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));
  border:1px solid rgba(201,169,97,.25);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  animation:gateIn 1.2s var(--ease-luxe) both;
}
@keyframes gateIn{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:none}
}
.gate-card::before,.gate-card::after{
  content:"";position:absolute;width:30px;height:30px;
  border-color:var(--gold-light);
}
.gate-card::before{top:-1px;left:-1px;border-top:1px solid;border-left:1px solid}
.gate-card::after{bottom:-1px;right:-1px;border-bottom:1px solid;border-right:1px solid}

.gate-emblem{
  width:80px;height:80px;margin:0 auto 30px;
  display:grid;place-items:center;
  border:1px solid var(--gold-light);border-radius:50%;
  position:relative;
}
.gate-emblem::before{
  content:"";position:absolute;inset:6px;border:1px solid var(--gold);border-radius:50%;opacity:.5;
}
.gate-emblem-mark{
  font-family:var(--f-display);
  font-size:34px;font-style:italic;font-weight:300;
  color:var(--gold-light);
  line-height:1;
}

.gate-card .eyebrow{
  color:var(--gold-light);margin-bottom:20px;
  justify-content:center;
}
.gate-card .eyebrow::before{background:var(--gold-light)}

.gate-card h1{
  font-size:clamp(32px,4vw,46px);
  color:var(--paper);
  font-weight:300;
  margin-bottom:14px;
}
.gate-card p.subtitle{
  font-family:var(--f-display);font-style:italic;font-size:17px;
  color:rgba(255,255,255,.65);
  margin-bottom:42px;font-weight:300;
}

.gate-form{
  display:flex;flex-direction:column;gap:18px;
}
.gate-input-wrap{
  position:relative;text-align:left;
}
.gate-input-wrap label{
  display:block;font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.5);font-weight:500;margin-bottom:10px;
}
.gate-input-wrap input{
  width:100%;
  background:transparent;
  border:none;border-bottom:1px solid rgba(201,169,97,.35);
  outline:none;
  padding:10px 0;
  font-family:var(--f-sans);font-size:15px;
  color:var(--paper);
  letter-spacing:.04em;
  transition:border-color .4s var(--ease);
}
.gate-input-wrap input:focus{border-color:var(--gold-light)}
.gate-input-wrap input::placeholder{color:rgba(255,255,255,.25)}

.gate-btn{
  margin-top:14px;
  padding:16px 30px;
  background:transparent;
  color:var(--gold-light);
  border:1px solid var(--gold-light);
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;
  cursor:pointer;
  transition:all .5s var(--ease-luxe);
  display:inline-flex;align-items:center;justify-content:center;gap:14px;
}
.gate-btn:hover{background:var(--gold);color:var(--paper);border-color:var(--gold)}
.gate-btn .arrow{transition:transform .4s var(--ease)}
.gate-btn:hover .arrow{transform:translateX(6px)}

.gate-msg{
  margin-top:18px;
  min-height:18px;
  font-size:12px;letter-spacing:.04em;
  font-family:var(--f-display);font-style:italic;
  color:rgba(255,255,255,.5);
  transition:color .3s;
}
.gate-msg.error{color:#d4825d}
.gate-msg.success{color:var(--gold-light)}

.gate-foot{
  position:absolute;bottom:30px;left:0;right:0;
  text-align:center;
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;
  color:rgba(255,255,255,.3);font-weight:500;
}

.gate-exit{
  animation:gateExit .9s var(--ease-luxe) forwards;
}
@keyframes gateExit{
  to{opacity:0;transform:scale(.98)}
}

/* ---------- UTILITIES ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0!important}
.mb-0{margin-bottom:0!important}
.mt-sm{margin-top:24px}
.mt-md{margin-top:48px}
.mb-md{margin-bottom:48px}
.bg-cream{background:var(--cream)}
.bg-ivory{background:var(--ivory)}
.bg-ink{background:var(--ink);color:var(--paper)}
.bg-ink h1,.bg-ink h2,.bg-ink h3,.bg-ink h4{color:var(--paper)}
.bg-ink p{color:rgba(255,255,255,.7)}
.bg-ink .eyebrow{color:var(--gold-light)}
.bg-ink .eyebrow::before{background:var(--gold-light)}

@media (max-width:560px){
  :root{--gut:22px}
  body{font-size:15px}
}

/* ---------- PRINT ---------- */
@media print{
  .nav,.footer,.gate{display:none}
}
