/* ============================================================
   LOLA'S — bright brand system
   Built to the Lola's Cantina Mexicana brand guide:
   White · Pastel Pink #FFD1D6 · Terracotta Earth #E2D9BB · Black #231F20
   Type: Poppins (body/UI).  Headings use --font-display
   (Poppins now — swap to Lola's custom display font when supplied).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Sacramento&display=swap');

:root{
  /* brand palette */
  --paper:      #ffffff;   /* cards / header / crisp white  */
  --bg:         #f7f2e9;   /* page background — warm off-white */
  --paper-2:    #faf7f0;   /* faint warm white             */
  --beige:      #e2d9bb;   /* Terracotta Earth (sandy)     */
  --beige-soft: #efe9d6;   /* light beige tint             */
  --pink:       #ffd1d6;   /* Pastel / Sunset Pink         */
  --pink-soft:  #ffe6e9;
  --rose:       #e1a7a1;   /* logo dusty rose — accent     */
  --rose-deep:  #c9837c;   /* hover / deeper accent        */
  --ink:        #231f20;   /* black — text & branding      */
  --ink-soft:   #6f686a;   /* secondary text               */
  --line:       rgba(35,31,32,.14);
  --line-soft:  rgba(35,31,32,.08);
  --hero-tint:  .18;       /* photo scrim strength         */

  --maxw: 1280px;
  --pad: clamp(20px, 5vw, 72px);

  /* Display headings use Poppins */
  --font-display:'Poppins', system-ui, sans-serif;
  --font-body:   'Poppins', system-ui, sans-serif;
  --font-label:  'Poppins', system-ui, sans-serif;
  --font-script: 'Sacramento', cursive;
  --display-track: .02em;   /* letter-spacing for display font */

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- type ---------- */
.display{
  font-family:var(--font-display);
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:.005em;
  font-weight:800;
  margin:0;
}
.script{ font-family:var(--font-script); text-transform:none; letter-spacing:0; line-height:.9; font-weight:400; }
.eyebrow{
  font-family:var(--font-label);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:12px;
  color:var(--rose-deep);
  margin:0 0 18px;
  font-weight:600;
}
.lede{ font-size:clamp(18px,2vw,22px); color:var(--ink-soft); max-width:60ch; font-weight:400; }
p{ text-wrap:pretty; }

