
:root {
  --black:#0a0a0a; --deep:#111; --red:#cc0000; --red-hot:#ff1a1a;
  --white:#f0ece0; --cream:#d4c9b0; --gray:#2a2a2a; --smoke:#1a1a1a;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color: transparent;}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--white);font-family:'Special Elite',cursive;overflow-x:hidden}


  /* HERO BG TEXT */
  .hero-bg-text {
    position: absolute;
    font-family: 'Bebas Neue', sans-serif;
    font-size: clamp(100px, 22vw, 260px);
    color: rgba(204,0,0,0.05);
    letter-spacing: -8px;
    user-select: none;
    white-space: nowrap;
    pointer-events: none;
    animation: driftBg 20s linear infinite;
  }
  @keyframes driftBg { 0%{transform:translateX(-5%)} 50%{transform:translateX(5%)} 100%{transform:translateX(-5%)} }

.hero-logo-img {
  width: clamp(250px, 70vw, 650px); /* Aumentamos el tamaño considerablemente */
  height: auto;
  margin-bottom: 20px; /* Eliminamos el espacio de abajo del logo */
  filter: drop-shadow(0 0 15px rgba(204, 0, 0, 0.4));
  animation: hornBob 3s ease-in-out infinite;
  z-index: 2;
  display: block; /* Asegura que respete los márgenes */
  margin-left: auto;
  margin-right: auto;
}

/* Ajuste para móviles */
@media (max-width: 640px) {
  .hero-logo-img {
    width: clamp(200px, 80vw, 300px);
    margin-bottom: 10px;
  }
}

  /* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;transition:background .4s}
nav.scrolled{background:rgba(10,10,10,.95);backdrop-filter:blur(10px);border-bottom:1px solid rgba(204,0,0,.2)}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--white);letter-spacing:5px;text-decoration:none}
.nav-logo span{color:var(--red)}
.nav-links{display:flex;gap:16px;list-style:none;align-items:center}
.nav-links a{font-family:'Oswald',sans-serif;font-weight:300;color:var(--cream);text-decoration:none;letter-spacing:2px;font-size:12px;text-transform:uppercase}
.nav-links a.pedir-btn{background:var(--red);color:#fff;padding:8px 16px;font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px}

/* HERO */
#hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;background:radial-gradient(ellipse at center top,#1a0000 0%,var(--black) 70%);text-align:center;padding:20px}
.flames{position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent,var(--red),var(--red-hot),var(--red),transparent);animation:flamePulse 2s ease-in-out infinite;box-shadow:0 0 20px var(--red)}
@keyframes flamePulse{0%,100%{opacity:.8}50%{opacity:1}}
.horns-svg{width:clamp(80px,15vw,160px);margin-bottom:-8px;filter:drop-shadow(0 0 10px rgba(204,0,0,.6));animation:hornBob 3s ease-in-out infinite}
@keyframes hornBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.logo-text{font-family:'Bebas Neue',sans-serif;font-size:clamp(100px,20vw,250px);letter-spacing:16px;color:var(--white);line-height:1}
.tagline {
  margin-top: 10px; /* Usamos un margen negativo para pegarlo más al logo si es necesario */
  font-family: 'Oswald', sans-serif;
  font-weight: 300;
  font-size: clamp(12px, 3vw, 18px);
  letter-spacing: 6px;
  color: var(--cream);
  text-transform: uppercase;
  opacity: .7;
}
.hero-cta {
  margin-top: 25px; /* Reducimos de 40px a 25px */
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}
.btn-main{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px;padding:14px 36px;border:none;cursor:pointer;text-decoration:none;display:inline-block;transition:all .2s}
.btn-red{background:var(--red);color:var(--white)}
.btn-red:hover{background:var(--red-hot)}
.btn-ghost{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.3)}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}


  /* GALERÍA INFINITA ESTILO REFERENCIA */
#galeria {
    padding: 60px 0; /* Espacio arriba y abajo */
    background: #000; /* Fondo negro como en tu foto */
    overflow: hidden;
    width: 100%;
}

.galeria-wrap {
    display: flex;
    overflow: hidden;
    mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent); /* Opcional: difuminado en los bordes */
}

.galeria-track {
    display: flex;
    gap: 20px; /* El espacio entre imágenes que pediste */
    width: max-content;
    animation: loopInfinito 30s linear infinite; /* 30s controla la velocidad */
}

