/* ============================================
   Yurrito — shared styles
   ============================================ */

:root{
  --charcoal:#221d1a;
  --charcoal-soft:#332b26;
  --cream:#fff8ec;
  --cream-dim:#f7ecd9;
  --chili:#d62828;
  --chili-dark:#a31e1e;
  --marigold:#f6a823;
  --marigold-dark:#d98a12;
  --avocado:#5c7a3d;
  --avocado-dark:#46602c;
  --lime:#d7e07a;
  --white:#ffffff;
  --shadow: 0 14px 32px -14px rgba(34,29,26,.35);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --maxw: 1180px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--cream);
  color:var(--charcoal);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:'Fredoka',sans-serif;
  font-weight:600;
  line-height:1.1;
  margin:0 0 .5em;
  color:var(--charcoal);
}
h1{font-size:clamp(2.4rem,5vw,4.2rem);}
h2{font-size:clamp(1.8rem,3.4vw,2.6rem);}
h3{font-size:1.3rem;}
p{margin:0 0 1em;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{margin:0;padding:0;list-style:none;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Fredoka',sans-serif;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.78rem;
  color:var(--chili);
  background:rgba(232,85,42,.1);
  padding:6px 14px;
  border-radius:999px;
  margin-bottom:14px;
}
.section{padding:88px 0;}
.section--tight{padding:56px 0;}
.section--charcoal{background:var(--charcoal);color:var(--cream);}
.section--charcoal h2, .section--charcoal h3{color:var(--cream);}
.section--cream-dim{background:var(--cream-dim);}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Fredoka',sans-serif;
  font-weight:600;
  font-size:1rem;
  padding:14px 28px;
  border-radius:999px;
  border:2px solid transparent;
  cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--chili);color:var(--white);box-shadow:var(--shadow);}
.btn-primary:hover{background:var(--chili-dark);}
.btn-outline{border-color:var(--charcoal);color:var(--charcoal);background:transparent;}
.btn-outline:hover{background:var(--charcoal);color:var(--cream);}
.btn-light{background:var(--cream);color:var(--charcoal);}
.btn-light:hover{background:var(--white);}

/* ============ Header ============ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,248,236,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(34,29,26,.08);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;
  max-width:var(--maxw);margin:0 auto;
}
.logo{
  display:flex;align-items:center;
}
.logo-img{height:80px;width:auto;display:block;}
@media (max-width:860px){.logo-img{height:58px;}}
.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{
  font-family:'Fredoka',sans-serif;
  font-weight:500;
  font-size:.98rem;
  position:relative;
  padding:4px 0;
}
.nav-links a.active,
.nav-links a:hover{color:var(--chili);}
.nav-cta{display:flex;align-items:center;gap:16px;}
.nav-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  flex-direction:column;gap:5px;
  padding:6px;
}
.nav-toggle span{
  width:24px;height:2.5px;background:var(--charcoal);border-radius:2px;
}

@media (max-width:860px){
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    background:var(--cream);
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    padding:8px 24px 18px;
    border-bottom:1px solid rgba(34,29,26,.08);
    display:none;
  }
  .nav-links.open{display:flex;}
  .nav-links a{padding:12px 0;width:100%;border-bottom:1px solid rgba(34,29,26,.06);}
  .nav-toggle{display:flex;}
  .nav-cta .btn-outline{display:none;}
}

/* ============ Hero ============ */
.hero{
  position:relative;
  overflow:hidden;
  padding:80px 0 100px;
  background:
    radial-gradient(620px 420px at 88% 8%, rgba(246,168,35,.35), transparent 60%),
    radial-gradient(560px 420px at 4% 92%, rgba(92,122,61,.28), transparent 60%),
    var(--cream);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:48px;
  align-items:center;
}
.hero h1{margin-bottom:.35em;}
.hero h1 em{
  font-style:normal;
  color:var(--chili);
  position:relative;
}
.hero-sub{font-size:1.15rem;max-width:480px;color:var(--charcoal-soft);}
.hero-actions{display:flex;gap:16px;margin-top:30px;flex-wrap:wrap;}
.hero-tags{display:flex;gap:10px;margin-top:36px;flex-wrap:wrap;}
.hero-tag{
  font-family:'Fredoka',sans-serif;
  font-size:.85rem;font-weight:500;
  background:var(--white);
  border:1px solid rgba(34,29,26,.1);
  padding:8px 14px;border-radius:999px;
  display:flex;align-items:center;gap:6px;
}
.hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:420px;}
.hero-blob{
  position:absolute;
  width:min(420px,85%);aspect-ratio:1/1;border-radius:50%;
  background:conic-gradient(from 220deg, var(--chili), var(--marigold), var(--chili-dark), var(--chili));
  box-shadow: 0 30px 60px -20px rgba(34,29,26,.4);
  animation:spin 30s linear infinite;
  opacity:.9;
}
@keyframes spin{to{transform:rotate(360deg);}}
.mascot-img{
  position:relative;
  z-index:2;
  width:min(300px,70%);
  filter:drop-shadow(0 24px 30px rgba(34,29,26,.35));
}
.hero-float{
  position:absolute;
  background:var(--white);
  border-radius:999px;
  padding:10px 16px;
  font-family:'Fredoka',sans-serif;font-weight:600;font-size:.85rem;
  box-shadow:var(--shadow);
  display:flex;align-items:center;gap:8px;
}
.hero-float--1{top:6%;left:-4%;}
.hero-float--2{bottom:10%;right:-6%;}

