/* ═══════════════════════════════════════
   HOME — Hero, Featured Dish, Catering, Location
═══════════════════════════════════════ */

/* Hero */
.hero{min-height:92vh;display:grid;grid-template-columns:55% 45%;overflow:hidden}
.hero-left{background:#000;overflow:hidden}
.hero-left img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}
.hero-right{background:linear-gradient(160deg,#1e1508 0%,#0e0c08 100%);display:flex;flex-direction:column;justify-content:center;padding:80px 64px 80px 56px;position:relative}
.hero-right::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,transparent,var(--gold),transparent)}
.hero-eyebrow{font-size:11px;letter-spacing:5px;color:var(--gold);text-transform:uppercase;margin-bottom:20px;opacity:0;animation:fadeUp .8s .2s forwards}
.hero-title{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(48px,5.5vw,80px);line-height:1.0;color:var(--cream);margin-bottom:8px;opacity:0;animation:fadeUp .8s .4s forwards}
.hero-title .flava{color:var(--gold);display:block}
.hero-title .cuisine{font-style:italic;font-size:0.72em;color:var(--muted)}
.hero-tagline{font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:var(--muted);margin:20px 0 12px;opacity:0;animation:fadeUp .8s .6s forwards}
.hero-divider{width:60px;height:2px;background:linear-gradient(90deg,var(--gold),transparent);margin-bottom:32px;opacity:0;animation:fadeUp .8s .7s forwards}
.hero-desc{font-size:14px;line-height:1.9;color:#a08860;max-width:360px;margin-bottom:44px;opacity:0;animation:fadeUp .8s .8s forwards}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp .8s 1s forwards}
.delivery-row{display:flex;align-items:center;gap:12px;margin-top:32px;opacity:0;animation:fadeUp .8s 1.1s forwards}
.delivery-label{font-size:10px;letter-spacing:3px;color:var(--muted);text-transform:uppercase}

/* Featured dish */
.featured{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.dish-image-panel{background:#181008;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:460px}
.dish-panel{background:var(--dark-wood);padding:72px 64px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid rgba(240,180,41,0.15)}
.dish-name{font-family:'Playfair Display',serif;font-size:clamp(32px,3.5vw,52px);font-weight:900;color:var(--cream);line-height:1.1;margin-bottom:24px}
.dish-desc{font-size:14px;line-height:1.9;color:var(--muted);max-width:400px;margin-bottom:36px}
.price-tag{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--gold);padding:10px 28px;width:fit-content;margin-bottom:32px}
.price-tag .currency{font-size:14px;color:var(--gold)}
.price-tag .amount{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--gold)}

/* Catering strip */
.catering-strip{background:var(--green-dark);border-top:2px solid var(--gold);border-bottom:2px solid var(--gold);padding:48px 80px;display:flex;align-items:center;justify-content:space-between;gap:40px}
.catering-text h3{font-family:'Playfair Display',serif;font-size:28px;font-weight:900;color:var(--gold);margin-bottom:8px}
.catering-text p{font-size:14px;color:rgba(245,234,214,0.7);letter-spacing:1px}
.catering-events{display:flex;gap:24px}
.event-pill{font-family:'Cinzel',serif;font-size:11px;letter-spacing:2px;padding:10px 20px;border:1px solid rgba(240,180,41,0.4);color:var(--gold);text-transform:uppercase}

/* Location */
.location-section{display:grid;grid-template-columns:1fr 1fr;min-height:520px}
.location-text{background:var(--black);padding:80px 72px;display:flex;flex-direction:column;justify-content:center}
.location-heading{font-family:'Playfair Display',serif;font-size:clamp(32px,3.5vw,48px);font-weight:900;color:var(--cream);line-height:1.2;margin-bottom:24px}
.location-heading em{color:var(--gold);font-style:italic}
.location-body{font-size:14px;line-height:1.9;color:var(--muted);max-width:380px;margin-bottom:40px}
.map-panel{background:#0e1a0e;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(26,107,47,0.1) 1px,transparent 1px),linear-gradient(90deg,rgba(26,107,47,0.1) 1px,transparent 1px);background-size:48px 48px}
.map-pin-wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px}
.map-pin{width:24px;height:24px;background:var(--red);border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 0 0 8px rgba(192,57,43,0.2),0 0 20px rgba(192,57,43,0.4)}
.map-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:4px;color:rgba(240,180,41,0.6);text-transform:uppercase}

/* ── Responsive ── */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr 1fr;min-height:70vh}
  .hero-right{padding:56px 40px 56px 36px}
  .featured{grid-template-columns:1fr 1fr}
  .dish-panel{padding:48px 40px}
  .catering-strip{padding:40px 40px;flex-wrap:wrap;gap:24px}
  .catering-events{flex-wrap:wrap;gap:12px}
  .location-text{padding:60px 48px}
}

@media(max-width:768px){
  .hero{grid-template-columns:1fr;grid-template-rows:45vh auto;min-height:auto}
  .hero-left{min-height:45vw}
  .hero-left img{object-position:center 20%}
  .hero-right{padding:44px 24px 52px;order:2}
  .hero-right::before{display:none}
  .hero-eyebrow{margin-bottom:12px}
  .hero-title{font-size:clamp(36px,10vw,56px)}
  .hero-tagline{font-size:16px;margin:12px 0 8px}
  .hero-divider{margin-bottom:20px}
  .hero-desc{margin-bottom:28px;font-size:14px}
  .hero-cta{gap:12px}
  .btn{padding:13px 24px;font-size:10px;letter-spacing:2px}
  .delivery-row{margin-top:20px;flex-wrap:wrap}
  .featured{grid-template-columns:1fr}
  .dish-image-panel{min-height:260px}
  .dish-panel{padding:44px 24px}
  .dish-name{font-size:clamp(28px,8vw,40px)}
  .catering-strip{padding:40px 24px;flex-direction:column;align-items:flex-start;gap:20px}
  .catering-events{flex-wrap:wrap;gap:10px}
  .event-pill{font-size:10px;padding:8px 14px}
  .location-section{grid-template-columns:1fr}
  .location-text{padding:52px 24px}
  .location-heading{font-size:clamp(28px,8vw,40px)}
  .map-panel{min-height:260px}
}

@media(max-width:480px){
  .hero-title{font-size:clamp(32px,11vw,48px)}
  .hero-cta{flex-direction:column;gap:10px}
  .hero-cta .btn{width:100%;text-align:center}
  .badge{font-size:11px;padding:5px 10px}
  .dish-name{font-size:clamp(26px,9vw,36px)}
  .catering-text h3{font-size:22px}
}
