/* ============================================
   Sweet n' Salt — sweet-n-salt.com
   Tokens + mobile-first responsive stylesheet
   ============================================ */

:root{
  /* palette */
  --ink:#0A0A0A;
  --coral:#F4A8B8;
  --hot:#E85A7C;
  --cream:#FAF5EE;
  --salt:#ECE6DA;
  --line:rgba(10,10,10,.14);

  /* type */
  --display:'Fraunces','Cormorant Garamond',serif;
  --body:'DM Sans',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  /* radii / shadows */
  --r-pill:999px;
  --r-md:8px;
  --r-sm:4px;
  --sh-sm:0 1px 2px rgba(10,10,10,.05);
  --sh-md:0 4px 12px rgba(10,10,10,.1);
  --sh-lg:0 12px 32px rgba(10,10,10,.15);

  /* spacing */
  --gutter:24px;
}

/* ----- reset ----- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","ss02";
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
:focus-visible{outline:2px solid var(--hot);outline-offset:3px;border-radius:2px}

/* ----- shared ----- */
.wrap{
  width:100%;max-width:1280px;
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.eyebrow{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  opacity:.6;display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:"";width:24px;height:1px;background:currentColor;
}

/* ============================================
   SALT-DOT — global brand asset
   ============================================ */
.amp{
  position:relative;display:inline-block;
  font-style:italic;font-weight:300;
  font-variation-settings:"SOFT" 100,"opsz" 144;
  padding:0 .22em 0 .06em;
}
.amp::after{
  content:"";position:absolute;right:0;top:.16em;
  width:.2em;height:.2em;border-radius:50%;
  background:currentColor;
}
.amp.pulse::after{animation:saltPulse 2.4s ease-in-out infinite}
@keyframes saltPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.25);opacity:.75}
}

/* the standalone salt-dot bullet (in taglines / lists) */
.bullet{
  display:inline-block;width:5px;height:5px;border-radius:50%;
  background:currentColor;vertical-align:.18em;
  margin:0 .55em;
}

/* monogram S·S */
.ss{
  font-family:var(--display);font-style:normal;font-weight:420;
  line-height:1;letter-spacing:-.015em;
  display:inline-flex;align-items:center;
  font-variation-settings:"SOFT" 50,"opsz" 144;
}
.ss-dot{
  display:inline-block;width:.14em;height:.14em;border-radius:50%;
  background:currentColor;margin:0 .08em;
  transform:translateY(-.16em);flex-shrink:0;
}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--body);font-weight:500;font-size:14px;
  letter-spacing:.01em;
  padding:14px 26px;border-radius:var(--r-pill);
  border:1px solid transparent;
  transition:background .15s,color .15s,border-color .15s,transform .15s;
}
.btn.primary{background:var(--hot);color:var(--cream);border-color:var(--hot)}
.btn.primary:hover{background:var(--ink);border-color:var(--ink)}
.btn.secondary{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.secondary:hover{background:var(--ink);color:var(--cream)}
.btn.outline-cream{background:transparent;color:var(--cream);border-color:var(--cream)}
.btn.outline-cream:hover{background:var(--coral);color:var(--ink);border-color:var(--coral)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--coral)}
.btn.big{padding:18px 32px;font-size:15px}
.btn .arr{transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}

/* ============================================
   STICKY NAV
   ============================================ */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(250,245,238,.93);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--salt);
}
.nav .wrap{
  display:flex;align-items:center;justify-content:space-between;
  min-height:64px;
}
.nav-brand{
  font-family:var(--display);font-weight:380;font-size:20px;
  letter-spacing:-.02em;line-height:1;
  display:flex;align-items:baseline;
}
.nav-links{
  display:none;
  gap:32px;align-items:center;
  font-family:var(--body);font-size:14px;font-weight:500;
}
.nav-links a{
  position:relative;padding:6px 0;opacity:.75;
  transition:opacity .15s;
}
.nav-links a:hover{opacity:1}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;
  height:1px;background:currentColor;
  transition:right .25s ease-out;
}
.nav-links a:hover::after{right:0}

