/* ===========================================================
   Govinda's — Shuddha Sattva  |  Phase 1 stylesheet
   =========================================================== */
:root{
  --maroon:#82392d;        /* brand (sampled from logo) */
  --maroon-dark:#5e2820;
  --maroon-deep:#3d1a14;
  --saffron:#e75b1e;       /* CTA / accent */
  --saffron-dark:#c8480f;
  --gold:#c79a3b;
  --gold-soft:#e3cf7a;
  --cream:#fbf4e6;
  --cream-2:#f6ecd8;
  --ink:#2c1d17;
  --ink-soft:#6b5347;
  --line:rgba(130,57,45,.16);
  --white:#fff;
  --shadow:0 18px 50px -22px rgba(61,26,20,.45);
  --shadow-sm:0 8px 24px -14px rgba(61,26,20,.4);
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Mulish",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --radius:16px;
  --maxw:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
section[id],footer[id]{scroll-margin-top:78px}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--maroon);text-decoration:none}
.container{width:min(var(--maxw),92vw);margin-inline:auto}
.section{padding:clamp(3.5rem,8vw,6.5rem) 0}
.section-cream{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%)}

/* ---------- typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.12;margin:0}
.section-title{font-size:clamp(2rem,4.4vw,3.1rem);color:var(--maroon);letter-spacing:.2px}
.section-title em{font-style:italic;color:var(--saffron)}
.section-title.light{color:#fff}
.eyebrow{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.22em;
  font-size:.72rem;color:var(--saffron);margin:0 0 .6rem}
.eyebrow.light{color:var(--gold-soft)}
.section-head{text-align:center;max-width:720px;margin:0 auto clamp(2rem,4vw,3.2rem)}
.section-intro{color:var(--ink-soft);font-size:1.05rem;margin:.8rem auto 0}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:700;font-size:.92rem;letter-spacing:.02em;
  padding:.85rem 1.6rem;border-radius:999px;border:2px solid transparent;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:.55rem 1.1rem;font-size:.82rem}
.btn-block{width:100%}
.btn-saffron{background:var(--saffron);color:#fff;box-shadow:0 10px 26px -12px rgba(231,91,30,.8)}
.btn-saffron:hover{background:var(--saffron-dark)}
.btn-maroon{background:var(--maroon);color:#fff;box-shadow:0 10px 26px -12px rgba(130,57,45,.8)}
.btn-maroon:hover{background:var(--maroon-dark)}
.btn-outline{border-color:var(--maroon);color:var(--maroon);background:transparent}
.btn-outline:hover{background:var(--maroon);color:#fff}
.btn-ghost{color:var(--maroon);background:rgba(130,57,45,.07)}
.btn-ghost:hover{background:rgba(130,57,45,.14)}
.btn-outline-light{border-color:rgba(255,255,255,.8);color:#fff}
.btn-outline-light:hover{background:#fff;color:var(--maroon)}
.btn-ghost-light{color:#fff;background:rgba(255,255,255,.14)}
.btn-ghost-light:hover{background:rgba(255,255,255,.26)}
.btn-disabled{opacity:.75;cursor:default;border-style:dashed}
.btn-disabled:hover{transform:none}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(251,244,230,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 6px 24px -16px rgba(61,26,20,.5)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand-logo{height:46px;width:auto}
.brand-sub{font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--maroon);
  border-left:1px solid var(--line);padding-left:.7rem}
.nav{display:flex;align-items:center;gap:1.7rem}
.nav a{font-weight:600;font-size:.94rem;color:var(--ink);position:relative}
.nav a:not(.btn):hover{color:var(--saffron)}
.nav a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;
  background:var(--saffron);transition:width .25s}
.nav a:not(.btn):hover::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;padding:.4rem;cursor:pointer}
.nav-toggle span{width:26px;height:2.5px;background:var(--maroon);border-radius:2px;transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;color:#fff;text-align:center;
  background:
    radial-gradient(115% 80% at 50% 16%,rgba(231,191,108,.30),transparent 58%),
    radial-gradient(90% 70% at 84% 92%,rgba(231,91,30,.26),transparent 55%),
    radial-gradient(70% 60% at 12% 88%,rgba(199,154,59,.18),transparent 55%),
    linear-gradient(158deg,#3d1a14 0%,#5e2820 46%,#82392d 100%)}
/* festive bokeh + vignette */
.hero-overlay{position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 18% 30%,rgba(255,224,160,.5) 0 2px,transparent 3px),
    radial-gradient(circle at 76% 22%,rgba(255,224,160,.4) 0 3px,transparent 4px),
    radial-gradient(circle at 62% 68%,rgba(255,224,160,.35) 0 2px,transparent 3px),
    radial-gradient(circle at 30% 76%,rgba(255,224,160,.3) 0 2px,transparent 3px),
    radial-gradient(circle at 88% 60%,rgba(255,224,160,.3) 0 2px,transparent 3px),
    radial-gradient(120% 100% at 50% 50%,transparent 60%,rgba(40,16,12,.55))}
