/* ---------- Tokens ---------- */
:root{
  --cream: #FBF6EC;
  --cream-2: #F4ECDD;
  --ink: #1E1A17;
  --ink-soft: #4A413A;
  --tomato: #C9482A;        /* primary accent — warm Salvadoran red */
  --tomato-dark: #A0341C;
  --sun: #E9B144;           /* secondary accent — sunshine */
  --sage: #4F6147;          /* tertiary — for depth */
  --line: rgba(30,26,23,.12);
  --shadow-sm: 0 1px 2px rgba(30,26,23,.06), 0 2px 6px rgba(30,26,23,.05);
  --shadow-md: 0 8px 24px rgba(30,26,23,.10), 0 2px 6px rgba(30,26,23,.06);
  --shadow-lg: 0 24px 60px rgba(30,26,23,.18);
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --container: 1180px;
  --pad-section: clamp(64px, 9vw, 112px);
}

/* ---------- Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:var(--tomato);text-decoration:none}
a:hover{color:var(--tomato-dark);text-decoration:underline;text-underline-offset:3px}

h1,h2,h3{
  font-family:'Fraunces', Georgia, 'Times New Roman', serif;
  font-weight:600;
  letter-spacing:-.01em;
  line-height:1.08;
  margin:0 0 .5em;
  color:var(--ink);
}
h2{font-size:clamp(2rem, 4vw, 3.1rem);}
h3{font-size:1.35rem;line-height:1.3;letter-spacing:0;}
p{margin:0 0 1em}

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 clamp(20px, 5vw, 40px);
}
.serif-italic{font-family:'Fraunces',serif;font-style:italic;font-weight:500;color:var(--tomato);}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(251,246,236,.88);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);font-weight:700;}
.brand:hover{text-decoration:none;color:var(--ink)}
.brand__logo{
  width:40px;height:40px;border-radius:50%;
  border:2px solid var(--tomato);
  object-fit:cover;
}
.brand__name{
  font-family:'Fraunces',serif;
  font-size:1.35rem;font-weight:700;letter-spacing:-.01em;
}
.brand__accent{color:var(--tomato);font-style:italic;font-weight:500}

.nav__links{display:flex;align-items:center;gap:28px;}
.nav__links a{color:var(--ink);font-weight:500;font-size:.97rem}
.nav__links a:hover{color:var(--tomato);text-decoration:none}
.nav__ig{
  background:var(--ink);color:var(--cream)!important;
  padding:8px 14px;border-radius:999px;font-size:.9rem;
  transition:background .2s ease;
}
.nav__ig:hover{background:var(--tomato);color:#fff!important}

.nav__toggle{
  display:none;background:none;border:0;padding:8px;cursor:pointer;
}
.nav__toggle span{
  display:block;width:24px;height:2px;background:var(--ink);
  margin:5px 0;transition:transform .25s ease, opacity .2s ease;
}

/* ---------- Hero ---------- */
.hero{
  padding:clamp(56px, 9vw, 96px) 0 clamp(40px, 7vw, 80px);
  background:
    radial-gradient(1200px 600px at 80% -20%, rgba(233,177,68,.20), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(201,72,42,.10), transparent 60%),
    var(--cream);
  overflow:hidden;
}
.hero__grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(32px, 5vw, 80px);
  align-items:center;
}
.eyebrow{
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.78rem;
  font-weight:600;
  color:var(--tomato);
  margin:0 0 18px;
}
.eyebrow--dark{color:var(--sage)}
.eyebrow--light{color:var(--sun)}
.hero__title{
  font-size:clamp(2.5rem, 6vw, 4.6rem);
  margin:0 0 22px;
}
.hero__lede{
  font-size:1.13rem;
  color:var(--ink-soft);
  max-width:46ch;
  margin-bottom:32px;
}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.hero__pills{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;gap:10px;
}
.hero__pills li{
  background:rgba(255,255,255,.7);
  border:1px solid var(--line);
  padding:8px 14px;border-radius:999px;
  font-size:.92rem;color:var(--ink-soft);font-weight:500;
}
.hero__pills a{color:var(--ink);font-weight:600}

