/* ============================================================
   ABHINANDANNATH SWAMI — SACRED HERITAGE PORTAL
   A premium digital sanctuary for the Fourth Tirthankara
   ============================================================ */

/* --- Root tokens ------------------------------------------- */
:root{
  --ivory:#f7f1e6;
  --ivory-soft:#fbf6ec;
  --ivory-deep:#efe5d2;
  --sand:#e7d8b9;
  --sand-deep:#d2bd95;
  --gold:#b9893f;
  --gold-soft:#d4ad6a;
  --gold-light:#e9cf9a;
  --maroon:#5a1e1e;
  --maroon-deep:#3d1212;
  --sage:#7a8c6a;
  --sage-deep:#566b4b;
  --charcoal:#262019;
  --charcoal-soft:#3a3128;
  --ink:#1c1610;
  --line:rgba(58,49,40,.14);
  --line-strong:rgba(58,49,40,.28);
  --shadow-sm:0 2px 12px rgba(58,30,10,.08);
  --shadow-md:0 14px 40px rgba(58,30,10,.12);
  --shadow-lg:0 30px 80px rgba(58,30,10,.18);
  --serif:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --display:'Cinzel', 'Cormorant Garamond', Georgia, serif;
  --body:'Inter', 'Manrope', system-ui, sans-serif;
  --easing:cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--body);
  color:var(--charcoal);
  background:var(--ivory);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; transition:color .35s var(--easing); }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

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

h1,h2,h3,h4{
  font-family:var(--display);
  letter-spacing:.04em;
  line-height:1.18;
  color:var(--ink);
  margin:0 0 .6em;
  font-weight:500;
}

p{ margin:0 0 1em; }

/* --- Layout helpers ---------------------------------------- */
.wrap{ width:min(1280px, 92%); margin:0 auto; }
.wrap-narrow{ width:min(960px, 92%); margin:0 auto; }
.section{ padding:120px 0; position:relative; }
.section-tight{ padding:80px 0; }

.eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--body);
  font-size:11px; letter-spacing:.42em; text-transform:uppercase;
  color:var(--gold); font-weight:500;
  margin-bottom:18px;
}
.eyebrow::before{
  content:""; width:36px; height:1px; background:var(--gold);
}
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{
  content:""; width:36px; height:1px; background:var(--gold);
}

.section-heading{
  font-size:clamp(2.2rem, 4vw, 3.6rem);
  margin-bottom:.4em;
}
.section-lede{
  font-family:var(--serif);
  font-size:clamp(1.15rem, 1.4vw, 1.4rem);
  color:var(--charcoal-soft);
  font-weight:400;
  font-style:italic;
  max-width:64ch;
}
.center{ text-align:center; }
.center .section-lede{ margin-left:auto; margin-right:auto; }

/* --- Mandala / ornament ------------------------------------ */
.ornament{
  display:flex; align-items:center; justify-content:center;
  gap:18px; margin:30px 0;
}
.ornament .line{ width:90px; height:1px; background:var(--gold-soft); }
.ornament .diamond{
  width:8px; height:8px; transform:rotate(45deg);
  background:var(--gold);
}
.ornament.solo{ margin:0 auto 30px; max-width:200px; }

/* --- Navigation -------------------------------------------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:80;
  background:rgba(247,241,230,.86);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:background .4s var(--easing), padding .4s var(--easing);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0;
}
.brand{
  display:flex; align-items:center; gap:14px;
  text-decoration:none;
}
.brand-mark{
  width:46px; height:46px; flex:none;
  border:1px solid var(--gold);
  display:grid; place-items:center;
  position:relative;
  background:var(--ivory-soft);
}
.brand-mark::before,
.brand-mark::after{
  content:""; position:absolute;
  width:6px; height:6px; background:var(--gold);
  transform:rotate(45deg);
}
.brand-mark::before{ top:-3.5px; left:50%; margin-left:-3px; }
.brand-mark::after{ bottom:-3.5px; left:50%; margin-left:-3px; }
.brand-mark span{
  font-family:var(--display); font-size:18px;
  color:var(--maroon); font-weight:600;
}
.brand-text{
  display:flex; flex-direction:column; line-height:1.05;
}
.brand-text .b1{
  font-family:var(--display);
  font-size:15px; letter-spacing:.18em;
  color:var(--ink); text-transform:uppercase; font-weight:600;
}
.brand-text .b2{
  font-family:var(--body);
  font-size:10.5px; letter-spacing:.34em;
  color:var(--gold); text-transform:uppercase; margin-top:4px;
}

.nav-menu{
  display:flex; align-items:center; gap:34px;
  list-style:none; margin:0; padding:0;
}
.nav-menu a{
  position:relative;
  font-size:12.5px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--charcoal); font-weight:500;
  padding:6px 0;
}
.nav-menu a::after{
  content:""; position:absolute; bottom:-2px; left:50%;
  width:0; height:1px; background:var(--gold);
  transition:width .4s var(--easing), left .4s var(--easing);
}
.nav-menu a:hover, .nav-menu a.active{ color:var(--maroon); }
.nav-menu a:hover::after, .nav-menu a.active::after{
  width:100%; left:0;
}

.nav-toggle{
  display:none;
  width:42px; height:42px; border:1px solid var(--gold);
  position:relative; background:transparent;
}
.nav-toggle span{
  position:absolute; left:10px; right:10px; height:1px;
  background:var(--ink); transition:.4s var(--easing);
}
.nav-toggle span:nth-child(1){ top:14px; }
.nav-toggle span:nth-child(2){ top:20px; }
.nav-toggle span:nth-child(3){ top:26px; }
.nav-toggle.is-open span:nth-child(1){ top:20px; transform:rotate(45deg); }
.nav-toggle.is-open span:nth-child(2){ opacity:0; }
.nav-toggle.is-open span:nth-child(3){ top:20px; transform:rotate(-45deg); }

/* --- Buttons ----------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:14px;
  padding:16px 30px;
  font-family:var(--body);
  font-size:11.5px; letter-spacing:.34em; text-transform:uppercase;
  font-weight:500;
  border:1px solid var(--gold);
  color:var(--ink);
  background:transparent;
  position:relative; overflow:hidden;
  transition:color .4s var(--easing);
}
.btn::before{
  content:""; position:absolute; inset:0;
  background:var(--gold);
  transform:scaleX(0); transform-origin:right center;
  transition:transform .55s var(--easing);
  z-index:-1;
}
.btn:hover{ color:var(--ivory); }
.btn:hover::before{ transform:scaleX(1); transform-origin:left center; }
.btn .arrow{
  width:14px; height:1px; background:currentColor; position:relative;
}
.btn .arrow::after{
  content:""; position:absolute; right:-1px; top:-3px;
  width:7px; height:7px;
  border-top:1px solid currentColor; border-right:1px solid currentColor;
  transform:rotate(45deg);
}
.btn-solid{
  background:var(--maroon); border-color:var(--maroon); color:var(--ivory);
}
.btn-solid::before{ background:var(--maroon-deep); }
.btn-ghost{ border-color:rgba(247,241,230,.7); color:var(--ivory); }
.btn-ghost::before{ background:var(--ivory); }
.btn-ghost:hover{ color:var(--maroon); }

/* ============================================================
   PASSCODE GATE
   ============================================================ */
