/* ================================================
   BabaFit — Warm Cream Theme
   ================================================ */

:root{
  /* Warm cream base — tuned to match the logo's left side */
  --bg:#f4ead6;
  --bg-soft:#ede0c3;
  --bg-tint:#e6d5ae;
  --bg-warm:#ddc796;
  --bg-deep:#d3ba83;
  --card:#f9f0dc;
  --card-warm:#f2e3c2;

  /* Text */
  --ink:#1f160d;
  --ink-dim:#574432;
  --muted:#8c7a62;

  /* Accents drawn from the logo */
  --amber:#c78535;
  --amber-light:#e8a24a;
  --amber-deep:#9c5f1f;
  --crimson:#2a4d32;
  --crimson-deep:#1a3322;
  --crimson-light:#3d6b44;

  /* Lines */
  --line:rgba(31,22,13,0.08);
  --line-2:rgba(31,22,13,0.14);
  --line-3:rgba(42,77,50,0.28);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  position:relative;
}

/* Subtle warm atmospherics (very soft, not overwhelming) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(900px 500px at 90% -10%, rgba(199,133,53,0.08), transparent 60%),
    radial-gradient(700px 500px at -10% 50%, rgba(42,77,50,0.05), transparent 60%);
  pointer-events:none;
  z-index:0;
}

.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 32px;
  position:relative;
  z-index:2;
}

/* ================================================
   NAV
   ================================================ */
nav{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  background:rgba(244,234,214,0.85);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 32px;
  max-width:1200px;
  margin:0 auto;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--ink);
}
.brand-logo{
  width:42px;
  height:42px;
  background-image:url("logo.png");
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
  flex-shrink:0;
}
.brand-logo.small{width:34px;height:34px}
.brand-name{
  font-family:'Fraunces',serif;
  font-weight:800;
  font-size:22px;
  letter-spacing:-0.01em;
}
.brand-name em{
  color:var(--crimson);
  font-style:normal;
}
.nav-links{
  display:flex;
  gap:28px;
  align-items:center;
}
.nav-links a{
  color:var(--ink-dim);
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  transition:color .2s;
}
.nav-links a:hover{color:var(--crimson)}
.nav-cta{
  padding:10px 20px;
  background:var(--crimson);
  color:var(--bg) !important;
  border-radius:999px;
  font-weight:600 !important;
  border:1px solid var(--crimson);
  transition:all .25s;
}
.nav-cta:hover{
  background:var(--crimson-deep);
  color:var(--bg) !important;
  transform:translateY(-1px);
  box-shadow:0 8px 24px -8px rgba(42,77,50,0.4);
}
@media(max-width:720px){
  .nav-links a:not(.nav-cta){display:none}
}

/* ================================================
   HERO
   ================================================ */
.hero{
  padding:70px 0 100px;
  position:relative;
  background:linear-gradient(180deg, var(--bg) 0%, var(--bg) 60%, var(--bg-soft) 100%);
}
.hero::after{
  content:"";
  position:absolute;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:80px;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--crimson), transparent);
  opacity:0.4;
}
.hero-container{
  max-width:1200px;
  margin:0 auto;
  padding:0 32px;
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:70px;
  align-items:center;
  position:relative;
  z-index:2;
}
@media(max-width:900px){
  .hero-container{grid-template-columns:1fr;gap:40px;text-align:center}
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.25em;
  color:var(--crimson);
  margin-bottom:32px;
  padding:8px 16px;
  background:rgba(42,77,50,0.06);
  border:1px solid var(--line-3);
  border-radius:999px;
}
.eyebrow .dot{
  width:6px;
  height:6px;
  background:var(--crimson);
  border-radius:50%;
  animation:pulse 2.5s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:0.5;transform:scale(1)}
  50%{opacity:1;transform:scale(1.2)}
}

.hero-title{
  font-family:'Fraunces',serif;
  font-weight:900;
  font-size:clamp(48px, 7.5vw, 88px);
  line-height:1;
  letter-spacing:-0.02em;
  margin-bottom:28px;
  color:var(--ink);
}
.hero-title em{
  font-weight:400;
  font-style:italic;
  color:var(--crimson);
  font-size:0.95em;
}