.hero__art{position:relative;min-height:420px}
.hero__img{
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
  object-fit:cover;
}
.hero__img--main{
  width:100%;
  aspect-ratio:4/5;
  transform:rotate(1.5deg);
}
.hero__img--accent{
  position:absolute;
  width:55%;
  aspect-ratio:1/1;
  bottom:-20px;left:-30px;
  transform:rotate(-4deg);
  border:6px solid var(--cream);
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 24px;border-radius:999px;
  font-weight:600;font-size:.98rem;letter-spacing:.01em;
  border:1px solid transparent;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  cursor:pointer;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--primary{background:var(--tomato);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--tomato-dark);color:#fff;box-shadow:var(--shadow-md)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn--small{padding:10px 18px;font-size:.9rem}

/* ---------- Section base ---------- */
.section{padding:var(--pad-section) 0}
.section--cream{background:var(--cream-2)}
.section--dark{background:var(--ink);color:var(--cream)}
.section--dark h2{color:var(--cream)}
.section__head{text-align:center;max-width:680px;margin:0 auto clamp(40px, 6vw, 64px)}
.section__sub{color:var(--ink-soft);font-size:1.08rem;margin:0}

/* ---------- Menu ---------- */
.menu__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(20px, 3vw, 32px);
}
.menu-card{
  background:#fff;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
  display:flex;flex-direction:column;
  position:relative;
}
.menu-card::before{
  /* hairline gradient border on hover */
  content:"";position:absolute;inset:0;border-radius:inherit;
  padding:1px;
  background:linear-gradient(135deg, var(--tomato), var(--sun));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:0;transition:opacity .25s ease;
  pointer-events:none;
}
.menu-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.menu-card:hover::before{opacity:1}
.menu-card__media{
  position:relative;
  aspect-ratio:4/5;            /* portrait — matches IG portrait + reel covers */
  overflow:hidden;
  background:var(--cream-2);
}
.menu-card__media img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center center;
  transition:transform .7s cubic-bezier(.2,.7,.2,1);
}
.menu-card:hover .menu-card__media img{transform:scale(1.05)}
.menu-card__media::after{
  /* gentle gradient at bottom so tag stays readable */
  content:"";position:absolute;inset:auto 0 0 0;height:55%;
  background:linear-gradient(180deg, transparent, rgba(30,26,23,.05) 60%, rgba(30,26,23,.18));
  pointer-events:none;
}
.menu-card__tag{
  position:absolute;top:14px;left:14px;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(140%) blur(6px);
  color:var(--ink);
  padding:7px 13px;border-radius:999px;
  font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  box-shadow:0 4px 12px rgba(30,26,23,.12);
  display:inline-flex;align-items:center;gap:6px;
}
.menu-card__tag::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--tomato);
}
.menu-card__tag--sun::before{background:var(--sun)}
.menu-card__tag--tomato::before{background:var(--tomato)}
.menu-card__tag--sage::before{background:var(--sage)}

.menu-card__body{padding:24px 24px 28px;flex:1;display:flex;flex-direction:column}
.menu-card__body h3{
  margin-bottom:18px;
  color:var(--tomato);
  font-style:italic;
  position:relative;
  padding-bottom:10px;
}
.menu-card__body h3::after{
  content:"";position:absolute;left:0;bottom:0;
  width:36px;height:2px;
  background:linear-gradient(90deg, var(--tomato), var(--sun));
  border-radius:2px;
}
.menu-list{margin:0 0 8px;padding:0;list-style:none}
.menu-list__sub{
  margin:18px 0 4px;
  font-family:var(--sans);
  font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--tomato);
}
.menu-list__sub:first-of-type{margin-top:4px}
.menu-list__sub em{
  color:var(--ink-soft);font-weight:500;
  font-style:italic;letter-spacing:.02em;
  text-transform:none;
}
.menu-list li{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
  padding:10px 0;
  border-bottom:1px dashed var(--line);
  font-size:.95rem;
  line-height:1.45;
}
.menu-list li:last-child{border-bottom:0}
.menu-list li > div{flex:1;min-width:0}
.menu-list strong{font-weight:600}
.menu-list em{
  font-style:italic;color:var(--tomato);
  font-size:.82rem;font-weight:500;
}
.menu-list small{
  display:block;color:var(--ink-soft);
  font-size:.82rem;line-height:1.4;margin-top:3px;
}
.price{
  flex-shrink:0;font-variant-numeric:tabular-nums;
  font-weight:600;color:var(--ink-soft);
  font-size:.92rem;
  padding-top:1px;
}
.menu__note{text-align:center;color:var(--ink-soft);margin-top:36px;font-size:.95rem}

/* ---------- Order & Catering ---------- */
.order__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(20px, 3vw, 28px);
  max-width:920px;margin:0 auto;
}
.order-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:clamp(28px, 4vw, 40px) clamp(24px, 3vw, 34px);
  box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;align-items:flex-start;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.order-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:rgba(201,72,42,.25)}
.order-card__kicker{
  font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--sage);margin-bottom:12px;
}
.order-card h3{font-size:1.55rem;margin-bottom:12px}
.order-card p{color:var(--ink-soft);max-width:42ch;margin-bottom:18px}
.order-card .btn{margin-top:auto}
.order-card__note{font-size:.86rem;color:var(--ink-soft);margin:14px 0 0;opacity:.85}
@media (max-width: 640px){
  .order__grid{grid-template-columns:1fr}
}