.gate{
  position:fixed; inset:0; z-index:9999;
  background:radial-gradient(circle at 50% 30%, #2a1208 0%, #160903 60%, #0a0502 100%);
  display:grid; place-items:center;
  overflow:hidden;
  transition:opacity .9s var(--easing), visibility .9s var(--easing);
}
.gate.hidden{ opacity:0; visibility:hidden; pointer-events:none; }
body.is-locked{ overflow:hidden; height:100vh; }

.gate-mandala{
  position:absolute; left:50%; top:50%;
  width:min(900px, 90vw); aspect-ratio:1;
  transform:translate(-50%,-50%);
  opacity:.18;
  pointer-events:none;
  animation:slow-spin 90s linear infinite;
}
.gate-mandala-2{
  position:absolute; left:50%; top:50%;
  width:min(680px, 75vw); aspect-ratio:1;
  transform:translate(-50%,-50%);
  opacity:.22;
  pointer-events:none;
  animation:slow-spin 60s linear infinite reverse;
}
@keyframes slow-spin{
  from{ transform:translate(-50%,-50%) rotate(0); }
  to{ transform:translate(-50%,-50%) rotate(360deg); }
}

.gate-glow{
  position:absolute; left:50%; top:42%;
  width:600px; height:600px;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(212,173,106,.35) 0%, rgba(212,173,106,0) 60%);
  filter:blur(20px);
  animation:pulse 6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%,100%{ opacity:.55; transform:translate(-50%,-50%) scale(1); }
  50%{ opacity:.85; transform:translate(-50%,-50%) scale(1.08); }
}

.gate-inner{
  position:relative; z-index:2;
  width:min(560px, 90%);
  text-align:center;
  color:var(--ivory);
  padding:40px;
}
.gate-syllable{
  font-family:var(--display);
  font-size:14px; letter-spacing:.6em;
  color:var(--gold-light); text-transform:uppercase;
  margin-bottom:24px;
}
.gate-symbol{
  display:inline-block;
  width:64px; height:64px;
  border:1px solid var(--gold-soft);
  position:relative;
  margin-bottom:30px;
  animation:float-soft 5s ease-in-out infinite;
}
.gate-symbol::before, .gate-symbol::after{
  content:""; position:absolute; inset:8px;
  border:1px solid var(--gold-light);
}
.gate-symbol::after{ transform:rotate(45deg); }
@keyframes float-soft{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-6px); }
}

.gate h1{
  font-family:var(--display);
  font-size:clamp(2rem, 3.8vw, 3.2rem);
  color:var(--ivory);
  margin:0 0 18px;
  font-weight:500;
}
.gate h1 em{
  font-style:normal; color:var(--gold-light);
  display:block; font-size:.6em; letter-spacing:.32em;
  margin-top:14px; font-weight:400;
}
.gate-sub{
  font-family:var(--serif);
  font-style:italic;
  color:rgba(247,241,230,.75);
  font-size:1.15rem;
  margin-bottom:46px;
  max-width:42ch; margin-left:auto; margin-right:auto;
}

