/* ===========================================================
   Apna Roti Time — Punjabi Cuisine & Tiffin Service
   =========================================================== */

:root{
  --paper:        #FBF5E9;
  --paper-2:      #F5ECDA;
  --cream-card:   #FFFCF5;
  --ink:          #251E16;
  --ink-soft:     #6B5D4C;
  --line:         #E7DAC2;

  --brick:        #B8442B;
  --brick-dark:   #8F3320;
  --brick-tint:   #FBE6DD;
  --green:        #356145;
  --green-dark:   #284C36;
  --saffron:      #E2A02C;
  --saffron-soft: #F6E2B4;

  --roti:         #F2D49B;
  --roti-edge:    #C98A3E;

  --shadow-sm: 0 2px 8px rgba(60,40,20,.06);
  --shadow:    0 14px 40px -18px rgba(80,45,20,.35);
  --shadow-lg: 0 30px 70px -30px rgba(80,40,15,.45);

  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;

  --font-display: "Fraunces", Georgia, serif;
  --font-body: "DM Sans", system-ui, -apple-system, sans-serif;

  --maxw: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:88px; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } *{ animation:none!important; transition:none!important; } }

body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:600; line-height:1.08; margin:0; letter-spacing:-.01em; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
ul{ margin:0; padding:0; list-style:none; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }

.skip-link{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--ink); color:#fff; padding:10px 16px; border-radius:0 0 10px 0;
}
.skip-link:focus{ left:0; }

.ico{ width:18px; height:18px; fill:currentColor; flex:none; }

/* ───────── Buttons ───────── */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--font-body); font-weight:600; font-size:1rem;
  padding:13px 24px; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; transition:transform .18s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap; line-height:1;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--brick); color:#fff; box-shadow:0 10px 22px -10px rgba(184,68,43,.7); }
.btn-primary:hover{ background:var(--brick-dark); box-shadow:0 14px 28px -10px rgba(184,68,43,.8); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:var(--brick); color:var(--brick); transform:translateY(-2px); }
.btn-sm{ padding:10px 18px; font-size:.94rem; }
.btn-lg{ padding:16px 30px; font-size:1.05rem; }
.btn-block{ display:flex; width:100%; }