/* hamburger */
.nav-burger{
  display:inline-flex;flex-direction:column;justify-content:center;
  width:40px;height:40px;gap:5px;padding:10px 8px;
  border-radius:50%;
}
.nav-burger span{
  display:block;height:1.5px;background:var(--ink);
  transition:transform .25s,opacity .25s;
}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-mobile{
  display:none;
  background:var(--cream);
  border-top:1px solid var(--salt);
  padding:8px var(--gutter) 20px;
}
.nav-mobile[data-open="true"]{display:block}
.nav-mobile a{
  display:block;padding:14px 0;
  font-family:var(--display);font-style:italic;font-size:24px;
  border-bottom:1px solid var(--salt);
}
.nav-mobile a:last-child{border-bottom:0}

/* ============================================
   01 HERO
   ============================================ */
section.hero{
  background:var(--coral);
  color:var(--ink);
  padding:80px var(--gutter) 56px;
  min-height:calc(100vh - 64px);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.hero-meta{
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-bottom:auto;
}
.hero-meta .meta-loc{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  opacity:.75;
  align-self:flex-start;padding-top:6px;
}
.meta-right{
  display:flex;flex-direction:column;align-items:flex-start;gap:12px;
}
.meta-right .live-status{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
  opacity:1;
}
.meta-right .live-status .ls-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--ink);opacity:.4;
  flex:0 0 auto;
}
.meta-right .live-status[data-status="open"] .ls-dot{
  background:var(--hot);opacity:1;
  animation:saltPulse 2.4s ease-in-out infinite;
}
.meta-right .live-status[data-status="open"] .ls-label{
  color:var(--hot);font-weight:500;
}
.meta-right .live-status[data-status="closed"] .ls-label{
  color:var(--ink);opacity:.6;
}
.meta-right .live-status[data-status="loading"] .ls-label{opacity:.5}
.meta-sep{
  display:block;width:100%;min-width:180px;
  height:1px;background:rgba(10,10,10,.2);
}
.meta-right .ls-hours{
  display:flex;flex-direction:column;
  font-family:var(--display);font-size:18px;line-height:1.3;letter-spacing:-.005em;
}
.meta-right .ls-hours .strong{font-weight:500}
.meta-right .ls-context{
  margin:0;
  font-family:var(--mono);
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  opacity:.55;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@keyframes saltPulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.3);opacity:.7}
}
@media (prefers-reduced-motion: reduce){
  .meta-right .live-status[data-status="open"] .ls-dot{animation:none}
}
.hero-mark{
  font-family:var(--display);font-weight:340;
  font-size:clamp(72px, 17vw, 240px);
  line-height:.88;letter-spacing:-.045em;
  margin:48px 0 0;
  font-variation-settings:"SOFT" 40,"opsz" 144;
}
.hero-tagline{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(20px, 2.6vw, 32px);
  line-height:1.25;letter-spacing:-.01em;
  margin:32px 0 0;max-width:540px;
}
.hero-date{
  margin:32px 0 0;
  font-family:var(--body);font-weight:500;
  font-size:clamp(16px, 1.8vw, 22px);
}
.hero-cta{margin:36px 0 0;display:flex;flex-wrap:wrap;gap:12px}

/* ============================================
   sections
   ============================================ */
section{
  padding:80px var(--gutter);
  position:relative;
}
.section-head{
  display:grid;gap:16px;
  margin-bottom:48px;
}
.section-head h2{
  font-family:var(--display);font-style:italic;font-weight:380;
  font-size:clamp(36px, 5.5vw, 64px);
  line-height:1.02;letter-spacing:-.02em;
  margin:0;
  font-variation-settings:"SOFT" 60;
}
.section-head .sub{
  font-size:15px;opacity:.7;line-height:1.6;
  margin:0;max-width:none;
}

/* ============================================
   02 MENU
   ============================================ */