.galeria-track img {
    width: 280px;      /* Ancho similar a tu referencia */
    height: 500px;     /* Formato vertical */
    object-fit: cover; /* Para que la imagen no se deforme */
    border: 1px solid #222; /* Borde sutil */
    flex-shrink: 0;
}

/* LA MAGIA DEL LOOP INFINITO */
@keyframes loopInfinito {
    0% {
        transform: translateX(0);
    }
    100% {
        /* Se mueve exactamente la mitad (porque duplicamos las fotos en el HTML) */
        transform: translateX(-40%);
    }
}

/* Ajuste para que en celulares no se vean gigantes */
@media (max-width: 640px) {
    .galeria-track img {
        width: 200px;
        height: 280px;
    }
    .galeria-track {
        gap: 12px;
    }
}


/* MEJOR ESTILO PARA BOTÓN INSTAGRAM */
.hero-social {
    margin-top: 20px; /* Más espacio para que respire */
    display: flex;
    justify-content: center;
}

.hero-social a {
    display: flex;
    align-items: center;
    gap: 12px;
    
    /* Estructura de botón */
    padding: 10px 24px;
    border: 1px solid rgba(255, 255, 255, 0.2); /* Borde sutil */
    background: rgba(255, 255, 255, 0.03); /* Fondo casi invisible */
    
    /* Tipografía de marca */
    color: var(--white);
    text-decoration: none;
    font-family: 'Bebas Neue', sans-serif; /* Cambiamos a la fuente de LUCO */
    font-size: 18px;
    letter-spacing: 2px;
    text-transform: uppercase;
    
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.hero-social a:hover {
    color: #fff;
    border-color: var(--red); /* El borde se vuelve rojo */
    background: rgba(204, 0, 0, 0.1); /* Fondo rojizo muy suave */
    transform: translateY(-5px) scale(1.05); /* Sube un poco y se agranda */
    
    /* Efecto de brillo (glow) rojo */
    box-shadow: 0 0 20px rgba(204, 0, 0, 0.4);
}

.hero-social svg {
    width: 20px;
    height: 20px;
    fill: currentColor;
    transition: transform 0.4s ease;
}

.hero-social a:hover svg {
    transform: rotate(12deg) scale(1.2); /* El icono gira un poquito al hacer hover */
    fill: var(--red);
}

/* Ajuste para móviles */
@media (max-width: 480px) {
    .hero-social a {
        padding: 8px 18px;
        font-size: 16px;
    }
}

  /* ABOUT */
#about{padding:80px 20px;background:var(--black)}
.about-inner{max-width:700px;margin:0 auto}
.about-inner h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(80px,10vw,90px);line-height:.9;margin-bottom:20px}
.about-inner h2 em{color:var(--red);font-style:normal}
.about-inner p{font-family:'Oswald',sans-serif;font-weight:300;font-size:15px;letter-spacing:1px;color:rgba(212,201,176,.7);line-height:1.9;margin-bottom:14px}
.skull-divider{font-size:24px;margin:20px 0;opacity:.4}

/* PEDIR AHORA */
#pedir{padding:80px 20px;background:var(--smoke);display:none}
#pedir.visible{display:block}
.back-btn{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:3px;background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--cream);padding:10px 20px;cursor:pointer;margin-bottom:32px;display:inline-flex;align-items:center;gap:8px}
.back-btn:hover{border-color:var(--red);color:var(--red)}
.pedir-intro{max-width:1100px;margin:0 auto 40px;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.pedir-chip{display:flex;align-items:center;gap:10px;background:var(--gray);border:1px solid rgba(204,0,0,.25);padding:14px 22px;font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;color:var(--white)}
.pedir-chip span:first-child{font-size:18px}

/* PRÓXIMAMENTE */
.proximamente-banner{max-width:1100px;margin:40px auto 0;background:linear-gradient(135deg,#1a0000,var(--smoke));border:1px solid rgba(204,0,0,.4);padding:32px 28px;position:relative;overflow:hidden}
.proximamente-banner::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(204,0,0,.03) 10px,rgba(204,0,0,.03) 20px)}
.prox-inner{position:relative;z-index:1;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.prox-badge{background:var(--red);font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:4px;color:#fff;padding:6px 16px;animation:pulse 2s infinite;white-space:nowrap}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}
.prox-text h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(22px,4vw,44px);letter-spacing:3px;color:var(--white);line-height:1}
.prox-text p{font-family:'Oswald',sans-serif;font-weight:300;font-size:13px;letter-spacing:1px;color:rgba(212,201,176,.6);margin-top:8px}
.prox-icon{font-size:48px}

/* SECTION HEADER */
.section-header{text-align:center;margin-bottom:48px}
.section-eyebrow{font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:6px;color:var(--red);text-transform:uppercase;display:block;margin-bottom:10px}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(42px,8vw,80px);line-height:.9;color:var(--white)}
.section-title::after{content:'';display:block;height:3px;background:linear-gradient(90deg,var(--red),transparent);margin-top:10px}

/* TABS */
.category-tabs{display:flex;gap:0;flex-wrap:nowrap;overflow-x:auto;margin-bottom:40px;border-bottom:2px solid var(--gray);-webkit-overflow-scrolling:touch;scrollbar-width:none;-webkit-overflow-scrolling: touch;}
.category-tabs::-webkit-scrollbar{display:none}
.tab-btn{font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:2px;padding:14px 22px;background:none;border:none;color:rgba(240,236,224,.4);cursor:pointer;transition:color .2s;white-space:nowrap;position:relative;flex-shrink:0}
.tab-btn.active,.tab-btn:hover{color:var(--white)}
.tab-btn.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--red)}