/* ---------- layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(64px,10vw,140px); position:relative; }
.band-beige{ background:var(--beige); }
.band-soft{ background:var(--paper-2); }
.band-pink{ background:var(--pink); }
.band-ink{ background:var(--ink); color:var(--paper); }
.band-ink .lede,.band-ink .section-title,.band-ink p{ color:var(--paper); }
.center{ text-align:center; }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--font-label); font-weight:600;
  text-transform:uppercase; letter-spacing:.16em; font-size:12.5px;
  padding:16px 26px; border:1.5px solid var(--ink);
  color:var(--ink); background:transparent; cursor:pointer; border-radius:999px;
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
  white-space:nowrap;
}
.btn:hover{ background:var(--ink); color:var(--paper); }
.btn--solid{ background:var(--ink); border-color:var(--ink); color:var(--paper); }
.btn--solid:hover{ background:var(--rose-deep); border-color:var(--rose-deep); color:#fff; }
.btn--pink{ background:var(--pink); border-color:var(--pink); color:var(--ink); }
.btn--pink:hover{ background:var(--rose); border-color:var(--rose); color:var(--ink); }
.btn--block{ width:100%; justify-content:center; }

.arrow-link{
  font-family:var(--font-label); text-transform:uppercase; letter-spacing:.18em;
  font-size:12.5px; font-weight:600; color:var(--ink); display:inline-flex; gap:.6em; align-items:center;
  border-bottom:1.5px solid var(--rose); padding-bottom:3px; transition:.3s var(--ease);
}
.arrow-link:hover{ color:var(--pink); border-color:var(--pink); gap:1em; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  background:var(--paper);
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; padding:14px var(--pad);
  transition:box-shadow .4s var(--ease), padding .4s var(--ease), background .4s var(--ease);
  border-bottom:1px solid var(--line-soft);
}
.site-header.shrink{ padding-block:9px; box-shadow:0 6px 30px rgba(35,31,32,.07); }
.hdr-left,.hdr-right{ flex:1; display:flex; align-items:center; gap:24px; }
.hdr-right{ justify-content:flex-end; }
.menu-toggle{ display:flex; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px 0; }
.menu-toggle span{ width:28px; height:2px; background:var(--ink); transition:.3s var(--ease); }
.menu-toggle:hover span{ background:var(--pink); }

.hdr-nav{ display:flex; gap:26px; align-items:center; }
.hdr-nav a{
  font-family:var(--font-label); font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  color:var(--ink); opacity:.7; transition:.25s var(--ease); position:relative; padding-block:4px;
}
.hdr-nav a:hover{ opacity:1; color:var(--pink); }
.hdr-nav a.active{ opacity:1; }
.hdr-nav a.active::after{ content:""; position:absolute; left:0; bottom:-2px; width:100%; height:2px; background:var(--rose); }

.brand-mark{ display:flex; align-items:center; }
.brand-mark img{ height:var(--logo-size,48px); width:auto; transition:height .4s var(--ease), opacity .25s var(--ease); }
.brand-mark:hover img{ opacity:.7; }
.site-header.shrink .brand-mark img{ height:calc(var(--logo-size,48px) - 6px); }
@media (max-width:560px){ .brand-mark img{ height:calc(var(--logo-size,48px) - 10px); } }

@media (max-width:980px){ .hdr-nav{ display:none; } }

/* drawer */
.drawer{ position:fixed; inset:0; z-index:80; background:rgba(35,31,32,.4); backdrop-filter:blur(5px); opacity:0; pointer-events:none; transition:opacity .4s var(--ease); }
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer-panel{
  position:absolute; inset:0 auto 0 0; width:min(440px,86vw); background:var(--paper);
  padding:34px var(--pad); transform:translateX(-100%); transition:transform .5s var(--ease);
  display:flex; flex-direction:column; border-right:1px solid var(--line);
}
.drawer.open .drawer-panel{ transform:none; }
.drawer-close{ align-self:flex-end; background:none; border:0; color:var(--ink); font-family:var(--font-label); font-size:13px; letter-spacing:.18em; cursor:pointer; text-transform:uppercase; font-weight:600; }
.drawer-nav{ margin-top:30px; display:flex; flex-direction:column; gap:4px; }
.drawer-nav a{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(30px,6.5vw,46px); line-height:1.12; color:var(--ink); transition:.25s var(--ease); }
.drawer-nav a:hover{ color:var(--pink); padding-left:14px; }
.drawer-sub{ display:flex; gap:18px; padding-left:6px; margin:-2px 0 8px; }
.drawer-sub a{ font-family:var(--font-label); font-size:13px; letter-spacing:.1em; text-transform:uppercase; font-weight:500; color:var(--ink-soft); }
.drawer-sub a:hover{ color:var(--pink); padding:0; }
.drawer-foot{ margin-top:auto; display:flex; gap:18px; align-items:center; padding-top:30px; border-top:1px solid var(--line); }
.drawer-foot a{ font-family:var(--font-label); font-size:12px; letter-spacing:.12em; text-transform:uppercase; font-weight:500; color:var(--ink-soft); }
.drawer-foot a:hover{ color:var(--pink); }

/* ============================================================
   PLACEHOLDER IMAGES (light)
   ============================================================ */
.ph{
  position:relative; overflow:hidden; background:var(--beige-soft);
  background-image:repeating-linear-gradient(135deg, rgba(225,167,161,.18) 0 2px, transparent 2px 15px);
  display:flex; align-items:center; justify-content:center;
}
.ph::after{
  content:attr(data-label);
  font-family:var(--font-label); font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:500;
  color:var(--ink-soft); opacity:.85; padding:6px 12px; border:1px solid var(--line); background:rgba(255,255,255,.5);
  text-align:center; max-width:80%; border-radius:4px;
}
.ph--pink{ background-color:var(--pink-soft); background-image:repeating-linear-gradient(135deg, rgba(225,167,161,.3) 0 2px, transparent 2px 15px); }

