/* Maa ChinnaMasta Temple — static rebuild
   Single lightweight stylesheet. System fonts, no external requests. */

:root{
  --maroon:#6a1b3d;
  --maroon-dark:#4d122c;
  --saffron:#c8841f;
  --gold:#d9a534;
  --cream:#fdf7f0;
  --cream-2:#f6ebdd;
  --ink:#241a1f;
  --muted:#6c5b62;
  --line:#e8d6c6;
  --maxw:1100px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--maroon);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:50;background:var(--cream);border-bottom:1px solid var(--line);box-shadow:0 1px 8px rgba(0,0,0,.04)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:78px}
.brand{display:flex;align-items:center;flex:0 0 auto}  /* never let the flex row squeeze the logo */
/* max-width:none defeats the global img{max-width:100%}: with height pinned at 48px, a
   clamped width breaks the logo's true 410:72 ratio (it renders ~212px wide = squished). */
.brand img{height:40px;width:auto;max-width:none;display:block}

nav.main{display:flex;align-items:center;gap:4px}
nav.main ul{list-style:none;display:flex;align-items:center;margin:0;padding:0;gap:2px}
nav.main li{position:relative}
nav.main > ul > li > a{display:block;padding:10px 9px;color:var(--ink);font-weight:600;font-size:15px;border-radius:6px;white-space:nowrap}
nav.main > ul > li > a:hover{background:var(--cream-2);text-decoration:none;color:var(--maroon)}
nav.main .dropdown{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,.12);min-width:230px;padding:6px;display:none;flex-direction:column}
nav.main li:hover > .dropdown,nav.main li:focus-within > .dropdown{display:flex}
nav.main .dropdown a{padding:8px 12px;border-radius:6px;color:var(--ink);font-size:14.5px;white-space:nowrap}
nav.main .dropdown a:hover{background:var(--cream-2);color:var(--maroon);text-decoration:none}
nav.main .dropdown .dd-head{font-weight:700;color:var(--maroon);white-space:normal}
/* Wide, scrollable Temples mega-dropdown (20+ shrines) */
nav.main .dropdown-temples{min-width:300px;max-height:72vh;overflow-y:auto}
nav.main .dropdown-temples .dd-head + a{margin-top:2px}
nav.main .dropdown-temples a.dd-head:last-child{margin-top:6px;border-top:1px solid var(--line);padding-top:10px}

/* Call-to-action buttons in the nav */
nav.main .nav-cta{margin-left:4px}
nav.main .nav-cta a{display:block;padding:9px 12px;border-radius:8px;font-weight:700;font-size:14.5px}
nav.main .nav-cta a:hover{text-decoration:none}
/* NB: scoped under `nav.main .nav-cta` so they outrank the general nav-link rule
   `nav.main > ul > li > a{color:var(--ink)}` (0,0,1,4); a bare `.btn-join` (0,0,1,0)
   loses the cascade and the label renders dark-on-maroon. */