.hero-sub{
  font-size:19px;
  color:var(--ink-dim);
  max-width:520px;
  margin-bottom:40px;
  line-height:1.6;
}
@media(max-width:900px){.hero-sub{margin-left:auto;margin-right:auto}}

.hero-cta-row{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
@media(max-width:900px){.hero-cta-row{justify-content:center}}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 30px;
  border-radius:999px;
  font-weight:600;
  font-size:15px;
  text-decoration:none;
  transition:all .25s cubic-bezier(.2,.8,.3,1);
  border:1px solid transparent;
  cursor:pointer;
  font-family:'Inter',sans-serif;
}
.btn-primary{
  background:var(--crimson);
  color:var(--bg);
  border-color:var(--crimson);
  box-shadow:0 10px 28px -10px rgba(42,77,50,0.5);
}
.btn-primary:hover{
  background:var(--crimson-deep);
  transform:translateY(-2px);
  box-shadow:0 16px 36px -10px rgba(42,77,50,0.55);
}
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border-color:var(--line-2);
}
.btn-ghost:hover{
  border-color:var(--crimson);
  color:var(--crimson);
  background:rgba(42,77,50,0.04);
  transform:translateY(-2px);
}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(4px)}

/* Hero visual */
.hero-visual{
  position:relative;
  aspect-ratio:1/1;
  max-width:500px;
  margin:0 auto;
  width:100%;
}
.hero-logo-glow{
  position:absolute;
  inset:5%;
  background:
    radial-gradient(circle at 50% 55%, rgba(199,133,53,0.28), transparent 60%),
    radial-gradient(circle at 50% 60%, rgba(42,77,50,0.15), transparent 65%);
  filter:blur(40px);
  z-index:0;
}
.hero-logo{
  position:relative;
  z-index:1;
  width:100%;
  height:100%;
  background-image:url("logo.png");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  filter:drop-shadow(0 25px 35px rgba(42,77,50,0.25));
}

/* ================================================
   SHARED SECTION STYLES
   ================================================ */
section{position:relative;z-index:2}

.section-label{
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--crimson);
  display:block;
  margin-bottom:20px;
}

h2{
  font-family:'Fraunces',serif;
  font-weight:800;
  font-size:clamp(36px, 5.5vw, 58px);
  line-height:1.05;
  letter-spacing:-0.02em;
  margin-bottom:24px;
  color:var(--ink);
}
h2 em{
  font-weight:400;
  font-style:italic;
  color:var(--crimson);
  font-size:1em;
}

.section-sub{
  font-size:18px;
  color:var(--ink-dim);
  max-width:620px;
  margin:0 auto;
  line-height:1.6;
}

/* ================================================
   ABOUT
   ================================================ */
.about{
  padding:100px 0 80px;
  border-top:1px solid var(--line);
  background:var(--bg-soft);
}
.about-grid{
  display:grid;
  grid-template-columns:0.9fr 1.1fr;
  gap:70px;
  align-items:start;
  margin-bottom:80px;
}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:30px}}

.about-header h2{margin-bottom:0}

.about-body .lead{
  font-family:'Fraunces',serif;
  font-size:24px;
  line-height:1.45;
  color:var(--ink);
  margin-bottom:22px;
  font-weight:400;
}
.about-body p{
  font-size:17px;
  color:var(--ink-dim);
  line-height:1.75;
}

