/* ===========================================================
   Masala Roots — shared site stylesheet
   Used by all pages. Brand system from the logo emblem.
   =========================================================== */
:root{
  --ink:#2A1B16; --ink-2:#3a2620; --gold:#E1A03B; --gold-deep:#c8842a;
  --clay:#B5482E; --ivory:#F7F1E7; --cream:#F4E9D6; --green:#3C5240;
  --text:#33302C; --muted:#6f675f; --line:rgba(42,27,22,.14);
  --radius:18px; --shadow:0 18px 50px -22px rgba(42,27,22,.45); --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--text);background:var(--ivory);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;color:var(--ink);line-height:1.12;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{font-family:'Inter';font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:.72rem;color:var(--gold-deep)}
.eyebrow.on-dark{color:var(--gold)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.96rem;padding:.85rem 1.5rem;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-deep)}
.btn-ghost{background:transparent;border-color:rgba(247,241,231,.4);color:var(--ivory)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-outline:hover{border-color:var(--ink);background:var(--ink);color:var(--ivory)}
.btn-dark-outline{background:transparent;border-color:rgba(247,241,231,.4);color:var(--ivory)}
.btn-dark-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-sm{padding:.6rem 1.05rem;font-size:.85rem}

/* Header */
header{position:sticky;top:0;z-index:50;background:rgba(247,241,231,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:'Fraunces';font-weight:600;font-size:1.15rem;letter-spacing:.04em;color:var(--ink)}
.brand .dot{width:8px;height:8px;border-radius:50%;background:var(--gold)}
nav.links{display:flex;align-items:center;gap:2rem}
nav.links a{font-size:.92rem;font-weight:500;color:var(--ink);opacity:.82}
nav.links a:hover,nav.links a.active{opacity:1;color:var(--gold-deep)}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.hamb{display:none;background:none;border:0;cursor:pointer;padding:6px}
.hamb span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0}
.mmenu{display:none;flex-direction:column;padding:14px 22px 22px;border-top:1px solid var(--line);background:var(--ivory)}
.mmenu a{padding:.7rem 0;font-weight:500;border-bottom:1px solid var(--line)}
.mmenu.open{display:flex}

/* Page hero (compact) */
.phero{position:relative;color:var(--ivory);background:var(--ink);overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;opacity:.4;background-size:cover;background-position:center}
.phero .inner{position:relative;padding:64px 0 56px}
.phero h1{color:var(--ivory);font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:600;letter-spacing:-.01em;max-width:18ch}
.phero p{color:rgba(247,241,231,.84);max-width:42ch;margin:.9rem 0 0;font-size:1.05rem}
.crumb{font-size:.8rem;color:rgba(247,241,231,.6);margin-bottom:1rem;letter-spacing:.02em}
.crumb a:hover{color:var(--gold)}
.phero-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.5rem}

/* Generic sections */
section.block{padding:72px 0}
.sec-head{max-width:42rem;margin-bottom:38px}
.sec-head h2{font-size:clamp(1.8rem,3.2vw,2.5rem);margin-top:.5rem}
.sec-head p{color:var(--muted);font-size:1.05rem;margin:.7rem 0 0}
.band-cream{background:var(--cream)}
.band-ink{background:var(--ink);color:var(--ivory)}
.band-ink .sec-head h2{color:var(--ivory)}
.band-ink .sec-head p{color:rgba(247,241,231,.72)}

/* Chips / category nav */
.chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:34px}
.chip{font-size:.82rem;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--line);padding:.5rem .95rem;border-radius:999px;transition:all .16s ease}
.chip:hover{background:var(--ink);color:var(--ivory);border-color:var(--ink)}

/* Menu list */
.menu-cat{margin-bottom:48px;scroll-margin-top:90px}
.menu-cat > h3{font-size:1.6rem;margin-bottom:.3rem}
.menu-cat .desc{color:var(--muted);margin:0 0 1.2rem;max-width:48ch}
.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px}
.mi{display:flex;justify-content:space-between;gap:1rem;padding:.65rem 0;border-bottom:1px dashed var(--line)}
.mi .name{font-weight:600;color:var(--ink)}
.mi .note{font-size:.84rem;color:var(--muted)}
.tagline-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.3rem}
.t{font-size:.66rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:999px}
.t.veg{color:var(--green);background:rgba(60,82,64,.12)}
.t.spice{color:var(--clay);background:rgba(181,72,46,.1)}
.t.pop{color:var(--gold-deep);background:rgba(225,160,59,.15)}