.hero-content{position:relative;z-index:2;padding:5rem 0;max-width:840px}
.hero-eyebrow{text-transform:uppercase;letter-spacing:.3em;font-size:.74rem;font-weight:700;
  color:var(--gold-soft);margin:0 0 1.6rem}
.hero-logo{height:clamp(82px,13vw,136px);width:auto;margin:0 auto;
  filter:drop-shadow(0 6px 22px rgba(0,0,0,.45))}
.hero-sub{display:flex;align-items:center;justify-content:center;gap:1rem;
  font-family:var(--serif);font-size:clamp(1.3rem,3vw,1.9rem);font-style:italic;
  letter-spacing:.32em;text-transform:uppercase;margin:.4rem 0 1.2rem;color:#fff}
.hero-sub .rule{height:1px;width:clamp(28px,8vw,70px);background:var(--gold-soft);opacity:.8}
.hero-tagline{font-family:var(--serif);font-size:clamp(1.5rem,3.6vw,2.3rem);color:var(--gold-soft);margin:.2rem 0 .6rem}
.hero-lead{font-size:1.1rem;max-width:560px;margin:0 auto 2rem;color:rgba(255,255,255,.9)}
.hero-cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.8);font-size:1.6rem;z-index:2;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- ethos ---------- */
.ethos{background:var(--maroon);color:#fff;padding:clamp(2.4rem,5vw,3.4rem) 0}
.ethos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
.ethos-item{text-align:center;padding:0 .6rem}
.ethos-item h3{font-size:1.3rem;margin:.6rem 0 .3rem;color:var(--gold-soft)}
.ethos-item p{font-size:.92rem;color:rgba(255,255,255,.82);margin:0}
.ethos-icon{display:inline-block;width:44px;height:44px;border:2px solid var(--gold-soft);
  border-radius:50%;position:relative}
.ethos-icon::after{content:"❀";position:absolute;inset:0;display:grid;place-items:center;
  color:var(--gold-soft);font-size:1.2rem}
.ethos-icon[data-icon="no-garlic"]::after{content:"⊘"}
.ethos-icon[data-icon="lotus"]::after{content:"卐";font-size:1rem}
.ethos-icon[data-icon="heart"]::after{content:"♥"}
.ethos-icon[data-icon="leaf"]::after{content:"☘"}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.about-media{position:relative}
.about-photo{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}
.about-iskcon{position:absolute;top:-26px;left:-18px;width:104px;height:104px;object-fit:contain;
  background:var(--cream);border-radius:50%;padding:12px;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.about-body{font-size:1.08rem;color:var(--ink-soft);margin:1rem 0 1.4rem}
.about-tags{display:flex;flex-wrap:wrap;gap:.55rem}
.about-tags span{font-size:.8rem;font-weight:700;color:var(--maroon);
  background:rgba(199,154,59,.16);border:1px solid var(--line);padding:.35rem .85rem;border-radius:999px}

/* ---------- menu tiers ---------- */
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:start}
.tier-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.8rem 1.6rem;box-shadow:var(--shadow-sm)}
.tier-featured{border:2px solid var(--gold);box-shadow:0 24px 50px -24px rgba(130,57,45,.5);transform:translateY(-6px)}
.tier-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--saffron);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;padding:.3rem .9rem;border-radius:999px}
.tier-head{text-align:center;padding-bottom:1rem;border-bottom:1px dashed var(--line);margin-bottom:1rem}
.tier-head h3{font-size:1.8rem;color:var(--maroon)}
.tier-head h3 span{color:var(--gold);font-style:italic;font-weight:500}
.tier-head p{font-size:.9rem;color:var(--ink-soft);margin:.3rem 0 0}
.tier-list{list-style:none;margin:0;padding:0}
.tier-list li{display:flex;justify-content:space-between;gap:1rem;padding:.42rem 0;
  border-bottom:1px solid rgba(130,57,45,.07);font-size:.92rem}