/* Focus card (South Asian) */
.focus-card{
  padding:60px;
  border-radius:20px;
  background:
    linear-gradient(135deg, rgba(42,77,50,0.06), rgba(199,133,53,0.08)),
    var(--card);
  border:1px solid var(--line-3);
  position:relative;
  overflow:hidden;
}
@media(max-width:700px){.focus-card{padding:36px 28px}}
.focus-card::before{
  content:"";
  position:absolute;
  top:-100px;
  right:-100px;
  width:300px;
  height:300px;
  background:radial-gradient(circle, rgba(199,133,53,0.2), transparent 65%);
  pointer-events:none;
}
.focus-label{
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--crimson);
  margin-bottom:18px;
  position:relative;
}
.focus-card h3{
  font-family:'Fraunces',serif;
  font-weight:700;
  font-size:clamp(28px, 3.5vw, 38px);
  line-height:1.15;
  margin-bottom:22px;
  color:var(--ink);
  position:relative;
  max-width:680px;
}
.focus-card p{
  font-size:17px;
  color:var(--ink-dim);
  line-height:1.75;
  max-width:720px;
  margin-bottom:16px;
  position:relative;
}
.focus-card p:last-child{margin-bottom:0}

/* ================================================
   TRANSFORMATION — proof / real results
   ================================================ */
.transformation{
  padding:100px 0;
  background:var(--bg-soft);
  border-top:1px solid var(--line);
  position:relative;
  overflow:hidden;
}
.transformation::before{
  content:"";
  position:absolute;
  top:-100px;
  right:-150px;
  width:500px;
  height:500px;
  background:radial-gradient(circle, rgba(199,133,53,0.1), transparent 70%);
  pointer-events:none;
  z-index:0;
}
.transformation-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:70px;
  align-items:center;
  position:relative;
  z-index:1;
}
@media(max-width:900px){
  .transformation-grid{grid-template-columns:1fr;gap:40px}
}

.transformation-image{
  position:relative;
}
.image-frame{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  box-shadow:
    0 30px 60px -25px rgba(31,22,13,0.4),
    0 0 0 1px rgba(42,77,50,0.18);
  background:var(--bg-tint);
}
.image-frame img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}
.image-frame::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:50%;
  height:2px;
  background:linear-gradient(90deg,
    transparent,
    var(--bg-soft) 20%,
    var(--bg-soft) 80%,
    transparent);
  transform:translateY(-50%);
  pointer-events:none;
}
.image-caption{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-top:18px;
  font-family:'Inter',sans-serif;
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--muted);
}
.caption-label{
  flex-shrink:0;
}
.caption-divider{
  width:30px;
  height:1px;
  background:var(--crimson);
  opacity:0.6;
}

.transformation-text{
  padding-left:10px;
}
@media(max-width:900px){.transformation-text{padding-left:0;text-align:center}}

.transformation-text h2{
  margin-bottom:32px;
}
.stat-row{
  display:flex;
  align-items:center;
  gap:24px;
  margin-bottom:32px;
  padding:24px 28px;
  background:var(--card);
  border:1px solid var(--line-2);
  border-radius:16px;
}
@media(max-width:900px){
  .stat-row{justify-content:center}
}
@media(max-width:480px){
  .stat-row{padding:20px;gap:16px}
}
.stat{
  flex:1;
  text-align:center;
}
.stat-num{
  font-family:'Fraunces',serif;
  font-weight:800;
  font-size:clamp(36px, 5vw, 52px);
  line-height:1;
  color:var(--crimson);
  margin-bottom:8px;
  letter-spacing:-0.02em;
}
.stat-num span{
  font-size:0.45em;
  font-weight:600;
  color:var(--ink-dim);
  margin-left:2px;
  letter-spacing:0.05em;
}
.stat-label{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.25em;
  color:var(--muted);
}
.stat-plus{
  font-family:'Fraunces',serif;
  font-size:32px;
  color:var(--amber);
  font-weight:600;
  flex-shrink:0;
}
.transformation-text p{
  font-size:17px;
  color:var(--ink-dim);
  line-height:1.7;
  margin-bottom:18px;
}
.transformation-text p.micro{
  font-size:13px;
  font-style:italic;
  color:var(--muted);
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--line-2);
}

/* ================================================
   PILLARS
   ================================================ */
