:root{
  --red:#D42B1E;
  --red-deep:#5a0a06;
  --teal:#123234;
  --teal-bright:#3FD9C9;
  --cream:#F3EAD8;
  --ink:#0C1A1B;
  --gold:#E8A820;
  --header-h:88px;
}
*,*::before,*::after{box-sizing:border-box}
html,body{max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Barlow',system-ui,sans-serif;
  background:var(--ink);
  color:var(--cream);
  line-height:1.6;
  overflow-wrap:break-word;
}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 22px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* Paper grain overlay */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Type helpers */
.flag{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--teal-bright);font-size:.95rem;margin:0 0 12px;
}
.flag-lg{font-size:clamp(1.6rem,5vw,2.6rem);color:var(--teal-bright);line-height:1;margin-bottom:20px}

/* Buttons */
.btn{
  display:inline-block;font-family:'Barlow Condensed',sans-serif;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;
  padding:14px 30px;border-radius:4px;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease;
  border:2px solid transparent;min-height:48px;
}
.btn-red{background:var(--red);color:var(--cream);box-shadow:0 6px 0 var(--red-deep)}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 8px 0 var(--red-deep)}
.btn-ghost{background:transparent;color:var(--cream);border-color:var(--cream)}
.btn-ghost:hover{background:var(--cream);color:var(--ink)}
.btn-teal{background:var(--teal-bright);color:var(--ink);font-weight:800}
.btn-teal:hover{transform:translateY(-2px);box-shadow:0 6px 0 rgba(0,0,0,.3)}
:focus-visible{outline:3px solid var(--teal-bright);outline-offset:3px}

/* PROMO BAR */
.promo{background:var(--red);color:var(--cream);overflow:hidden;border-bottom:2px solid var(--red-deep)}
.promo-track{
  display:flex;gap:44px;white-space:nowrap;width:max-content;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.1em;
  font-size:.82rem;text-transform:uppercase;padding:8px 0;
  animation:marq 22s linear infinite;
}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:100;background:var(--ink);
  border-bottom:2px solid var(--red);transition:padding .25s ease;
}
.site-header.shrink{box-shadow:0 6px 24px rgba(0,0,0,.55)}
.header-inner{
  max-width:1280px;margin:0 auto;padding:14px 22px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  transition:padding .25s ease;
}
.site-header.shrink .header-inner{padding:8px 22px}
.brand-logo{height:60px;width:auto;transition:height .25s ease}
.site-header.shrink .brand-logo{height:48px}

.main-nav{display:flex;align-items:center;gap:26px}
.main-nav ul{display:flex;gap:20px;list-style:none;margin:0;padding:0;align-items:center;flex-wrap:wrap}
.main-nav a{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;font-size:1rem;color:var(--cream);position:relative;padding:4px 0;
}
.main-nav a:hover,.main-nav a.active{color:var(--teal-bright)}
.main-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--red)}
.nav-foot{display:flex;align-items:center;gap:18px}
.btn-book{
  background:var(--red);color:var(--cream);font-family:'Barlow Condensed',sans-serif;
  font-weight:800;text-transform:uppercase;letter-spacing:.05em;font-size:1rem;
  padding:11px 20px;border-radius:4px;box-shadow:0 4px 0 var(--red-deep);
  transition:transform .18s ease,box-shadow .18s ease;white-space:nowrap;
}
.btn-book:hover{transform:translateY(-2px);box-shadow:0 6px 0 var(--red-deep)}
.follow{display:flex;align-items:center;gap:8px}
.follow span{font-family:'Barlow Condensed',sans-serif;font-style:italic;font-weight:600;color:var(--teal-bright);font-size:.9rem}
.soc{color:var(--cream);transition:color .18s}
.soc:hover{color:var(--teal-bright)}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;width:44px;height:44px}
.hamburger span{width:26px;height:3px;background:var(--cream);border-radius:2px;transition:.25s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* HERO */
.hero{position:relative;background:var(--ink);overflow:hidden;min-height:520px}
.hero-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:52% 48%;
  filter:grayscale(1) contrast(1.08);
}
/* Gradient scrim — explicit z-index so hero-bar can sit above it */
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(13,8,8,.96) 0%,rgba(13,8,8,.78) 44%,rgba(13,8,8,.28) 100%);
}
/* Red left-edge accent bar — brand binding edge */
.hero-bar{
  position:absolute;left:0;top:0;bottom:0;width:6px;
  background:var(--red);z-index:4;pointer-events:none;
}
.hero-grid{
  position:relative;z-index:2;max-width:1200px;margin:0 auto;
  padding:72px 22px 84px 28px;
  display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;
  min-width:0;
}
.hero-text .flag{color:var(--gold)}
.hero-title{
  font-family:'Anton',sans-serif;font-weight:400;line-height:.82;text-transform:uppercase;
  margin:0 0 18px;color:var(--cream);letter-spacing:.01em;
  display:flex;flex-direction:column;
}
.hero-title span:first-child{
  font-size:clamp(2.8rem,8vw,5.2rem);
  text-shadow:4px 4px 0 var(--red-deep);
}
.hero-title .big{
  font-size:clamp(4.8rem,16vw,10rem);
  color:var(--red);
  -webkit-text-stroke:2px var(--cream);
  text-shadow:6px 6px 0 rgba(0,0,0,.55),12px 12px 32px rgba(0,0,0,.3);
  line-height:.88;
}
.hero-sub{font-size:1.18rem;max-width:36ch;color:var(--cream);margin:0 0 26px;line-height:1.55}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px}
.hero-addr{
  font-family:'Barlow Condensed',sans-serif;font-size:1.05rem;
  letter-spacing:.03em;color:var(--cream);opacity:.88;line-height:1.6;
}
.hero-addr a{color:var(--teal-bright)}