.tier-list li:last-child{border-bottom:0}
.tier-cat{font-weight:700;color:var(--ink)}
.tier-detail{color:var(--ink-soft);text-align:right;flex-shrink:0}
.menu-note{text-align:center;color:var(--ink-soft);max-width:660px;margin:1.8rem auto 0;font-size:.96rem}
.menu-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:1.6rem}

/* ---------- weekend buffet ---------- */
.buffet{position:relative;background:var(--buffet-img) center/cover no-repeat fixed;color:#fff}
.buffet-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(61,26,20,.92) 38%,rgba(61,26,20,.6))}
.buffet-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr .8fr;
  gap:clamp(1.6rem,4vw,3rem);align-items:center}
.buffet-sub{font-size:1.15rem;color:var(--gold-soft);margin:.6rem 0 1.3rem;font-family:var(--serif);font-style:italic}
.buffet-highlights{columns:2;gap:1.4rem;list-style:none;padding:0;margin:0 0 1.8rem}
.buffet-highlights li{padding:.3rem 0 .3rem 1.5rem;position:relative;color:rgba(255,255,255,.92);font-size:.96rem}
.buffet-highlights li::before{content:"❖";position:absolute;left:0;color:var(--gold-soft)}
.buffet-cta{display:flex;gap:.8rem;flex-wrap:wrap}
.buffet-card{background:rgba(255,255,255,.97);color:var(--ink);border-radius:var(--radius);
  padding:2rem 1.6rem;text-align:center;box-shadow:var(--shadow);border-top:5px solid var(--gold)}
.buffet-card-label{text-transform:uppercase;letter-spacing:.2em;font-size:.72rem;font-weight:700;color:var(--saffron);margin:0}
.buffet-price{font-family:var(--serif);font-size:4.2rem;color:var(--maroon);line-height:1;margin:.4rem 0 0;font-weight:700}
.buffet-price span{font-size:2.2rem;vertical-align:super}
.buffet-perhead{color:var(--ink-soft);margin:.1rem 0 1rem}
.buffet-meta{border-top:1px dashed var(--line);padding-top:1rem}
.buffet-meta p{margin:.2rem 0;font-size:.96rem}
.buffet-meta strong{color:var(--maroon);font-size:1.1rem}

/* ---------- cakes ---------- */
.cake-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.cake-group{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm)}
.cake-group-name{font-size:1.5rem;color:var(--maroon);text-align:center;padding-bottom:.7rem;
  margin-bottom:.7rem;border-bottom:2px solid var(--gold-soft);position:relative}
.cake-flavours{list-style:none;margin:0;padding:0}
.cake-flavours li{padding:.45rem 0 .45rem 1.6rem;position:relative;color:var(--ink-soft);
  border-bottom:1px solid rgba(130,57,45,.07);font-size:.95rem}
.cake-flavours li:last-child{border-bottom:0}
.cake-flavours li::before{content:"✦";position:absolute;left:0;color:var(--gold)}
.cake-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin:1.8rem 0}
.cake-posters{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:1rem}
.cake-posters img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow-sm)}

/* ---------- gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gallery-item{position:relative;margin:0;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);
  aspect-ratio:1;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-item:hover img,.gallery-item:focus img{transform:scale(1.08)}
.gallery-item figcaption{position:absolute;inset:auto 0 0 0;padding:1.4rem .8rem .6rem;
  background:linear-gradient(transparent,rgba(61,26,20,.85));color:#fff;font-size:.85rem;font-weight:600;
  opacity:0;transform:translateY(8px);transition:.3s}
.gallery-item:hover figcaption,.gallery-item:focus figcaption{opacity:1;transform:none}

/* ---------- ratings ---------- */
.rating-score{color:var(--saffron)}
.rating-stars{color:var(--gold);font-size:1.6rem;vertical-align:middle;margin-left:.4rem;letter-spacing:2px}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.testimonial{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;
  margin:0;box-shadow:var(--shadow-sm)}
.t-stars{color:var(--gold);letter-spacing:2px;margin-bottom:.6rem}
.t-stars .t-dim{color:rgba(130,57,45,.2)}
.testimonial blockquote{margin:0 0 1rem;font-family:var(--serif);font-size:1.2rem;color:var(--ink);line-height:1.45}
.testimonial figcaption{font-weight:700;color:var(--maroon);font-size:.92rem}
.ratings-cta{text-align:center;margin-top:2rem}

