/* Raaviraj Foundation — Jaipur Pink City palette
   Saffron, terracotta, indigo, raw cream. No emoji icons. */

:root{
  --pink:        #c2185b;
  --pink-deep:   #8a1144;
  --saffron:     #e87722;
  --indigo:      #1f2a55;
  --cream:       #fdf6ec;
  --cream-2:     #f6ead4;
  --ink:         #1a1410;
  --ink-soft:    #4a3f37;
  --line:        rgba(26,20,16,.12);
  --line-light:  rgba(255,255,255,.18);
  --max:         1200px;
  --radius:      14px;
  --radius-sm:   8px;
  --shadow:      0 1px 0 rgba(26,20,16,.04), 0 8px 24px -16px rgba(26,20,16,.18);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg{ display:block; max-width:100%; }
a{ color:var(--pink); text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset:3px; }
h1,h2,h3{
  font-family:'Fraunces',Georgia,serif;
  font-weight:700;
  letter-spacing:-0.015em;
  color:var(--ink);
  margin:0 0 .5em;
  line-height:1.1;
}
h1{ font-size:clamp(2.4rem,5.5vw,4.4rem); font-weight:900; }
h2{ font-size:clamp(1.9rem,3.6vw,3rem); }
h3{ font-size:1.3rem; line-height:1.25; }
p{ margin:0 0 1em; }
em{ font-style:italic; color:var(--pink-deep); }

/* ---------- NAV ---------- */
.nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:24px;
  padding:18px clamp(20px,4vw,48px);
  background:rgba(253,246,236,.85);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--ink); }
.brand:hover{ text-decoration:none; }
.brand-mark{
  display:grid; place-items:center;
  width:42px; height:42px; border-radius:50%;
  background:var(--pink); color:var(--cream);
  font-family:'Tiro Devanagari Hindi',serif; font-size:22px;
  box-shadow:0 4px 12px -4px rgba(194,24,91,.5);
}
.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-name{ font-family:'Fraunces',serif; font-weight:700; font-size:1.15rem; }
.brand-sub{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); }

.nav-links{ display:flex; gap:26px; margin-left:auto; }
.nav-links a{
  color:var(--ink-soft); font-weight:500; font-size:.95rem;
  text-decoration:none;
}
.nav-links a:hover{ color:var(--pink); text-decoration:none; }
.nav-cta{ margin-left:8px; }

@media (max-width:780px){
  .nav-links{ display:none; }
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 22px; border-radius:999px;
  font-weight:600; font-size:.95rem; letter-spacing:.01em;
  text-decoration:none; cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  border:1px solid transparent;
}
.btn:hover{ text-decoration:none; transform:translateY(-1px); }
.btn-primary{ background:var(--pink); color:var(--cream); box-shadow:0 6px 18px -6px rgba(194,24,91,.55); }
.btn-primary:hover{ background:var(--pink-deep); box-shadow:0 10px 22px -8px rgba(194,24,91,.65); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(0,0,0,.03); }

/* ---------- HERO ---------- */
.hero{
  position:relative; overflow:hidden;
  padding:clamp(60px,9vw,120px) clamp(20px,4vw,48px) clamp(60px,7vw,100px);
  background:
    radial-gradient(1100px 500px at 85% -10%, rgba(232,119,34,.18), transparent 60%),
    radial-gradient(900px 600px at -10% 110%, rgba(194,24,91,.16), transparent 55%),
    linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
}
.hero-pattern{
  position:absolute; inset:0; pointer-events:none; opacity:.10;
  background-image:
    radial-gradient(circle at 1px 1px, var(--pink-deep) 1px, transparent 1.5px);
  background-size:22px 22px;
  mask-image:linear-gradient(180deg, transparent 0, black 30%, black 70%, transparent 100%);
}
.hero-inner{
  position:relative; max-width:var(--max); margin:0 auto;
}
.eyebrow{
  display:inline-block;
  font-family:'Tiro Devanagari Hindi','Fraunces',serif;
  color:var(--pink-deep);
  font-size:1.05rem;
  letter-spacing:.04em;
  margin-bottom:18px;
}
.eyebrow-dark{ color:var(--pink); font-family:'Inter',sans-serif; font-weight:600; font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; }
.eyebrow-light{ color:rgba(255,255,255,.85); font-family:'Inter',sans-serif; font-weight:600; font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; }
.hero h1{ max-width:18ch; margin-bottom:24px; }
.hero h1 .accent{ color:var(--pink); font-style:italic; font-weight:700; }
.lede{
  max-width:60ch; font-size:1.15rem; color:var(--ink-soft); margin-bottom:36px;
}
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:64px; }

.hero-stats{
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px; margin:0; padding-top:32px;
  border-top:1px solid var(--line);
}
.hero-stats > div{ display:flex; flex-direction:column; gap:4px; }
.hero-stats dt{
  font-family:'Fraunces',serif; font-weight:700;
  font-size:clamp(1.8rem,3.6vw,2.6rem);
  color:var(--ink); line-height:1;
}
.hero-stats dd{
  margin:0; font-size:.85rem; letter-spacing:.04em;
  color:var(--ink-soft); text-transform:uppercase;
}
@media (max-width:680px){
  .hero-stats{ grid-template-columns:repeat(2,1fr); gap:24px 16px; }
}