.gate-form{
  position:relative;
  display:flex; align-items:center;
  border:1px solid rgba(212,173,106,.35);
  background:rgba(20,10,4,.5);
  backdrop-filter:blur(6px);
  margin:0 auto; max-width:440px;
}
.gate-form label{
  position:absolute; left:24px; top:-9px;
  background:#160903; padding:0 10px;
  font-size:10px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--gold-light);
}
.gate-form input{
  flex:1; background:transparent; border:none; outline:none;
  padding:22px 24px;
  font-family:var(--body);
  letter-spacing:.3em; font-size:14px;
  color:var(--ivory);
  text-align:center;
}
.gate-form input::placeholder{ color:rgba(247,241,230,.35); letter-spacing:.3em; }
.gate-form button{
  padding:0 26px; height:100%;
  border-left:1px solid rgba(212,173,106,.35);
  color:var(--gold-light);
  letter-spacing:.3em; text-transform:uppercase; font-size:11px;
  align-self:stretch;
  transition:background .4s var(--easing), color .4s var(--easing);
}
.gate-form button:hover{ background:var(--gold); color:#160903; }

.gate-msg{
  margin-top:22px;
  min-height:24px;
  font-size:12px; letter-spacing:.28em; text-transform:uppercase;
  color:#e9b27a;
  opacity:0; transform:translateY(-4px);
  transition:opacity .35s var(--easing), transform .35s var(--easing);
}
.gate-msg.show{ opacity:1; transform:translateY(0); }
.gate-msg.error{ color:#ef9a8a; }
.gate-msg.success{ color:var(--gold-light); }

.gate-shake{ animation:shake .55s ease; }
@keyframes shake{
  0%,100%{ transform:translateX(0); }
  20%,60%{ transform:translateX(-8px); }
  40%,80%{ transform:translateX(8px); }
}

.gate-foot{
  position:absolute; bottom:32px; left:0; right:0;
  text-align:center; z-index:2;
  font-family:var(--body); font-size:10px; letter-spacing:.45em; text-transform:uppercase;
  color:rgba(212,173,106,.5);
}

/* ============================================================
   HOMEPAGE — HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px 0 80px;
  overflow:hidden;
  background:linear-gradient(180deg, var(--ivory) 0%, var(--ivory-deep) 100%);
}
.hero::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:120px;
  background:linear-gradient(to top, var(--ivory), transparent);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:center;
  gap:80px;
  position:relative; z-index:2;
}
.hero-text{ max-width:580px; }
.hero-eyebrow{
  font-family:var(--body);
  font-size:11px; letter-spacing:.45em; text-transform:uppercase;
  color:var(--gold); margin-bottom:30px;
  display:flex; align-items:center; gap:14px;
}
.hero-eyebrow::before{ content:""; width:60px; height:1px; background:var(--gold); }
.hero-title{
  font-family:var(--display);
  font-size:clamp(3rem, 6.4vw, 6rem);
  line-height:1.02;
  letter-spacing:.02em;
  margin:0 0 28px;
  font-weight:500;
}
.hero-title em{
  font-family:var(--serif);
  font-style:italic;
  color:var(--maroon);
  font-weight:400;
  font-size:.86em;
  letter-spacing:0;
  display:block;
  margin-top:6px;
}
.hero-lead{
  font-family:var(--serif);
  font-size:1.4rem;
  font-style:italic;
  color:var(--charcoal-soft);
  margin-bottom:38px;
  line-height:1.5;
  max-width:30ch;
}
.hero-actions{ display:flex; gap:18px; flex-wrap:wrap; }

.hero-portrait{
  position:relative;
  aspect-ratio:4/5;
  background:var(--sand);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.hero-portrait::before{
  content:""; position:absolute; inset:18px;
  border:1px solid rgba(247,241,230,.55);
  z-index:2; pointer-events:none;
}
.hero-portrait img{
  width:100%; height:100%; object-fit:cover; object-position:center 22%;
  transform:scale(1.02);
  transition:transform 1.5s var(--easing);
}
.hero-portrait:hover img{ transform:scale(1.06); }

.hero-portrait-frame{
  position:absolute; inset:-22px;
  border:1px solid var(--gold);
  pointer-events:none;
}
.hero-portrait-tag{
  position:absolute; left:-30px; bottom:60px;
  background:var(--maroon);
  color:var(--ivory);
  padding:14px 22px;
  font-family:var(--body);
  font-size:10.5px; letter-spacing:.35em; text-transform:uppercase;
  z-index:3;
}
.hero-portrait-tag em{
  font-style:normal; color:var(--gold-light); margin-right:10px;
}

.hero-meta{
  position:absolute; right:-30px; top:60px;
  background:var(--ivory);
  border:1px solid var(--line);
  padding:22px 26px;
  z-index:3; min-width:180px;
}
.hero-meta strong{
  display:block;
  font-family:var(--display);
  font-size:14px; letter-spacing:.18em;
  color:var(--maroon); margin-bottom:10px;
}
.hero-meta span{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.15rem;
  color:var(--ink);
}

.hero-floor{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  border-top:1px solid var(--line);
  margin-top:90px;
  padding-top:30px;
}
.hero-floor div{
  padding:20px 24px;
  border-left:1px solid var(--line);
}
.hero-floor div:first-child{ border-left:none; padding-left:0; }
.hero-floor strong{
  display:block;
  font-family:var(--display);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold); margin-bottom:8px;
}
.hero-floor span{
  font-family:var(--serif);
  font-size:1.25rem; font-style:italic;
  color:var(--ink);
}

/* ============================================================
   PILLARS / VALUES
   ============================================================ */
.pillars{
  background:var(--ivory-soft);
  position:relative;
}
.pillars-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:30px;
  margin-top:60px;
}
.pillar{
  background:var(--ivory);
  border:1px solid var(--line);
  padding:46px 36px;
  position:relative;
  transition:transform .55s var(--easing), box-shadow .55s var(--easing), border-color .55s var(--easing);
}
.pillar:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-soft);
}
.pillar-num{
  font-family:var(--display);
  font-size:14px; letter-spacing:.3em;
  color:var(--gold); margin-bottom:24px;
}
.pillar-icon{
  width:54px; height:54px;
  border:1px solid var(--gold);
  display:grid; place-items:center;
  margin-bottom:26px;
  position:relative;
  color:var(--maroon);
}
.pillar-icon::before{
  content:""; position:absolute; inset:-6px;
  border:1px solid var(--gold-light);
  opacity:0; transition:opacity .5s var(--easing);
}
.pillar:hover .pillar-icon::before{ opacity:1; }
.pillar h3{
  font-size:1.5rem;
  margin-bottom:14px;
}
.pillar p{
  font-family:var(--body);
  color:var(--charcoal-soft);
  font-size:.95rem; line-height:1.75;
  margin:0;
}

/* ============================================================
   ABOUT BAND (homepage)
   ============================================================ */