.pillars-section{
  padding:100px 0;
  background:var(--bg-tint);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.pillars-header{
  text-align:center;
  margin-bottom:60px;
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}
.pillars-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
@media(max-width:800px){.pillars-grid{grid-template-columns:1fr}}

.pillar{
  padding:36px;
  background:var(--card);
  border:1px solid var(--line-2);
  border-radius:16px;
  transition:all .3s cubic-bezier(.2,.8,.3,1);
}
.pillar:hover{
  transform:translateY(-4px);
  border-color:var(--crimson);
  box-shadow:0 20px 40px -20px rgba(42,77,50,0.2);
}
.pillar-num{
  font-family:'Fraunces',serif;
  font-size:14px;
  font-weight:600;
  color:var(--crimson);
  margin-bottom:14px;
  letter-spacing:0.1em;
}
.pillar h3{
  font-family:'Fraunces',serif;
  font-weight:700;
  font-size:22px;
  line-height:1.2;
  color:var(--ink);
  margin-bottom:12px;
}
.pillar p{
  font-size:15px;
  color:var(--ink-dim);
  line-height:1.65;
}

/* ================================================
   BEGIN TILES
   ================================================ */
.begin{
  padding:100px 0;
  border-top:1px solid var(--line);
  background:var(--bg-soft);
}
.begin-header{
  text-align:center;
  margin-bottom:50px;
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}

.begin-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:16px;
}
@media(max-width:900px){.begin-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.begin-grid{grid-template-columns:1fr}}

.tile{
  grid-column:span 2;
  display:flex;
  flex-direction:column;
  padding:28px;
  border:1px solid var(--line-2);
  border-radius:16px;
  background:var(--card);
  text-decoration:none;
  color:var(--ink);
  transition:all .3s cubic-bezier(.2,.8,.3,1);
  min-height:240px;
  position:relative;
  overflow:hidden;
}
.tile:hover{
  transform:translateY(-4px);
  border-color:var(--crimson);
  box-shadow:0 20px 40px -20px rgba(42,77,50,0.25);
}

.tile-primary{
  grid-column:span 6;
  flex-direction:row;
  align-items:flex-start;
  gap:40px;
  min-height:220px;
  background:
    linear-gradient(135deg, rgba(199,133,53,0.12), rgba(42,77,50,0.08)),
    var(--card);
  border-color:var(--line-3);
}

@media(max-width:640px){
  .begin-grid .tile,
  .begin-grid .tile-primary{grid-column:span 1}
}
@media(max-width:700px){
  .tile-primary{flex-direction:column;gap:16px}
}
.tile-primary .tile-top{flex-shrink:0;margin-bottom:0}
.tile-primary .tile-body{flex:1}
.tile-primary .tile-title{font-size:32px}

.tile-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:20px;
}
.tile-icon{
  width:44px;
  height:44px;
  border-radius:12px;
  background:rgba(42,77,50,0.08);
  display:grid;
  place-items:center;
  color:var(--crimson);
  flex-shrink:0;
}
.tile-icon svg{width:22px;height:22px}
.tile-label{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.25em;
  color:var(--muted);
}
.tile-primary .tile-label{margin-top:12px}

.tile-body{
  flex:1;
  display:flex;
  flex-direction:column;
}
.tile-title{
  font-family:'Fraunces',serif;
  font-weight:700;
  font-size:22px;
  line-height:1.2;
  margin-bottom:10px;
  color:var(--ink);
}
.tile-desc{
  font-size:14px;
  color:var(--ink-dim);
  line-height:1.6;
  flex:1;
  margin-bottom:20px;
}
.tile-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:600;
  color:var(--crimson);
  padding-top:16px;
  border-top:1px solid var(--line-2);
  margin-top:auto;
}
.tile-cta .arrow{transition:transform .25s}
.tile:hover .tile-cta .arrow{transform:translateX(4px)}

/* ================================================
   BOLLYWOOD BANNER — cinematic title card
   ================================================ */