/* ---------- About ---------- */
.about__grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(32px, 5vw, 72px);
  align-items:center;
}
.about__copy p{font-size:1.08rem;color:var(--ink-soft);max-width:52ch}
.about__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.about__chips span{
  background:#fff;border:1px solid var(--line);
  padding:8px 14px;border-radius:999px;
  font-size:.9rem;font-weight:500;color:var(--ink);
}
.about__media img{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-md);
  transform:rotate(-1.5deg);
}

/* ---------- Visit ---------- */
.visit__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(16px, 2.5vw, 24px);
  margin-bottom:40px;
}
.visit__card{
  background:#fff;
  border-radius:var(--r-md);
  padding:28px 26px;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--line);
}
.visit__card h3{
  font-family:'Inter',sans-serif;
  font-size:.82rem;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--sage);
  font-weight:700;
  margin-bottom:14px;
}
.visit__big{
  font-family:'Fraunces',serif;
  font-size:1.45rem;
  line-height:1.25;
  font-weight:500;
  margin:0 0 18px;
  color:var(--ink);
}
.visit__big a{color:var(--ink)}
.visit__note{font-size:.88rem;color:var(--ink-soft);margin:14px 0 0}
.hours{width:100%;border-collapse:collapse;font-size:.95rem}
.hours td{padding:6px 0;border-bottom:1px solid var(--line)}
.hours td:first-child{color:var(--ink-soft);font-weight:500;width:40%}
.hours tr:last-child td{border-bottom:0}
.hours__closed td{color:var(--ink-soft);opacity:.6}

.map{
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  border:1px solid var(--line);
  aspect-ratio:16/7;
}
.map iframe{width:100%;height:100%;border:0;display:block}

/* ---------- Follow (dark section) ---------- */
.follow__inner{text-align:center}
.follow__inner h2{margin-bottom:14px}
.follow__lede{
  color:rgba(251,246,236,.75);
  max-width:46ch;margin:0 auto 32px;
}
.follow__grid{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  gap:10px;margin-top:48px;
}
.follow__grid a{
  display:block;aspect-ratio:1/1;overflow:hidden;border-radius:var(--r-sm);
  transition:opacity .2s ease, transform .25s ease;
}
.follow__grid img{width:100%;height:100%;object-fit:cover}
.follow__grid a:hover{opacity:.9;transform:translateY(-2px)}

/* ---------- Footer ---------- */
.footer{
  background:var(--cream-2);
  padding:48px 0 64px;
  border-top:1px solid var(--line);
  text-align:center;
}
.footer__brand{
  font-family:'Fraunces',serif;
  font-size:1.6rem;
  font-weight:600;
  margin:0 0 10px;
  color:var(--ink);
}
.footer p{margin:4px 0;color:var(--ink-soft)}
.footer__fine{font-size:.85rem;margin-top:24px!important;opacity:.7}

/* ---------- Open badge (nav) ---------- */
.open-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:999px;
  background:rgba(79,97,71,.10);
  color:var(--sage);
  font-size:.82rem;font-weight:600;letter-spacing:.01em;
  border:1px solid rgba(79,97,71,.18);
  transition:background .25s ease, color .25s ease, border-color .25s ease;
}
.open-badge--open{
  background:rgba(79,97,71,.14);
  color:#3a4a32;
  border-color:rgba(79,97,71,.30);
}
.open-badge--closed{
  background:rgba(201,72,42,.10);
  color:var(--tomato-dark);
  border-color:rgba(201,72,42,.25);
}
.open-badge__dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--sage);
  position:relative;
}
.open-badge--open .open-badge__dot{
  background:#4caf50;
  box-shadow:0 0 0 0 rgba(76,175,80,.55);
  animation:pulse 1.8s ease-out infinite;
}
.open-badge--closed .open-badge__dot{background:var(--tomato)}
@keyframes pulse{
  0%   { box-shadow: 0 0 0 0 rgba(76,175,80,.55); }
  70%  { box-shadow: 0 0 0 10px rgba(76,175,80,0); }
  100% { box-shadow: 0 0 0 0 rgba(76,175,80,0); }
}

/* ---------- Hero pill dot ---------- */
.pill-dot{
  display:inline-block;width:7px;height:7px;border-radius:50%;
  background:#4caf50;margin-right:7px;vertical-align:middle;
  box-shadow:0 0 0 3px rgba(76,175,80,.18);
}