.about-band{
  background:var(--ivory);
  position:relative;
}
.about-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:90px;
  align-items:center;
}
.about-image{
  position:relative;
  aspect-ratio:5/6;
  overflow:hidden;
  background:var(--sand);
}
.about-image img{
  width:100%; height:100%; object-fit:cover; object-position:center 25%;
}
.about-image::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0) 60%, rgba(38,32,25,.35));
  pointer-events:none;
}
.about-image .corner{
  position:absolute; top:-1px; right:-1px;
  width:90px; height:90px;
  border-top:1px solid var(--gold);
  border-right:1px solid var(--gold);
}
.about-image .corner.bl{
  top:auto; right:auto; bottom:-1px; left:-1px;
  border-top:none; border-right:none;
  border-bottom:1px solid var(--gold);
  border-left:1px solid var(--gold);
}
.about-image .label{
  position:absolute; bottom:24px; left:24px;
  color:var(--ivory);
  font-family:var(--body);
  font-size:11px; letter-spacing:.4em; text-transform:uppercase;
  z-index:2;
}
.about-image .label em{
  font-style:normal; color:var(--gold-light); margin-right:10px;
}

.about-text h2{
  font-size:clamp(2rem, 3.6vw, 3.2rem);
}
.about-quote{
  font-family:var(--serif);
  font-size:1.35rem; font-style:italic;
  color:var(--maroon);
  border-left:2px solid var(--gold);
  padding-left:24px;
  margin:30px 0;
  line-height:1.55;
}
.about-stats{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:30px; margin-top:40px;
  border-top:1px solid var(--line);
  padding-top:30px;
}
.about-stat strong{
  display:block;
  font-family:var(--display);
  font-size:2.4rem;
  color:var(--maroon);
  margin-bottom:6px;
  line-height:1;
}
.about-stat strong > span,
.fact strong > span{
  font-size:inherit;
  letter-spacing:0;
  text-transform:none;
  color:inherit;
}
.about-stat strong > .ord,
.fact strong > .ord{
  font-style:normal;
  font-family:var(--body);
  font-size:.34em;
  letter-spacing:.1em;
  vertical-align:.95em;
  margin-left:5px;
  color:var(--gold);
  text-transform:uppercase;
  font-weight:600;
}
.about-stat span{
  font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--charcoal-soft);
}

/* ============================================================
   TEACHING PREVIEW
   ============================================================ */
.teach-preview{
  background:linear-gradient(180deg, var(--ivory-deep) 0%, var(--ivory-soft) 100%);
}
.teach-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:40px;
  margin-top:60px;
}
.teach-card{
  background:var(--ivory);
  padding:42px 38px;
  border:1px solid var(--line);
  display:flex; gap:24px;
  position:relative;
  transition:transform .55s var(--easing), border-color .55s var(--easing);
}
.teach-card:hover{ transform:translateY(-4px); border-color:var(--gold); }
.teach-num{
  font-family:var(--display);
  font-size:2.4rem;
  color:var(--gold-soft);
  flex:none; line-height:1;
  letter-spacing:.04em;
}
.teach-card h3{
  font-size:1.45rem; margin-bottom:10px;
}
.teach-card p{
  font-family:var(--body);
  font-size:.95rem; line-height:1.75;
  color:var(--charcoal-soft); margin:0;
}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta-strip{
  position:relative;
  padding:130px 0;
  background:url('../images/1711604833-abhinandan-nath-jain-mandir-faridabad-02.webp') center/cover;
  isolation:isolate;
  text-align:center;
  color:var(--ivory);
}
.cta-strip::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(rgba(20,10,4,.78), rgba(20,10,4,.85));
  z-index:-1;
}
.cta-strip h2{
  color:var(--ivory);
  font-size:clamp(2.2rem, 4vw, 3.6rem);
  max-width:24ch; margin:0 auto 22px;
}
.cta-strip p{
  font-family:var(--serif); font-style:italic;
  font-size:1.3rem; color:rgba(247,241,230,.78);
  max-width:54ch; margin:0 auto 40px;
}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.page-head{
  position:relative;
  padding:200px 0 90px;
  background:linear-gradient(180deg, var(--ivory-deep) 0%, var(--ivory) 100%);
  overflow:hidden;
}
.page-head::before{
  content:""; position:absolute; right:-100px; top:140px;
  width:380px; height:380px;
  border:1px solid var(--gold-soft);
  border-radius:50%;
  opacity:.4;
}
.page-head::after{
  content:""; position:absolute; right:0; top:240px;
  width:180px; height:180px;
  border:1px solid var(--gold-light);
  border-radius:50%;
  opacity:.5;
}
.page-head .wrap{ position:relative; z-index:2; }
.page-head-eyebrow{
  font-family:var(--body);
  font-size:11px; letter-spacing:.45em; text-transform:uppercase;
  color:var(--gold); margin-bottom:24px;
  display:flex; align-items:center; gap:14px;
}
.page-head-eyebrow::before{ content:""; width:50px; height:1px; background:var(--gold); }
.page-head h1{
  font-size:clamp(2.6rem, 5.4vw, 5rem);
  max-width:18ch;
  margin-bottom:24px;
}
.page-head h1 em{
  font-family:var(--serif); font-style:italic;
  color:var(--maroon); display:block; font-size:.7em;
  margin-top:6px; letter-spacing:0;
}
.page-head-lead{
  font-family:var(--serif);
  font-size:1.3rem; font-style:italic;
  max-width:60ch;
  color:var(--charcoal-soft);
}
.crumb{
  font-family:var(--body);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--charcoal-soft);
  margin-bottom:28px;
}
.crumb a{ color:var(--gold); }
.crumb span{ margin:0 12px; color:var(--line-strong); }

/* ============================================================
   ABOUT PAGE — DETAILED BIO
   ============================================================ */
