/* ==================================================================
   11 CHICKS - ESTILOS DEL SITIO
   Si quieres cambiar colores o fuentes, edita las variables de abajo.
   ================================================================== */

/* ===== 1) COLORES (cambia aqui la paleta de marca) ===== */
:root{
  --purple:     #3A2879;
  --orange:     #F18133;
  --beige:      #D0C599;
  --green:      #A8F99D;
  --warm:       #FFF8E8;
  --black:      #171717;

  /* ===== 2) FUENTES (las cargamos desde Google Fonts en el index.html) ===== */
  --font-display: 'preconnect', 'preconnect', Georgia, serif;
  --font-body:    'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ===== Reset basico ===== */
*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  background: var(--warm);
  color: var(--black);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}
img{ max-width: 100%; display: block; }
a{ color: inherit; }
button{ font-family: inherit; cursor: pointer; border: 0; background: transparent; }

.font-display{ font-family: var(--font-display); letter-spacing: -0.01em; }
.sr-only{ position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* Utilidades */
.container{ max-width: 1200px; margin: 0 auto; padding: 0 20px; }
@media(min-width:1024px){ .container{ padding: 0 40px; } }

.brutal{ border: 3px solid var(--black); box-shadow: 6px 6px 0 0 var(--black); }
.brutal-sm{ border: 2px solid var(--black); box-shadow: 4px 4px 0 0 var(--black); }

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding: 14px 22px;
  font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
  font-size: 13px;
  border: 2px solid var(--black);
  border-radius: 999px;
  box-shadow: 6px 6px 0 0 var(--black);
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease;
  text-decoration: none;
}
.btn:hover{ transform: translate(-2px,-2px); box-shadow: 8px 8px 0 0 var(--black); }
.btn:active{ transform: translate(2px,2px); box-shadow: 3px 3px 0 0 var(--black); }
.btn--orange{ background: var(--orange); color: #fff; }
.btn--purple{ background: var(--purple); color: var(--warm); }
.btn--green { background: var(--green);  color: var(--black); }
.btn--outline-dark{ background: transparent; color: var(--black); }
.btn--outline-light{ background: transparent; color: var(--warm); border-color: var(--warm); }
.btn--outline-light:hover{ background: var(--warm); color: var(--purple); }
.btn--sm{ padding: 10px 18px; font-size: 12px; box-shadow: 4px 4px 0 0 var(--black); }

.wavy{
  position: relative; display: inline-block;
}
.wavy::after{
  content:''; position: absolute; left:0; bottom:-8px; width:100%; height:8px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='8' viewBox='0 0 100 8'%3E%3Cpath d='M0 4 Q 12.5 0 25 4 T 50 4 T 75 4 T 100 4' stroke='%23F18133' stroke-width='3' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: repeat-x; background-size: 60px 8px;
}

/* =========================================================
   HEADER
   ========================================================= */
.header{
  position: fixed; top: 0; left: 0; right: 0; z-index: 40;
  background: var(--purple);
  transition: background-color .2s ease, border-color .2s ease;
}
.header--scrolled{ background: rgba(58,40,121,.95); backdrop-filter: blur(10px); border-bottom: 2px solid var(--black); }
.header__inner{ display:flex; align-items:center; justify-content: space-between; height: 80px; gap: 16px; }
.header__logo img{ height: 48px; width:auto; }
.nav{ display: none; gap: 30px; }
@media(min-width: 1024px){ .nav{ display: flex; } }
.nav__link{ background: transparent; color: var(--warm); font-weight: 600; font-size: 13px; text-transform: uppercase; letter-spacing: .12em; }
.nav__link:hover{ color: var(--green); }
.header__actions{ display:flex; align-items:center; gap: 12px; }

.lang{
  display:none; align-items:center;
  background: var(--warm); border: 2px solid var(--black); border-radius: 999px; overflow:hidden;
  font-size: 12px; font-weight: 700;
}
@media(min-width: 640px){ .lang{ display:inline-flex; } }
.lang button{ padding: 6px 12px; color: var(--purple); }
.lang button.active{ background: var(--purple); color: var(--warm); }
.lang .sep{ width: 2px; height: 20px; background: var(--black); }

.cart-btn{
  position: relative; width: 40px; height: 40px; border-radius: 999px;
  background: var(--green); border: 2px solid var(--black); box-shadow: 3px 3px 0 0 var(--black);
  display:flex; align-items:center; justify-content:center;
}
.cart-btn__count{
  position: absolute; top: -8px; right: -8px; min-width: 22px; height: 22px; padding: 0 4px;
  background: var(--orange); border: 2px solid var(--black); border-radius: 999px;
  font-size: 10px; font-weight: 800; display:flex; align-items:center; justify-content:center;
}
.burger{ display:flex; width: 40px; height: 40px; border-radius: 999px; background: var(--warm); border: 2px solid var(--black); align-items:center; justify-content:center; }
@media(min-width: 1024px){ .burger{ display: none; } }
.header__cta{ display:none; }
@media(min-width: 768px){ .header__cta{ display:inline-flex; } }

.mobile-menu{ display: none; background: var(--purple); border-top: 2px solid var(--black); padding: 20px; }
.mobile-menu.open{ display: block; }
.mobile-menu button{ display:block; width:100%; text-align: left; color: var(--warm); padding: 10px 0; border-bottom: 1px solid rgba(255,248,232,.1); font-weight: 600; text-transform: uppercase; letter-spacing: .12em; font-size: 13px; }

/* =========================================================
   HERO SLIDER (full-bleed)
   ========================================================= */
.hero{
  position: relative; width: 100%; overflow: hidden;
  height: 78vh; min-height: 500px;
}
@media(min-width: 640px){ .hero{ height: 85vh; } }
@media(min-width: 1024px){ .hero{ height: 100vh; min-height: 640px; } }

.hero__slide{ position: absolute; inset: 0; opacity: 0; transition: opacity 1s ease-in-out; z-index: 0; }
.hero__slide.active{ opacity: 1; z-index: 1; }
.hero__slide img{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; transform: scale(1); transition: transform 7s ease-out; }
.hero__slide.active img{ transform: scale(1.05); }
.hero__overlay{ position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(23,23,23,.85) 0%, rgba(58,40,121,.65) 35%, rgba(23,23,23,.25) 70%, rgba(23,23,23,.05) 100%); }
.hero__content{ position: relative; z-index: 2; height: 100%; display: flex; align-items: center; padding: 120px 20px 60px; }
@media(min-width: 768px){ .hero__content{ padding: 120px 48px 60px; } }
.hero__inner{ max-width: 680px; }
.hero__bars{ display: none; flex-direction: column; gap: 4px; margin-bottom: 20px; transform: rotate(-6deg); }
@media(min-width: 640px){ .hero__bars{ display: flex; } }
.hero__bars span{ width: 48px; height: 6px; background: var(--orange); border-radius: 999px; }
.hero__title{
  font-family: var(--font-display);
  color: var(--warm);
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  line-height: 1.05;
  margin: 0 0 20px; text-shadow: 0 4px 20px rgba(0,0,0,.45);
}
.hero__subtitle{
  color: var(--warm); opacity: .95;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  text-shadow: 0 2px 10px rgba(0,0,0,.5);
  max-width: 560px;
}
.hero__ctas{ margin-top: 28px; display: flex; flex-wrap: wrap; gap: 14px; }
.hero__arrow{
  display: none; position: absolute; top: 50%; transform: translateY(-50%); z-index: 3;
  width: 48px; height: 48px; border-radius: 999px;
  background: rgba(255,248,232,.9); border: 2px solid var(--black); box-shadow: 3px 3px 0 0 var(--black);
  align-items: center; justify-content: center; font-size: 20px; font-weight: 700; color: var(--black);
}
@media(min-width: 640px){ .hero__arrow{ display: flex; } }
.hero__arrow:hover{ background: var(--warm); }
.hero__arrow--prev{ left: 16px; }
.hero__arrow--next{ right: 16px; }
.hero__dots{ position: absolute; left: 50%; transform: translateX(-50%); bottom: 28px; z-index: 3; display: flex; gap: 10px; }
.hero__dot{ height: 8px; width: 12px; background: rgba(255,248,232,.85); border: 1px solid rgba(23,23,23,.6); border-radius: 999px; transition: width .2s, background .2s; }
.hero__dot.active{ width: 40px; background: var(--green); }
.hero__counter{ position: absolute; right: 24px; top: 100px; z-index: 3; color: rgba(255,248,232,.8); font-family: var(--font-display); font-size: 14px; letter-spacing: .15em; display: none; }
@media(min-width: 768px){ .hero__counter{ display: block; } }
.hero__counter b{ color: var(--green); }