.menu{background:var(--cream)}
.menu-section{margin-top:64px}
.menu-section:first-of-type{margin-top:48px}
.menu-divider{
  display:flex;align-items:baseline;gap:.18em;
  font-family:var(--display);font-style:italic;font-weight:500;
  font-size:clamp(40px, 5.5vw, 64px);
  line-height:1.05;letter-spacing:-.02em;
  margin:0 0 32px;
  color:var(--ink);
}
.menu-divider .menu-divider-icon{
  display:block;flex:0 0 auto;
  width:.58em !important;
  height:.58em !important;
  max-width:.58em !important;
  vertical-align:baseline;
  color:currentColor;
  opacity:.55;
  transform:translateY(.08em);
  transition:opacity .3s cubic-bezier(.16,1,.3,1), transform .3s cubic-bezier(.16,1,.3,1);
}
.menu-divider:hover .menu-divider-icon{
  opacity:.85;transform:translateY(.08em) rotate(-2deg);
}
.mc-title{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;opacity:.6;display:block;
}
.mc-sub{
  font-family:var(--display);font-style:italic;font-size:24px;
  line-height:1.15;letter-spacing:-.015em;margin:8px 0 0;
}

/* ---------- HERO BESTSELLER (czarne tło, asymmetric) ---------- */
.menu-hero{
  background:var(--ink);color:var(--cream);
  border-radius:var(--r-md);
  padding:32px 24px;margin-bottom:32px;
  display:grid;gap:28px;
}
.menu-hero-text .mc-title{color:var(--coral);opacity:1}
.menu-hero-text .mc-sub{color:var(--cream)}
.menu-hero-lead{
  font-family:var(--body);font-size:14px;line-height:1.55;
  margin:14px 0 0;opacity:.75;max-width:38ch;
}
.menu-hero-items{
  display:grid;gap:18px;
  grid-template-columns:1fr 1fr;
}
.menu-hero-item{margin:0}
.menu-hero-item picture{
  display:block;aspect-ratio:1/1;
  background:rgba(250,245,238,.04);
  border-radius:var(--r-md);overflow:hidden;
}
.menu-hero-item img{
  display:block;width:100%;height:100%;object-fit:contain;
  transition:transform 400ms cubic-bezier(.16,1,.3,1);
}
.menu-hero-item:hover img{transform:scale(1.03)}
.menu-hero-item figcaption{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:8px;margin-top:12px;
  font-family:var(--display);font-style:italic;font-size:17px;font-weight:300;
  color:var(--cream);
  transition:color .35s cubic-bezier(.16,1,.3,1);
}
.menu-hero-item:hover figcaption{color:var(--coral)}
.menu-hero-item figcaption em{font-style:normal;font-weight:420}
.menu-hero-item .menu-item-price{
  font-family:var(--mono);font-style:normal;font-size:13px;font-weight:500;
  letter-spacing:.04em;opacity:.85;flex-shrink:0;
}

/* ---------- MENU LEAD (Gofr — duża sekcja z obrazem + listą dodatków) ---------- */
.menu-lead{
  display:grid;gap:24px;
  grid-template-columns:1fr;
  margin-bottom:48px;
}
.menu-lead-image{margin:0}
.menu-lead-image picture{
  display:block;aspect-ratio:1/1;
  background:#fff;
  border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);
}
.menu-lead-image img{
  display:block;width:100%;height:100%;object-fit:contain;
  transition:transform 400ms cubic-bezier(.16,1,.3,1);
}
.menu-lead:hover .menu-lead-image img{transform:scale(1.02)}
.menu-lead-text .mc-sub{margin:8px 0 16px}
.menu-lead-list{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;
}
.menu-lead-list li{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding:10px 0;border-bottom:1px solid rgba(10,10,10,.08);
  font-family:var(--display);font-size:17px;font-style:italic;font-weight:300;
  line-height:1.3;letter-spacing:-.005em;
}
.menu-lead-list li:last-child{border-bottom:0}
.menu-lead-list li em{font-style:normal;font-weight:420}
.menu-lead-list li .price{
  font-family:var(--mono);font-style:normal;font-size:13px;font-weight:500;
  letter-spacing:.04em;opacity:.8;flex-shrink:0;white-space:nowrap;
}

/* ---------- SUBHEAD (sub-section title, e.g. "Napoje") ---------- */
.menu-subhead{margin:0 0 24px}
.menu-subhead .mc-sub{font-size:22px}