.hero-poster{position:relative;display:flex;justify-content:center;align-items:center}
.playbill{
  transform:rotate(3deg);border:8px solid var(--cream);
  box-shadow:0 28px 60px rgba(0,0,0,.75),0 8px 20px rgba(0,0,0,.4);
  max-width:360px;background:var(--cream);
  transition:transform .4s ease,box-shadow .4s ease;
}
.hero-poster:hover .playbill{
  transform:rotate(0deg) scale(1.03);
  box-shadow:0 36px 70px rgba(0,0,0,.8),0 10px 24px rgba(0,0,0,.5);
}
.poster-tag{
  position:absolute;top:-14px;left:8%;background:var(--gold);color:var(--ink);
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  letter-spacing:.06em;padding:6px 14px;border-radius:3px;
  transform:rotate(-4deg);font-size:.9rem;
  box-shadow:0 4px 12px rgba(0,0,0,.45);z-index:2;
}

/* SPECIALS */
.specials{background:var(--teal);padding:76px 0 80px;position:relative}
.specials::before{
  content:"";position:absolute;top:-24px;left:0;right:0;height:24px;background:var(--teal);
  clip-path:polygon(0 100%,4% 0,8% 100%,12% 0,16% 100%,20% 0,24% 100%,28% 0,32% 100%,36% 0,40% 100%,44% 0,48% 100%,52% 0,56% 100%,60% 0,64% 100%,68% 0,72% 100%,76% 0,80% 100%,84% 0,88% 100%,92% 0,96% 100%,100% 0);
}

/* BENTO — Asymmetric editorial layout: tall left tile + two stacked right tiles */
.bento{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  grid-template-rows:auto auto;
  gap:20px;
  align-items:stretch;
}

/* Base tile styles */
.tile{
  border-radius:8px;padding:32px 28px;position:relative;overflow:hidden;
  border:2px solid rgba(255,255,255,.08);
  transition:transform .28s ease,box-shadow .28s ease;
  min-width:0;
}
.tile h3{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  letter-spacing:.03em;font-size:1.5rem;margin:.4rem 0 .3rem;line-height:1.05;
}
.tile p{margin:0;color:var(--cream);opacity:.9}

/* Hover — pointer devices only */
@media(hover:hover){
  .tile:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(0,0,0,.5)}
}

/* TILE 1: Weekend Lunch — tall, spans both rows */
.tile-lunch{
  grid-column:1;
  grid-row:1 / span 2;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding-top:56px;
  background:var(--red);
  background-image:repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 14px,
    rgba(255,255,255,.04) 14px,
    rgba(255,255,255,.04) 28px
  );
  color:var(--cream);
  border-color:var(--red-deep);
}
/* Ghost watermark at top of tall tile */
.tile-lunch::before{
  content:"WEEKEND";
  display:block;
  font-family:'Anton',sans-serif;
  font-size:clamp(3rem,6vw,4.5rem);
  color:rgba(255,255,255,.09);
  line-height:1.1;
  letter-spacing:.03em;
  pointer-events:none;
  user-select:none;
  margin-bottom:auto;
}
.tile-lunch .price{
  font-family:'Anton',sans-serif;
  font-size:clamp(3rem,5vw,3.8rem);
  line-height:1;color:var(--gold);
  display:block;
  text-shadow:3px 3px 0 var(--red-deep);
}

/* TILE 2: Happy Hour */
.tile-hh{
  grid-column:2;
  grid-row:1;
  background:var(--ink);
}
.hh-bar{
  display:inline-block;background:var(--red);color:var(--cream);
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;padding:6px 14px;border-radius:3px;font-size:1.15rem;
}
.tile-hh .big-time{
  font-family:'Anton',sans-serif;font-size:clamp(1.8rem,3.5vw,2.4rem);
  color:var(--teal-bright);letter-spacing:.02em;margin:.4rem 0 0;
}

