:root{
  --cream:#f4e8cc;
  --cream-2:#ecdcb6;
  --cream-3:#e3cf9e;
  --red:#b03028;
  --red-dark:#8a2521;
  --green:#2f6e4f;
  --green-dark:#1d4d35;
  --gold:#f0a81f;
  --gold-dark:#d3870f;
  --brown:#3a2417;
  --ink:#2a1b12;
  --paper-line:rgba(58,36,23,.08);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Bitter',Georgia,serif;
  color:var(--ink);
  background-color:var(--cream);
  background-image:
    radial-gradient(circle at 18% 12%, rgba(255,255,255,.35), transparent 45%),
    radial-gradient(circle at 85% 80%, rgba(58,36,23,.06), transparent 50%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
  line-height:1.6;
  overflow-x:hidden;
}
.fiesta{
  height:22px;
  background:
    repeating-linear-gradient(90deg,var(--red) 0 26px,var(--gold) 26px 52px,var(--green) 52px 78px,var(--cream-3) 78px 104px);
  position:relative;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.18), inset 0 3px 0 rgba(255,255,255,.18);
}
.fiesta::after{
  content:"";position:absolute;left:0;right:0;bottom:-13px;height:13px;
  background-image:
    radial-gradient(circle at 13px 0, transparent 12px, var(--green-dark) 12px 13px, transparent 13px);
  background-size:26px 26px;background-position:0 -13px;
  opacity:.25;
}
h1,h2,h3,.display{font-family:'Alfa Slab One',serif;font-weight:400;letter-spacing:.5px;line-height:1.02}
.label{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:2px}

.topbar{
  background:var(--ink);color:var(--cream);
  display:flex;justify-content:center;gap:28px;flex-wrap:wrap;
  padding:9px 18px;font-family:'Oswald',sans-serif;font-size:.82rem;
  text-transform:uppercase;letter-spacing:1.5px;
}
.topbar span{display:flex;align-items:center;gap:7px}
.topbar a{color:var(--gold);text-decoration:none;font-weight:600}

nav{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,#c0382f,var(--red));
  border-bottom:4px solid var(--gold);
  box-shadow:0 6px 18px rgba(42,27,18,.25);
}
.nav-inner{
  max-width:1180px;margin:0 auto;padding:12px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand .mark{width:46px;height:46px;flex:none}
.brand b{font-family:'Alfa Slab One',serif;color:var(--cream);font-size:1.5rem;
  line-height:.9;text-shadow:2px 2px 0 var(--red-dark)}
.brand b small{display:block;font-family:'Oswald',sans-serif;font-size:.62rem;
  letter-spacing:4px;color:var(--gold);font-weight:600;margin-top:3px}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{color:var(--cream);text-decoration:none;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:1.5px;font-size:.9rem;font-weight:500;
  transition:color .2s;position:relative}
.nav-links a:hover{color:var(--gold)}
.nav-links a.call{
  background:var(--gold);color:var(--ink);padding:9px 18px;border-radius:4px;
  font-weight:700;box-shadow:0 3px 0 var(--gold-dark);transition:transform .12s,box-shadow .12s}
.nav-links a.call:hover{transform:translateY(2px);box-shadow:0 1px 0 var(--gold-dark);color:var(--ink)}
.burger{display:none;background:none;border:none;cursor:pointer}
.burger span{display:block;width:26px;height:3px;background:var(--cream);margin:5px 0;border-radius:2px}

header.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(circle at 50% 120%, rgba(240,168,31,.18), transparent 55%),
    var(--cream);
  padding:64px 22px 30px;
}
.hero-inner{max-width:1180px;margin:0 auto;display:grid;
  grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.eyebrow{display:inline-block;background:var(--green);color:var(--cream);
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:3px;
  font-size:.78rem;font-weight:600;padding:6px 16px;border-radius:3px;
  box-shadow:2px 2px 0 var(--green-dark)}
.hero h1{font-size:clamp(3rem,8vw,6.2rem);color:var(--red);margin:18px 0 6px;
  text-shadow:4px 4px 0 var(--gold), 7px 7px 0 rgba(58,36,23,.18)}
.hero h1 .moy{color:var(--green);text-shadow:4px 4px 0 var(--gold),7px 7px 0 rgba(58,36,23,.18)}
.hero .sub{font-size:clamp(1.05rem,2.4vw,1.5rem);max-width:32ch;color:var(--brown);
  font-weight:500;margin-bottom:26px}
.hero .sub b{color:var(--red-dark)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
  font-weight:700;text-decoration:none;padding:15px 26px;border-radius:5px;
  display:inline-flex;align-items:center;gap:9px;font-size:1rem;cursor:pointer;border:none;
  transition:transform .12s,box-shadow .12s}
.btn-red{background:var(--red);color:var(--cream);box-shadow:0 5px 0 var(--red-dark)}
.btn-red:hover{transform:translateY(3px);box-shadow:0 2px 0 var(--red-dark)}
.btn-green{background:var(--green);color:var(--cream);box-shadow:0 5px 0 var(--green-dark)}
.btn-green:hover{transform:translateY(3px);box-shadow:0 2px 0 var(--green-dark)}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:0 5px 0 var(--gold-dark)}
.btn-gold:hover{transform:translateY(3px);box-shadow:0 2px 0 var(--gold-dark)}
.btn-outline{background:transparent;color:var(--brown);border:3px solid var(--brown);padding:12px 23px}
.btn-outline:hover{background:var(--brown);color:var(--cream)}
.btn[disabled]{opacity:.6;cursor:not-allowed;transform:none}