/* ---------- visit ---------- */
.visit-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3rem)}
.info-block{margin-top:1.4rem}
.info-block h4{font-size:1.05rem;color:var(--saffron);font-family:var(--sans);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}
.info-block p{margin:.2rem 0}
.info-row{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.muted{color:var(--ink-soft)}
.small{font-size:.85rem}
.link-arrow{font-weight:700;color:var(--saffron)}
.visit-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.8rem}
.visit-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:420px;border:1px solid var(--line)}
.visit-map iframe{width:100%;height:100%;min-height:420px;border:0;display:block}

/* ---------- footer ---------- */
.site-footer{background:var(--maroon-deep);color:rgba(255,255,255,.8)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem;padding:3.4rem 0 2.4rem}
.footer-logo{height:58px;margin-bottom:.7rem}
.footer-sub{font-size:.85rem;margin:0 0 .4rem}
.footer-tag{font-family:var(--serif);font-style:italic;color:var(--gold-soft);font-size:1.15rem;margin:.2rem 0 1rem}
.footer-iskcon{height:66px;opacity:.92}
.footer-links{display:flex;flex-direction:column;gap:.5rem}
.footer-links h5,.footer-contact h5{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;
  font-size:.78rem;color:var(--gold-soft);margin:0 0 .7rem}
.footer-links a{color:rgba(255,255,255,.8);font-size:.92rem}
.footer-links a:hover{color:#fff}
.footer-contact p{font-size:.9rem;margin:.3rem 0}
.footer-contact a{color:rgba(255,255,255,.85)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:1.1rem 0}
.footer-bottom .container{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom p{margin:0;font-size:.82rem;color:rgba(255,255,255,.6)}

/* ---------- floating whatsapp ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:70;width:56px;height:56px;border-radius:50%;
  background:#25d366;color:#fff;display:grid;place-items:center;box-shadow:0 12px 28px -8px rgba(0,0,0,.4);
  transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:90;display:none}
.modal.open{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(40,16,12,.6);backdrop-filter:blur(3px)}
.modal-dialog{position:relative;z-index:2;background:var(--cream);max-width:520px;width:92vw;
  margin:6vh auto;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow);
  max-height:88vh;overflow:auto;border-top:5px solid var(--gold)}
.modal-dialog h3{font-size:1.7rem;color:var(--maroon)}
.modal-sub{color:var(--ink-soft);margin:.3rem 0 1.2rem;font-size:.95rem}
.modal-close{position:absolute;top:.7rem;right:.9rem;background:none;border:0;font-size:1.8rem;
  color:var(--ink-soft);cursor:pointer;line-height:1}
.book-form .field{margin-bottom:.9rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.book-form label{display:block;font-size:.82rem;font-weight:700;color:var(--maroon);margin-bottom:.3rem}
.book-form input,.book-form select,.book-form textarea{width:100%;padding:.7rem .85rem;border:1px solid var(--line);
  border-radius:10px;font-family:var(--sans);font-size:.95rem;background:#fff;color:var(--ink)}
.book-form input:focus,.book-form select:focus,.book-form textarea:focus{outline:2px solid var(--saffron);border-color:transparent}
.book-note{font-size:.82rem;color:var(--ink-soft);background:rgba(199,154,59,.14);padding:.7rem .9rem;
  border-radius:10px;margin:.4rem 0 1rem}
.form-status{font-size:.9rem;margin-bottom:.8rem;display:none}
.form-status.show{display:block}
.form-status.ok{color:#1c7a3e}
.form-status.err{color:#b3261e}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}
  .hero{background-attachment:scroll}.buffet{background-attachment:scroll}}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .ethos-grid{grid-template-columns:repeat(2,1fr);gap:1.8rem}
  .tier-grid,.cake-groups,.testimonials{grid-template-columns:1fr;max-width:520px;margin-inline:auto}
  .tier-featured{transform:none}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .about-grid,.buffet-inner,.visit-grid{grid-template-columns:1fr}
  .about-iskcon{width:84px;height:84px;top:-18px}
  .buffet-highlights{columns:1}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .hero{background-attachment:scroll}
  .buffet{background-attachment:scroll}
  .nav{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;align-items:flex-start;
    gap:1.2rem;background:var(--cream);padding:5rem 2rem 2rem;transform:translateX(100%);
    transition:transform .32s ease;box-shadow:var(--shadow);z-index:55}
  .nav.open{transform:none}
  .nav a{font-size:1.1rem}
  .nav-toggle{display:flex;z-index:56}
  .nav-toggle.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
  .brand-sub{display:none}
  .cake-posters{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .info-row,.field-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom .container{justify-content:center;text-align:center}
}