/* ============================================================
   HERO — bright split (logo + photo)
   ============================================================ */
.hero{
  display:grid; grid-template-columns:1.05fr .95fr; align-items:stretch;
  min-height:100svh; padding-top:78px;
}
.hero__left{ display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; padding:clamp(40px,6vw,90px) var(--pad); }
.hero__logo{ width:min(72%, 335px); height:auto; max-height:235px; }
.hero__tag{ font-size:clamp(14px,1.3vw,16px); color:var(--ink-soft); max-width:42ch; margin:26px auto 0; }
.hero__meta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; justify-content:center; margin-top:32px; }
.hero__right{ position:relative; overflow:hidden; }
.hero__right .ph{ position:absolute; inset:0; }
.hero__right::after{ content:""; position:absolute; inset:0; background:var(--pink); mix-blend-mode:multiply; opacity:var(--hero-tint); pointer-events:none; }
@media (max-width:900px){
  .hero{ grid-template-columns:1fr; min-height:auto; }
  .hero__right{ min-height:48vh; order:-1; }
  .hero__left{ padding-block:clamp(40px,9vw,70px); }
  .hero__logo{ width:min(64%, 275px); max-height:none; }
}

.scroll-cue{ position:absolute; bottom:22px; left:clamp(20px,5vw,72px); z-index:2; font-family:var(--font-label); font-size:10px; letter-spacing:.26em; text-transform:uppercase; font-weight:600; color:var(--ink-soft); display:flex; align-items:center; gap:10px; }
.scroll-cue .line{ width:40px; height:1px; background:var(--rose); }
@media (max-width:900px){ .scroll-cue{ display:none; } }

/* ============================================================
   SECTIONS
   ============================================================ */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,6vw,90px); align-items:center; }
/* About — three-piece layout (image · text · image) to fill wide-screen space */
.about-grid{ display:grid; grid-template-columns:0.82fr 1.05fr 0.92fr; gap:clamp(22px,3vw,46px); align-items:stretch; }
.about-grid__media{ position:relative; min-height:420px; border-radius:8px; overflow:hidden; }
.about-grid__text{ display:flex; flex-direction:column; justify-content:center; }
@media (max-width:980px){
  .about-grid{ grid-template-columns:1fr 1fr; }
  .about-grid__media{ display:none; }
}
@media (max-width:860px){
  .about-grid{ grid-template-columns:1fr; gap:28px; }
  .about-grid__text{ order:-1; }
}
.split--rev .split__media{ order:-1; }
@media (max-width:860px){ .split{ grid-template-columns:1fr; } .split--rev .split__media{ order:0; } }

.section-title{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; line-height:.98; font-size:clamp(26px,4.3vw,60px); color:var(--ink); margin:0; letter-spacing:.005em; }
.section-title em{ color:var(--rose-deep); font-style:normal; }
.kicker-row{ display:flex; align-items:baseline; gap:18px; flex-wrap:wrap; }

.media-tall{ aspect-ratio:4/5; }
.media-wide{ aspect-ratio:16/10; }
.media-sq{ aspect-ratio:1/1; }