/* ───────── Header ───────── */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(251,245,233,.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled{ border-color:var(--line); box-shadow:var(--shadow-sm); }
.header-inner{ display:flex; align-items:center; gap:18px; min-height:72px; }

.brand{ display:flex; align-items:center; gap:11px; margin-right:auto; }
.brand-mark{ width:42px; height:42px; color:var(--brick); flex:none;
  background:var(--brick-tint); border-radius:13px; padding:5px; }
.brand-mark .bm-roti{ fill:var(--roti); stroke:var(--roti-edge); stroke-width:3; }
.brand-mark .bm-spots circle{ fill:var(--roti-edge); opacity:.7; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{ font-family:var(--font-display); font-weight:600; font-size:1.22rem; color:var(--ink); letter-spacing:-.02em; }
.brand-sub{ font-size:.68rem; text-transform:uppercase; letter-spacing:.22em; color:var(--brick); font-weight:600; margin-top:3px; }

.nav{ display:flex; gap:6px; }
.nav a{ padding:9px 14px; border-radius:999px; font-weight:500; font-size:.96rem; color:var(--ink-soft); transition:color .18s, background .18s; }
.nav a:hover{ color:var(--ink); background:var(--paper-2); }

.header-cta{ display:flex; align-items:center; gap:18px; }
.header-phone{ display:inline-flex; align-items:center; gap:7px; font-weight:600; font-size:.95rem; color:var(--ink); transition:color .18s; }
.header-phone .ico{ color:var(--brick); width:16px; height:16px; }
.header-phone:hover{ color:var(--brick); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; width:44px; height:40px; border:none; background:transparent; cursor:pointer; padding:8px; }
.nav-toggle span{ height:2.5px; width:100%; background:var(--ink); border-radius:2px; transition:transform .25s ease, opacity .2s ease; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

.mobile-nav{ display:none; flex-direction:column; gap:4px; padding:10px clamp(20px,5vw,40px) 22px; border-top:1px solid var(--line); background:var(--paper); }
.mobile-nav a{ padding:13px 6px; font-weight:500; font-size:1.05rem; border-bottom:1px solid var(--line); }
.mobile-nav a.btn{ margin-top:12px; border-bottom:none; justify-content:center; }

/* ───────── Hero ───────── */
.hero{ position:relative; padding:clamp(48px,8vw,96px) 0 clamp(56px,7vw,86px); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.blob{ position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; }
.blob-1{ width:520px; height:520px; background:radial-gradient(circle,#F6D9A0,transparent 70%); top:-160px; right:-120px; }
.blob-2{ width:440px; height:440px; background:radial-gradient(circle,#E9C3B4,transparent 70%); bottom:-180px; left:-140px; opacity:.45; }

.hero-inner{ position:relative; z-index:1; display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(30px,5vw,70px); align-items:center; }

.eyebrow{ display:inline-flex; align-items:center; gap:9px; font-size:.82rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--green-dark); background:#E6EFE3; padding:7px 14px; border-radius:999px; }
.eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 0 4px rgba(53,97,69,.18); }

h1{ font-size:clamp(2.4rem,5.6vw,4rem); margin:20px 0 0; font-weight:600; }
h1 .accent{ color:var(--brick); font-style:italic; font-weight:500; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.22rem); color:var(--ink-soft); max-width:34ch; margin-top:18px; }

.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.hero-points{ display:flex; flex-wrap:wrap; gap:8px 22px; margin-top:30px; }
.hero-points li{ display:flex; align-items:center; gap:8px; font-size:.95rem; color:var(--ink-soft); font-weight:500; }
.hero-points .ico{ color:var(--green); width:16px; height:16px; }
.hero-points strong{ color:var(--ink); }

/* Hero tiffin illustration */
.hero-card{ position:relative; justify-self:center; }
.tiffin-illo{ position:relative; width:min(360px,80vw); margin-inline:auto;
  filter:drop-shadow(0 28px 46px rgba(120,70,20,.26));
  animation:floaty 7s ease-in-out infinite; }
.tiffin-illo::before{ content:""; position:absolute; inset:-8% -8% 2%; z-index:-1; border-radius:50%;
  background:radial-gradient(circle at 50% 42%, #FFFFFF 0%, #FBF2DD 50%, rgba(251,242,221,0) 72%); }
.tiffin-svg{ width:100%; height:auto; display:block; overflow:visible; }
.steam path{ transform-box:fill-box; transform-origin:center bottom; opacity:0; animation:steam 3.4s ease-in-out infinite; }
.steam path:nth-child(2){ animation-delay:.55s; }
.steam path:nth-child(3){ animation-delay:1.1s; }
@keyframes steam{ 0%{ opacity:0; transform:translateY(5px) scaleY(.85); } 35%{ opacity:.55; } 100%{ opacity:0; transform:translateY(-12px) scaleY(1.1); } }

.hero-card-tag{
  position:absolute; bottom:2%; right:-4%;
  display:flex; align-items:center; gap:11px;
  background:var(--cream-card); padding:12px 16px; border-radius:var(--r);
  box-shadow:var(--shadow); border:1px solid var(--line);
}
.hero-card-tag strong{ display:block; font-size:.95rem; }
.hero-card-tag small{ color:var(--ink-soft); font-size:.78rem; }
.veg-dot{ width:18px; height:18px; border:2.5px solid var(--green); border-radius:4px; display:grid; place-items:center; flex:none; }
.veg-dot::after{ content:""; width:8px; height:8px; border-radius:50%; background:var(--green); }

@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-12px); } }

/* ───────── Trust strip ───────── */
.trust{ background:var(--ink); color:var(--paper); }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; padding:26px 0; }
.trust-item{ display:flex; align-items:center; gap:13px; }
.trust-ico{ font-size:1.7rem; line-height:1; }
.trust-item strong{ display:block; font-size:1.02rem; font-family:var(--font-display); }
.trust-item small{ color:#C9BBA6; font-size:.83rem; }

/* ───────── Sections ───────── */
.section{ padding:clamp(56px,8vw,104px) 0; }
.section-head{ max-width:680px; margin-bottom:clamp(34px,5vw,52px); }
.kicker{ font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.18em; color:var(--brick); margin-bottom:14px; }
.section-head h2{ font-size:clamp(1.9rem,3.8vw,2.9rem); }
.section-sub{ color:var(--ink-soft); font-size:1.08rem; margin-top:16px; }

/* ───────── Tiffin ───────── */
.tiffin{ background:linear-gradient(180deg,var(--paper),var(--paper-2)); }
.tiffin-layout{ display:grid; grid-template-columns:340px 1fr; gap:clamp(24px,3vw,40px); align-items:start; }

.plan-card{
  position:relative; background:var(--green-dark); color:#fff;
  border-radius:var(--r-lg); padding:34px 30px;
  box-shadow:var(--shadow); overflow:hidden;
}
.plan-card::before{ content:""; position:absolute; top:-60px; right:-60px; width:180px; height:180px; border-radius:50%; background:rgba(255,255,255,.06); }
.plan-badge{ display:inline-block; background:var(--saffron); color:#3a2a08; font-weight:700; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:999px; margin-bottom:18px; }
.plan-card h3{ font-size:1.6rem; }
.plan-price{ display:flex; align-items:baseline; flex-wrap:wrap; gap:6px; margin:10px 0 22px; }
.plan-from{ width:100%; font-size:.82rem; text-transform:uppercase; letter-spacing:.12em; color:#BFD6C4; }
.plan-amt{ font-family:var(--font-display); font-size:3rem; font-weight:600; line-height:1; }
.plan-per{ color:#BFD6C4; font-weight:500; }
.plan-list{ display:grid; gap:11px; margin-bottom:26px; }
.plan-list li{ position:relative; padding-left:28px; font-size:.97rem; color:#EAF2EC; }
.plan-list li::before{ content:""; position:absolute; left:0; top:3px; width:18px; height:18px; border-radius:50%; background:var(--saffron);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/13px no-repeat; }
.plan-card .btn-primary{ background:var(--saffron); color:#3a2a08; box-shadow:none; }
.plan-card .btn-primary:hover{ background:#f2ad3e; }
.plan-note{ font-size:.8rem; color:#BFD6C4; margin-top:14px; line-height:1.5; }

.schedule{ background:var(--cream-card); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(22px,3vw,34px); box-shadow:var(--shadow-sm); }
.schedule-head{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; margin-bottom:22px; }
.schedule-head h3{ font-size:1.35rem; }
.week-toggle{ display:inline-flex; background:var(--paper-2); border-radius:999px; padding:4px; gap:2px; }
.wt-btn{ border:none; background:transparent; font-family:var(--font-body); font-weight:600; font-size:.92rem; color:var(--ink-soft); padding:9px 20px; border-radius:999px; cursor:pointer; transition:color .2s, background .2s; }
.wt-btn.is-active{ background:var(--brick); color:#fff; box-shadow:0 4px 12px -4px rgba(184,68,43,.6); }

.day-list{ display:grid; gap:2px; }
.day-row{ display:grid; grid-template-columns:62px 1fr; gap:16px; align-items:center; padding:15px 8px; border-bottom:1px solid var(--line); }
.day-row:last-child{ border-bottom:none; }
.day-name{ font-family:var(--font-display); font-weight:600; font-size:.95rem; color:#fff; background:var(--brick); text-align:center; padding:7px 0; border-radius:9px; letter-spacing:.02em; }
.day-row:nth-child(even) .day-name{ background:var(--green); }
.day-meal{ font-size:1rem; color:var(--ink); font-weight:500; }
.schedule-foot{ margin-top:18px; font-size:.84rem; color:var(--ink-soft); }
.week-panel[hidden]{ display:none; }

/* ───────── Menu ───────── */
.menu-filter{ display:flex; flex-wrap:wrap; gap:9px; margin-bottom:38px; position:sticky; top:72px; z-index:20;
  background:rgba(251,245,233,.9); backdrop-filter:blur(8px); padding:12px 0; }
.chip{ border:1.5px solid var(--line); background:var(--cream-card); color:var(--ink-soft); font-family:var(--font-body); font-weight:600; font-size:.9rem; padding:9px 17px; border-radius:999px; cursor:pointer; transition:all .18s ease; }
.chip:hover{ border-color:var(--brick); color:var(--brick); }
.chip.is-active{ background:var(--brick); border-color:var(--brick); color:#fff; }

.menu-order{ display:flex; flex-direction:column; align-items:center; gap:12px; text-align:center; margin-bottom:36px; }
.menu-order > span{ color:var(--ink-soft); font-size:.92rem; }
.menu-order > span a{ color:var(--brick); font-weight:600; }

.menu-cat{ margin-bottom:46px; }
.menu-cat[hidden]{ display:none; }
.cat-head{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.cat-head h3{ font-size:1.55rem; }
.cat-head::after{ content:""; flex:1; height:1px; background:var(--line); }
.cat-flag{ order:1; background:var(--brick-tint); color:var(--brick-dark); font-weight:700; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; padding:5px 11px; border-radius:999px; }
.cat-head::after{ order:0; }

.menu-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(310px,1fr)); gap:14px; }
.dish{ background:var(--cream-card); border:1px solid var(--line); border-radius:var(--r); padding:20px 22px; transition:transform .18s ease, box-shadow .2s ease, border-color .2s; }
.dish:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--saffron); }
.dish-top{ display:flex; align-items:baseline; gap:12px; justify-content:space-between; }
.dish-top h4{ font-size:1.12rem; font-weight:600; }
.price{ font-family:var(--font-display); font-weight:600; color:var(--brick); font-size:1.05rem; white-space:nowrap; }
.dish p{ color:var(--ink-soft); font-size:.92rem; margin-top:7px; }
.tag{ display:inline-block; margin-top:12px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; padding:5px 11px; border-radius:999px; }
.tag-bogo{ background:var(--brick); color:#fff; }
.menu-foot{ color:var(--ink-soft); font-size:.9rem; text-align:center; margin-top:8px; }

/* ───────── Story ───────── */
.story{ background:var(--green-dark); color:var(--paper); }
.story .kicker{ color:var(--saffron); }
.story-inner{ display:grid; grid-template-columns:1.4fr 1fr; gap:clamp(30px,5vw,64px); align-items:center; }
.story-copy h2{ color:#fff; font-size:clamp(1.9rem,3.6vw,2.8rem); margin-bottom:20px; }
.story-copy p{ color:#DCE7DD; margin-bottom:16px; font-size:1.05rem; max-width:58ch; }
.story-stats{ display:flex; flex-wrap:wrap; gap:14px 34px; margin-top:30px; padding-top:28px; border-top:1px solid rgba(255,255,255,.14); }
.story-stats div{ display:flex; flex-direction:column; }
.story-stats strong{ font-family:var(--font-display); font-size:2.3rem; font-weight:600; color:var(--saffron); line-height:1; }
.story-stats span{ font-size:.86rem; color:#BFD0C2; margin-top:6px; }

.story-quote{ position:relative; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-lg); padding:38px 34px; }
.quote-mark{ font-family:var(--font-display); font-size:5rem; line-height:.6; color:var(--saffron); display:block; height:42px; }
.story-quote p{ font-family:var(--font-display); font-style:italic; font-size:1.7rem; color:#fff; font-weight:500; }
.story-quote small{ display:block; margin-top:16px; color:#BFD0C2; }

/* ───────── Visit ───────── */
.visit-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(20px,3vw,34px); align-items:stretch; }
.info-cards{ display:grid; grid-template-columns:1fr 1fr; gap:14px; align-content:start; }
.info-card{ display:flex; gap:14px; align-items:flex-start; background:var(--cream-card); border:1px solid var(--line); border-radius:var(--r); padding:20px; transition:transform .18s, box-shadow .2s, border-color .2s; }
a.info-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--brick); }
.info-ico{ font-size:1.4rem; line-height:1; }
.info-card strong{ display:block; font-size:1rem; margin-bottom:4px; }
.info-card span{ display:block; color:var(--ink-soft); font-size:.92rem; word-break:break-word; }
.info-hours .closed{ color:var(--brick); font-weight:600; }
.map-card{ position:relative; border-radius:var(--r-lg); overflow:hidden; min-height:340px; border:1px solid var(--line); box-shadow:var(--shadow);
  background:
    radial-gradient(circle at 30% 30%, #EAD9B8 0 2px, transparent 2px) 0 0/46px 46px,
    linear-gradient(135deg,#F3E8D2,#EDE0C6); }
.map-fallback{ position:absolute; inset:0; z-index:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; text-align:center; padding:24px; color:var(--ink); }
.map-fallback .map-pin{ font-size:2rem; margin-bottom:6px; }
.map-fallback strong{ font-family:var(--font-display); font-size:1.2rem; }
.map-fallback span{ color:var(--ink-soft); }
.map-fallback .map-open{ margin-top:12px; color:var(--brick); font-weight:600; }
.map-card iframe{ position:relative; z-index:1; width:100%; height:100%; min-height:340px; display:block; filter:saturate(.92); }

/* ───────── Footer ───────── */
.site-footer{ background:var(--ink); color:#CFC2AD; padding:clamp(44px,6vw,64px) 0 26px; }
.footer-inner{ display:grid; grid-template-columns:1.5fr 1fr 1.3fr; gap:34px; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer-brand{ display:flex; gap:14px; align-items:flex-start; }
.brand-mark-lg{ width:54px; height:54px; }
.footer-brand .brand-name{ color:#fff; font-size:1.25rem; }
.footer-brand p{ font-size:.92rem; margin-top:8px; max-width:34ch; }
.footer-links{ display:flex; flex-direction:column; gap:11px; }
.footer-links a{ color:#CFC2AD; font-weight:500; width:fit-content; transition:color .18s; }
.footer-links a:hover{ color:var(--saffron); }
.footer-contact{ display:flex; flex-direction:column; gap:9px; font-size:.93rem; }
.footer-contact a:hover{ color:var(--saffron); }
.footer-social{ display:flex; gap:18px; margin-top:6px; }
.footer-social a{ display:inline-flex; align-items:center; gap:7px; color:#CFC2AD; font-weight:500; transition:color .18s; }
.footer-social a:hover{ color:var(--saffron); }
.footer-social svg{ width:18px; height:18px; }
.footer-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; padding-top:22px; font-size:.84rem; color:#9C8F7B; }

/* ───────── Responsive ───────── */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; }
  .hero-card{ order:-1; }
  .lead{ max-width:46ch; }
  .tiffin-layout{ grid-template-columns:1fr; }
  .plan-card{ max-width:460px; }
  .story-inner{ grid-template-columns:1fr; }
  .visit-grid{ grid-template-columns:1fr; }
  .footer-inner{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1 / -1; }
}

@media (max-width:760px){
  .nav, .header-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .mobile-nav{ display:none; }
  .mobile-nav.open{ display:flex; }
  .trust-grid{ grid-template-columns:1fr 1fr; gap:20px 16px; }
  .info-cards{ grid-template-columns:1fr; }
  .info-hours{ grid-column:auto; }
  .menu-filter{ top:64px; }
  html{ scroll-padding-top:78px; }
}

@media (max-width:480px){
  .footer-inner{ grid-template-columns:1fr; }
  .story-quote p{ font-size:1.4rem; }
  .day-row{ grid-template-columns:54px 1fr; gap:12px; }
  .hero-card-tag{ right:0; }
}