/* ---------- GALLERY (siatka image cards bez boxa) ---------- */
.menu-gallery{
  display:grid;gap:24px 16px;
  grid-template-columns:repeat(2, 1fr);
  margin-bottom:24px;
}
.menu-item{margin:0}
.menu-item picture{
  display:block;aspect-ratio:1/1;
  background:linear-gradient(180deg, #fff 0%, var(--salt) 100%);
  border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);
}
.menu-item img{
  display:block;width:100%;height:100%;object-fit:contain;
  transition:transform 400ms cubic-bezier(.16,1,.3,1), filter 400ms cubic-bezier(.16,1,.3,1);
}
.menu-item:hover img{transform:scale(1.03);filter:brightness(1.02)}
.menu-item:active img{transform:scale(.99);transition-duration:120ms}
.menu-item figcaption{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:8px;margin-top:12px;
  font-family:var(--display);font-style:italic;font-size:16px;font-weight:300;
  line-height:1.3;letter-spacing:-.005em;
  transition:color .35s cubic-bezier(.16,1,.3,1);
}
.menu-item:hover figcaption{color:var(--hot)}
.menu-item figcaption em{font-style:normal;font-weight:420}
.menu-item .menu-item-name{flex:1;min-width:0}
.menu-item .menu-item-price{
  font-family:var(--mono);font-style:normal;font-size:13px;font-weight:500;
  letter-spacing:.04em;opacity:.8;flex-shrink:0;white-space:nowrap;
}

/* ---------- ADD-ON (Sos + extras line) ---------- */
.menu-add{
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;
  margin:0 0 40px;
  font-family:var(--display);font-style:italic;font-size:15px;font-weight:300;
  color:var(--ink);opacity:.75;
}
.menu-add .price{
  font-family:var(--mono);font-style:normal;font-size:12px;font-weight:500;
  letter-spacing:.04em;
}

.menu-foot{
  margin-top:48px;font-family:var(--body);font-size:13px;line-height:1.5;
  opacity:.65;
}
@media (min-width:768px){
  .menu-foot{font-size:14px}
}

/* ============================================
   03 O NAS
   ============================================ */
.about{background:var(--salt)}
.about-grid{display:grid;gap:48px;grid-template-columns:1fr}
.about-body p{
  font-family:var(--display);font-size:20px;line-height:1.55;
  margin:0 0 24px;max-width:540px;letter-spacing:-.005em;
}
.about-body .sig{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:24px;letter-spacing:-.01em;
  display:inline-block;margin-top:8px;
}
.about-photo{
  aspect-ratio:4/5;
  border-radius:var(--r-md);
  background:var(--cream);
  border:1px solid var(--line);
  position:relative;overflow:hidden;
  margin:0;
}
.about-photo picture,
.about-photo img{
  display:block;width:100%;height:100%;
}
.about-photo img{object-fit:cover}
.about-photo figcaption{
  position:absolute;left:14px;bottom:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--cream);
  padding:6px 10px;
  background:rgba(10,10,10,.55);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  border-radius:6px;
}

/* ============================================
   04 LOKALIZACJA
   ============================================ */