.bollywood-banner{
  padding:50px 24px;
  background:
    linear-gradient(90deg,
      rgba(42,77,50,0.08),
      rgba(199,133,53,0.15) 40%,
      rgba(199,133,53,0.15) 60%,
      rgba(42,77,50,0.08)),
    var(--bg-warm);
  border-top:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
  position:relative;
  overflow:hidden;
}
.bollywood-banner::before,
.bollywood-banner::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:6px;
  background:
    repeating-linear-gradient(90deg,
      rgba(35,24,17,0.3) 0 14px,
      transparent 14px 28px);
  pointer-events:none;
}
.bollywood-banner::before{top:0}
.bollywood-banner::after{bottom:0}

.banner-frame{
  max-width:1100px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:32px;
  justify-content:center;
}
.banner-marks{
  flex-shrink:0;
  color:var(--crimson);
  opacity:0.55;
  width:80px;
}
.banner-marks svg{width:100%;height:auto;display:block}
@media(max-width:700px){
  .banner-marks{display:none}
}

.banner-text{
  text-align:center;
  flex:1;
}
.banner-label{
  font-size:11px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.35em;
  color:var(--crimson);
  margin-bottom:14px;
  font-family:'Inter',sans-serif;
}
.banner-headline{
  font-family:'Fraunces',serif;
  font-weight:800;
  font-size:clamp(28px, 4.5vw, 48px);
  line-height:1.1;
  letter-spacing:-0.015em;
  color:var(--ink);
  margin:0;
}
.banner-headline em{
  font-weight:400;
  font-style:italic;
  color:var(--crimson);
  position:relative;
  padding:0 4px;
}

/* ================================================
   FINAL CTA
   ================================================ */
.final-cta{
  padding:140px 0;
  border-top:1px solid var(--line);
  background:
    radial-gradient(ellipse at center top, rgba(199,133,53,0.25), transparent 55%),
    radial-gradient(ellipse at center bottom, rgba(42,77,50,0.1), transparent 60%),
    var(--bg-deep);
  position:relative;
  overflow:hidden;
}
.final-cta::before{
  content:"";
  position:absolute;
  top:30px;
  left:50%;
  transform:translateX(-50%);
  width:60px;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--crimson), transparent);
  opacity:0.5;
}
.final-inner{
  max-width:720px;
  margin:0 auto;
  text-align:center;
}
.final-cta h2{
  margin-bottom:20px;
}
.final-cta p{
  font-size:18px;
  color:var(--ink-dim);
  margin-bottom:40px;
  line-height:1.6;
  max-width:540px;
  margin-left:auto;
  margin-right:auto;
}
.final-cta-row{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

/* ================================================
   FOOTER
   ================================================ */
footer{
  padding:40px 0;
  border-top:1px solid var(--line);
  background:var(--bg);
  position:relative;
  z-index:2;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:24px;
}
.footer-socials{
  display:flex;
  gap:10px;
}
.footer-socials a{
  width:38px;
  height:38px;
  border-radius:50%;
  border:1px solid var(--line-2);
  display:grid;
  place-items:center;
  color:var(--ink-dim);
  transition:all .25s;
}
.footer-socials a:hover{
  color:var(--crimson);
  border-color:var(--crimson);
  background:rgba(42,77,50,0.05);
  transform:translateY(-2px);
}
.footer-socials svg{width:16px;height:16px}
.footer-copy{
  font-size:13px;
  color:var(--muted);
}

/* ================================================
   REVEAL ANIMATION
   ================================================ */
.reveal{
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity .9s cubic-bezier(.2,.8,.3,1) var(--d, 0s),
    transform .9s cubic-bezier(.2,.8,.3,1) var(--d, 0s);
}
.reveal.in{opacity:1;transform:none}

/* ================================================
   MOBILE POLISH
   ================================================ */
@media(max-width:600px){
  .container,.nav-inner,.hero-container{padding-left:20px;padding-right:20px}
  .hero{padding:50px 0 70px}
  .about,.pillars-section,.begin{padding:70px 0}
  .final-cta{padding:90px 0}
  .focus-card{padding:32px 24px}
  .pillar{padding:28px}
  .tile{padding:24px}
}