/* MENU GRID */
.menu-category{display:none}
.menu-category.active{display:block}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;max-width:1100px;margin:0 auto}
.menu-card{background:var(--deep);border:1px solid rgba(255,255,255,.06);padding:20px;cursor:pointer;transition:all .25s}
.menu-card:hover{border-color:rgba(204,0,0,.4);transform:translateY(-3px)}
.menu-card.in-cart{border-color:var(--red)}
.card-name{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:2px;margin-bottom:6px}
.card-desc{font-size:12px;color:rgba(212,201,176,.6);line-height:1.6;margin-bottom:16px;font-family:'Oswald',sans-serif;font-weight:300}
.card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}
.price{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--red)}
.add-btn{width:40px;height:40px;background:var(--red);border:none;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.add-btn:hover{background:var(--red-hot)}
.size-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.size-chip{font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:2px;padding:5px 12px;border:1px solid var(--gray);background:none;color:var(--cream);cursor:pointer;transition:all .2s;text-transform:uppercase}
.size-chip.selected{border-color:var(--red);color:var(--red);background:rgba(204,0,0,.08)}
.item-tag{font-family:'Bebas Neue';font-size:11px;letter-spacing:3px;color:var(--red);margin-bottom:6px}

/* PRÓXIMAMENTE BANNER */
.prox-banner{max-width:1100px;margin:40px auto 0;background:linear-gradient(135deg,#1a0000,var(--smoke));border:1px solid rgba(204,0,0,.4);padding:28px 24px}
.prox-badge{display:inline-block;background:var(--red);font-family:'Bebas Neue',sans-serif;font-size:12px;letter-spacing:4px;color:#fff;padding:6px 16px;margin-bottom:12px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}
.prox-banner h3{font-family:'Bebas Neue',sans-serif;font-size:clamp(22px,4vw,40px);letter-spacing:3px;line-height:1;margin-bottom:8px}
.prox-banner p{font-family:'Oswald',sans-serif;font-weight:300;font-size:13px;color:rgba(212,201,176,.6);letter-spacing:1px}

/* FRANQUICIA */
#franquicia{padding:80px 20px;background:var(--black)}
.franchise-inner{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.franchise-left h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,7vw,72px);line-height:.9;margin-bottom:20px}
.franchise-left h2 em{color:var(--red);font-style:normal}
.franchise-left p{font-family:'Oswald',sans-serif;font-weight:300;font-size:14px;letter-spacing:1px;color:rgba(212,201,176,.7);line-height:1.9;margin-bottom:12px}
.perks{margin-top:28px;display:flex;flex-direction:column;gap:16px}
.perk{display:flex;align-items:flex-start;gap:14px}
.perk-icon{font-size:24px;flex-shrink:0}
.perk strong{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px;display:block}
.perk span{font-family:'Oswald',sans-serif;font-weight:300;font-size:12px;letter-spacing:1px;color:rgba(212,201,176,.5)}
.franchise-form{background:var(--smoke);border:1px solid rgba(255,255,255,.06);padding:32px 24px}
.form-title{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:3px;margin-bottom:6px}
.form-sub{font-family:'Oswald',sans-serif;font-weight:300;font-size:12px;letter-spacing:2px;color:rgba(212,201,176,.4);margin-bottom:28px}
.form-group{margin-bottom:16px}
.form-label{display:block;font-family:'Oswald',sans-serif;font-size:10px;letter-spacing:3px;color:rgba(212,201,176,.4);text-transform:uppercase;margin-bottom:6px}
.form-input,.form-select,.form-textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--gray);color:var(--white);padding:12px 14px;font-family:'Special Elite',cursive;font-size:14px;outline:none;transition:border-color .2s;border-radius:0}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--red)}
.form-input::placeholder,.form-textarea::placeholder{color:rgba(240,236,224,.2)}
.form-select{font-family:'Oswald',sans-serif;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23cc0000' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-color:rgba(255,255,255,.04)}
.form-select option{background:#1a1a1a;color:var(--white)}
.form-textarea{resize:none;height:90px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.franchise-submit-btn{width:100%;margin-top:8px;padding:18px;background:var(--red);border:none;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:4px;cursor:pointer;transition:all .25s}
.franchise-submit-btn:hover{background:var(--red-hot)}
.form-success{display:none;text-align:center;padding:40px 20px}
.form-success-icon{font-size:48px;margin-bottom:14px}
.form-success h3{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:3px;color:var(--red);margin-bottom:10px}
.form-success p{font-family:'Oswald',sans-serif;font-weight:300;font-size:13px;letter-spacing:2px;color:rgba(212,201,176,.6);line-height:1.8}

/* CART BAR */
.cart-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(10, 10, 10, .97);
  border-top: 2px solid var(--red);
  padding: 12px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 200;
  
  /* Esto la oculta bajo la pantalla */
  transform: translateY(100%); 
  visibility: hidden; /* Evita que se pueda clickear si está oculta */
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), visibility 0.4s;
  backdrop-filter: blur(10px);
  padding-bottom: calc(12px + env(safe-area-inset-bottom));
}

/* Cuando tiene la clase .visible se muestra */
.cart-bar.visible {
  transform: translateY(0);
  visibility: visible;
}
.cart-info{display:flex;align-items:center;gap:14px}
.cart-icon{font-size:24px;position:relative;display: inline-block;
  transition: transform 0.2s;}
.cart-badge{position:absolute;top:-6px;right:-6px;background:var(--red);color:#fff;width:18px;height:18px;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-weight:700}
.cart-summary{font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2px;color:var(--cream)}
.cart-total{font-family:'Bebas Neue',sans-serif;font-size:26px;color:var(--white)}
.cart-actions{display:flex;gap:8px}
.view-cart-btn{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;padding:10px 20px;border:1px solid var(--red);background:transparent;color:var(--red);cursor:pointer;transition:all .2s}
.checkout-btn{font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;padding:10px 20px;background:var(--red);border:none;color:#fff;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}
.checkout-btn:hover{background:var(--red-hot)}
.cart-bounce {
  animation: bounce 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes bounce {
  0% { transform: scale(1); }
  50% { transform: scale(1.4); }
  100% { transform: scale(1); }
}
/* CART MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;display:none;align-items:flex-end;justify-content:flex-end}
.modal-overlay.open{display:flex}
.cart-modal{background:var(--smoke);border-left:1px solid var(--gray);border-top:3px solid var(--red);width:100%;max-width:440px;height: 100%; /* Mejor que 100vh en móviles */
  height: -webkit-fill-available;;overflow-y:auto;padding:32px 24px;animation:slideIn .4s cubic-bezier(.16,1,.3,1);padding-bottom: env(safe-area-inset-bottom);}
@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:3px}
.close-btn{background:none;border:1px solid var(--gray);color:var(--white);width:36px;height:36px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:border-color .2s}
.close-btn:hover{border-color:var(--red);color:var(--red)}
.cart-item{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--gray);gap:12px}
.cart-item-name{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:2px}
.cart-item-variant{font-family:'Oswald',sans-serif;font-size:10px;letter-spacing:2px;color:rgba(212,201,176,.4);margin-top:3px}
.cart-item-price{font-family:'Bebas Neue',sans-serif;font-size:20px;color:var(--red);white-space:nowrap}
.qty-ctrl{display:flex;align-items:center;gap:10px}
.qty-btn{width:28px;height:28px;background:var(--gray);border:none;color:var(--white);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.qty-btn:hover{background:var(--red)}
.qty-num{font-family:'Bebas Neue',sans-serif;font-size:20px;min-width:20px;text-align:center}
.cart-empty{text-align:center;padding:50px 20px;opacity:.4}
.cart-empty-icon{font-size:40px;margin-bottom:12px}
.cart-empty p{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:3px}
.cart-subtotal{margin-top:28px;padding-top:20px;border-top:1px solid var(--gray)}
.subtotal-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}
.subtotal-label{font-family:'Oswald',sans-serif;font-size:12px;letter-spacing:3px;color:rgba(212,201,176,.5)}
.subtotal-value{font-family:'Bebas Neue',sans-serif;font-size:32px;color:var(--white)}
.note-field{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--gray);color:var(--white);padding:12px 14px;font-family:'Special Elite',cursive;font-size:13px;outline:none;transition:border-color .2s;resize:none;height:70px;border-radius:0;margin-bottom:16px}
.note-field:focus{border-color:var(--red)}
.note-field::placeholder{color:rgba(240,236,224,.2)}
.whatsapp-order-btn{width:100%;padding:18px;background:#25D366;border:none;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s}
.whatsapp-order-btn:hover{background:#1db954}
.form-input, .form-select, .form-textarea, .note-field {
  font-size: 16px !important; /* iPhone requiere 16px mínimo para no hacer zoom */
}
/* TOAST */
.toast{position:fixed;top:20px;right:16px;z-index:500;background:var(--smoke);border-left:4px solid var(--red);padding:14px 20px;display:flex;align-items:center;gap:10px;transform:translateX(120%);transition:transform .4s;box-shadow:0 8px 32px rgba(0,0,0,.5);min-width:220px}
.toast.show{transform:translateX(0)}
.toast-name{font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:2px}
.toast-sub{font-family:'Oswald',sans-serif;font-size:11px;color:rgba(212,201,176,.5);letter-spacing:1px}

/* WHATSAPP FLOAT */
#luco-cta {
  position: fixed;
  bottom: 25px;
  right: 25px;
  z-index: 999;
  transition: transform 0.3s ease, opacity 0.3s ease;
  bottom: calc(25px + env(safe-area-inset-bottom));
}

/* Ocultar si el carrito está visible para no tapar */
body:has(.cart-bar.visible) #luco-cta {
  transform: translateY(-80px);
}