.bio-section{ background:var(--ivory); }
.bio-grid{
  display:grid;
  grid-template-columns:5fr 7fr;
  gap:80px;
  align-items:flex-start;
}
.bio-aside{
  position:sticky; top:120px;
}
.bio-aside-img{
  aspect-ratio:4/5;
  overflow:hidden;
  border:1px solid var(--line);
  position:relative;
}
.bio-aside-img img{
  width:100%; height:100%; object-fit:cover; object-position:center 25%;
}
.bio-aside-img::after{
  content:""; position:absolute; inset:18px;
  border:1px solid rgba(247,241,230,.7);
  pointer-events:none;
}
.bio-card{
  margin-top:28px;
  background:var(--ivory-soft);
  padding:30px;
  border:1px solid var(--line);
}
.bio-card h4{
  font-family:var(--body);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold); margin:0 0 18px;
  font-weight:600;
}
.bio-card dl{ margin:0; }
.bio-card dt{
  font-family:var(--body);
  font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--charcoal-soft);
  margin-bottom:4px;
}
.bio-card dd{
  font-family:var(--serif);
  font-size:1.18rem; font-style:italic;
  color:var(--ink);
  margin:0 0 16px;
}
.bio-card dd:last-child{ margin-bottom:0; }

.bio-content h2{
  font-size:clamp(1.8rem, 3vw, 2.6rem);
  margin-top:0;
}
.bio-content h3{
  font-size:1.5rem;
  margin-top:50px;
  padding-top:30px;
  border-top:1px solid var(--line);
  position:relative;
}
.bio-content h3::before{
  content:""; position:absolute; top:-1px; left:0;
  width:60px; height:1px; background:var(--gold);
}
.bio-content p{
  font-size:1.05rem; line-height:1.85;
  color:var(--charcoal-soft);
}
.bio-content p:first-of-type::first-letter{
  font-family:var(--display);
  font-size:4.6rem;
  float:left;
  line-height:.85;
  margin:6px 16px 0 0;
  color:var(--maroon);
}
.bio-quote{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.5rem;
  line-height:1.5;
  color:var(--maroon);
  padding:30px 0 30px 30px;
  border-left:2px solid var(--gold);
  margin:40px 0;
}

/* ============================================================
   JOURNEY TIMELINE
   ============================================================ */
.timeline{
  position:relative;
  background:var(--ivory);
}
.timeline-track{
  position:relative;
  margin-top:70px;
}
.timeline-track::before{
  content:""; position:absolute;
  left:50%; top:0; bottom:0;
  width:1px; background:var(--gold-soft);
  transform:translateX(-50%);
}
.tl-item{
  position:relative;
  display:grid;
  grid-template-columns:1fr 80px 1fr;
  align-items:center;
  margin-bottom:80px;
}
.tl-item:last-child{ margin-bottom:0; }
.tl-card{
  background:var(--ivory-soft);
  padding:38px 36px;
  border:1px solid var(--line);
  position:relative;
  transition:transform .5s var(--easing), border-color .5s var(--easing);
}
.tl-card:hover{
  transform:translateY(-4px);
  border-color:var(--gold);
}
.tl-card .num{
  font-family:var(--display);
  font-size:14px; letter-spacing:.32em;
  color:var(--gold);
  margin-bottom:16px;
}
.tl-card h3{
  font-size:1.55rem; margin-bottom:12px;
}
.tl-card p{
  font-family:var(--body);
  color:var(--charcoal-soft);
  font-size:.96rem; line-height:1.75;
  margin:0;
}
.tl-image{
  aspect-ratio:5/4;
  overflow:hidden;
  position:relative;
  border:1px solid var(--line);
}
.tl-image img{
  width:100%; height:100%; object-fit:cover;
}
.tl-image::after{
  content:""; position:absolute; inset:14px;
  border:1px solid rgba(247,241,230,.5);
}
.tl-dot{
  width:18px; height:18px;
  border:1px solid var(--gold);
  background:var(--ivory);
  margin:0 auto;
  position:relative;
}
.tl-dot::after{
  content:""; position:absolute; inset:5px;
  background:var(--gold);
}

.tl-item.left .tl-card{ grid-column:1; }
.tl-item.left .tl-image{ grid-column:3; }
.tl-item.right .tl-image{ grid-column:1; }
.tl-item.right .tl-card{ grid-column:3; }
.tl-item .tl-dot-wrap{ grid-column:2; display:grid; place-items:center; }

/* ============================================================
   TEACHINGS GRID
   ============================================================ */
.teachings-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:30px;
  margin-top:60px;
}
.t-card{
  background:var(--ivory);
  border:1px solid var(--line);
  padding:46px 38px;
  position:relative; overflow:hidden;
  transition:transform .55s var(--easing), border-color .55s var(--easing);
}
.t-card::before{
  content:""; position:absolute; left:0; top:0;
  width:0; height:3px; background:var(--gold);
  transition:width .55s var(--easing);
}
.t-card:hover{ transform:translateY(-6px); border-color:var(--gold-soft); }
.t-card:hover::before{ width:100%; }
.t-card .t-num{
  font-family:var(--display);
  font-size:54px;
  color:var(--ivory-deep);
  position:absolute;
  right:24px; top:24px;
  font-weight:600;
  line-height:1;
}
.t-card .t-icon{
  width:56px; height:56px;
  margin-bottom:30px;
  color:var(--maroon);
  position:relative;
}
.t-card h3{ font-size:1.4rem; margin-bottom:14px; }
.t-card p{
  font-family:var(--body);
  color:var(--charcoal-soft); font-size:.95rem; line-height:1.75;
  margin:0;
}