/* =========================================================
   FLAVORS CAROUSEL
   ========================================================= */
.flavors{ background: var(--beige); padding: 80px 0; position: relative; }
.flavors__head{ display: flex; flex-direction: column; gap: 20px; align-items: flex-start; }
@media(min-width: 1024px){ .flavors__head{ flex-direction: row; align-items: flex-end; justify-content: space-between; } }
.flavors__title{ font-family: var(--font-display); color: var(--purple); font-size: clamp(2rem, 4.2vw, 3.5rem); line-height: 1.1; margin: 0; max-width: 520px; }
.flavors__lead{ color: var(--black); max-width: 440px; margin-top: 16px; }
.flavors__actions{ display: flex; gap: 10px; align-items: center; }
.circle-btn{ width: 48px; height: 48px; border-radius: 999px; background: var(--warm); border: 2px solid var(--black); box-shadow: 3px 3px 0 0 var(--black); display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; }
.circle-btn:hover{ transform: translate(-2px,-2px); box-shadow: 5px 5px 0 0 var(--black); }

.flavors__track{
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 40px 4px 30px;
  margin-top: 24px;
  scrollbar-width: none;
  align-items: stretch;
}
.flavors__track::-webkit-scrollbar{ display: none; }

.flavor-card{
  position: relative;
  flex: 0 0 200px;
  scroll-snap-align: start;
  height: 380px;
  padding: 0;
  border-radius: 36px;
  border: 0;
  box-shadow: none;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .25s ease;
}
@media(min-width: 640px){ .flavor-card{ flex-basis: 220px; height: 420px; } }
.flavor-card:hover{ transform: translateY(-6px); }