/* ---------- Flag emoji bump (some platforms render flat) ---------- */
.flag{
  display:inline-block;
  transform:translateY(1px);
  filter:saturate(115%);
}

/* ---------- Wiggle ---------- */
.wiggle{
  display:inline-block;
  transform-origin:70% 80%;
  animation:wiggle 4s ease-in-out infinite;
}
@keyframes wiggle{
  0%, 90%, 100% { transform: rotate(0); }
  92% { transform: rotate(-14deg); }
  94% { transform: rotate(12deg); }
  96% { transform: rotate(-8deg); }
  98% { transform: rotate(5deg); }
}

/* ---------- About sticker ---------- */
.about__media{position:relative;margin:0}
.about__sticker{
  position:absolute;bottom:-22px;right:-14px;
  background:var(--sun);
  color:var(--ink);
  padding:14px 18px;
  border-radius:14px;
  box-shadow:var(--shadow-md);
  font-family:'Fraunces',serif;font-style:italic;font-weight:500;
  transform:rotate(-4deg);
  display:flex;align-items:center;gap:10px;
  font-size:.98rem;
  border:3px solid var(--cream-2);
}
.about__sticker span{font-size:1.4rem;line-height:1;font-style:normal}
.about__sticker small{font-size:.9rem;line-height:1}

/* ---------- Scroll reveal ---------- */
[data-reveal]{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
  will-change:opacity, transform;
}
[data-reveal].is-visible{opacity:1;transform:none}
/* stagger menu cards a touch */
.menu-card[data-reveal]:nth-child(2){transition-delay:.08s}
.menu-card[data-reveal]:nth-child(3){transition-delay:.16s}

/* ---------- Subtle hero photo float ---------- */
@keyframes floatA{
  0%,100% { transform: rotate(1.5deg) translateY(0) }
  50%     { transform: rotate(1.5deg) translateY(-6px) }
}
@keyframes floatB{
  0%,100% { transform: rotate(-4deg) translateY(0) }
  50%     { transform: rotate(-4deg) translateY(6px) }
}
.hero__img--main{animation:floatA 9s ease-in-out infinite}
.hero__img--accent{animation:floatB 11s ease-in-out infinite}

/* ---------- Visit card hover ---------- */
.visit__card{transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.visit__card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:rgba(201,72,42,.25);
}

/* ---------- Follow grid lift ---------- */
.follow__grid a{transition:transform .35s cubic-bezier(.2,.7,.2,1), filter .25s ease, opacity .2s ease}
.follow__grid a:hover{transform:translateY(-4px) scale(1.02);filter:saturate(115%)}

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .menu__grid{grid-template-columns:repeat(2,1fr)}
  .visit__grid{grid-template-columns:1fr 1fr}
  .visit__grid .visit__card:last-child{grid-column:1/-1}
  .follow__grid{grid-template-columns:repeat(3,1fr)}
  .hero__grid,
  .about__grid{grid-template-columns:1fr}
  .hero__art{min-height:380px;order:2}
  .about__media{order:-1;max-width:520px;margin:0 auto}
  .about__media img{aspect-ratio:4/3;transform:none}
}

@media (max-width: 900px){
  .open-badge{display:none}
}

@media (max-width: 640px){
  .nav__links{
    position:fixed;top:72px;left:0;right:0;
    background:var(--cream);
    flex-direction:column;
    align-items:stretch;
    gap:0;
    border-bottom:1px solid var(--line);
    transform:translateY(-12px);
    opacity:0;pointer-events:none;
    transition:transform .2s ease, opacity .2s ease;
    padding:12px 24px 20px;
  }
  .nav__links a{padding:14px 4px;border-bottom:1px solid var(--line)}
  .nav__links a:last-child{border-bottom:0}
  .nav__ig{margin-top:8px;align-self:flex-start}
  .nav.is-open .nav__links{
    transform:translateY(0);opacity:1;pointer-events:auto;
  }
  .nav__toggle{display:block}
  .nav.is-open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.is-open .nav__toggle span:nth-child(2){opacity:0}
  .nav.is-open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .menu__grid{grid-template-columns:1fr}
  .visit__grid{grid-template-columns:1fr}
  .visit__grid .visit__card:last-child{grid-column:auto}
  .follow__grid{grid-template-columns:repeat(2,1fr)}
  .hero__img--accent{width:48%;bottom:-12px;left:-12px}
  .map{aspect-ratio:4/3}
}

@media (prefers-reduced-motion: reduce){
  *{transition:none!important;animation:none!important}
  html{scroll-behavior:auto}
  [data-reveal]{opacity:1;transform:none}
  .hero__img--main{transform:rotate(1.5deg)}
  .hero__img--accent{transform:rotate(-4deg)}
}