/* Cards / feature grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.card{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:0 12px 34px -26px rgba(42,27,22,.5)}
.card h3{font-size:1.3rem;margin-bottom:.4rem}
.card p{color:var(--muted);font-size:.95rem;margin:0}
.icon-num{width:38px;height:38px;border-radius:50%;background:var(--gold);color:var(--ink);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Fraunces';margin-bottom:.8rem}

/* Order options (reused) */
.order-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.ocard{background:var(--ink-2);border:1px solid rgba(247,241,231,.12);border-radius:var(--radius);padding:30px}
.ocard h3{color:var(--ivory);font-size:1.4rem}
.ocard .loc{display:flex;align-items:center;gap:.5rem;color:rgba(247,241,231,.7);font-size:.88rem;margin:.4rem 0 1.1rem}
.opts{display:flex;flex-direction:column;gap:12px;margin-top:.5rem}
.opt{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:rgba(247,241,231,.04);border:1px solid rgba(247,241,231,.12);border-radius:14px;padding:14px 16px;transition:border-color .18s ease,background .18s ease}
.opt:hover{border-color:var(--gold);background:rgba(225,160,59,.08)}
.opt .meta{font-size:.82rem;color:rgba(247,241,231,.66)}
.opt .meta b{color:var(--ivory);font-weight:600;font-size:.96rem;display:block;font-family:'Inter'}
.pill{font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--ink);background:var(--gold);padding:3px 9px;border-radius:999px}

/* Story */
.story{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.story blockquote{font-family:'Fraunces';font-style:italic;font-size:1.5rem;color:var(--ink);line-height:1.35;margin:0 0 1.2rem;border-left:3px solid var(--gold);padding-left:1.1rem}
.badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.3rem}
.badge{font-size:.78rem;font-weight:600;color:var(--green);background:rgba(60,82,64,.1);border:1px solid rgba(60,82,64,.2);padding:.4rem .8rem;border-radius:999px}
.photo-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5;background-size:cover;background-position:center}

/* Timeline */
.timeline{border-left:2px solid var(--line);padding-left:26px;display:flex;flex-direction:column;gap:26px}
.tl-item h4{font-size:1.15rem;margin-bottom:.2rem}
.tl-item span{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-deep)}
.tl-item p{color:var(--muted);margin:.3rem 0 0;font-size:.95rem}

/* Forms */
.form{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .full{grid-column:1/-1}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:.35rem}
.field input,.field textarea,.field select{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;background:#fff;color:var(--text)}
.field textarea{min-height:120px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--gold);border-color:var(--gold)}
.form-note{font-size:.8rem;color:var(--muted);margin-top:.4rem}

/* Info / contact rows */
.info-row{display:flex;gap:.8rem;align-items:flex-start;padding:.9rem 0;border-bottom:1px solid var(--line)}
.info-row .ic{color:var(--gold-deep);font-size:1.1rem;line-height:1.4}
.info-row b{display:block;color:var(--ink)}
.info-row span{color:var(--muted);font-size:.95rem}
.hours-table{width:100%;border-collapse:collapse;margin-top:.4rem}
.hours-table td{padding:.55rem 0;border-bottom:1px solid var(--line);font-size:.95rem}
.hours-table td:last-child{text-align:right;font-weight:600;color:var(--ink)}
.map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:340px;border:0;width:100%}

/* FAQ accordion */
.faq{max-width:48rem;margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa summary{cursor:pointer;list-style:none;padding:1.1rem 0;font-weight:600;color:var(--ink);font-size:1.05rem;display:flex;justify-content:space-between;gap:1rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:"+";color:var(--gold-deep);font-size:1.3rem;line-height:1}
.qa[open] summary::after{content:"–"}
.qa p{color:var(--muted);margin:0 0 1.1rem;font-size:.97rem}

/* CTA band */
.cta-band{position:relative;border-radius:24px;overflow:hidden;color:#fff;background:var(--ink);box-shadow:var(--shadow);text-align:center}
.cta-band .cin{position:relative;padding:54px 30px}
.cta-band h2{color:#fff;font-size:2rem}
.cta-band p{color:rgba(255,255,255,.82);margin:.7rem auto 1.5rem;max-width:34rem}

/* Footer */
footer{background:var(--ink);color:rgba(247,241,231,.7);padding:64px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
footer .emblem{width:120px;margin-bottom:1rem}
footer h5{font-family:'Inter';font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem}
footer a{display:block;color:rgba(247,241,231,.74);font-size:.92rem;margin-bottom:.6rem}
footer a:hover{color:var(--gold)}
.foot-bottom{border-top:1px solid rgba(247,241,231,.12);margin-top:42px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.82rem;color:rgba(247,241,231,.5)}

/* Mobile sticky order bar */
.mobile-order{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--ink);border-top:1px solid rgba(247,241,231,.14);padding:10px 14px;gap:10px}
.mobile-order .btn{flex:1;justify-content:center}

/* Reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* Responsive */
@media(max-width:900px){
  .grid-3,.grid-2,.order-grid,.story,.menu-items,.form{grid-template-columns:1fr}
  nav.links,.nav-cta .btn{display:none}
  .hamb{display:block}
  .mobile-order{display:flex}
  footer{padding-bottom:84px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