/* Teaching wisdom strip */
.wisdom-strip{
  background:var(--maroon);
  color:var(--ivory);
  text-align:center;
}
.wisdom-strip h2{
  font-family:var(--serif); font-style:italic;
  font-size:clamp(1.6rem, 3vw, 2.6rem);
  color:var(--ivory);
  max-width:36ch; margin:0 auto 16px;
  font-weight:400;
  line-height:1.45;
}
.wisdom-strip cite{
  font-family:var(--body);
  font-size:11px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--gold-light);
  font-style:normal;
}

/* ============================================================
   HERITAGE / SYMBOLISM
   ============================================================ */
.symbol-section{
  background:var(--ivory);
}
.symbol-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.symbol-stage{
  position:relative;
  aspect-ratio:1;
  display:grid; place-items:center;
  background:var(--ivory-soft);
  border:1px solid var(--line);
}
.symbol-stage::before{
  content:""; position:absolute; inset:30px;
  border:1px solid var(--gold-soft);
}
.symbol-stage::after{
  content:""; position:absolute; inset:60px;
  border:1px solid var(--gold-light);
  border-radius:50%;
}
.symbol-mark{
  font-family:var(--display);
  position:relative;
  font-size:130px;
  color:var(--maroon);
  z-index:2;
  line-height:1;
}
.symbol-mark span{
  display:block;
  text-align:center;
  font-family:var(--body);
  font-size:11px; letter-spacing:.5em; text-transform:uppercase;
  color:var(--gold); margin-top:20px; font-weight:500;
}

.heritage-list{
  list-style:none; margin:30px 0 0; padding:0;
}
.heritage-list li{
  padding:18px 0;
  border-top:1px solid var(--line);
  display:grid;
  grid-template-columns:60px 1fr;
  gap:24px;
  align-items:flex-start;
}
.heritage-list li:last-child{ border-bottom:1px solid var(--line); }
.heritage-list .num{
  font-family:var(--display);
  font-size:14px; letter-spacing:.3em;
  color:var(--gold); padding-top:4px;
}
.heritage-list h4{
  font-family:var(--display);
  font-size:1.15rem; margin:0 0 6px;
}
.heritage-list p{
  font-family:var(--body);
  font-size:.95rem; line-height:1.7;
  color:var(--charcoal-soft); margin:0;
}

/* Heritage facts */
.facts{
  background:var(--ivory-deep);
}
.facts-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  margin-top:50px;
}
.fact{
  padding:50px 32px;
  border-left:1px solid var(--line);
  background:var(--ivory);
  text-align:center;
  transition:background .4s var(--easing);
}
.fact:first-child{ border-left:none; }
.fact:hover{ background:var(--ivory-soft); }
.fact strong{
  display:block;
  font-family:var(--display);
  font-size:3rem;
  color:var(--maroon);
  margin-bottom:14px;
  line-height:1;
}
.fact span{
  font-family:var(--body);
  font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--charcoal-soft);
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-section{ background:var(--ivory); }
.gallery-filter{
  display:flex; gap:24px; margin-top:40px; margin-bottom:50px;
  flex-wrap:wrap;
  border-bottom:1px solid var(--line);
  padding-bottom:18px;
}
.gallery-filter button{
  font-family:var(--body);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--charcoal-soft);
  padding:6px 0;
  position:relative;
  transition:color .35s var(--easing);
}
.gallery-filter button::after{
  content:""; position:absolute; bottom:-19px; left:0;
  width:0; height:2px; background:var(--maroon);
  transition:width .4s var(--easing);
}
.gallery-filter button.active,
.gallery-filter button:hover{ color:var(--maroon); }
.gallery-filter button.active::after{ width:100%; }

.masonry{
  column-count:3;
  column-gap:24px;
}
.masonry-item{
  break-inside:avoid;
  margin-bottom:24px;
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  cursor:zoom-in;
  background:var(--ivory-soft);
}
.masonry-item img{
  width:100%; height:auto; display:block;
  transition:transform 1.2s var(--easing), filter .6s var(--easing);
}
.masonry-item::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to bottom, transparent 50%, rgba(20,10,4,.7));
  opacity:0; transition:opacity .5s var(--easing);
}
.masonry-item:hover img{ transform:scale(1.04); }
.masonry-item:hover::after{ opacity:1; }
.masonry-cap{
  position:absolute;
  bottom:18px; left:22px; right:22px;
  z-index:2;
  color:var(--ivory);
  transform:translateY(8px); opacity:0;
  transition:transform .5s var(--easing), opacity .5s var(--easing);
}
.masonry-item:hover .masonry-cap{ transform:translateY(0); opacity:1; }
.masonry-cap em{
  display:block;
  font-family:var(--body);
  font-size:10px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--gold-light); margin-bottom:6px;
  font-style:normal;
}
.masonry-cap strong{
  font-family:var(--display);
  font-size:1.05rem;
  font-weight:500;
  letter-spacing:.04em;
}

/* Lightbox */
.lightbox{
  position:fixed; inset:0; z-index:9000;
  background:rgba(20,10,4,.95);
  display:none; align-items:center; justify-content:center;
  padding:60px;
}
.lightbox.show{ display:flex; }
.lightbox img{
  max-width:90vw; max-height:85vh;
  object-fit:contain;
  box-shadow:var(--shadow-lg);
}
.lightbox-close{
  position:absolute; top:30px; right:40px;
  width:50px; height:50px;
  border:1px solid var(--gold-soft);
  color:var(--ivory);
  font-size:18px;
}
.lightbox-close:hover{ background:var(--gold); color:var(--ink); }

/* ============================================================
   ARTICLES
   ============================================================ */