.deal-card{position:relative;display:flex;justify-content:center}
.deal{
  background:var(--green);color:var(--cream);border-radius:18px;padding:30px 26px;
  text-align:center;border:5px solid var(--cream);
  box-shadow:0 14px 30px rgba(29,77,53,.4), inset 0 0 0 3px var(--green-dark);
  transform:rotate(-3deg);max-width:330px;width:100%}
.deal .kicker{font-family:'Oswald',sans-serif;letter-spacing:3px;text-transform:uppercase;
  font-size:.8rem;color:var(--gold);font-weight:600}
.deal .big{font-family:'Alfa Slab One',serif;font-size:2.2rem;line-height:1;margin:8px 0;color:var(--cream)}
.deal .big em{color:var(--gold);font-style:normal}
.deal .price{
  background:var(--gold);color:var(--ink);font-family:'Alfa Slab One',serif;
  font-size:3.6rem;width:130px;height:130px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:14px auto 6px;
  box-shadow:0 0 0 5px var(--green-dark), 0 8px 16px rgba(0,0,0,.3);
  position:relative}
.deal .price::before{content:"$";font-size:1.6rem;vertical-align:super;margin-right:1px}
.deal small{font-family:'Oswald',sans-serif;letter-spacing:2px;text-transform:uppercase;font-size:.72rem;opacity:.9}
.deal .price-wrap{position:relative}
.deal .price-wrap::before{
  content:"";position:absolute;inset:-22px;border-radius:50%;
  background:repeating-conic-gradient(from 0deg, rgba(240,168,31,.35) 0 9deg, transparent 9deg 18deg);
  z-index:-1}

section{padding:72px 22px;position:relative}
.wrap{max-width:1180px;margin:0 auto}
.wrap-narrow{max-width:760px;margin:0 auto}
.sec-head{text-align:center;margin-bottom:46px}
.sec-head .label{color:var(--green);font-size:.95rem;font-weight:600}
.sec-head h2{font-size:clamp(2.2rem,5vw,3.4rem);color:var(--red);margin-top:6px}
.sec-head .rule{width:120px;height:5px;margin:16px auto 0;border-radius:3px;
  background:repeating-linear-gradient(90deg,var(--red) 0 14px,var(--gold) 14px 28px,var(--green) 28px 42px)}

.menu-section{background:var(--green-dark);color:var(--cream)}
.menu-section .sec-head h2{color:var(--gold)}
.menu-section .sec-head .label{color:var(--cream)}
.menu-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:30px}
.menu-card{
  background:var(--cream);color:var(--ink);border-radius:12px;padding:30px 30px 34px;
  border:4px solid var(--gold);box-shadow:0 12px 26px rgba(0,0,0,.28);position:relative}