/* menu trio cards */
.trio{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media (max-width:860px){ .trio{ grid-template-columns:1fr; } }
.mcard{ position:relative; overflow:hidden; display:block; aspect-ratio:3/4; border-radius:6px; }
.mcard .ph{ position:absolute; inset:0; transition:transform .7s var(--ease); }
.mcard:hover .ph{ transform:scale(1.06); }
.mcard__label{ position:absolute; inset:auto 0 0 0; z-index:2; padding:24px; background:linear-gradient(transparent, rgba(255,255,255,.92)); display:flex; align-items:flex-end; justify-content:space-between; gap:12px; }
.mcard__label h3{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(22px,3vw,32px); margin:0; color:var(--ink); }
.mcard__label .plus{ font-family:var(--font-label); color:var(--rose-deep); font-weight:700; font-size:20px; }

/* locations */
.loc-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:860px){ .loc-grid{ grid-template-columns:1fr; } }
.loc{ background:var(--paper); border:1px solid var(--line); overflow:hidden; border-radius:8px; }
.loc .ph{ aspect-ratio:16/9; }
.loc__body{ padding:30px; }
.loc__body h3{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(26px,4vw,40px); margin:0 0 8px; }
.loc__body .addr{ color:var(--ink-soft); font-size:15px; margin:0 0 22px; }
a.addr{ transition:color .2s var(--ease); }
a.addr:hover{ color:var(--rose-deep); }
/* contact location buttons: pink hover (not black) */
.loc__body .btn:hover{ background:var(--pink); border-color:var(--pink); color:var(--ink); }

/* hours */
.hours{ display:flex; flex-direction:column; align-items:center; gap:14px; text-align:center; }
.hours .big{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(34px,6vw,72px); color:var(--ink); margin:0; }
.hours .big em{ color:var(--rose-deep); font-style:normal; }

/* gallery */
.gallery{ display:flex; gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:14px; }
.gallery::-webkit-scrollbar{ height:6px; }
.gallery::-webkit-scrollbar-thumb{ background:var(--line); border-radius:3px; }
.gallery .ph{ flex:0 0 clamp(320px,42vw,560px); aspect-ratio:3/4; scroll-snap-align:start; border-radius:6px; }
.gallery .gal-slot{ flex:0 0 clamp(320px,42vw,560px); aspect-ratio:3/4; scroll-snap-align:start; display:block; object-fit:cover; border-radius:6px; }
.gallery-ctrl{ display:flex; gap:10px; }
.gallery-ctrl button{ width:48px; height:48px; border:1.5px solid var(--ink); background:none; color:var(--ink); cursor:pointer; font-size:18px; border-radius:999px; transition:.25s var(--ease); }
.gallery-ctrl button:hover{ background:var(--ink); color:var(--paper); }

/* feature */
.feature{ display:grid; grid-template-columns:1.1fr .9fr; gap:0; align-items:stretch; border-radius:8px; overflow:hidden; }
@media (max-width:860px){ .feature{ grid-template-columns:1fr; } }
.feature__media .ph{ height:100%; min-height:340px; }
.feature__body{ padding:clamp(36px,6vw,80px); display:flex; flex-direction:column; justify-content:center; }

/* faq */
.faq{ max-width:920px; margin-inline:auto; }
.faq-item{ border-top:1px solid var(--line); }
.faq-item:last-child{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:none; border:0; color:var(--ink); cursor:pointer; font-family:var(--font-body); font-weight:600; font-size:clamp(18px,2.2vw,23px); padding:26px 44px 26px 0; position:relative; }
.faq-q::after{ content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%); font-family:var(--font-label); color:var(--rose-deep); font-size:26px; transition:.3s var(--ease); }
.faq-item.open .faq-q::after{ transform:translateY(-50%) rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ color:var(--ink-soft); margin:0 0 26px; max-width:70ch; }

/* reservation bar */
.resbar{ background:var(--pink); color:var(--ink); }
.resbar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding-block:34px; flex-wrap:wrap; }
.resbar h3{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(28px,4vw,52px); margin:0; }
.resbar .btn{ border-color:var(--ink); color:var(--ink); }
.resbar .btn:hover{ background:var(--ink); color:var(--pink); }

/* ============================================================
   PAGE HEROES / MENU
   ============================================================ */