#cta-btn {
  display: flex;
  align-items: center;
  gap: 15px;
  background: var(--black);
  border: 2px solid var(--red);
  padding: 8px 8px 8px 20px;
  border-radius: 50px;
  text-decoration: none;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5), 0 0 15px rgba(204,0,0,0.2);
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

#cta-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 15px 40px rgba(0,0,0,0.6), 0 0 25px rgba(204,0,0,0.4);
}

.cta-content {
  display: flex;
  flex-direction: column;
}

#cta-status {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--red);
  font-weight: 700;
}

#cta-text {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 18px;
  letter-spacing: 1px;
  color: var(--white);
}

.cta-icon {
  width: 45px;
  height: 45px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: pulse-green 2s infinite;
}

.cta-icon svg {
  width: 25px;
  height: 25px;
}

@keyframes pulse-green {
  0% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0.7); }
  70% { box-shadow: 0 0 0 12px rgba(37, 211, 102, 0); }
  100% { box-shadow: 0 0 0 0 rgba(37, 211, 102, 0); }
}

/* Estado Cerrado */
#cta-btn.is-closed {
  border-color: #555;
  opacity: 0.9;
}
#cta-btn.is-closed #cta-status { color: #aaa; }
#cta-btn.is-closed .cta-icon { 
  background: #555; 
  animation: none;
}
@media (max-width: 640px) {
  #luco-cta { right: 15px; bottom: 20px; }
  #cta-text { font-size: 16px; }
  .cta-content { display: none; } /* Opcional: en móvil muy pequeño solo icono */
}