nav.main .nav-cta a.btn-join{background:var(--maroon);color:#fff}
nav.main .nav-cta a.btn-join:hover{background:var(--maroon-dark);color:#fff}
nav.main .nav-cta a.btn-contact{background:transparent;border:1.5px solid var(--maroon);color:var(--maroon)}
nav.main .nav-cta a.btn-contact:hover{background:var(--maroon);color:#fff}

.menu-toggle{display:none;background:var(--maroon);color:#fff;border:0;border-radius:6px;padding:9px 12px;font-size:16px;cursor:pointer}

/* Collapse to the hamburger at 1080px: below this the wide horizontal nav
   (~780px) + logo no longer fit the 1100px content column without crowding. */
@media(max-width:1080px){
  .menu-toggle{display:block}
  nav.main{display:none;position:absolute;top:78px;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--line);padding:10px 20px;max-height:calc(100vh - 78px);overflow-y:auto}
  nav.main.open{display:block}
  nav.main ul{flex-direction:column;align-items:stretch;gap:0;width:100%}
  nav.main > ul > li > a{padding:12px 8px;border-bottom:1px solid var(--line)}
  nav.main .dropdown{position:static;display:flex;box-shadow:none;border:0;padding:0 0 6px 14px;min-width:0;max-height:none}
  nav.main .dropdown a{padding:8px;white-space:normal}
  nav.main .nav-cta{margin:8px 0 0}
  nav.main .nav-cta a{text-align:center}
}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(135deg,var(--maroon) 0%,var(--maroon-dark) 100%);color:#fdeede;text-align:center;padding:64px 20px 56px}
.hero h1{font-size:40px;margin:0 0 12px;color:#fff;line-height:1.2}
.hero p{font-size:19px;max-width:720px;margin:0 auto 26px;color:#f0d8c2}
.hero .yantra{width:140px;height:140px;margin:0 auto 22px;border-radius:50%;background:#fff;padding:8px;box-shadow:0 6px 24px rgba(0,0,0,.25)}
.quick{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:8px}
.quick a{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;padding:10px 18px;border-radius:30px;font-weight:600;font-size:15px}
.quick a:hover{background:var(--gold);color:var(--maroon-dark);text-decoration:none;border-color:var(--gold)}

/* ---------- Sections ---------- */
main{padding:0 0 10px}
section.block{padding:48px 0}
section.block:nth-child(even){background:var(--cream-2)}
.block h2{color:var(--maroon);font-size:28px;margin:0 0 18px;line-height:1.25}
.block h3{color:var(--maroon-dark);font-size:21px;margin:26px 0 8px}
.lead{font-size:19px;color:var(--muted)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.two-col img{border-radius:12px;box-shadow:0 8px 28px rgba(0,0,0,.14)}
@media(max-width:760px){.two-col{grid-template-columns:1fr;gap:22px}.hero h1{font-size:30px}}

.mantra{background:#fff;border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:10px;
  padding:22px 26px;margin:22px 0;font-size:19px;color:var(--maroon-dark);font-weight:600;text-align:center}
.mantra span{display:block;margin:6px 0}

.btn{display:inline-block;background:var(--maroon);color:#fff;padding:12px 24px;border-radius:30px;font-weight:600;margin-top:10px}
.btn:hover{background:var(--saffron);color:#fff;text-decoration:none}

/* ---------- Gallery grid ---------- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
.gallery a{display:block;border-radius:10px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.12);background:#fff}
.gallery img{width:100%;height:auto;display:block;transition:transform .3s}
.gallery a:hover img{transform:scale(1.05)}
@media(max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px;box-shadow:0 3px 14px rgba(0,0,0,.05)}
.card h3{margin-top:0}

/* ---------- Tables ---------- */
table.data{width:100%;border-collapse:collapse;margin:18px 0;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 3px 14px rgba(0,0,0,.06)}
table.data th{background:var(--maroon);color:#fff;text-align:left;padding:11px 14px;font-size:15px}
table.data td{padding:10px 14px;border-top:1px solid var(--line);font-size:15.5px}
table.data tr:nth-child(even) td{background:var(--cream)}
.month-tag{font-weight:700;color:var(--saffron)}

/* ---------- Forms ---------- */
form.temple-form{background:#fff;border:1px solid var(--line);border-radius:12px;padding:26px;max-width:620px;box-shadow:0 3px 14px rgba(0,0,0,.06)}
form.temple-form label{display:block;font-weight:600;margin:14px 0 5px;font-size:15px}
form.temple-form input,form.temple-form textarea,form.temple-form select{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:8px;font-size:15px;font-family:inherit;background:var(--cream)}
form.temple-form textarea{min-height:120px;resize:vertical}

/* ---------- Footer ---------- */
.site-footer{background:var(--maroon-dark);color:#e9d6c4;padding:46px 0 26px;margin-top:30px}
.site-footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.site-footer h4{color:#fff;font-size:16px;margin:0 0 12px;letter-spacing:.03em}
.site-footer a{color:#e9d6c4;font-size:14.5px}
.site-footer a:hover{color:var(--gold)}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:6px 0}
.social a{display:inline-block;margin-right:12px;font-weight:600}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:28px;padding-top:18px;text-align:center;font-size:13px;color:#caa890}
.disclaimer{font-size:12.5px;color:#b9967f;max-width:760px;margin:14px auto 0;text-align:center}
@media(max-width:760px){.site-footer .cols{grid-template-columns:1fr;gap:22px}}

/* ---------- Display typography (site-wide, dependency-free) ---------- */
:root{--serif:"Iowan Old Style","Palatino Linotype",Palatino,"Book Antiqua",Georgia,"Times New Roman",serif}
.hero h1,.block h2,.block h3,.site-footer h4{font-family:var(--serif);letter-spacing:.01em}

/* screen-reader-only (keep an H1 for SEO while the hero shows only imagery) */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ================= HOME PAGE ENHANCEMENTS (scoped to body.home) ================= */
/* Hero: deep cosmic night sky with a generated starfield, a framed temple poster,
   and a row of section cards — mirrors the live home page. */
.home .hero{position:relative;overflow:hidden;padding:40px 20px 56px;text-align:center;
  background:
    radial-gradient(1100px 560px at 50% -12%,#2c2f63 0%,transparent 60%),
    radial-gradient(820px 520px at 86% 116%,#3a2856 0%,transparent 56%),
    linear-gradient(180deg,#0a0d27 0%,#11143b 48%,#090b22 100%)}
/* Two tiled layers of stars for depth */
.home .hero::before,.home .hero::after{content:"";position:absolute;inset:0;pointer-events:none}
.home .hero::before{opacity:.9;background-repeat:repeat;background-size:260px 260px;
  background-image:
    radial-gradient(1.4px 1.4px at 24px 38px,#fff,transparent),
    radial-gradient(1.2px 1.2px at 140px 96px,rgba(255,255,255,.9),transparent),
    radial-gradient(1px 1px at 70px 180px,rgba(255,255,255,.8),transparent),
    radial-gradient(1.6px 1.6px at 210px 50px,#fff,transparent),
    radial-gradient(1px 1px at 188px 210px,rgba(255,255,255,.7),transparent),
    radial-gradient(1.2px 1.2px at 40px 230px,rgba(255,255,255,.85),transparent)}
.home .hero::after{opacity:.55;background-repeat:repeat;background-size:380px 380px;
  background-image:
    radial-gradient(2px 2px at 320px 120px,#fff,transparent),
    radial-gradient(1px 1px at 90px 300px,rgba(255,255,255,.7),transparent),
    radial-gradient(2.2px 2.2px at 250px 330px,rgba(255,255,255,.95),transparent),
    radial-gradient(1px 1px at 150px 40px,rgba(255,255,255,.6),transparent)}
.home .hero>*{position:relative;z-index:1}
.hero-poster{width:88%;max-width:700px;margin:8px auto 0;border-radius:14px;
  box-shadow:0 22px 60px rgba(0,0,0,.6),0 0 0 1px rgba(217,165,52,.3)}

/* Section cards under the poster */
.hero-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:1000px;margin:34px auto 0}
.hcard{position:relative;display:block;border-radius:12px;overflow:hidden;aspect-ratio:1/1;
  box-shadow:0 10px 30px rgba(0,0,0,.45);background:#1a1c3a}
.hcard img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.hcard:hover{text-decoration:none}
.hcard:hover img{transform:scale(1.07)}
.hcard span{position:absolute;left:0;right:0;bottom:0;padding:30px 10px 12px;
  font-family:var(--serif);font-size:18px;font-weight:700;color:#fff;text-align:center;letter-spacing:.01em;
  text-shadow:0 2px 6px rgba(0,0,0,.85);background:linear-gradient(to top,rgba(0,0,0,.78),transparent)}
@media(max-width:760px){
  .hero-cards{grid-template-columns:repeat(2,1fr);gap:12px}
  .hero-poster{width:94%}
  .hcard span{font-size:16px;padding:24px 8px 10px}
}

/* Section heading flourish */
.home .block h2{position:relative;padding-bottom:14px}
.home .block h2::after{content:"";position:absolute;left:0;bottom:0;width:62px;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--gold),var(--saffron))}

/* Intro image framing */
.home .two-col img{border:1px solid var(--line)}

/* Mantra as a centrepiece with a faint Om watermark */
.home .mantra{position:relative;overflow:hidden;text-align:center;border-left:0;
  border:1px solid var(--line);border-top:4px solid var(--gold);
  background:linear-gradient(180deg,#fff,var(--cream));padding:34px 30px;font-size:20px}
.home .mantra::before{content:"\0950";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:190px;line-height:1;color:var(--gold);opacity:.07;pointer-events:none}
.home .mantra span{position:relative}

/* floating whatsapp */
.wa{position:fixed;right:18px;bottom:18px;width:54px;height:54px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.3);z-index:60}
.wa img{width:30px;height:30px}
