/* =========================================================
   LA's Grill — Detroit halal smash-burger truck
   System: Airbnb (photo-first, warm white, single red accent,
   soft three-layer shadows, generous rounding, pill filters)
   Type:   Schibsted Grotesk
   ========================================================= */

:root{
  --bg:        #ffffff;
  --bg-soft:   #f7f6f3;   /* warm off-white alt sections */
  --ink:       #222222;   /* warm near-black, never pure black */
  --ink-2:     #6a6a6a;   /* secondary text */
  --line:      rgba(0,0,0,.10);
  --line-soft: rgba(0,0,0,.06);

  /* single brand accent (flame red) + sparse gold for halal/logo only */
  --red:       #e23b1d;
  --red-deep:  #c1310f;
  --gold:      #e3a23a;
  --halal:     #2e8b57;

  --shadow:  0 0 0 1px rgba(0,0,0,.04), 0 2px 6px rgba(0,0,0,.045), 0 12px 26px -10px rgba(0,0,0,.14);
  --shadow-hover: 0 0 0 1px rgba(0,0,0,.05), 0 6px 14px rgba(0,0,0,.07), 0 22px 40px -14px rgba(0,0,0,.20);

  --r-btn:  10px;
  --r-card: 18px;
  --r-lg:   28px;

  --maxw: 1200px;
  --font: "Schibsted Grotesk", system-ui, -apple-system, sans-serif;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---------- shared ---------- */
.section-title{
  font-weight:800; letter-spacing:-.022em; line-height:1.05; margin:0;
  font-size:clamp(1.9rem, 3.4vw, 2.8rem);
}
.section-sub{ color:var(--ink-2); font-size:1.02rem; margin:.7rem 0 0; max-width:54ch; }

.eyebrow{
  font-weight:700; font-size:.82rem; letter-spacing:.02em; color:var(--red);
  margin:0 0 1rem; text-transform:none;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font); font-weight:700; font-size:.96rem; line-height:1;
  padding:.8rem 1.25rem; border-radius:var(--r-btn); border:1.5px solid transparent;
  cursor:pointer; transition:transform .2s var(--ease), background .2s, color .2s, border-color .2s, box-shadow .2s;
  white-space:nowrap;
}
.btn:active{ transform:scale(.97); }
.btn--red{ background:var(--red); color:#fff; }
.btn--red:hover{ background:var(--red-deep); }
.btn--outline{ background:#fff; border-color:var(--ink); color:var(--ink); }
.btn--outline:hover{ background:var(--ink); color:#fff; }
.btn--dark{ background:var(--ink); color:#fff; }
.btn--dark:hover{ background:var(--red); }
.btn--lg{ padding:1rem 1.6rem; font-size:1.02rem; }
.btn--block{ width:100%; }

/* =========================================================
   HEADER
   ========================================================= */
.hdr{
  position:sticky; top:0; z-index:100; background:rgba(255,255,255,.9);
  backdrop-filter:saturate(1.4) blur(10px); border-bottom:1px solid transparent;
  transition:border-color .3s, box-shadow .3s;
}
.hdr.is-stuck{ border-bottom-color:var(--line-soft); box-shadow:0 1px 0 rgba(0,0,0,.02); }
.hdr__inner{ max-width:var(--maxw); margin:0 auto; padding:.85rem 1.4rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem; }

.brand{ display:inline-flex; align-items:center; gap:.6rem; }
.brand__logo{ width:42px; height:42px; border-radius:50%; flex:none; }
.brand__type{ font-weight:800; font-size:1.3rem; letter-spacing:-.02em; }

.hdr__nav{ display:flex; align-items:center; gap:2rem; }
.hdr__nav a{ font-weight:600; font-size:.98rem; color:var(--ink); position:relative; padding:.2rem 0; }
.hdr__nav a::after{ content:""; position:absolute; left:0; right:0; bottom:-4px; height:2px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease); }
.hdr__nav a:hover::after{ transform:scaleX(1); }

.hdr__actions{ display:flex; align-items:center; gap:.9rem; }
.hdr__phone{ font-weight:700; font-size:.95rem; }
.hdr__phone:hover{ color:var(--red); }
.hdr__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.hdr__burger span{ width:22px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.hdr.is-open .hdr__burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.hdr.is-open .hdr__burger span:nth-child(2){ opacity:0; }
.hdr.is-open .hdr__burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.hdr__mobile{ display:none; flex-direction:column; gap:.2rem; padding:0 1.4rem;
  max-height:0; overflow:hidden; background:#fff; border-bottom:1px solid transparent;
  transition:max-height .4s var(--ease), padding .4s var(--ease), border-color .4s; }
.hdr.is-open .hdr__mobile{ max-height:360px; padding:.4rem 1.4rem 1.2rem; border-bottom-color:var(--line-soft); }
.hdr__mobile a{ font-weight:600; padding:.75rem 0; border-bottom:1px solid var(--line-soft); }
.hdr__mobile a.btn{ border:1.5px solid transparent; margin-top:.7rem; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ max-width:var(--maxw); margin:0 auto; padding:6rem 1.4rem 4rem; }
.hero__text{ max-width:900px; }
.hero__title{ font-weight:800; letter-spacing:-.035em; line-height:1.0; margin:0 0 1.3rem;
  font-size:clamp(2.7rem, 7.4vw, 5.4rem); }
.hero__lede{ color:var(--ink-2); font-size:1.2rem; max-width:52ch; margin:0 0 2rem; }
.hero__cta{ display:flex; gap:.8rem; flex-wrap:wrap; }

/* =========================================================
   MENU
   ========================================================= */
.menu{ max-width:var(--maxw); margin:0 auto; padding:3rem 1.4rem 4rem; }
.menu__head{ margin-bottom:1.4rem; }

/* category pills (sticky under header) */
.pills{ position:sticky; top:64px; z-index:40; display:flex; gap:.55rem; overflow-x:auto;
  padding:.9rem 0; margin-bottom:1.4rem; background:rgba(255,255,255,.92); backdrop-filter:blur(8px);
  scrollbar-width:none; }
.pills::-webkit-scrollbar{ display:none; }
.pill{ flex:0 0 auto; font-family:var(--font); font-weight:600; font-size:.92rem; color:var(--ink);
  background:#fff; border:1.5px solid var(--line); border-radius:999px; padding:.55rem 1.05rem;
  cursor:pointer; transition:.2s var(--ease); }
.pill:hover{ border-color:var(--ink); }
.pill.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }

.grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.6rem 1.4rem; }

.card{ display:flex; flex-direction:column; border-radius:var(--r-card); background:#fff;
  transition:transform .25s var(--ease); }
.card:hover{ transform:translateY(-4px); }
.card__media{ position:relative; border-radius:var(--r-card); overflow:hidden; box-shadow:var(--shadow);
  background:var(--bg-soft); }
.card__media img{ width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform .5s var(--ease); }
.card:hover .card__media img{ transform:scale(1.05); }

/* photo-less placeholder tiles (branded, intentional) */
.card__media--ph{ display:grid; place-items:center; aspect-ratio:4/3; }
.card__media--ph .card__phmark{ width:46%; aspect-ratio:auto; opacity:.5; mix-blend-mode:multiply; }
.card:hover .card__media--ph .card__phmark{ transform:none; }
.card__media--ph[data-ph="1"]{ background:#f3ece0; }
.card__media--ph[data-ph="2"]{ background:#efe7da; }
.card__media--ph[data-ph="3"]{ background:#f4e7dd; }
.card__media--ph[data-ph="4"]{ background:#eee9df; }

.card__info{ padding:.85rem .3rem .2rem; }
.card__row{ display:flex; align-items:baseline; justify-content:space-between; gap:.6rem; }
.card__row h3{ font-size:1.04rem; font-weight:700; letter-spacing:-.01em; margin:0; line-height:1.2; }
.card__price{ font-weight:700; font-size:1.02rem; white-space:nowrap; }
.card__desc{ color:var(--ink-2); font-size:.9rem; margin:.3rem 0 0; }
.card__meta{ color:var(--red); font-size:.8rem; font-weight:600; margin:.45rem 0 0; }

/* =========================================================
   BUILD YOUR OWN
   ========================================================= */
.build{ background:var(--bg-soft); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); }
.build__head{ max-width:var(--maxw); margin:0 auto; padding:4rem 1.4rem 0; }
.build__cols{ max-width:var(--maxw); margin:0 auto; padding:2rem 1.4rem 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; align-items:start; }
.bcard{ background:#fff; border-radius:var(--r-card); box-shadow:var(--shadow); padding:1.6rem; }
.bcard__h{ font-size:1.05rem; font-weight:800; margin:0 0 1rem; letter-spacing:-.01em; }
.bcard__h--gap{ margin-top:1.6rem; }
.bcard__h em{ font-style:normal; font-weight:700; color:var(--halal); font-size:.85rem; margin-left:.35rem; }
.bcard__list{ list-style:none; margin:0; padding:0; }
.bcard__list li{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem;
  padding:.6rem 0; border-top:1px solid var(--line-soft); font-size:.98rem; }
.bcard__list li:first-child{ border-top:0; }
.bcard__list li span{ font-weight:600; }
.bcard__list li b{ font-weight:700; color:var(--ink); }
.bcard__tags{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:.5rem; }
.bcard__tags li{ font-size:.88rem; font-weight:600; background:var(--bg-soft); border:1px solid var(--line-soft);
  padding:.4rem .75rem; border-radius:999px; }
.build__cta{ max-width:var(--maxw); margin:0 auto; padding:2.4rem 1.4rem 4rem; display:flex; gap:.8rem; flex-wrap:wrap; }

/* =========================================================
   VISIT
   ========================================================= */
.visit{ max-width:var(--maxw); margin:0 auto; padding:4.5rem 1.4rem; }
.visit__grid{ display:grid; grid-template-columns:1fr 1fr; gap:2rem; align-items:stretch; }
.visit__card{ background:#fff; }
.visit__rows{ margin:1.8rem 0; }
.visit__rows > div{ display:grid; grid-template-columns:96px 1fr; gap:1rem; padding:1rem 0; border-top:1px solid var(--line-soft); }
.visit__rows > div:last-child{ border-bottom:1px solid var(--line-soft); }
.visit__rows dt{ font-weight:700; font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-2); padding-top:.15rem; }
.visit__rows dd{ margin:0; font-size:1.04rem; }
.visit__rows dd em{ font-style:normal; color:var(--halal); font-weight:600; font-size:.92rem; }
.visit__rows dd a:hover{ color:var(--red); }
.visit__cta{ display:flex; gap:.8rem; flex-wrap:wrap; }
.visit__map{ border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); min-height:440px; }
.visit__map iframe{ width:100%; height:100%; min-height:440px; border:0; display:block; }

/* =========================================================
   FOOTER
   ========================================================= */
.foot{ background:var(--ink); color:#fff; padding:3.5rem 1.4rem 2rem; }
.foot__inner{ max-width:var(--maxw); margin:0 auto; display:grid;
  grid-template-columns:2fr 1fr 1fr 1.4fr; gap:2rem; }
.foot__brand .brand__type{ color:#fff; }
.foot__brand p{ color:rgba(255,255,255,.6); font-size:.92rem; margin:1rem 0 0; max-width:34ch; }
.foot__k{ font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.5); margin:0 0 .7rem; }
.foot__col p{ margin:0; color:rgba(255,255,255,.82); line-height:1.7; font-size:.95rem; }
.foot__col a:hover{ color:var(--gold); }
.foot__bar{ max-width:var(--maxw); margin:2.5rem auto 0; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  font-size:.85rem; color:rgba(255,255,255,.5); }

/* =========================================================
   REVEAL
   ========================================================= */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.07s; }
.reveal[data-d="2"]{ transition-delay:.14s; }
.reveal[data-d="3"]{ transition-delay:.21s; }
.reveal[data-d="4"]{ transition-delay:.28s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1040px){
  .grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width: 860px){
  .hdr__nav{ display:none; }
  .hdr__phone{ display:none; }
  .hdr__burger{ display:flex; }
  .hdr__mobile{ display:flex; }
  .hero{ padding-top:3.5rem; }
  .grid{ grid-template-columns:repeat(2,1fr); }
  .build__cols{ grid-template-columns:1fr; }
  .visit__grid{ grid-template-columns:1fr; }
  .visit__map{ min-height:340px; }
  .visit__map iframe{ min-height:340px; }
  .pills{ top:60px; }
  .foot__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 520px){
  .grid{ grid-template-columns:1fr 1fr; gap:1.1rem .9rem; }
  .card__info{ padding-left:.1rem; padding-right:.1rem; }
  .card__row h3{ font-size:.96rem; }
  .hero__title{ font-size:2.4rem; }
  .foot__inner{ grid-template-columns:1fr; gap:1.6rem; }
  .foot__bar{ justify-content:center; text-align:center; }
  .btn--lg{ flex:1 1 auto; }
}