/* Si quieres que se vea el texto en móvil también, borra la línea de arriba */
@media (max-width: 480px) {
    .cta-content { display: flex; }
    #cta-text { font-size: 14px; }
}

footer {
    background: #050505;
    border-top: 2px solid rgba(204, 0, 0, 0.2);
    padding: 60px 20px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.footer-logo {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 50px;
    letter-spacing: 12px;
    color: rgba(240, 236, 224, 0.12);
    margin-bottom: 25px; /* Espacio debajo del logo LUCO */
}

.footer-content {
    display: flex;
    flex-direction: column;
    gap: 12px; /* Espacio entre el Insta y la Dirección */
}

.footer-row {
    font-family: 'Oswald', sans-serif;
    font-weight: 300;
    font-size: 13px;
    letter-spacing: 2px;
    color: rgba(212, 201, 176, 0.5);
}

.footer-link {
    color: inherit;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-link:hover {
    color: var(--red);
}

.rock-tag {
    margin-top: 5px;
    color: var(--red); /* Resalta el Rock & Burgers en rojo */
    font-weight: 700;
    opacity: 0.8;
}
/* ESTILO MEJORADO PARA INSTAGRAM EN FOOTER */
.ig-row {
    margin-bottom: 5px; /* Ajusta el espacio con la dirección */
}

.ig-footer-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: rgba(212, 201, 176, 0.6); /* Color crema suave por defecto */
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.ig-footer-link span {
    font-family: 'Bebas Neue', sans-serif;
    font-size: 20px; /* Más grande y con la fuente de la marca */
    letter-spacing: 2px;
}

.ig-footer-icon {
    width: 18px;
    height: 18px;
    fill: currentColor;
    transition: transform 0.3s ease;
}

/* EFECTO HOVER */
.ig-footer-link:hover {
    color: var(--red); /* Cambia al rojo de LUCO */
    transform: scale(1.05);
    text-shadow: 0 0 10px rgba(204, 0, 0, 0.5); /* Resplandor rojo */
}

.ig-footer-link:hover .ig-footer-icon {
    transform: rotate(10deg); /* El icono gira un poquito */
}

/* MOBILE */
@media(max-width:640px){
  .nav-links a:not(.pedir-btn){display:none}
  .hero-cta{flex-direction:column;align-items:center}
  .btn-main{width:100%;max-width:280px;text-align:center}
  .franchise-inner{grid-template-columns:1fr;gap:40px}
  .form-row{grid-template-columns:1fr}
  .cart-bar{padding:10px 14px}
  .cart-actions{flex-direction:column;gap:6px}
  .view-cart-btn,.checkout-btn{padding:8px 16px;font-size:13px}
  .cart-modal{max-width:100%;padding-bottom: env(safe-area-inset-bottom); }
  #about,.franchise-left,.franchise-form{padding-left:0;padding-right:0}
  .menu-grid{grid-template-columns:1fr}
  .category-tabs{padding-bottom:4px}
  .prox-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .pedir-chip{width:100%;justify-content:flex-start}
}
@media (max-width: 480px) {
  /* Títulos un poco más pequeños para que no se corten */
  .logo-text {
    font-size: 80px;
    letter-spacing: 5px;
  }
  
  /* Margen lateral para que respire la app */
  section {
    padding-left: 15px;
    padding-right: 15px;
  }

  /* Tarjetas de menú más compactas */
  .menu-card {
    padding: 15px;
  }

  /* Botón de pedir más grande para pulgares */
  .add-btn {
    width: 45px;
    height: 45px;
  }
}
@media(max-width:400px){
  .logo-text{font-size:64px;letter-spacing:10px}
  .tab-btn{font-size:14px;padding:12px 14px}
}

.cta-strip {
  margin: 40px auto;
  max-width: 1100px;
  padding: 20px 25px;
  border: 1px solid rgba(255,0,0,0.4);
  background: linear-gradient(135deg, #0a0a0a, #1a0000);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  border-radius: 8px;
  position: relative;
  overflow: hidden;
}

/* Glow animado */
.cta-strip::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,0,0,0.3), transparent);
  animation: glowMove 3s infinite;
}

@keyframes glowMove {
  0% { left: -100%; }
  100% { left: 100%; }
}

.cta-text {
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  letter-spacing: 0.5px;
}

.cta-btn {
  background: #ff0000;
  color: #fff;
  padding: 12px 22px;
  font-weight: bold;
  text-decoration: none;
  border-radius: 6px;
  transition: all 0.3s ease;
  font-family: 'Oswald', sans-serif;
}

.cta-btn:hover {
  background: #ff2a2a;
  transform: scale(1.05);
  box-shadow: 0 0 15px rgba(255,0,0,0.6);
}

/* Responsive */
@media (max-width: 768px) {
  .cta-strip {
    flex-direction: column;
    text-align: center;
  }

  .cta-btn {
    width: 100%;
  }
}