.articles-section{ background:var(--ivory); }
.articles-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:40px;
  margin-top:60px;
}
.article-card{
  background:var(--ivory);
  border:1px solid var(--line);
  display:flex; flex-direction:column;
  transition:transform .5s var(--easing), border-color .5s var(--easing), box-shadow .5s var(--easing);
}
.article-card:hover{
  transform:translateY(-6px);
  border-color:var(--gold);
  box-shadow:var(--shadow-md);
}
.article-thumb{
  aspect-ratio:4/3; overflow:hidden; position:relative;
  background:var(--sand);
}
.article-thumb img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.2s var(--easing);
}
.article-card:hover .article-thumb img{ transform:scale(1.06); }
.article-tag{
  position:absolute; top:18px; left:18px;
  background:var(--ivory);
  color:var(--maroon);
  padding:8px 14px;
  font-family:var(--body);
  font-size:10px; letter-spacing:.32em; text-transform:uppercase;
  z-index:2;
}
.article-body{
  padding:34px 32px 36px;
  flex:1; display:flex; flex-direction:column;
}
.article-meta{
  font-family:var(--body);
  font-size:10.5px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}
.article-card h3{
  font-size:1.35rem;
  margin-bottom:14px;
  line-height:1.3;
}
.article-card p{
  font-family:var(--body);
  color:var(--charcoal-soft);
  font-size:.95rem; line-height:1.7;
  flex:1;
}
.article-link{
  font-family:var(--body);
  font-size:11px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--maroon);
  margin-top:18px;
  display:inline-flex; align-items:center; gap:14px;
  font-weight:500;
}
.article-link .arrow{
  width:16px; height:1px; background:currentColor; position:relative;
  transition:width .4s var(--easing);
}
.article-link .arrow::after{
  content:""; position:absolute; right:-1px; top:-3px;
  width:7px; height:7px;
  border-top:1px solid currentColor; border-right:1px solid currentColor;
  transform:rotate(45deg);
}
.article-card:hover .article-link .arrow{ width:30px; }

/* Featured article */
.featured-article{
  display:grid; grid-template-columns:1.2fr 1fr; gap:0;
  background:var(--ivory-soft);
  border:1px solid var(--line);
  margin-bottom:60px;
  overflow:hidden;
}
.featured-article-img{
  aspect-ratio:5/4; overflow:hidden;
}
.featured-article-img img{
  width:100%; height:100%; object-fit:cover;
}
.featured-article-body{
  padding:60px 56px;
  display:flex; flex-direction:column; justify-content:center;
}
.featured-article-body .tag{
  font-family:var(--body);
  font-size:10.5px; letter-spacing:.4em; text-transform:uppercase;
  color:var(--gold); margin-bottom:18px;
}
.featured-article-body h2{
  font-size:clamp(1.8rem, 3vw, 2.5rem);
  margin-bottom:18px;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-section{ background:var(--ivory); }
.contact-grid{
  display:grid;
  grid-template-columns:5fr 7fr;
  gap:80px;
  align-items:flex-start;
}
.contact-info h2{
  font-size:clamp(1.8rem, 3vw, 2.6rem);
}
.contact-row{
  display:grid; grid-template-columns:60px 1fr;
  gap:24px;
  padding:24px 0;
  border-top:1px solid var(--line);
  align-items:flex-start;
}
.contact-row:last-child{ border-bottom:1px solid var(--line); }
.contact-row .ic{
  width:44px; height:44px;
  border:1px solid var(--gold);
  display:grid; place-items:center;
  color:var(--maroon);
}
.contact-row strong{
  display:block;
  font-family:var(--body);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--charcoal-soft);
  margin-bottom:6px;
  font-weight:500;
}
.contact-row a, .contact-row span{
  font-family:var(--serif);
  font-size:1.25rem;
  font-style:italic;
  color:var(--ink);
}
.contact-row a:hover{ color:var(--maroon); }

.contact-form{
  background:var(--ivory-soft);
  padding:50px 50px 60px;
  border:1px solid var(--line);
}
.contact-form h3{
  font-size:1.6rem; margin-bottom:8px;
}
.contact-form p{
  font-family:var(--serif); font-style:italic;
  color:var(--charcoal-soft);
  margin-bottom:30px;
}
.cf-row{
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
}
.cf-field{ position:relative; margin-bottom:22px; }
.cf-field label{
  position:absolute; top:-9px; left:14px;
  background:var(--ivory-soft);
  padding:0 8px;
  font-family:var(--body);
  font-size:10px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold); font-weight:500;
}
.cf-field input,
.cf-field textarea{
  width:100%;
  border:1px solid var(--line);
  background:var(--ivory);
  padding:18px 18px;
  font-family:var(--body);
  font-size:.96rem;
  color:var(--ink);
  outline:none;
  transition:border-color .35s var(--easing);
  resize:vertical;
}
.cf-field input:focus, .cf-field textarea:focus{ border-color:var(--gold); }
.cf-field textarea{ min-height:140px; }
.cf-status{
  margin-top:18px; min-height:24px;
  font-family:var(--body);
  font-size:11px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--sage-deep);
}

.map-band{
  background:var(--ivory-soft);
}
.map-band-grid{
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:60px;
}
.map-card{
  aspect-ratio:5/4;
  position:relative;
  background:url('../images/1711604833-abhinandan-nath-jain-mandir-faridabad-02.webp') center/cover;
  border:1px solid var(--line);
}
.map-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(rgba(20,10,4,.35), rgba(20,10,4,.5));
}
.map-card .pin{
  position:absolute; left:50%; top:50%;
  transform:translate(-50%,-50%);
  width:60px; height:60px;
  border:1px solid var(--ivory);
  border-radius:50%;
  display:grid; place-items:center;
  color:var(--ivory);
  z-index:2;
  background:rgba(90,30,30,.75);
}
.map-card .pin::before{
  content:""; position:absolute; inset:-12px;
  border:1px solid rgba(247,241,230,.5);
  border-radius:50%;
  animation:pulse-ring 3s ease-out infinite;
}
@keyframes pulse-ring{
  0%{ transform:scale(.9); opacity:.8; }
  100%{ transform:scale(1.5); opacity:0; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--ink);
  color:var(--ivory);
  padding:80px 0 30px;
  position:relative;
}
.footer::before{
  content:""; position:absolute; left:0; right:0; top:0;
  height:1px;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:60px;
  margin-bottom:60px;
}
.footer-brand .b1{
  font-family:var(--display);
  font-size:18px; letter-spacing:.2em;
  text-transform:uppercase;
  margin-bottom:8px;
  display:block;
}
.footer-brand .b2{
  font-family:var(--body);
  font-size:10.5px; letter-spacing:.34em; text-transform:uppercase;
  color:var(--gold-light);
  margin-bottom:24px;
  display:block;
}
.footer-brand p{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  color:rgba(247,241,230,.55);
  max-width:36ch;
}