.page-hero{ padding-top:150px; padding-bottom:40px; }
.page-hero .display{ font-size:clamp(38px,8vw,98px); }
.menu-section{ padding-block:clamp(40px,6vw,72px); }
.menu-cat{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(28px,5vw,52px); color:var(--rose-deep); margin:0 0 6px; }
.menu-cat-note{ font-family:var(--font-label); font-size:12px; letter-spacing:.14em; text-transform:uppercase; font-weight:500; color:var(--ink-soft); margin:0 0 30px; }
.menu-list{ display:grid; gap:6px; }
.menu-row{ display:grid; grid-template-columns:1fr auto; gap:16px; align-items:baseline; padding:16px 0; border-bottom:1px solid var(--line-soft); }
.menu-row__main{ display:flex; flex-direction:column; gap:5px; }
.menu-row__name{ font-weight:600; font-size:19px; display:flex; align-items:center; gap:10px; }
.menu-row__desc{ color:var(--ink-soft); font-size:15px; max-width:62ch; }
.menu-row__price{ font-family:var(--font-label); font-weight:600; color:var(--ink); font-size:16px; white-space:nowrap; }
.tag{ font-family:var(--font-label); font-size:9px; letter-spacing:.1em; text-transform:uppercase; font-weight:600; padding:3px 7px; border:1px solid var(--rose); color:var(--rose-deep); border-radius:3px; }
.menu-cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,80px); }
@media (max-width:820px){ .menu-cols{ grid-template-columns:1fr; } }

/* real menu image sheets */
.menu-sheets{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
@media (max-width:760px){ .menu-sheets{ grid-template-columns:1fr; } }
.menu-sheets img{ width:100%; height:auto; border:1px solid var(--line); border-radius:8px; box-shadow:0 14px 44px rgba(35,31,32,.08); background:var(--paper); }
.sheet-note{ font-family:var(--font-label); font-size:12px; letter-spacing:.06em; color:var(--ink-soft); text-align:center; margin:0 0 30px; }

/* ============================================================
   DIGITAL MENU (SEO-friendly text menu)
   ============================================================ */
.menu-wrap{ max-width:1180px; margin:0 auto; padding-inline:var(--pad); }
.menu-toc{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 0 10px; }
.menu-toc a{ font-family:var(--font-label); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; font-weight:600; color:var(--ink-soft); padding:8px 14px; border:1px solid var(--line); border-radius:999px; transition:.2s var(--ease); }
.menu-toc a:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.menu-cat-head{ display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; margin:0 0 4px; scroll-margin-top:120px; }
.menu-cat-head .menu-cat{ margin:0; }
.menu-cat-head .cat-price{ font-family:var(--font-label); font-weight:700; font-size:clamp(16px,2vw,20px); color:var(--ink); letter-spacing:.02em; }
.menu-cat-head .cat-en{ font-family:var(--font-label); font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:500; color:var(--ink-soft); }
.menu-intro{ color:var(--ink-soft); font-size:15.5px; margin:2px 0 24px; max-width:64ch; }

.menu-grid{ display:grid; grid-template-columns:1fr 1fr; gap:6px clamp(34px,6vw,84px); align-items:start; }
@media (max-width:760px){ .menu-grid{ grid-template-columns:1fr; } }
.menu-grid--solo{ grid-template-columns:1fr; max-width:760px; }

.mi{ padding:15px 0; border-bottom:1px solid var(--line-soft); break-inside:avoid; }
.mi__top{ display:flex; align-items:baseline; gap:8px; }
.mi__name{ font-weight:600; font-size:18px; color:var(--ink); display:flex; align-items:baseline; gap:9px; flex-wrap:wrap; }
.mi__dots{ flex:1; border-bottom:1.5px dotted var(--line); transform:translateY(-4px); min-width:18px; }
.mi__price{ font-family:var(--font-label); font-weight:700; color:var(--ink); font-size:15.5px; white-space:nowrap; letter-spacing:.02em; }
.mi__price .alt{ color:var(--ink-soft); font-weight:500; }
.mi__desc{ color:var(--ink-soft); font-size:14.5px; margin:5px 0 0; max-width:60ch; line-height:1.5; }

.tag{ font-family:var(--font-label); font-size:9px; letter-spacing:.08em; text-transform:uppercase; font-weight:700; padding:2px 6px; border:1px solid var(--rose); color:var(--rose-deep); border-radius:3px; line-height:1.5; }

/* a “choose a filling” chip cluster */
.fillings{ display:flex; flex-wrap:wrap; gap:7px; margin:14px 0 0; }
.fillings .chip{ font-family:var(--font-label); font-size:12px; font-weight:500; letter-spacing:.02em; color:var(--ink); background:var(--paper); border:1px solid var(--line); border-radius:999px; padding:6px 13px; }
.fillings .chip .tag{ margin-left:5px; }
.fillings-note{ font-family:var(--font-label); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--rose-deep); font-weight:600; margin:12px 0 0; }