.location{background:var(--ink);color:var(--cream)}
.location .section-head h2{color:var(--cream)}
.location .section-head .sub{opacity:.7}
.location-grid{display:grid;gap:32px;grid-template-columns:1fr}
.map-frame{
  aspect-ratio:16/9;border-radius:var(--r-md);
  background:#2a2724;
  position:relative;overflow:hidden;
  border:1px solid rgba(250,245,238,.1);
}
.map-link{
  display:block;text-decoration:none;cursor:pointer;
  transition:transform .3s ease, box-shadow .3s ease;
}
.map-link picture,.map-link img{
  display:block;width:100%;height:100%;object-fit:cover;
}
.map-link:hover{
  transform:translateY(-2px);
  box-shadow:0 16px 40px rgba(10,10,10,.35);
}
.map-link:hover .map-cta{background:var(--hot)}
.map-link:focus-visible{
  outline:2px solid var(--hot);outline-offset:4px;
}
.map-cta{
  position:absolute;right:16px;bottom:16px;z-index:3;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  background:var(--ink);color:var(--cream);
  padding:10px 16px;border-radius:var(--r-pill);
  box-shadow:0 4px 16px rgba(10,10,10,.4);
  transition:background .25s ease;
}
.map-pin{
  position:absolute;left:45%;top:56%;transform:translate(-50%,-100%);
  z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:0;
  pointer-events:none;
}
.map-pin .pin-label{
  display:inline-block;
  font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);background:var(--cream);
  padding:7px 13px;border-radius:6px;
  border:1px solid rgba(10,10,10,.1);
  box-shadow:0 4px 14px rgba(10,10,10,.15);
  white-space:nowrap;
  margin-bottom:8px;
  position:relative;
}
.map-pin .pin-label::after{
  content:"";position:absolute;left:50%;bottom:-5px;
  width:8px;height:8px;background:var(--cream);
  border-right:1px solid rgba(10,10,10,.1);
  border-bottom:1px solid rgba(10,10,10,.1);
  transform:translateX(-50%) rotate(45deg);
}
.map-pin .pin-stem{
  display:block;width:1px;height:14px;
  background:rgba(10,10,10,.35);
}
.map-pin .pin{
  position:relative;
  width:48px;height:48px;border-radius:50% 50% 50% 0;
  background:var(--coral);color:var(--ink);
  transform:rotate(-45deg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(10,10,10,.4), 0 0 0 3px rgba(250,245,238,.85);
}
.map-pin .pin-pulse{
  position:absolute;inset:-2px;
  border-radius:50% 50% 50% 0;
  background:var(--coral);
  opacity:.55;
  animation:pinPulse 2.4s cubic-bezier(.16,1,.3,1) infinite;
  z-index:-1;
  pointer-events:none;
}
@keyframes pinPulse{
  0%{transform:scale(.9);opacity:.55}
  70%{transform:scale(1.6);opacity:0}
  100%{transform:scale(1.6);opacity:0}
}
.map-pin .pin .ss{transform:rotate(45deg);font-size:18px;color:var(--ink);position:relative;z-index:1}
.map-pin .pin .ss-dot{transform:translateY(-.16em)}
@media (prefers-reduced-motion: reduce){
  .map-pin .pin-pulse{animation:none;opacity:0}
}

.location-info{display:flex;flex-direction:column;gap:24px}
.location-info .row{display:flex;flex-direction:column;gap:4px}
.location-info .label{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  opacity:.55;
}
.location-info .value{
  font-family:var(--display);font-size:24px;line-height:1.2;letter-spacing:-.01em;
  font-style:italic;font-weight:400;
}
.location-info .value strong{font-style:normal;font-weight:400}

/* ============================================
   05 KONTAKT
   ============================================ */
.contact{background:var(--coral);color:var(--ink)}
.contact-grid{display:grid;gap:32px;grid-template-columns:1fr;margin-bottom:48px}
.contact-card{
  display:flex;flex-direction:column;gap:6px;
}
.contact-card .label{
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  opacity:.55;
}
.contact-card a{
  font-family:var(--display);font-size:22px;letter-spacing:-.01em;
  font-style:italic;font-weight:400;
  display:inline-block;width:fit-content;
  border-bottom:1px solid transparent;
  transition:border-color .15s;
}
.contact-card a:hover{border-bottom-color:var(--ink)}
.contact-card .note{
  font-family:var(--body);font-size:13px;line-height:1.5;opacity:.7;margin-top:4px;
}
.contact-card.social a{display:flex;align-items:center;gap:8px;font-size:18px}
.contact-card.social .icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border-radius:50%;background:var(--ink);color:var(--coral);
}
.contact-cta{margin-top:8px}

/* ============================================
   06 FOOTER
   ============================================ */
.foot{background:var(--ink);color:var(--cream);padding:64px var(--gutter) 32px}
.foot-grid{display:grid;gap:32px;grid-template-columns:1fr;margin-bottom:48px}
.foot-brand{display:flex;flex-direction:column;gap:14px}
.foot-brand .mark{
  display:inline-flex;align-items:center;gap:14px;
}
.foot-brand .ss-circle{
  width:40px;height:40px;border-radius:50%;background:var(--coral);color:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;
}
.foot-brand .ss-circle .ss{font-size:20px}
.foot-brand .copy{font-size:13px;opacity:.65;max-width:300px;line-height:1.5}
.foot-links{display:flex;flex-direction:column;gap:8px}
.foot-links a{
  font-family:var(--display);font-style:italic;font-size:18px;letter-spacing:-.01em;
  opacity:.85;
}
.foot-links a:hover{opacity:1}
.foot-legal{display:flex;flex-direction:column;gap:10px}
.foot-legal-head{
  font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  opacity:.5;margin-bottom:6px;
}
.foot-legal a{
  font-size:13px;line-height:1.5;opacity:.75;
  border-bottom:none;text-decoration:none;
  transition:opacity .2s ease;
}
.foot-legal a:hover{opacity:1;text-decoration:underline;text-underline-offset:3px}
.foot-disclaimer{
  border-top:1px solid rgba(250,245,238,.12);
  padding-top:24px;margin-top:8px;
  font-family:var(--body);font-size:12px;line-height:1.55;opacity:.55;
}
.foot-bottom{
  border-top:1px solid rgba(250,245,238,.12);
  padding-top:24px;margin-top:24px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.55;
}