/* ============ Cards ============ */
.grid{display:grid;gap:28px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}
@media (max-width:920px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.grid-3,.grid-4{grid-template-columns:1fr;}}

.dish-card{
  background:var(--white);
  border-radius:var(--radius-md);
  padding:26px;
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease;
}
.dish-card:hover{transform:translateY(-6px);}
.dish-emoji{
  width:64px;height:64px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;
  background:var(--cream-dim);
  margin-bottom:16px;
}
.dish-photo{
  width:calc(100% + 52px);
  margin:-26px -26px 18px;
  aspect-ratio:3/2;
  overflow:hidden;
  border-radius:var(--radius-md) var(--radius-md) 0 0;
}
.dish-photo img{width:100%;height:100%;object-fit:cover;display:block;}
.dish-card h3{margin-bottom:6px;}
.dish-price{
  font-family:'Fredoka',sans-serif;font-weight:600;color:var(--chili);
}
.dish-desc{color:var(--charcoal-soft);font-size:.95rem;margin-bottom:0;}

.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:700px){.cat-grid{grid-template-columns:1fr;}}
.combo-graphic{
  width:100%;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);aspect-ratio:3/2;display:block;
}
.combo-graphic img{width:100%;height:100%;object-fit:cover;display:block;}
.combo-caption{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;margin-top:18px;
}
.combo-caption p{margin:0;color:var(--charcoal-soft);}
.cat-tile{
  position:relative;display:block;
  border-radius:var(--radius-md);
  overflow:hidden;
  aspect-ratio:16/9;
  box-shadow:var(--shadow);
}
.cat-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease;}
.cat-tile:hover img{transform:scale(1.045);}
/* ============ Brand-style banner (matches the section-graphic look:
   dark bg, halftone dot accent, photo bleeding right, bold white headline
   + marigold subtitle) — used for the Combo tile/section ============ */