.menu-card > .head{
  font-family:'Alfa Slab One',serif;color:var(--cream);background:var(--red);
  display:inline-block;padding:8px 22px;border-radius:6px;font-size:1.5rem;
  transform:rotate(-1.5deg);box-shadow:3px 3px 0 var(--red-dark);
  margin:-50px 0 22px}
.menu-card.sides > .head{background:var(--green);box-shadow:3px 3px 0 var(--green-dark)}
.taco-list{list-style:none}
.taco-list li{
  display:flex;align-items:baseline;gap:10px;padding:13px 0;
  border-bottom:2px dotted rgba(58,36,23,.25)}
.taco-list li:last-child{border-bottom:none}
.taco-list .star{color:var(--gold);font-size:1.1rem;flex:none;line-height:1.4}
.taco-list .name{font-family:'Oswald',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;font-size:1.25rem;color:var(--red-dark)}
.taco-list .tag{font-family:'Bitter',serif;font-style:italic;color:var(--brown);font-size:.95rem}
.menu-note{margin-top:18px;font-style:italic;color:var(--brown);font-size:.95rem}
.sides .taco-list .name{color:var(--green-dark)}

.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:10px}
.feat{
  background:var(--cream);border:3px solid var(--cream-3);border-radius:12px;
  padding:30px 26px;text-align:center;box-shadow:0 8px 20px rgba(58,36,23,.12);
  transition:transform .18s,box-shadow .18s}
.feat:hover{transform:translateY(-6px);box-shadow:0 16px 30px rgba(58,36,23,.2);border-color:var(--gold)}
.feat .ico{width:62px;height:62px;margin:0 auto 14px;display:flex;align-items:center;
  justify-content:center;background:var(--red);border-radius:50%;box-shadow:0 4px 0 var(--red-dark)}
.feat:nth-child(2) .ico{background:var(--green);box-shadow:0 4px 0 var(--green-dark)}
.feat:nth-child(3) .ico{background:var(--gold);box-shadow:0 4px 0 var(--gold-dark)}
.feat h3{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:1px;
  font-size:1.2rem;color:var(--red-dark);margin-bottom:8px}
.feat p{color:var(--brown);font-size:.98rem}

.events{margin-top:46px;text-align:center}
.events .label{color:var(--green);font-size:.85rem;display:block;margin-bottom:16px}
.pill-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.pill{background:var(--green);color:var(--cream);font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:1.5px;font-size:.82rem;font-weight:500;
  padding:9px 18px;border-radius:30px;box-shadow:2px 2px 0 var(--green-dark)}
.pill:nth-child(even){background:var(--red);box-shadow:2px 2px 0 var(--red-dark)}