/* ============================================
   RESPONSIVE — tablet 768+
   ============================================ */
@media (min-width: 720px){
  :root{--gutter:48px}
  section{padding:104px var(--gutter)}

  .nav-burger{display:none}
  .nav-links{display:flex}

  .meta-right{align-items:flex-end}
  .cd-num{font-size:24px}
  .cd-cell + .cd-cell::before{top:13px}
  .open-now .on-hours{align-items:flex-end;font-size:20px}

  .section-head{
    grid-template-columns:1fr 1.2fr;
    align-items:end;gap:48px;
    padding-bottom:32px;
    border-bottom:1px solid var(--line);
  }
  .section-head .sub{justify-self:end;text-align:left;white-space:nowrap}

  /* MENU — tablet 720+ */
  .menu-hero{padding:40px 32px;grid-template-columns:1fr 1.4fr;align-items:start;gap:48px}
  .menu-hero-text{padding-top:8px}
  .menu-hero-items{grid-template-columns:1fr 1fr;gap:24px}
  .menu-lead{grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .menu-gallery{grid-template-columns:repeat(3, 1fr);gap:32px 24px}
  .menu-subhead .mc-sub{font-size:26px}

  .about-grid{grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .about-photo{order:2}

  .location-grid{grid-template-columns:1.4fr 1fr;gap:48px;align-items:center}
  .location .section-head h2{color:var(--cream)}

  .contact-grid{grid-template-columns:repeat(3, 1fr);gap:32px}
  .foot-grid{grid-template-columns:1.6fr 1fr 1fr;gap:64px}
  .foot{padding:80px var(--gutter) 32px}

  section.hero{padding:120px var(--gutter) 80px}
  .hero-tagline{margin-top:48px}
  .hero-cta{margin-top:48px}
}

/* ----- laptop+ ----- */
@media (min-width: 1024px){
  :root{--gutter:64px}
  section{padding:120px var(--gutter)}

  /* MENU — laptop 1024+ */
  .menu-hero{padding:48px 40px;gap:64px}
  .menu-hero-text .mc-sub{font-size:32px}
  .menu-hero-lead{font-size:15px}
  .menu-lead{gap:64px}
  .menu-lead-text .mc-sub{font-size:28px}
  .menu-gallery{grid-template-columns:repeat(3, 1fr);gap:40px 32px}
  .menu-item figcaption{font-size:17px;margin-top:14px}

  .cd-num{font-size:32px}
  .cd-cell + .cd-cell::before{top:17px;width:6px;height:6px;left:-14px}
  .open-now .on-hours{font-size:24px}
}

/* ----- desktop ----- */
@media (min-width: 1280px){
  .menu-hero{padding:56px 48px;gap:80px}
  .menu-hero-items{gap:32px}
  .menu-gallery{gap:48px 32px}
  .menu-item figcaption{font-size:18px}
}

/* ----- wide desktop (1440+, 1920+) ----- */
@media (min-width: 1440px){
  .wrap{max-width:1360px}
  section.hero{padding:160px var(--gutter) 96px;min-height:880px}
  .section-head{padding-bottom:40px;margin-bottom:64px}
}
@media (min-width: 1800px){
  .wrap{max-width:1480px}
  section.hero{min-height:920px}
}

/* Brand credit link w footerze */
.brand-credit{
  color:inherit;text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:3px;text-decoration-color:rgba(250,245,238,.3);
  transition:color .2s ease, text-decoration-color .2s ease;
}
.brand-credit:hover{color:var(--coral);text-decoration-color:var(--coral)}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto}
}