.footer-col h4{
  font-family:var(--body);
  font-size:11px; letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold);
  margin:0 0 22px;
  font-weight:500;
}
.footer-col ul{ list-style:none; padding:0; margin:0; }
.footer-col li{ margin-bottom:12px; }
.footer-col a{
  font-size:.95rem;
  color:rgba(247,241,230,.7);
  transition:color .35s var(--easing);
}
.footer-col a:hover{ color:var(--gold-light); }

.footer-contact a{
  display:block;
  font-family:var(--serif);
  font-style:italic;
  font-size:1.1rem;
  color:rgba(247,241,230,.78);
  margin-bottom:8px;
}
.footer-contact a:hover{ color:var(--gold-light); }

.footer-social{
  display:flex; gap:14px;
  margin-top:24px;
}
.footer-social a{
  width:40px; height:40px;
  border:1px solid rgba(247,241,230,.18);
  display:grid; place-items:center;
  color:rgba(247,241,230,.7);
  transition:all .4s var(--easing);
}
.footer-social a:hover{
  border-color:var(--gold);
  color:var(--ivory);
  background:var(--gold);
}
.footer-social svg{ width:16px; height:16px; }

.footer-base{
  border-top:1px solid rgba(247,241,230,.1);
  padding-top:30px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:18px;
  font-family:var(--body);
  font-size:11px; letter-spacing:.28em; text-transform:uppercase;
  color:rgba(247,241,230,.45);
}
.footer-base a{ color:var(--gold-light); }
.footer-base a:hover{ color:var(--ivory); }

/* ============================================================
   ANIMATIONS / REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(24px); transition:opacity .9s var(--easing), transform .9s var(--easing); }
.reveal.in{ opacity:1; transform:translateY(0); }
.reveal-d1{ transition-delay:.12s; }
.reveal-d2{ transition-delay:.24s; }
.reveal-d3{ transition-delay:.36s; }
.reveal-d4{ transition-delay:.48s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .hero-grid{ grid-template-columns:1fr; gap:60px; }
  .hero-portrait{ max-width:520px; margin:0 auto; }
  .hero-meta, .hero-portrait-tag{ display:none; }
  .about-grid, .contact-grid, .symbol-grid, .map-band-grid, .featured-article{
    grid-template-columns:1fr; gap:50px;
  }
  .bio-grid{ grid-template-columns:1fr; gap:50px; }
  .bio-aside{ position:static; }
  .pillars-grid, .articles-grid, .teachings-grid{
    grid-template-columns:repeat(2, 1fr);
  }
  .teach-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:40px; }
  .featured-article-body{ padding:50px 40px; }
  .masonry{ column-count:2; }
  .facts-grid{ grid-template-columns:repeat(2, 1fr); }
  .fact{ border-left:none; border-top:1px solid var(--line); }
  .fact:nth-child(odd){ border-right:1px solid var(--line); }
}

@media (max-width: 760px){
  .section{ padding:80px 0; }
  .nav-menu{
    position:fixed; top:0; right:0;
    height:100vh; width:min(360px, 88%);
    background:var(--ivory);
    flex-direction:column;
    align-items:flex-start;
    padding:120px 40px 40px;
    transform:translateX(100%);
    transition:transform .55s var(--easing);
    box-shadow:var(--shadow-lg);
    gap:22px;
  }
  .nav-menu.is-open{ transform:translateX(0); }
  .nav-menu a{ font-size:14px; }
  .nav-toggle{ display:block; }
  .pillars-grid, .articles-grid, .teachings-grid, .footer-grid{
    grid-template-columns:1fr;
  }
  .masonry{ column-count:1; }
  .hero-floor{ grid-template-columns:repeat(2, 1fr); }
  .hero-floor div{ border-left:none; border-top:1px solid var(--line); padding:18px 0; }
  .hero-floor div:nth-child(odd){ border-right:1px solid var(--line); padding-right:18px; }
  .hero-floor div:nth-child(even){ padding-left:18px; }
  .timeline-track::before{ left:24px; }
  .tl-item{ grid-template-columns:48px 1fr !important; gap:24px; }
  .tl-item .tl-dot-wrap{ grid-column:1 !important; }
  .tl-item .tl-card, .tl-item .tl-image{ grid-column:2 !important; }
  .tl-item .tl-image{ margin-top:18px; }
  .featured-article{ grid-template-columns:1fr; }
  .cf-row{ grid-template-columns:1fr; }
  .contact-form{ padding:36px 28px 44px; }
  .facts-grid{ grid-template-columns:1fr; }
  .fact{ border:none !important; border-top:1px solid var(--line) !important; }
  .footer-base{ flex-direction:column; align-items:flex-start; }
  .about-stats{ grid-template-columns:1fr 1fr; }
  .gate-form{ flex-direction:column; }
  .gate-form button{ border-left:none; border-top:1px solid rgba(212,173,106,.35); padding:16px; width:100%; }
}