.how{background:var(--cream-2)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{position:relative;background:var(--cream);border-radius:12px;padding:34px 26px 26px;
  border-left:6px solid var(--gold);box-shadow:0 8px 18px rgba(58,36,23,.12)}
.step .num{position:absolute;top:-20px;left:22px;width:46px;height:46px;border-radius:50%;
  background:var(--red);color:var(--cream);font-family:'Alfa Slab One',serif;font-size:1.4rem;
  display:flex;align-items:center;justify-content:center;box-shadow:0 4px 0 var(--red-dark)}
.step h3{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:1px;
  font-size:1.15rem;color:var(--green-dark);margin-bottom:8px}
.step p{color:var(--brown);font-size:.96rem}

.book{background:var(--red);color:var(--cream);text-align:center}
.book .sec-head h2{color:var(--cream)}
.book .sec-head .label{color:var(--gold)}
.book p.lead{max-width:46ch;margin:0 auto 30px;font-size:1.15rem}
.phone-mega{
  display:inline-flex;align-items:center;gap:16px;text-decoration:none;
  background:var(--cream);color:var(--ink);padding:20px 36px;border-radius:14px;
  box-shadow:0 10px 0 rgba(0,0,0,.25);transition:transform .12s,box-shadow .12s}
.phone-mega:hover{transform:translateY(4px);box-shadow:0 6px 0 rgba(0,0,0,.25)}
.phone-mega .ico{width:50px;height:50px;background:var(--green);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex:none}
.phone-mega .txt{text-align:left}
.phone-mega .txt small{display:block;font-family:'Oswald',sans-serif;text-transform:uppercase;
  letter-spacing:2px;font-size:.72rem;color:var(--red-dark);font-weight:600}
.phone-mega .txt b{font-family:'Alfa Slab One',serif;font-size:1.9rem;color:var(--green-dark);line-height:1}
.hours{margin-top:26px;font-family:'Oswald',sans-serif;letter-spacing:1.5px;
  text-transform:uppercase;font-size:.85rem;opacity:.92}

footer{background:var(--ink);color:var(--cream);padding:46px 22px 30px;text-align:center}
footer .fbrand{font-family:'Alfa Slab One',serif;font-size:2rem;color:var(--gold)}
footer .fbrand .moy{color:var(--cream)}
footer .tag{font-family:'Oswald',sans-serif;letter-spacing:3px;text-transform:uppercase;
  font-size:.78rem;color:var(--gold);margin:6px 0 18px}
footer a{color:var(--cream);text-decoration:none}
footer a:hover{color:var(--gold)}
footer .fline{font-size:.9rem;opacity:.7;margin-top:18px}

.sticky-call{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;
  background:var(--gold);color:var(--ink);text-align:center;padding:14px;
  font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:2px;font-weight:700;
  text-decoration:none;box-shadow:0 -4px 14px rgba(0,0,0,.3)}

/* ---- contact / booking form ---- */
.contact{background:var(--cream-2)}
.form-card{
  background:var(--cream);border-radius:16px;padding:38px 36px 42px;
  border:4px solid var(--gold);box-shadow:0 16px 36px rgba(58,36,23,.2)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1 / -1}
.field label{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
  font-size:.82rem;font-weight:600;color:var(--green-dark)}
.field label .req{color:var(--red)}
.field input,.field textarea,.field select{
  font-family:'Bitter',serif;font-size:1rem;color:var(--ink);
  background:#fff;border:2px solid var(--cream-3);border-radius:8px;padding:12px 14px;
  transition:border-color .15s,box-shadow .15s}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(47,110,79,.18)}
.field textarea{resize:vertical;min-height:110px}
.field.honey{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-actions{margin-top:26px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.form-note{font-size:.9rem;color:var(--brown)}
.form-note a{color:var(--red-dark);font-weight:700;text-decoration:none}
.alt-call{margin-top:30px;text-align:center;font-family:'Oswald',sans-serif;
  text-transform:uppercase;letter-spacing:1.5px;font-size:.9rem;color:var(--brown)}
.alt-call a{color:var(--red-dark);font-weight:700;text-decoration:none}
.form-msg{margin-top:20px;border-radius:10px;padding:16px 18px;font-weight:500;display:none}
.form-msg.show{display:block}
.form-msg.ok{background:rgba(47,110,79,.14);border:2px solid var(--green);color:var(--green-dark)}
.form-msg.err{background:rgba(176,48,40,.12);border:2px solid var(--red);color:var(--red-dark)}
.field.invalid input,.field.invalid textarea{border-color:var(--red);box-shadow:0 0 0 3px rgba(176,48,40,.15)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.hero .eyebrow,.hero h1,.hero .sub,.hero .cta-row{opacity:0;animation:rise .8s ease forwards}
.hero h1{animation-delay:.12s}.hero .sub{animation-delay:.24s}.hero .cta-row{animation-delay:.36s}
.deal{opacity:0;animation:pop .8s cubic-bezier(.2,.8,.3,1.2) .4s forwards}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:rotate(-3deg) scale(.85)}to{opacity:1;transform:rotate(-3deg) scale(1)}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}

@media(max-width:880px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero .sub{margin-left:auto;margin-right:auto}
  .cta-row{justify-content:center}
  .menu-grid,.feat-grid,.steps,.form-grid{grid-template-columns:1fr}
  .nav-links{position:absolute;top:100%;left:0;right:0;background:var(--red);
    flex-direction:column;padding:18px;gap:16px;display:none;border-bottom:4px solid var(--gold)}
  .nav-links.open{display:flex}
  .burger{display:block}
  .sticky-call{display:block}
  body{padding-bottom:54px}
}