/* TILE 3: Match Days */
.tile-match{
  grid-column:2;
  grid-row:2;
  background:linear-gradient(155deg,#1a4143 0%,var(--ink) 100%);
}
.match-flag{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;
  text-transform:uppercase;color:var(--gold);letter-spacing:.05em;
}
.tile-links{display:flex;flex-wrap:wrap;gap:16px;margin-top:16px}
.tile-links a{
  color:var(--teal-bright);font-family:'Barlow Condensed',sans-serif;
  font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  transition:color .18s;
}
.tile-links a:hover{color:var(--cream)}

/* FOOD BAND */
.foodband{position:relative;min-height:380px;display:flex;align-items:center;overflow:hidden}
.foodband img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:50% 55%;
}
.foodband::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(90,10,6,.85) 0%,rgba(90,10,6,.3) 58%,transparent 100%);
}
.foodband-text{
  position:relative;z-index:2;padding:60px 22px;
  max-width:1200px;margin:0 auto;width:100%;
}
.foodband-text .flag{color:var(--gold)}
.foodband-text h2{
  font-family:'Anton',sans-serif;
  font-size:clamp(2.4rem,7vw,4.8rem);
  line-height:.9;text-transform:uppercase;color:var(--cream);margin:0;
  text-shadow:4px 4px 0 rgba(0,0,0,.45);
}

/* MENUS */
.menus{background:var(--ink);padding:80px 0}
.menus-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;min-width:0}
.lede{font-size:1.2rem;max-width:52ch;margin:0 0 26px;line-height:1.65}
.menus-stat{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.stat{
  background:var(--teal);border:2px solid rgba(63,217,201,.18);
  border-radius:8px;padding:22px;
  transition:transform .28s ease,box-shadow .28s ease;
}
@media(hover:hover){
  .stat:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.35)}
}
.stat strong{
  display:block;font-family:'Barlow Condensed',sans-serif;font-weight:800;
  text-transform:uppercase;font-size:1.5rem;color:var(--gold);
}
.stat span{color:var(--cream);opacity:.85;font-size:.95rem}

/* MID CTA */
.midcta{background:var(--red);padding:56px 0;position:relative}
.midcta-inner{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;
}
.midcta h2{
  font-family:'Anton',sans-serif;
  font-size:clamp(1.8rem,5vw,3.2rem);
  text-transform:uppercase;margin:0;color:var(--cream);line-height:.94;
  text-shadow:3px 3px 0 var(--red-deep);
}
.midcta-btn{background:var(--cream);color:var(--red);border-color:var(--cream);box-shadow:0 6px 0 rgba(0,0,0,.3)}
.midcta-btn:hover{background:var(--ink);color:var(--cream);border-color:var(--ink);box-shadow:0 8px 0 rgba(0,0,0,.4)}

/* LOCATION */
.location{
  background:var(--teal);padding:80px 0;position:relative;
  background-image:
    linear-gradient(rgba(18,50,52,.91),rgba(18,50,52,.95)),
    url("/cdn/demos/wwwvoteforpedrofun/assets/6166d048-7b78c6_11bf47ff687f4058990f53c0554144b2-mv2.jpg");
  background-size:cover;background-position:center;
}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;min-width:0}
.loc-addr{
  font-style:normal;font-family:'Barlow Condensed',sans-serif;
  font-size:1.4rem;letter-spacing:.02em;margin:0 0 26px;
}
.hours-title{
  display:inline-block;background:var(--red);color:var(--cream);
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  letter-spacing:.04em;padding:8px 18px;border-radius:4px;font-size:1.35rem;margin:0 0 18px;
}
.hours{list-style:none;margin:0;padding:0;max-width:420px}
.hours li{
  display:flex;justify-content:space-between;gap:16px;
  padding:13px 0;border-bottom:1px dashed rgba(243,234,216,.22);
  font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;letter-spacing:.02em;
}
.hours li:last-child{border-bottom:none}
.hours li span:first-child{color:var(--teal-bright);font-weight:700}
.closed{color:var(--gold)}
.map-card{
  background:var(--ink);border:2px solid rgba(63,217,201,.25);border-radius:14px;
  padding:40px 32px;text-align:center;
  box-shadow:0 24px 56px rgba(0,0,0,.45);
}
.map-pin{color:var(--red);display:flex;justify-content:center;margin-bottom:14px}
.map-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  font-size:1.6rem;margin:0 0 8px;
}
.map-sub{margin:0 0 24px;opacity:.82;font-size:1rem}