.brand-banner{
  position:relative;
  background:var(--charcoal);
  border-radius:var(--radius-md);
  overflow:hidden;
  aspect-ratio:16/9;
  display:flex;
  align-items:center;
  box-shadow:var(--shadow);
  isolation:isolate;
}
.brand-banner-photo{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:75% center;
  z-index:0;
}
.brand-banner::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg, rgba(15,13,12,.96) 0%, rgba(15,13,12,.82) 30%, rgba(15,13,12,.15) 62%, rgba(15,13,12,0) 80%);
}
.brand-banner::before{
  content:"";position:absolute;left:0;bottom:0;z-index:1;
  width:50%;height:75%;
  background-image:radial-gradient(var(--chili) 1.4px, transparent 1.4px);
  background-size:9px 9px;
  -webkit-mask-image:radial-gradient(circle at 0% 100%, black 0%, transparent 65%);
  mask-image:radial-gradient(circle at 0% 100%, black 0%, transparent 65%);
  opacity:.5;
}
.brand-banner-content{
  position:relative;z-index:2;
  padding:0 16px 0 7%;
  max-width:62%;
}
.brand-banner-content h2,
.brand-banner-content h3{
  margin:0;line-height:.98;font-weight:700;
  font-size:clamp(1.8rem,4.4vw,2.7rem);
  letter-spacing:-.01em;
}
.brand-banner-content h2 span,
.brand-banner-content h3 span{display:block;}
.bb-white{color:var(--white);}
.bb-gold{color:var(--marigold);}
.brand-banner-tagline{
  color:rgba(255,255,255,.88);
  font-family:'Inter',sans-serif;font-weight:500;
  font-size:clamp(.8rem,1.5vw,.95rem);
  margin-top:10px;
}
.brand-banner-price{
  display:inline-block;
  font-family:'Fredoka',sans-serif;font-weight:600;color:var(--white);
  background:var(--chili);
  padding:4px 14px;border-radius:999px;
  font-size:.9rem;margin-top:12px;
}
.menu-category .brand-banner{aspect-ratio:16/9;margin-bottom:0;}

/* ============ Diet tags ============ */
.diet-row{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;}
.diet-pill{
  display:flex;align-items:center;gap:10px;
  background:var(--white);
  border-radius:999px;
  padding:12px 22px;
  font-family:'Fredoka',sans-serif;font-weight:500;
  box-shadow:var(--shadow);
}

/* ============ Split/about blocks ============ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
@media (max-width:860px){.split{grid-template-columns:1fr;}}
.split-art{
  border-radius:var(--radius-lg);
  aspect-ratio:3/2;
  background:linear-gradient(135deg, var(--marigold), var(--chili));
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;
  box-shadow:var(--shadow);
}
.split.reverse .split-art{order:2;}

/* ============ Hours / location strip ============ */
.hours-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
@media (max-width:760px){.hours-strip{grid-template-columns:1fr;}}
.hours-card{
  background:var(--charcoal-soft);
  border-radius:var(--radius-md);
  padding:30px;
}
.hours-card h3{color:var(--marigold);}
.hours-table{width:100%;border-collapse:collapse;}
.hours-table td{padding:6px 0;border-bottom:1px solid rgba(255,248,236,.08);font-size:.95rem;}
.hours-table td:last-child{text-align:right;color:var(--cream-dim);}

/* ============ CTA banner ============ */
.cta-banner{
  background:linear-gradient(120deg, var(--chili), var(--marigold));
  border-radius:var(--radius-lg);
  padding:56px;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;flex-wrap:wrap;
  color:var(--white);
}
.cta-banner h2{color:var(--white);margin-bottom:6px;}
.cta-banner p{color:rgba(255,255,255,.9);margin:0;}

/* ============ Menu page ============ */
.menu-nav{
  display:flex;gap:10px;flex-wrap:wrap;
  justify-content:center;
  margin-bottom:54px;
}
.menu-nav a{
  font-family:'Fredoka',sans-serif;font-weight:500;font-size:.9rem;
  background:var(--white);
  border:1px solid rgba(34,29,26,.1);
  padding:9px 18px;border-radius:999px;
}
.menu-nav a:hover{background:var(--chili);color:var(--white);border-color:var(--chili);}
.menu-category{margin-bottom:64px;scroll-margin-top:110px;}
.menu-banner{
  width:100%;border-radius:var(--radius-lg);overflow:hidden;
  margin-bottom:26px;box-shadow:var(--shadow);
  aspect-ratio:16/9;
}
.menu-banner img{width:100%;height:100%;object-fit:cover;display:block;}
.menu-category-head{
  display:flex;align-items:baseline;gap:16px;margin-bottom:8px;
}
.menu-category-head .cat-emoji-sm{font-size:1.8rem;}
.menu-category-sub{color:var(--charcoal-soft);max-width:640px;margin-bottom:30px;}
.menu-list{display:grid;grid-template-columns:1fr 1fr;gap:18px 40px;}
@media (max-width:760px){.menu-list{grid-template-columns:1fr;}}
.menu-item{
  display:flex;justify-content:space-between;gap:16px;
  padding:16px 0;
  border-bottom:1px dashed rgba(34,29,26,.18);
}
.menu-item-name{font-family:'Fredoka',sans-serif;font-weight:600;font-size:1.04rem;}
.menu-item-desc{color:var(--charcoal-soft);font-size:.88rem;margin-top:3px;}
.menu-item-price{
  font-family:'Fredoka',sans-serif;font-weight:600;color:var(--chili);
  white-space:nowrap;
}
.tag-chip-row{display:flex;gap:8px;margin-top:32px;flex-wrap:wrap;}
.tag-chip{
  font-size:.78rem;font-family:'Fredoka',sans-serif;font-weight:500;
  background:var(--charcoal-soft);color:var(--cream);
  padding:5px 12px;border-radius:999px;
}