/* highlighted callout (e.g. ANY 3 TACOS) */
.menu-callout{ display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; text-align:center; background:var(--pink); border-radius:10px; padding:20px 26px; margin:26px 0 0; }
.menu-callout strong{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(20px,3vw,30px); color:var(--ink); letter-spacing:.02em; }
.menu-callout span{ font-size:14px; color:var(--ink); opacity:.75; }

.menu-pill-note{ display:inline-block; font-family:var(--font-label); font-size:12px; letter-spacing:.08em; text-transform:uppercase; font-weight:600; color:var(--rose-deep); border:1px solid var(--rose); border-radius:999px; padding:7px 16px; margin:18px 0 0; }

/* refined "Any 3 Tacos" deal — minimal outlined pill, centered */
.taco-deal{ display:inline-flex; align-items:baseline; gap:12px; margin:30px auto 0; padding:11px 22px; border:1px solid var(--line); border-radius:999px; background:transparent; }
.menu-section .taco-deal{ }
.taco-deal__label{ font-family:var(--font-label); font-weight:600; font-size:14px; letter-spacing:.04em; color:var(--ink); }
.taco-deal__price{ font-family:var(--font-label); font-weight:700; font-size:15px; color:var(--ink); }
.taco-deal__note{ font-family:var(--font-label); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); }
.taco-deal-wrap{ text-align:center; }

/* price-options header (Neat / Rocks / Frozen) */
.price-opts{ display:flex; flex-wrap:wrap; gap:10px 26px; margin:0 0 22px; }
.price-opts .po{ display:flex; align-items:baseline; gap:8px; }
.price-opts .po b{ font-family:var(--font-label); font-size:12px; letter-spacing:.12em; text-transform:uppercase; font-weight:600; color:var(--ink-soft); }
.price-opts .po span{ font-family:var(--font-label); font-weight:700; color:var(--ink); }

/* simple centered list (cocktails, spirits) */
.menu-simple{ display:grid; gap:9px; }
.menu-simple .ms{ display:flex; align-items:baseline; gap:8px; }
.menu-simple .ms__name{ font-weight:600; font-size:16.5px; color:var(--ink); }
.menu-simple .ms__dots{ flex:1; border-bottom:1.5px dotted var(--line); transform:translateY(-4px); min-width:16px; }
.menu-simple .ms__price{ font-family:var(--font-label); font-weight:700; font-size:15px; color:var(--ink); white-space:nowrap; }
.menu-simple .ms__sub{ color:var(--ink-soft); font-size:13.5px; font-weight:400; }

.menu-foot-note{ text-align:center; font-style:italic; color:var(--ink-soft); font-size:13.5px; margin:46px 0 0; padding-top:22px; border-top:1px solid var(--line); }
.menu-legend{ text-align:center; font-family:var(--font-label); font-size:11.5px; letter-spacing:.08em; color:var(--ink-soft); margin:8px 0 0; }

/* promo cards */
.promo-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
@media (max-width:900px){ .promo-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .promo-grid{ grid-template-columns:1fr; } }
.promo-card{ border-radius:8px; overflow:hidden; border:1px solid var(--line); background:var(--paper); box-shadow:0 10px 34px rgba(35,31,32,.06); }
.promo-card img{ width:100%; height:auto; display:block; }