/* ---------- SECTIONS ---------- */
.section{
  padding:clamp(70px,9vw,130px) clamp(20px,4vw,48px);
  max-width:var(--max); margin:0 auto;
}
.section-cream{
  background:var(--cream-2); max-width:none;
  padding-left:clamp(20px,4vw,48px); padding-right:clamp(20px,4vw,48px);
}
.section-cream > *{ max-width:var(--max); margin-left:auto; margin-right:auto; }
.section-pink{
  background:linear-gradient(165deg, var(--pink) 0%, var(--pink-deep) 100%);
  color:var(--cream);
  max-width:none;
  padding-left:clamp(20px,4vw,48px); padding-right:clamp(20px,4vw,48px);
}
.section-pink > *{ max-width:var(--max); margin-left:auto; margin-right:auto; }
.section-pink h2{ color:var(--cream); }
.section-dark{
  background:var(--indigo); color:var(--cream);
  max-width:none;
  padding-left:clamp(20px,4vw,48px); padding-right:clamp(20px,4vw,48px);
}
.section-dark > *{ max-width:var(--max); margin-left:auto; margin-right:auto; }
.section-dark h2{ color:var(--cream); }

.section-head{ max-width:60ch; margin-bottom:48px; }
.section-head-light{ color:var(--cream); }
.section-head-light h2{ color:var(--cream); }
.section-sub{ color:var(--ink-soft); font-size:1.1rem; }
.section-head-light .section-sub{ color:rgba(255,255,255,.85); }

/* ---------- MISSION ---------- */
.grid-2{
  display:grid; grid-template-columns:1fr 1.4fr;
  gap:clamp(40px,7vw,100px); align-items:start;
}
.mission-body p{ color:var(--ink-soft); font-size:1.08rem; }
.mission-body p:first-child{ color:var(--ink); font-size:1.18rem; }
.signature{ font-family:'Fraunces',serif; font-style:italic; color:var(--pink-deep); margin-top:24px; }
@media (max-width:780px){
  .grid-2{ grid-template-columns:1fr; gap:24px; }
}

/* ---------- CARDS ---------- */
.cards{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:18px;
}
.card{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 26px 30px;
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform:translateY(-3px);
  border-color:var(--pink);
  box-shadow:0 1px 0 rgba(26,20,16,.04), 0 18px 36px -20px rgba(194,24,91,.4);
}
.card h3{ margin-bottom:8px; }
.card p{ margin:0; color:var(--ink-soft); font-size:.98rem; line-height:1.55; }
.card-icon{
  width:44px; height:44px; border-radius:10px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(194,24,91,.10), rgba(232,119,34,.10));
  color:var(--pink-deep);
  margin-bottom:20px;
}
.card-icon svg{ width:24px; height:24px; }
.card-quiet{
  background:transparent;
  border-style:dashed;
  box-shadow:none;
}

/* ---------- IMPACT ---------- */
.impact-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--line-light);
  border-left:1px solid var(--line-light);
}
.impact-stat{
  border-right:1px solid var(--line-light);
  border-bottom:1px solid var(--line-light);
  padding:36px 28px;
  display:flex; flex-direction:column; gap:8px;
  min-height:160px; justify-content:center;
}
.impact-stat .num{
  font-family:'Fraunces',serif; font-weight:700;
  font-size:clamp(2.4rem,4.5vw,3.4rem);
  line-height:1; color:var(--cream);
}
.impact-stat .label{
  color:rgba(255,255,255,.78); font-size:.92rem;
  max-width:24ch;
}
@media (max-width:780px){
  .impact-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:480px){
  .impact-grid{ grid-template-columns:1fr; }
}

/* ---------- INVOLVE ---------- */
.involve-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.involve-card{
  background:#fff; border:1px solid var(--line);
  border-radius:var(--radius);
  padding:32px 28px;
  display:flex; flex-direction:column; gap:14px;
  box-shadow:var(--shadow);
}
.involve-card h3{ margin:6px 0 0; }
.involve-card p{ color:var(--ink-soft); margin:0; }
.involve-card .btn{ align-self:flex-start; margin-top:6px; }
.involve-card .micro{
  font-size:.82rem; color:var(--ink-soft);
  margin-top:auto; padding-top:8px;
}
.badge{
  align-self:flex-start;
  background:var(--pink); color:var(--cream);
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase;
  font-weight:600;
  padding:5px 10px; border-radius:999px;
}
.badge-quiet{
  background:transparent; color:var(--ink-soft);
  border:1px solid var(--line);
}
@media (max-width:840px){
  .involve-grid{ grid-template-columns:1fr; }
}

/* ---------- CONTACT ---------- */
.contact-inner{
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:clamp(40px,7vw,80px); align-items:start;
}
.contact-body{ color:rgba(255,255,255,.82); font-size:1.1rem; max-width:38ch; }
.contact-list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:18px;
}
.contact-list li{
  display:grid; grid-template-columns:130px 1fr;
  gap:24px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line-light);
  color:rgba(255,255,255,.92);
}
.contact-list li:last-child{ border-bottom:none; }
.contact-label{
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.contact-list a{ color:var(--cream); text-decoration:underline; text-underline-offset:3px; text-decoration-color:rgba(255,255,255,.4); }
.contact-list a:hover{ text-decoration-color:var(--cream); }
@media (max-width:780px){
  .contact-inner{ grid-template-columns:1fr; }
  .contact-list li{ grid-template-columns:1fr; gap:4px; }
}

/* ---------- FOOTER ---------- */
.foot{
  background:#0f1430; color:rgba(255,255,255,.7);
  padding:28px clamp(20px,4vw,48px);
  font-size:.88rem;
}
.foot-inner{
  max-width:var(--max); margin:0 auto;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  flex-wrap:wrap;
}
.foot-mantra{
  font-family:'Tiro Devanagari Hindi',serif;
  color:rgba(255,255,255,.55);
  letter-spacing:.05em;
}

/* ---------- MOTION ---------- */
@media (prefers-reduced-motion: reduce){
  *{ transition:none !important; animation:none !important; }
  html{ scroll-behavior:auto; }
}