/* ============ Contact ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;}}
.info-card{
  background:var(--white);border-radius:var(--radius-md);
  padding:24px 26px;box-shadow:var(--shadow);
  display:flex;gap:16px;align-items:flex-start;margin-bottom:18px;
}
.info-card .ic{font-size:1.6rem;}
.form-field{margin-bottom:18px;}
.form-field label{
  display:block;font-family:'Fredoka',sans-serif;font-weight:500;font-size:.9rem;margin-bottom:6px;
}
.form-field input,.form-field textarea{
  width:100%;padding:13px 16px;border-radius:var(--radius-sm);
  border:1px solid rgba(34,29,26,.18);
  font-family:'Inter',sans-serif;font-size:.96rem;
  background:var(--white);
}
.form-field textarea{resize:vertical;min-height:120px;}
.map-placeholder{
  border-radius:var(--radius-lg);
  background:
    repeating-linear-gradient(45deg, rgba(214,40,40,.08) 0 2px, transparent 2px 14px),
    var(--cream-dim);
  border:2px dashed rgba(214,40,40,.3);
  aspect-ratio:4/3;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;color:var(--chili-dark);font-family:'Fredoka',sans-serif;font-weight:500;
  text-align:center;padding:20px;
}

/* ============ Newsletter ============ */
.newsletter{
  background:var(--charcoal);
  border-radius:var(--radius-lg);
  padding:46px 48px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  color:var(--white);
}
.newsletter h3{color:var(--white);margin-bottom:4px;}
.newsletter p{color:rgba(255,255,255,.85);margin:0;}
.newsletter form{display:flex;gap:10px;flex-wrap:wrap;}
.newsletter input{
  padding:13px 18px;border-radius:999px;border:none;min-width:240px;font-family:'Inter',sans-serif;
}

/* ============ Footer ============ */
.site-footer{background:var(--charcoal);color:var(--cream-dim);padding:64px 0 28px;}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,248,236,.1);
}
@media (max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-grid h4{
  color:var(--cream);font-family:'Fredoka',sans-serif;font-size:1rem;margin-bottom:16px;
}
.footer-grid li{margin-bottom:10px;font-size:.92rem;}
.footer-grid a:hover{color:var(--marigold);}
.footer-logo{margin-bottom:14px;}
.footer-logo-img{height:48px;width:auto;display:block;}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;font-size:.84rem;color:rgba(255,248,236,.55);
  flex-wrap:wrap;gap:10px;
}
.social-row{display:flex;gap:12px;}
.social-row a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,248,236,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;
}
.social-row a:hover{background:var(--chili);}

/* ============ Page hero (sub pages) ============ */
.page-hero{
  padding:64px 0 56px;
  text-align:center;
  background:
    radial-gradient(500px 320px at 50% 0%, rgba(246,168,35,.28), transparent 65%),
    var(--cream);
}
.page-hero p{max-width:560px;margin:0 auto;color:var(--charcoal-soft);}

.center{text-align:center;}
.mx-auto{margin-left:auto;margin-right:auto;}
.section-head{max-width:640px;margin-bottom:48px;}
.section-head.center{margin-left:auto;margin-right:auto;}