.flavor-card--orange{ background: var(--orange); color: var(--warm); }
.flavor-card--purple{ background: var(--purple); color: var(--warm); }
.flavor-card--green { background: var(--green);  color: var(--black); }
.flavor-card--beige { background: var(--beige);  color: var(--black); }

.flavor-card__img{
  width: 100%;
  height: 58%;
  overflow: hidden;
  background: rgba(23,23,23,.06);
}
.flavor-card__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .5s ease;
}
.flavor-card:hover .flavor-card__img img{ transform: scale(1.06); }

.flavor-card__name{
  font-family: var(--font-display);
  font-size: 24px;
  line-height: 1.1;
  margin: 18px 22px 6px;
  cursor: pointer;
  text-align: left;
  padding: 0;
  color: inherit;
  background: transparent;
}
.flavor-card--orange .flavor-card__name,
.flavor-card--green  .flavor-card__name,
.flavor-card--beige  .flavor-card__name{ color: var(--purple); }
.flavor-card--purple .flavor-card__name{ color: var(--warm); }
.flavor-card__name:hover{ text-decoration: underline; }

.flavor-card__short{
  font-size: 13px;
  line-height: 1.35;
  opacity: .92;
  margin: 0 22px 0;
  max-width: 180px;
}

.flavor-card__add{
  position: absolute;
  bottom: 18px;
  right: 18px;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.18);
  border: 2px solid currentColor;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  padding: 0;
  transition: background-color .15s ease, transform .15s ease;
}
.flavor-card--orange .flavor-card__add,
.flavor-card--purple .flavor-card__add{ color: var(--warm); background: rgba(255,255,255,0.18); }
.flavor-card--green  .flavor-card__add,
.flavor-card--beige  .flavor-card__add{ color: var(--black); background: rgba(0,0,0,0.10); }
.flavor-card__add:hover{
  background: var(--warm);
  color: var(--purple);
  transform: scale(1.1);
}
.flavor-card--green .flavor-card__add:hover,
.flavor-card--beige .flavor-card__add:hover{ background: var(--purple); color: var(--warm); }
.flavor-card__add .plus{ display: inline-block; margin-top: -3px; }