/* MAILING LIST */
.mailing{background:var(--ink);padding:80px 0}
.ml-card{
  background:linear-gradient(155deg,var(--teal),#0b2022);
  border:2px solid rgba(63,217,201,.2);border-radius:16px;
  padding:44px 38px;max-width:680px;margin:0 auto;text-align:center;
  box-shadow:0 24px 56px rgba(0,0,0,.45);
}
.ml-sub{margin:0 0 24px;opacity:.88;font-size:1.05rem}
.ml-card form{display:flex;flex-direction:column;gap:16px;align-items:center;text-align:left}
.field{width:100%;max-width:420px}
.field label{
  display:block;font-family:'Barlow Condensed',sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;color:var(--teal-bright);
}
.field input{
  width:100%;padding:14px 16px;border-radius:6px;
  border:2px solid rgba(243,234,216,.3);background:rgba(12,26,27,.6);
  color:var(--cream);font-size:1rem;min-height:48px;
  transition:border-color .18s;
}
.field input:focus{border-color:var(--teal-bright);outline:none}
.err{color:var(--gold);font-size:.85rem;margin:6px 0 0;min-height:1em}
.check{
  display:flex;align-items:flex-start;gap:10px;
  max-width:420px;width:100%;font-size:.95rem;cursor:pointer;
}
.check input{width:20px;height:20px;margin-top:2px;accent-color:var(--red);flex:none}
.ml-ok{color:var(--teal-bright);font-weight:700;margin:8px 0 0}

/* FOOTER */
.site-footer{background:var(--ink);border-top:6px solid var(--red);padding:56px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px;min-width:0}
/* Footer logo: dark-bg variant (21c2ad82), circular crop with red border accent */
.footer-logo{
  width:88px;
  height:88px;
  border-radius:50%;
  object-fit:cover;
  object-position:center center;
  border:3px solid rgba(212,43,30,.65);
  box-shadow:0 0 0 5px rgba(212,43,30,.12);
  display:block;
}
.footer-brand p{max-width:32ch;opacity:.82;margin:14px 0}
.foot-soc{display:flex;gap:14px}
.footer-nav h3,.footer-visit h3{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;color:var(--teal-bright);margin:0 0 14px;font-size:1.2rem;
}
.footer-nav ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-nav a{opacity:.85;transition:color .18s,opacity .18s}
.footer-nav a:hover{color:var(--teal-bright);opacity:1}
.footer-visit p{margin:0 0 12px;opacity:.88}
.footer-visit a:hover{color:var(--teal-bright)}
.footer-visit .btn{margin-top:8px}
.copyright{
  text-align:center;font-family:'Barlow Condensed',sans-serif;
  letter-spacing:.05em;opacity:.65;margin:36px 0 0;
  border-top:1px solid rgba(243,234,216,.1);padding-top:22px;
}

/* ============================
   RESPONSIVE
   ============================ */

/* Tablet: collapse nav to drawer */
@media(max-width:1080px){
  .main-nav{
    position:fixed;top:0;right:0;height:100vh;width:min(320px,85vw);
    background:var(--teal);flex-direction:column;align-items:flex-start;
    padding:100px 30px 30px;gap:26px;
    transform:translateX(100%);transition:transform .3s ease;
    z-index:99;box-shadow:-10px 0 40px rgba(0,0,0,.55);overflow-y:auto;
  }
  .main-nav.open{transform:translateX(0)}
  .main-nav ul{flex-direction:column;gap:18px;align-items:flex-start}
  .main-nav a{font-size:1.25rem}
  .nav-foot{flex-direction:column;align-items:flex-start;gap:20px}
  .hamburger{display:flex;z-index:100}
}

/* Collapse to single column at tablet/mobile */
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;gap:32px;padding:50px 22px 60px 28px}
  .hero-poster{justify-content:flex-start}
  .playbill{max-width:min(300px,85vw)}

  /* Reset bento to single column stacking */
  .bento{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }
  .tile-lunch{
    grid-column:auto;
    grid-row:auto;
    display:block;
    padding-top:32px;
  }
  .tile-lunch::before{display:none}
  .tile-hh{grid-column:auto;grid-row:auto}
  .tile-match{grid-column:auto;grid-row:auto}

  .menus-grid{grid-template-columns:1fr;gap:32px}
  .loc-grid{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
}

/* Small phones */
@media(max-width:480px){
  .hero-title .big{font-size:22vw;-webkit-text-stroke:1.5px var(--cream)}
  .hero-title span:first-child{font-size:clamp(2rem,10vw,3.2rem)}
  .menus-stat{grid-template-columns:1fr}
  .btn{width:100%;text-align:center}
  .hero-cta .btn{width:auto;flex:1 1 140px}
  .midcta-inner .btn{width:auto}
  .map-card .btn,.ml-card .btn{width:auto}
  .midcta-inner{flex-direction:column;align-items:flex-start}
}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .promo-track{animation:none}
  *{transition-duration:.01ms !important;animation-duration:.01ms !important}
  html{scroll-behavior:auto}
}