:root {
      --dk:    #1e0a00;
      --brown: #3d1a00;
      --mid:   #7a3010;
      --amber: #c8621a;
      --gold:  #e8a45a;
      --warm:  #f5e4cc;
      --cream: #fdf8f2;
      --text:  #2c1304;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'Montserrat', sans-serif;
      background: var(--cream);
      color: var(--text);
      overflow-x: hidden;
    }
    body::after {
      content: ''; position: fixed; inset: 0; z-index: 9999;
      pointer-events: none; opacity: 0.025;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    }

    /* ══ HEADER ══════════════════════════════════════════════ */
    header {
      position: fixed; top: 0; left: 0; right: 0; z-index: 100;
      padding: 0 5vw;
      display: flex; align-items: center; justify-content: space-between;
      height: 78px;
      background: rgba(20,7,0,.55);
      backdrop-filter: blur(6px);
      transition: background .4s, box-shadow .4s, height .3s;
    }
    header.scrolled {
      background: rgba(20,7,0,.96);
      backdrop-filter: blur(16px);
      box-shadow: 0 2px 30px rgba(0,0,0,.5);
      height: 66px;
    }
    .logo {
      height: 54px; object-fit: contain; cursor: pointer;
      transition: height .3s, opacity .2s;
    }
    header.scrolled .logo { height: 46px; }
    .logo:hover { opacity: .85; }

    /* Nav links */
    nav { display: flex; align-items: center; gap: 8px; }
    .nav-link {
      font-size: 11px; font-weight: 700; letter-spacing: 1px;
      text-transform: uppercase; color: rgba(255,255,255,.82);
      text-decoration: none; padding: 8px 14px; border-radius: 8px;
      transition: color .2s, background .2s;
      cursor: pointer;
    }
    .nav-link:hover { color: var(--gold); background: rgba(255,255,255,.07); }

    /* WhatsApp CTA in nav */
    .nav-wa {
      background: #25D366; color: #fff !important;
      border-radius: 50px; padding: 9px 18px !important;
      display: inline-flex; align-items: center; gap: 7px;
      box-shadow: 0 4px 14px rgba(37,211,102,.35);
      transition: transform .15s, box-shadow .2s !important;
      margin-left: 4px;
    }
    .nav-wa:hover { transform: translateY(-2px); box-shadow: 0 8px 22px rgba(37,211,102,.45) !important; background: #22c05e !important; }
    /* ── Rotating glow — PEDIR AHORA ── */
    @keyframes btnRotate { to { transform: rotate(360deg); } }

    .nav-wa-glow {
      background: #25D366 !important;
      box-shadow: none !important;
      padding: 0 !important;
      border-radius: 50px !important;
      position: relative;
      z-index: 1;
      overflow: hidden;
    }
    .nav-wa-glow::before {
      content: '';
      position: absolute;
      /* Franja delgada que rota desde el centro — toca todos los bordes igual */
      width: 22px;
      height: 400%;
      top: -150%;
      left: calc(50% - 11px);
      background: linear-gradient(
        to bottom,
        transparent 0%,
        rgba(255,255,255,0.1) 18%,
        rgba(255,255,255,0.85) 40%,
        white 50%,
        rgba(255,255,255,0.85) 60%,
        rgba(255,255,255,0.1) 82%,
        transparent 100%
      );
      transform-origin: center center;
      animation: btnRotate 3s linear infinite;
      z-index: 0;
    }
    .nav-wa-glow::after {
      content: '';
      position: absolute;
      inset: 2px;
      border-radius: 48px;
      background: #25D366;
      z-index: 1;
    }
    .nav-wa-glow svg,
    .nav-wa-glow .nav-wa-inner {
      position: relative;
      z-index: 2;
    }
    .nav-wa-inner {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      padding: 9px 18px;
      color: #fff !important;
      font-weight: 700;
      font-size: 13px;
    }

    /* Hamburger */
    .menu-toggle {
      display: none; background: none; border: none; cursor: pointer;
      flex-direction: column; gap: 5px; padding: 4px;
    }
    .menu-toggle span {
      display: block; width: 24px; height: 2px;
      background: #fff; border-radius: 2px; transition: all .3s;
    }
    .menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
    .menu-toggle.open span:nth-child(2) { opacity: 0; }
    .menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

    /* ══ CAROUSEL ════════════════════════════════════════════ */
    .carousel { position: relative; height: 100vh; min-height: 580px; overflow: hidden; }
    .slide {
      position: absolute; inset: 0;
      opacity: 0; transition: opacity 1s ease;
      display: flex; align-items: center;
    }
    .slide.active { opacity: 1; }

    /* Todos los slides en tono café/ámbar del primer slide */
    .slide-1 { background: linear-gradient(138deg, #1e0a00 0%, #5c2008 45%, #a84010 80%, #c8621a 100%); }
    .slide-2 { background: linear-gradient(150deg, #1a0800 0%, #4e1c06 42%, #8c3412 76%, #b85c1c 100%); }
    .slide-3 { background: linear-gradient(125deg, #160700 0%, #4a1e00 44%, #8e3a18 78%, #c4682a 100%); }
    .slide-4 { background: linear-gradient(145deg, #1c0900 0%, #541e06 42%, #923c16 75%, #c06020 100%); }

    /* Textura diagonal sutil en todos */
    .slide::before {
      content: ''; position: absolute; inset: 0; pointer-events: none;
      background: repeating-linear-gradient(
        -55deg, transparent, transparent 60px,
        rgba(255,255,255,.018) 60px, rgba(255,255,255,.018) 61px
      );
    }
    /* Halo de luz derecho */
    /* Orb handled by .slide-orb element below */

    .slide-content {
      position: relative; z-index: 2;
      padding: 0 8vw; max-width: 680px;
    }
    /* Gradiente protector de texto — cubre solo lado izquierdo */
    .slide::after {
      content: "";
      position: absolute; inset: 0;
      background: linear-gradient(to right,
        rgba(0,0,0,0.55) 0%,
        rgba(0,0,0,0.35) 40%,
        rgba(0,0,0,0.0)  68%
      );
      z-index: 1;
      pointer-events: none;
    }
    .slide-tag {
      display: inline-block;
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.22);
      border-radius: 50px; padding: 5px 16px;
      font-size: 10px; font-weight: 700; letter-spacing: 2px;
      color: var(--gold); text-transform: uppercase; margin-bottom: 20px;
    }
    .slide-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: clamp(46px, 7vw, 92px);
      line-height: 1.02; color: #fff; font-weight: 700; margin-bottom: 18px;
    }
    .slide-title em { font-style: italic; color: var(--gold); }
    .slide-desc {
      font-size: 15px; color: rgba(255,255,255,.72);
      line-height: 1.75; max-width: 460px; margin-bottom: 34px;
    }
    .slide-cta {
      display: inline-flex; align-items: center; gap: 10px;
      background: var(--gold); color: var(--brown);
      text-decoration: none; border-radius: 50px;
      padding: 13px 30px; font-size: 13px; font-weight: 700; letter-spacing: 0.3px;
      transition: background .2s, transform .15s, box-shadow .2s;
      box-shadow: 0 8px 28px rgba(232,164,90,.4);
    }
    .slide-cta:hover { background: #f0b86a; transform: translateY(-2px); }

    .slide-art {
      position: absolute; right: 6vw; top: 50%; transform: translateY(-50%);
      font-size: clamp(90px, 13vw, 190px);
      filter: drop-shadow(0 20px 50px rgba(0,0,0,.25));
      animation: floatArt 5s ease-in-out infinite;
      user-select: none; pointer-events: none;
    }
    .slide-art-delivery {
      position: absolute !important;
      right: -6vw !important;
      left: auto !important;
      top: 50% !important;
      transform: translateY(-50%) !important;
      animation: floatDelivery 5s ease-in-out infinite;
      pointer-events: none;
      user-select: none;
    }
    @media (max-width: 700px) {
      .slide::after {
        background: linear-gradient(to right,
          rgba(0,0,0,0.75) 0%,
          rgba(0,0,0,0.60) 50%,
          rgba(0,0,0,0.25) 80%
        ) !important;
      }
    }
    @media (max-width: 1024px) and (min-width: 701px) {
      /* iPad — imágenes más arriba y menos zoom */
      .slide-art-semita    { top: 50% !important; right: -14vw !important; }
      .slide-art-quesadilla{ top: 52% !important; right: -14vw !important; }
      .slide-art-salpor    { top: 50% !important; right: -14vw !important; }
      .slide-art-delivery  { top: 50% !important; right: -6vw  !important; }
      .slide-art-semita img,
      .slide-art-quesadilla img,
      .slide-art-salpor img  { width: clamp(300px, 48vw, 560px) !important; }
      .slide-art-delivery img { width: clamp(280px, 42vw, 500px) !important; }
    }
    @media (max-width: 700px) {
      .slide-art-semita,
      .slide-art-quesadilla,
      .slide-art-salpor {
        position: absolute !important;
        left: auto !important;
        right: -20vw !important;
        top: 50% !important;
      }
      .slide-art-semita img,
      .slide-art-quesadilla img,
      .slide-art-salpor img {
        width: clamp(260px, 72vw, 480px) !important;
      }
    }
    @media (max-width: 600px) {
      .slide-art-delivery {
        right: -15vw !important;
        width: clamp(220px, 70vw, 400px) !important;
        opacity: 0.55;
      }
      .slide-art-delivery img {
        width: clamp(220px, 70vw, 400px) !important;
      }
    }
    @keyframes floatDelivery {
      0%,100% { transform: translateY(-50%) scale(1);    filter: drop-shadow(0 20px 40px rgba(0,0,0,.4)); }
      50%      { transform: translateY(-52%) scale(1.03); filter: drop-shadow(0 28px 50px rgba(0,0,0,.55)); }
    }
    .slide-art-salpor {
      right: -20vw; top: 56%;
      animation: floatSalpor 5s ease-in-out infinite;
    }
    @keyframes floatSalpor {
      0%,100% { transform: translateY(-50%) scale(1);     filter: drop-shadow(0 20px 40px rgba(0,0,0,.4)); }
      50%      { transform: translateY(-50%) scale(1.03);  filter: drop-shadow(0 30px 55px rgba(0,0,0,.55)); }
    }
    .slide-art-semita {
      right: -28vw; top: 54%;
      animation: floatSemita 5s ease-in-out infinite;
    }
    @keyframes floatSemita {
      0%,100% { transform: translateY(-50%) scale(1);    filter: drop-shadow(0 20px 40px rgba(0,0,0,.4)); }
      50%      { transform: translateY(-50%) scale(1.03); filter: drop-shadow(0 30px 55px rgba(0,0,0,.55)); }
    }
    .slide-art-quesadilla {
      right: -22vw; top: 56%;
      animation: floatQuesadilla 4s ease-in-out infinite;
    }
    @keyframes floatQuesadilla {
      0%,100% { transform: translateY(-50%) rotate(-5deg) scale(1); filter: drop-shadow(0 20px 40px rgba(0,0,0,.35)); }
      50%      { transform: translateY(-50%) rotate(-5deg) scale(1.04); filter: drop-shadow(0 30px 60px rgba(0,0,0,.5)); }
    }
    @keyframes floatArt {
      0%,100% { transform: translateY(-50%) rotate(-3deg); }
      50%      { transform: translateY(calc(-50% - 14px)) rotate(3deg); }
    }

    /* ══ SCROLL ARROWS ══════════════════════════════════════════ */
    .scroll-arrows {
      position: absolute;
      bottom: 72px;
      left: 50%;
      transform: translateX(-50%);
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 6px;
      z-index: 10;
      pointer-events: none;
    }
    .m_scroll_arrows {
      display: block;
      width: 22px;
      height: 22px;
      border-right: 2.5px solid rgba(255,255,255,0.85);
      border-bottom: 2.5px solid rgba(255,255,255,0.85);
      transform: rotate(45deg);
      animation: arrow-glow 1.8s ease-in-out infinite;
    }
    .unu  { animation-delay: 0s; }
    .doi  { animation-delay: 0.3s; }
    .trei { animation-delay: 0.6s; }

    @keyframes arrow-glow {
      0% {
        opacity: 0;
        filter: drop-shadow(0 0 0px rgba(255,255,255,0));
        transform: rotate(45deg) translate(-4px, -4px);
      }
      50% {
        opacity: 1;
        filter: drop-shadow(0 0 6px rgba(255,255,255,0.9))
                drop-shadow(0 0 14px rgba(255,255,255,0.4));
        transform: rotate(45deg) translate(0px, 0px);
      }
      100% {
        opacity: 0;
        filter: drop-shadow(0 0 0px rgba(255,255,255,0));
        transform: rotate(45deg) translate(4px, 4px);
      }
    }

    .carousel-dots {
      position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%);
      display: flex; gap: 10px; z-index: 10;
    }
    .dot {
      width: 8px; height: 8px; border-radius: 50%;
      background: rgba(255,255,255,.3); border: none; cursor: pointer;
      transition: width .3s, background .3s; padding: 0;
    }
    .dot.active { width: 28px; border-radius: 4px; background: var(--gold); }

    .carousel-arrow {
      position: absolute; top: 50%; z-index: 10; transform: translateY(-50%);
      background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.2);
      color: #fff; border-radius: 50%; width: 46px; height: 46px;
      cursor: pointer; font-size: 20px;
      display: flex; align-items: center; justify-content: center;
      transition: background .2s;
    }
    .carousel-arrow:hover { background: rgba(255,255,255,.2); }
    .arr-prev { left: 24px; }
    .arr-next { right: 24px; }

    /* ══ SECTIONS ════════════════════════════════════════════ */
    section { padding: 90px 8vw; }
    .sec-tag {
      display: inline-block; background: var(--warm); color: var(--amber);
      border-radius: 50px; padding: 4px 14px;
      font-size: 10px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase;
      margin-bottom: 12px;
    }
    .sec-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: clamp(30px, 4vw, 54px);
      color: var(--brown); line-height: 1.15; margin-bottom: 10px;
    }
    .sec-title em { font-style: italic; color: var(--amber); }
    .sec-sub {
      font-size: 14px; color: #7a5035; line-height: 1.75;
      max-width: 560px; margin-bottom: 48px;
    }

    /* ══ PRODUCTOS ══════════════════════════════════════════ */
    #productos { background: #fff; }
    .domicilio-badge {
      background: linear-gradient(135deg, var(--brown), var(--mid));
      border-radius: 18px; padding: 24px 28px;
      display: flex; align-items: center; gap: 18px;
      margin-bottom: 40px; flex-wrap: wrap;
    }
    .dom-icon  { font-size: 40px; flex-shrink: 0; }
    .dom-title { font-size: 15px; font-weight: 800; color: #fff; margin-bottom: 4px; }
    .dom-text  { font-size: 13px; color: rgba(255,255,255,.75); line-height: 1.6; }
    .dom-text strong { color: var(--gold); }

    .prod-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(215px, 1fr));
      gap: 18px;
    }
    .prod-card {
      border: 1.5px solid rgba(61,26,0,.07);
      border-radius: 20px; padding: 24px 18px;
      background: var(--cream);
      transition: transform .22s, box-shadow .22s, border-color .22s;
      position: relative; overflow: hidden;
    }
    .prod-card::after {
      content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 3px;
      background: linear-gradient(90deg, var(--amber), var(--gold));
      transform: scaleX(0); transform-origin: left; transition: transform .3s;
    }
    .prod-card:hover { transform: translateY(-5px); box-shadow: 0 18px 44px rgba(61,26,0,.1); border-color: rgba(200,98,26,.25); }
    .prod-card:hover::after { transform: scaleX(1); }
    .prod-emoji { font-size: 36px; margin-bottom: 12px; display: block; font-family: 'Segoe UI Emoji', 'Apple Color Emoji', 'Noto Color Emoji', 'Twemoji Mozilla', sans-serif; }
    .prod-name  { font-size: 14px; font-weight: 700; color: var(--brown); margin-bottom: 6px; }
    .prod-cat {
      display: inline-block; background: var(--warm); color: var(--amber);
      border-radius: 50px; padding: 2px 10px;
      font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
      margin-bottom: 10px;
    }
    .prod-desc { font-size: 12px; color: #8a6040; line-height: 1.65; }
    .prod-price { margin-top: 10px; font-size: 15px; font-weight: 700; color: #c8621a; }
    .prod-unit  { font-size: 11px; font-weight: 400; color: #a07050; }

    /* ══ NOSOTROS ═══════════════════════════════════════════ */
    #nosotros {
      background: linear-gradient(160deg, var(--brown) 0%, #6b2d0a 50%, var(--amber) 100%);
      position: relative; overflow: hidden;
    }
    #nosotros::before {
      content: '🍞'; position: absolute;
      right: 5%; top: 50%; transform: translateY(-50%);
      font-size: clamp(120px, 18vw, 250px); opacity: .05; pointer-events: none;
    }
    #nosotros .sec-tag  { background: rgba(255,255,255,.14); color: rgba(255,255,255,.9); }
    #nosotros .sec-title{ color: #fff; }
    #nosotros .sec-sub  { color: rgba(255,255,255,.72); max-width: 620px; }
    .nos-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 18px; }
    .nos-card {
      background: rgba(255,255,255,.1); backdrop-filter: blur(8px);
      border: 1px solid rgba(255,255,255,.14);
      border-radius: 18px; padding: 26px 20px; transition: background .2s;
    }
    .nos-card:hover { background: rgba(255,255,255,.16); }
    .nos-icon   { font-size: 30px; margin-bottom: 10px; }
    .nos-label  { font-size: 13px; font-weight: 700; color: #fff; margin-bottom: 5px; }
    .nos-text   { font-size: 12px; color: rgba(255,255,255,.68); line-height: 1.65; }
    .nos-number {
      font-family: 'Cormorant Garamond', serif;
      font-size: 46px; font-weight: 700; color: var(--gold);
      line-height: 1; margin-bottom: 4px;
    }

    /* ══ PEDIDOS / HORARIO ═══════════════════════════════════ */
    #horario { background: var(--cream); }
    .horario-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; align-items: start; }
    .hor-block { margin-bottom: 22px; }
    .hor-block-title {
      font-size: 11px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase;
      color: var(--amber); margin-bottom: 10px;
    }
    .horario-table { border: 1.5px solid rgba(61,26,0,.08); border-radius: 16px; overflow: hidden; }
    .hor-head {
      background: linear-gradient(90deg,var(--brown),var(--mid));
      color: #fff; padding: 12px 20px;
      font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
      display: flex; justify-content: space-between;
    }
    .hor-row {
      display: flex; justify-content: space-between; align-items: center;
      padding: 11px 20px; border-bottom: 1px solid rgba(61,26,0,.05); font-size: 13px;
    }
    .hor-row:last-child { border-bottom: none; }
    .hor-row:nth-child(odd) { background: #fff; }
    .hor-day    { font-weight: 600; color: var(--brown); }
    .hor-time   { color: var(--amber); font-weight: 700; font-size: 12px; }
    .hor-closed { color: #ccc; font-weight: 400; font-style: italic; font-size: 12px; }
    .hor-special { background: rgba(200,98,26,.08) !important; border-left: 3px solid var(--amber); }
    .hor-special .hor-day { color: var(--amber); }

    .horario-info { display: flex; flex-direction: column; gap: 14px; }
    .info-box {
      background: #fff; border: 1.5px solid rgba(61,26,0,.07);
      border-radius: 14px; padding: 18px 20px;
      display: flex; align-items: flex-start; gap: 14px;
    }
    .info-icon  { font-size: 22px; flex-shrink: 0; }
    .info-title { font-size: 13px; font-weight: 700; color: var(--brown); margin-bottom: 4px; }
    .info-text  { font-size: 12px; color: #8a6040; line-height: 1.65; }
    .info-text a { color: var(--amber); text-decoration: none; font-weight: 600; }
    .info-text a:hover { text-decoration: underline; }

    /* ══ CONTACTO ════════════════════════════════════════════ */
    #contacto { background: var(--dk); text-align: center; padding: 80px 8vw; }
    .social-row { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
    .soc-btn {
      display: inline-flex; align-items: center; gap: 9px;
      padding: 12px 22px; border-radius: 50px;
      font-size: 13px; font-weight: 700; text-decoration: none;
      transition: transform .15s; letter-spacing: 0.2px;
    }
    .soc-btn:hover { transform: translateY(-3px); }
    .soc-btn.wa { background:#25D366; color:#fff; }
    .soc-btn.ig { background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); color:#fff; }
    .soc-btn.fb { background:#1877F2; color:#fff; }
    .soc-btn.tt { background:#000; color:#fff; border:1px solid #333; }

    /* ══ FOOTER ═════════════════════════════════════════════ */
    footer {
      background: var(--brown); padding: 36px 8vw;
      display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 20px;
    }
    /* Footer logo — PNG ya es blanco */
    footer img { height: 40px; object-fit: contain; opacity: .9; cursor: pointer; }
    .footer-text { font-size: 11px; color: rgba(255,255,255,.5); line-height: 1.75; }
    .footer-text strong { color: rgba(255,255,255,.8); }
    .footer-links { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
    .footer-links a { color: rgba(255,255,255,.45); text-decoration: none; font-size: 11px; transition: color .2s; }
    .footer-links a:hover { color: var(--gold); }
    /* Icono de acceso interno — muy discreto */
    .footer-admin { opacity: .18; font-size: 13px; transition: opacity .2s; }
    .footer-admin:hover { opacity: .5 !important; color: var(--gold) !important; }

    /* ══ MOBILE ═════════════════════════════════════════════ */
    @media (max-width: 880px) {
      nav {
        display: none; position: fixed; top: 66px; left: 0; right: 0;
        flex-direction: column; align-items: stretch;
        background: rgba(20,7,0,.97); backdrop-filter: blur(14px);
        padding: 20px 24px; gap: 4px;
        box-shadow: 0 12px 40px rgba(0,0,0,.4);
      }
      nav.open { display: flex; }
      .nav-link { font-size: 13px; padding: 12px 16px; border-radius: 10px; }
      .nav-wa   { justify-content: center; border-radius: 10px; }
      .menu-toggle { display: flex; }
      .slide-art { font-size: 70px; right: 3vw; opacity: .4; }
      .slide-art-semita,
      .slide-art-quesadilla,
      .slide-art-salpor {
        position: absolute !important;
        right: -18vw !important;
        left: auto !important;
        opacity: 1 !important;
      }
      .slide-art-semita img,
      .slide-art-quesadilla img,
      .slide-art-salpor img {
        width: clamp(280px, 75vw, 500px) !important;
      }
      .horario-wrap { grid-template-columns: 1fr; }
      .carousel-arrow { display: none; }
      header { padding: 0 6vw; }
    }
    @media (max-width: 520px) {
      section { padding: 60px 5vw; }
      .slide-content { padding: 0 6vw; }
      .prod-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
      .prod-card { padding: 14px 12px; }
      .prod-emoji { font-size: 28px; }
    }

    /* ══ ANIMATIONS ═════════════════════════════════════════ */
    .reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s, transform .7s; }
    .reveal.in { opacity: 1; transform: translateY(0); }
    .reveal-d1 { transition-delay: .12s; }
    .reveal-d2 { transition-delay: .22s; }
    .reveal-d3 { transition-delay: .32s; }


    /* ── Halo decorativo — posicionado bajo el texto ── */
    .slide-orb {
      position: absolute;
      right: 35%;
      bottom: -80px;
      width: 500px; height: 500px; border-radius: 50%;
      background: radial-gradient(circle, rgba(232,164,90,.13) 0%, transparent 68%);
      pointer-events: none; z-index: 1;
    }
    @media (min-width: 1400px) {
      .slide-orb { right: 38%; bottom: -120px; width: 620px; height: 620px; }
    }
    /* ── Pantallas grandes 1400px+ — imágenes pegadas al borde derecho ── */
    @media (min-width: 1400px) {
      .slide-content        { padding: 0 8vw; max-width: 700px; }
      .slide-art            { right: -4vw; }
      .slide-art-delivery   { right: -6vw  !important; }
      .slide-art-semita     { right: -10vw !important; }
      .slide-art-quesadilla { right: -12vw !important; }
      .slide-art-salpor     { right: -16vw !important; }
    }
    @media (min-width: 1700px) {
      .slide-content        { padding: 0 10vw; max-width: 820px; }
      .slide-art-delivery   { right: -8vw  !important; }
      .slide-art-semita     { right: -12vw !important; }
      .slide-art-quesadilla { right: -14vw !important; }
      .slide-art-salpor     { right: -18vw !important; }
    }
    @media (min-width: 2000px) {
      .slide-content        { padding: 0 12vw; max-width: 960px; }
    }
    @media (max-width: 860px) {
      .mapa-layout { grid-template-columns: 1fr; }
      #mapa-sv { height: 360px; }
      .mapa-legend { flex-direction: row; flex-wrap: wrap; }
      .legend-group { flex: 1 1 45%; }
    }
    @media (max-width: 500px) {
      .mapa-legend { flex-direction: column; }
      .legend-group { flex: unset; }
    }

    }

    }


    /* ══ COBERTURA ══════════════════════════════════════════ */
    #cobertura { background: var(--cream); }
    /* Leaflet CSS */
    .leaflet-container { font-family: 'Montserrat', sans-serif; }

    .cob-layout {
      display: grid;
      grid-template-columns: 340px 1fr;
      gap: 36px;
      align-items: start;
      margin-top: 0;
    }
    .cob-legend { display: flex; flex-direction: column; gap: 10px; }
    .cob-map-box {
      position: relative;
      border-radius: 20px;
      box-shadow: 0 8px 40px rgba(61,26,0,.18);
      background: #e8f0f8;
    }
    #leafletMap {
      width: 100%;
      height: 700px;
      border-radius: 20px;
      display: block;
    }
    @media (max-width: 900px) {
      .cob-layout { grid-template-columns: 1fr; }
      #leafletMap { height: 420px; }
    }
    .cob-legend-title { font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 700; color: var(--brown); }
    .cob-key { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 2px; }
    .cob-key-i { display: flex; align-items: center; gap: 6px; font-size: 11px; color: #7a5035; }
    .cob-key-sq { width: 14px; height: 14px; border-radius: 4px; flex-shrink: 0; }
    .cob-group { background: #fff; border-radius: 14px; padding: 14px 16px; border: 1px solid var(--warm); }
    .cob-group-h { font-size: 10px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase; color: var(--amber); margin-bottom: 8px; }
    .cob-item { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--text); padding: 4px 6px; border-radius: 6px; cursor: pointer; transition: background .15s; }
    .cob-item:hover { background: var(--warm); }
    .cob-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
    .cob-cta { background: linear-gradient(135deg, var(--amber), var(--mid)); color: #fff; border: none; border-radius: 50px; padding: 14px 20px; font-family: 'Montserrat', sans-serif; font-size: 13px; font-weight: 700; cursor: pointer; width: 100%; letter-spacing: .4px; box-shadow: 0 4px 18px rgba(200,98,26,.35); transition: transform .2s, box-shadow .2s; text-decoration: none; display: block; text-align: center; }
    .cob-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(200,98,26,.45); }

@keyframes comboPulse {
  0%,100% { box-shadow: 0 4px 16px rgba(200,98,26,.15), 0 0 0 0 rgba(200,98,26,.0); }
  50%      { box-shadow: 0 8px 28px rgba(200,98,26,.30), 0 0 0 6px rgba(200,98,26,.10); }
}
@keyframes comboShimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}
.card-combo {
  animation: comboPulse 3s ease-in-out infinite;
  background: linear-gradient(160deg,#fff 60%,#fff8f2) !important;
  border-color: #e8b48a !important;
  position: relative;
  overflow: hidden;
}
.card-combo::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,200,120,.18) 50%, transparent 60%);
  background-size: 200% 100%;
  animation: comboShimmer 2.8s ease-in-out infinite;
  pointer-events: none;
  border-radius: inherit;
}
.card-combo:hover {
  animation-play-state: paused;
  transform: translateY(-3px) scale(1.02);
  border-color: #c8621a !important;
}
.card-combo:hover::after { animation-play-state: paused; }
.card-combo.selected {
  animation-play-state: paused;
  border-color: #c8621a !important;
  box-shadow: 0 0 0 3px rgba(200,98,26,.2) !important;
}
.card-combo.selected::after { animation-play-state: paused; }
/* ── H1 accesible — ocupa cero espacio visual, legible por Google ── */
.site-h1 {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