.flavor-card__price-sr{ position: absolute; width: 1px; height: 1px; padding: 0; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* =========================================================
   BRUTAL SECTION
   ========================================================= */
.brutal-sec{ background: var(--purple); display: grid; grid-template-columns: 1fr; overflow: hidden; }
@media(min-width: 1024px){ .brutal-sec{ grid-template-columns: 1fr 1fr; } }
.brutal-sec__text{ padding: 64px 24px; position: relative; color: var(--warm); }
@media(min-width: 1024px){ .brutal-sec__text{ padding: 96px 64px; } }
.brutal-sec__title{ font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.5rem); line-height: 1.1; margin: 0 0 20px; }
.brutal-sec__title .hl{ color: var(--orange); }
.brutal-sec__img{ position: relative; min-height: 320px; }
.brutal-sec__img img{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.brutal-sec__badge{
  position: absolute; right: 24px; bottom: 24px; width: 128px; height: 128px; border-radius: 999px;
  background: var(--green); border: 2px solid var(--black); box-shadow: 6px 6px 0 0 var(--black);
  display: flex; align-items: center; justify-content: center; text-align: center; padding: 12px;
  font-size: 12px; font-weight: 800; text-transform: uppercase; color: var(--black);
  transform: rotate(8deg);
}

/* =========================================================
   BENEFITS
   ========================================================= */
.benefits{ background: var(--orange); padding: 80px 0; position: relative; }
.benefits__title{ text-align: center; color: var(--warm); font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3rem); margin: 0 0 48px; }
.benefits__grid{ display: grid; gap: 40px; grid-template-columns: repeat(2, 1fr); }
@media(min-width: 1024px){ .benefits__grid{ grid-template-columns: repeat(4, 1fr); } }
.benefit{ text-align: center; color: var(--warm); }
.benefit__icon{ width: 80px; height: 80px; margin: 0 auto; border-radius: 999px; background: var(--beige); border: 2px solid var(--black); box-shadow: 3px 3px 0 0 var(--black); display: flex; align-items: center; justify-content: center; font-size: 32px; }
.benefit__title{ font-family: var(--font-display); font-size: 22px; margin: 20px 0 6px; }
.benefit__text{ font-size: 14px; opacity: .9; max-width: 200px; margin: 0 auto; }

/* =========================================================
   REASONS
   ========================================================= */
.reasons{ background: var(--purple); padding: 80px 0; color: var(--warm); }
.reasons__inner{ display: grid; grid-template-columns: 1fr; gap: 40px; }
@media(min-width: 1024px){ .reasons__inner{ grid-template-columns: 1fr 2fr; } }
.reasons__title{ font-family: var(--font-display); font-size: clamp(2rem, 3.4vw, 2.8rem); line-height: 1.1; margin: 0; }
.reasons__grid{ display: grid; gap: 20px; grid-template-columns: 1fr; }
@media(min-width: 640px){ .reasons__grid{ grid-template-columns: 1fr 1fr; } }
@media(min-width: 1024px){ .reasons__grid{ grid-template-columns: repeat(3, 1fr); } }
.reason{ display: flex; gap: 12px; }
.reason__num{ flex: 0 0 auto; width: 36px; height: 36px; border-radius: 999px; background: var(--green); border: 2px solid var(--black); color: var(--black); font-weight: 800; display: flex; align-items: center; justify-content: center; }
.reason__text{ font-size: 14px; padding-top: 6px; }

/* =========================================================
   ORDER FORM
   ========================================================= */