/* photos masonry */
.masonry{ columns:3; column-gap:14px; }
@media (max-width:900px){ .masonry{ columns:2; } }
@media (max-width:560px){ .masonry{ columns:1; } }
.masonry .ph{ width:100%; margin-bottom:14px; break-inside:avoid; border-radius:6px; }
.masonry-img{ width:100%; margin-bottom:14px; break-inside:avoid; border-radius:6px; display:block; transition:filter .3s var(--ease), transform .4s var(--ease); }
.masonry-img:hover{ filter:brightness(1.05) saturate(1.05); transform:scale(1.01); }

/* events list */
.event{ display:grid; grid-template-columns:140px 1fr auto; gap:30px; align-items:center; padding:30px 0; border-top:1px solid var(--line); }
.event:last-child{ border-bottom:1px solid var(--line); }
.event__date{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; line-height:.9; }
.event__date .day{ font-size:46px; color:var(--rose-deep); display:block; }
.event__date .mo{ font-size:17px; color:var(--ink-soft); letter-spacing:.08em; }
.event__name{ font-family:var(--font-display); text-transform:uppercase; font-weight:800; font-size:clamp(22px,3vw,36px); margin:0 0 6px; }
.event__meta{ font-family:var(--font-label); font-size:12px; letter-spacing:.1em; text-transform:uppercase; font-weight:500; color:var(--ink-soft); }
@media (max-width:720px){ .event{ grid-template-columns:1fr; gap:12px; } }

/* contact */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:860px){ .contact-grid{ grid-template-columns:1fr; } }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-family:var(--font-label); font-size:11px; letter-spacing:.12em; text-transform:uppercase; font-weight:600; color:var(--ink-soft); }
.field input,.field textarea,.field select{ background:var(--paper); border:1px solid var(--line); color:var(--ink); padding:14px 16px; font-family:var(--font-body); font-size:16px; border-radius:6px; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--rose); }

/* ============================================================
   FOOTER — black anchor (white logo per brand rule)
   ============================================================ */
.site-footer{ background:var(--ink); color:var(--paper); padding-block:clamp(56px,8vw,96px); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
@media (max-width:860px){ .footer-top{ grid-template-columns:1fr; gap:34px; } }
.footer-brand p{ color:rgba(255,255,255,.66); font-size:14px; max-width:34ch; margin-top:18px; }
.footer-col h4{ font-family:var(--font-label); font-size:11px; letter-spacing:.2em; text-transform:uppercase; font-weight:600; color:var(--rose); margin:0 0 16px; }
.footer-col a, .footer-col p{ display:block; color:rgba(255,255,255,.66); font-size:14px; margin:0 0 10px; transition:.2s var(--ease); }
.footer-col a:hover{ color:var(--pink); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; gap:20px; margin-top:60px; padding-top:26px; border-top:1px solid rgba(255,255,255,.16); flex-wrap:wrap; }
.footer-bottom .legal{ font-family:var(--font-label); font-size:11px; letter-spacing:.1em; text-transform:uppercase; font-weight:500; color:rgba(255,255,255,.55); }
.socials{ display:flex; gap:14px; }
.socials a{ width:42px; height:42px; border:1px solid rgba(255,255,255,.25); display:flex; align-items:center; justify-content:center; color:#fff; border-radius:999px; transition:.25s var(--ease); }
.socials a:hover{ background:var(--rose); border-color:var(--rose); color:var(--ink); }
.socials svg{ width:18px; height:18px; }

/* reveal — VISIBLE by default; entrance is a pure enhancement so content
   can never be left stuck hidden if observers/timers misbehave */
@keyframes revealUp{ from{ opacity:0; transform:translateY(28px); } to{ opacity:1; transform:none; } }
.reveal.in{ animation:revealUp .7s var(--ease) both; }

/* ============================================================
   HOME FOOD SHOWCASE — full-bleed image band
   ============================================================ */
.food-feature{
  position:relative; min-height:clamp(440px,70vh,720px);
  display:flex; align-items:flex-end; overflow:hidden;
  background:var(--beige-soft);
}
.food-feature__img{ position:absolute; inset:0; width:100%; height:100%; display:block; }
.food-feature__img::part(empty){ background:var(--beige-soft); }
.food-feature::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(35,31,32,.72) 0%, rgba(35,31,32,.38) 42%, rgba(35,31,32,0) 72%);
}
.food-feature__overlay{
  position:relative; z-index:2; padding:clamp(34px,6vw,86px) var(--pad);
  max-width:760px; color:#fff;
}
.food-feature__overlay .section-title{ color:#fff; }
.food-feature__overlay .section-title em{ color:var(--pink); }
.food-feature__overlay .lede{ color:rgba(255,255,255,.86); }

/* ============================================================
   CAREERS
   ============================================================ */
.careers-intro{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,6vw,80px); }
@media (max-width:760px){ .careers-intro{ grid-template-columns:1fr; gap:30px; } }
.careers-intro h4{ font-family:var(--font-label); font-size:11px; letter-spacing:.2em; text-transform:uppercase; font-weight:600; color:var(--rose-deep); margin:0 0 16px; }
.careers-intro p{ color:var(--ink); font-size:17px; margin:0 0 18px; }