.order{ background: var(--warm); padding: 80px 0; }
.order__inner{ display: grid; gap: 40px; grid-template-columns: 1fr; }
@media(min-width: 1024px){ .order__inner{ grid-template-columns: 3fr 2fr; } }
.order__title{ font-family: var(--font-display); color: var(--purple); font-size: clamp(2rem, 4vw, 3rem); margin: 0 0 12px; line-height: 1.1; }
.order__lead{ max-width: 440px; margin-bottom: 30px; }
.order__form{ display: flex; flex-direction: column; gap: 20px; }
.order__row{ display: grid; grid-template-columns: 1fr; gap: 16px; }
@media(min-width: 640px){ .order__row{ grid-template-columns: 1fr 1fr; } }
.field label{ display: block; font-size: 11px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--purple); margin-bottom: 6px; }
.field input, .field textarea{
  width: 100%; padding: 12px 16px;
  background: #fff; border: 2px solid var(--black); border-radius: 16px;
  font-size: 14px; font-family: inherit; resize: none;
}
.field input:focus, .field textarea:focus{ outline: 4px solid rgba(168,249,157,.5); }
.toggle{ display: inline-flex; background: #fff; border: 2px solid var(--black); border-radius: 999px; padding: 4px; gap: 4px; }
.toggle button{ padding: 8px 20px; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; border-radius: 999px; color: var(--black); }
.toggle button.active{ background: var(--purple); color: var(--warm); }

.order__picker{
  background: var(--purple); color: var(--warm);
  border: 3px solid var(--black); border-radius: 28px; box-shadow: 8px 8px 0 0 var(--black);
  padding: 24px;
}
.order__picker h3{ font-family: var(--font-display); font-size: 24px; margin: 0 0 4px; }
.order__picker p{ font-size: 13px; color: var(--beige); margin: 0 0 16px; }
.order__picker-list{ display: flex; flex-direction: column; gap: 8px; max-height: 360px; overflow-y: auto; padding-right: 6px; }
.order__picker-item{ display: flex; align-items: center; gap: 10px; background: var(--warm); color: var(--black); border: 2px solid var(--black); border-radius: 16px; padding: 8px; }
.order__picker-item img{ width: 48px; height: 48px; border-radius: 12px; border: 2px solid var(--black); object-fit: cover; }
.order__picker-item .info{ flex: 1; min-width: 0; }
.order__picker-item .info b{ color: var(--purple); font-size: 14px; display: block; }
.order__picker-item .info span{ font-size: 12px; color: rgba(23,23,23,.7); }
.qty{ display: inline-flex; align-items: center; border: 2px solid var(--black); border-radius: 999px; background: #fff; }
.qty button{ width: 28px; height: 28px; font-weight: 700; }
.qty span{ width: 28px; text-align: center; font-weight: 700; font-size: 13px; }
.order__picker-total{ display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,248,232,.2); margin-top: 16px; padding-top: 14px; }
.order__picker-total span{ font-weight: 700; font-size: 13px; letter-spacing: .1em; text-transform: uppercase; }
.order__picker-total b{ font-family: var(--font-display); font-size: 30px; color: var(--green); }

.form-error{ color: var(--orange); font-weight: 700; font-size: 14px; }

/* =========================================================
   LOCATION
   ========================================================= */
.location{ display: grid; grid-template-columns: 1fr; background: var(--warm); }
@media(min-width: 1024px){ .location{ grid-template-columns: 1fr 1fr; } }
.location__img{ min-height: 320px; background: var(--purple); position: relative; }
.location__img img{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.location__content{ background: var(--beige); padding: 64px 24px; }
@media(min-width: 1024px){ .location__content{ padding: 96px 64px; } }
.location__title{ font-family: var(--font-display); color: var(--purple); font-size: clamp(2rem, 3.8vw, 3rem); line-height: 1.1; margin: 0 0 12px; }
.location__info{ margin: 24px 0; display: flex; flex-direction: column; gap: 16px; }
.location__info > div{ display: flex; gap: 10px; align-items: flex-start; }
.location__info small{ font-size: 11px; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; color: var(--purple); }
.location__map{ border: 3px solid var(--black); box-shadow: 4px 4px 0 0 var(--black); border-radius: 24px; overflow: hidden; }
.location__map iframe{ display: block; width: 100%; height: 220px; border: 0; }
.location__ctas{ margin-top: 24px; display: flex; gap: 12px; flex-wrap: wrap; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background: var(--black); color: var(--warm); padding: 64px 0 40px; }
.footer__grid{ display: grid; gap: 40px; grid-template-columns: 1fr; }
@media(min-width: 768px){ .footer__grid{ grid-template-columns: repeat(2, 1fr); } }
@media(min-width: 1024px){ .footer__grid{ grid-template-columns: 2fr 1fr 1fr 1fr; } }
.footer__brand img{ height: 48px; margin-bottom: 20px; }
.footer__tagline{ font-family: var(--font-display); font-size: 22px; color: var(--green); max-width: 240px; margin: 0; }
.footer h4{ color: var(--green); font-size: 11px; text-transform: uppercase; letter-spacing: .18em; margin: 0 0 10px; }
.footer p, .footer a{ color: rgba(255,248,232,.82); font-size: 14px; text-decoration: none; }
.footer a:hover{ color: var(--green); }
.footer__social{ display: flex; gap: 8px; margin-top: 14px; }
.footer__social a{ width: 36px; height: 36px; border: 1px solid var(--warm); border-radius: 999px; background: var(--purple); display: flex; align-items: center; justify-content: center; }
.footer__social a:hover{ background: var(--orange); color: var(--warm); }
.footer__bottom{ margin-top: 40px; padding-top: 20px; border-top: 1px solid rgba(255,248,232,.15); display: flex; flex-direction: column; gap: 8px; justify-content: space-between; font-size: 12px; color: rgba(255,248,232,.6); }
@media(min-width: 640px){ .footer__bottom{ flex-direction: row; } }

/* =========================================================
   MODAL
   ========================================================= */
.modal{ position: fixed; inset: 0; z-index: 60; background: rgba(23,23,23,.7); backdrop-filter: blur(4px); display: none; align-items: center; justify-content: center; padding: 20px; }
.modal.open{ display: flex; }
.modal__card{ width: 100%; max-width: 720px; background: var(--warm); border: 3px solid var(--black); box-shadow: 10px 10px 0 0 var(--black); border-radius: 28px; overflow: hidden; display: grid; grid-template-columns: 1fr; position: relative; max-height: 90vh; }
@media(min-width: 768px){ .modal__card{ grid-template-columns: 1fr 1fr; } }
.modal__close{ position: absolute; top: 16px; right: 16px; z-index: 2; width: 40px; height: 40px; border-radius: 999px; background: var(--orange); border: 2px solid var(--black); box-shadow: 3px 3px 0 0 var(--black); font-weight: 700; font-size: 18px; }
.modal__img{ background: var(--purple); padding: 24px; display: flex; align-items: center; justify-content: center; min-height: 260px; }
.modal__img img{ max-height: 300px; }
.modal__body{ padding: 28px; overflow-y: auto; }
.modal__body .eyebrow{ font-size: 11px; text-transform: uppercase; letter-spacing: .18em; color: var(--orange); font-weight: 700; }
.modal__body h3{ font-family: var(--font-display); color: var(--purple); font-size: 32px; margin: 8px 0 10px; }
.modal__body .short{ font-size: 14px; color: rgba(23,23,23,.8); margin-bottom: 20px; }
.modal__ingredients{ border-top: 2px dashed rgba(23,23,23,.3); padding-top: 18px; }
.modal__ingredients small{ font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--purple); }
.modal__ingredients p{ margin: 8px 0 0; font-size: 14px; }
.modal__price{ display: flex; justify-content: space-between; align-items: baseline; margin-top: 24px; }
.modal__price small{ font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(23,23,23,.6); }
.modal__price b{ font-family: var(--font-display); color: var(--orange); font-size: 32px; }
.modal__ctas{ display: flex; gap: 10px; margin-top: 16px; flex-direction: column; }
@media(min-width: 640px){ .modal__ctas{ flex-direction: row; } }

/* =========================================================
   CART DRAWER
   ========================================================= */
.drawer-overlay{ position: fixed; inset: 0; z-index: 55; background: rgba(23,23,23,.6); backdrop-filter: blur(4px); opacity: 0; pointer-events: none; transition: opacity .2s; }
.drawer-overlay.open{ opacity: 1; pointer-events: auto; }
.drawer{ position: fixed; top: 0; right: 0; bottom: 0; z-index: 60; width: 100%; max-width: 420px; background: var(--warm); border-left: 3px solid var(--black); display: flex; flex-direction: column; transform: translateX(100%); transition: transform .25s ease; }
.drawer.open{ transform: translateX(0); }
.drawer__head{ background: var(--purple); color: var(--warm); padding: 20px 24px; display: flex; align-items: center; justify-content: space-between; border-bottom: 2px solid var(--black); }
.drawer__head h3{ font-family: var(--font-display); margin: 0; font-size: 22px; }
.drawer__items{ flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.drawer__item{ display: flex; align-items: center; gap: 10px; background: #fff; border: 2px solid var(--black); border-radius: 16px; padding: 10px; box-shadow: 3px 3px 0 0 var(--black); }
.drawer__item img{ width: 60px; height: 60px; border-radius: 12px; border: 2px solid var(--black); object-fit: cover; }
.drawer__item .info{ flex: 1; min-width: 0; }
.drawer__item .info b{ color: var(--purple); font-size: 14px; }
.drawer__item .info span{ display: block; font-size: 12px; color: rgba(23,23,23,.7); }
.drawer__empty{ text-align: center; padding: 60px 20px; color: rgba(23,23,23,.7); }
.drawer__empty .ico{ font-size: 48px; margin-bottom: 12px; }
.drawer__foot{ border-top: 2px solid var(--black); padding: 20px 24px; background: var(--warm); }
.drawer__total{ display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.drawer__total span{ font-weight: 700; font-size: 13px; letter-spacing: .12em; text-transform: uppercase; }
.drawer__total b{ font-family: var(--font-display); font-size: 26px; color: var(--purple); }

.remove-btn{ width: 36px; height: 36px; border-radius: 999px; border: 2px solid var(--black); background: var(--orange); display: flex; align-items: center; justify-content: center; }

/* "+" button in the order form picker (next to each flavor row) */
.picker-add{
  flex: 0 0 auto;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: var(--green);
  color: var(--black);
  border: 2px solid var(--black);
  box-shadow: 2px 2px 0 0 var(--black);
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .15s ease, box-shadow .15s ease;
}
.picker-add:hover{
  transform: translate(-1px,-1px);
  box-shadow: 3px 3px 0 0 var(--black);
}
.picker-add:active{
  transform: translate(1px,1px);
  box-shadow: 1px 1px 0 0 var(--black);
}

/* =========================================================
   FLOATING BUTTONS
   ========================================================= */
.floating{ position: fixed; right: 24px; bottom: 24px; z-index: 50; display: flex; flex-direction: column; align-items: flex-end; gap: 14px; }
.fab{
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border: 2px solid var(--black); box-shadow: 6px 6px 0 0 var(--black);
  transition: transform .25s ease, box-shadow .25s ease, opacity .25s ease;
}
.fab:hover{ transform: translate(-2px,-2px) scale(1.05); box-shadow: 8px 8px 0 0 var(--black); }
.fab:active{ transform: scale(1); box-shadow: 3px 3px 0 0 var(--black); }
.fab--top{ width: 48px; height: 48px; border-radius: 999px; background: var(--orange); color: #fff; font-size: 22px; opacity: 0; pointer-events: none; transform: translateY(12px); }
.fab--top.show{ opacity: 1; pointer-events: auto; transform: translateY(0); }
.fab--wa{ width: 56px; height: 56px; border-radius: 999px; background: var(--green); color: var(--black); position: relative; }
@media(min-width: 640px){ .fab--wa{ width: auto; height: 56px; padding: 0 22px; gap: 8px; } }
.fab--wa .pulse{ position: absolute; inset: 0; border-radius: 999px; background: var(--green); animation: ping 2s cubic-bezier(0,0,.2,1) infinite; opacity: .3; }
.fab--wa .label{ display: none; font-weight: 700; font-size: 12px; text-transform: uppercase; letter-spacing: .1em; position: relative; }
@media(min-width: 640px){ .fab--wa .label{ display: inline; } }
.fab--wa svg{ position: relative; }

@keyframes ping{ 0%{ transform: scale(1); opacity: .5; } 75%,100%{ transform: scale(2); opacity: 0; } }

/* =========================================================
   ANIMATIONS
   ========================================================= */
@keyframes fadeUp{ from{ opacity: 0; transform: translateY(10px); } to{ opacity: 1; transform: translateY(0); } }
.fade-in{ animation: fadeUp .7s ease both; }