.dept-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:42px; }
@media (max-width:900px){ .dept-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .dept-grid{ grid-template-columns:1fr; } }
.dept-card{ border:1px solid rgba(255,255,255,.16); border-radius:8px; padding:34px 22px; text-align:center; background:rgba(255,255,255,.02); cursor:pointer; transition:border-color .3s var(--ease), transform .3s var(--ease), background .3s var(--ease); }
.dept-card:hover{ border-color:var(--pink); transform:translateY(-4px); background:rgba(255,209,214,.06); }
.dept-card__icon{ width:46px; height:auto; margin:0 auto 16px; display:block; filter:brightness(0) invert(1); opacity:.92; }
.dept-card h3{ font-family:var(--font-display); font-weight:800; text-transform:uppercase; font-size:clamp(20px,2.4vw,26px); margin:0 0 6px; color:var(--paper); }
.dept-card .id{ font-family:var(--font-body); font-size:13px; font-weight:600; color:var(--pink); margin:0 0 16px; }
.dept-card .apply-tag{ font-family:var(--font-label); font-size:11px; letter-spacing:.18em; text-transform:uppercase; font-weight:600; color:var(--pink); opacity:0; transition:opacity .3s var(--ease); }
.dept-card:hover .apply-tag{ opacity:1; }

.cv-drop{ border:1.5px dashed var(--line); border-radius:8px; padding:30px; display:flex; align-items:center; gap:14px; justify-content:center; color:var(--ink-soft); cursor:pointer; transition:border-color .25s var(--ease), background .25s var(--ease); font-size:15px; }
.cv-drop:hover, .cv-drop.dragover{ border-color:var(--rose); background:var(--pink-soft); }
.cv-drop svg{ width:24px; height:24px; flex:none; }
.cv-drop.has-file{ border-style:solid; border-color:var(--rose-deep); color:var(--ink); }
.careers-form .field--full{ grid-column:1 / -1; }
.careers-note{ font-family:var(--font-body); font-size:14px; color:var(--ink-soft); margin-top:16px; }
.careers-note strong{ color:var(--ink); }

/* utility */
.mt-s{ margin-top:18px; } .mt-m{ margin-top:34px; } .mt-l{ margin-top:56px; }
.maxw-prose{ max-width:64ch; }

/* ============================================================
   PAGE LOADER — spinning Frida mark
   ============================================================ */
.page-loader{
  position:fixed; inset:0; z-index:9999;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg);
  opacity:1; transition:opacity .5s var(--ease);
}
.page-loader.is-hidden{ opacity:0; pointer-events:none; }
.page-loader__mark{
  width:clamp(74px,11vw,108px); height:auto; display:block;
  animation:loaderSpin 1.1s linear infinite;
  transform-origin:50% 50%;
}
@keyframes loaderSpin{ to{ transform:rotate(360deg); } }
@media (prefers-reduced-motion: reduce){
  .page-loader__mark{ animation:loaderPulse 1.2s ease-in-out infinite; }
  @keyframes loaderPulse{ 0%,100%{ opacity:.4; } 50%{ opacity:1; } }
}
