/* ════════════════════════════════════════════════════════════
   Café CMV  ·  style.css
   Paleta: Slate · Crema · Carbón · Gris
   ════════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
    --brand:        #404E50;   /* Slate teal principal */
    --brand-mid:    #5A6E70;   /* Slate medio */
    --brand-light:  #6B8285;   /* Slate claro */
    --acento:       #D8D5CA;   /* Crema/beige — accent */
    --acento-claro: #EAE7DE;   /* Crema claro */
    --crema:        #F4F2EE;   /* Blanco cálido */
    --arena:        #EDE9E0;   /* Arena/beige */
    --carbon:       #1B2020;   /* Negro profundo */
    --texto:        #1B2020;
    --texto-suave:  #858781;   /* Gris complementario */
    --gris-medio:   #AAAAA2;   /* Gris claro */
    --borde:        #D5D2C9;
    --sombra-s:     0 2px 12px rgba(27,32,32,.07);
    --sombra-m:     0 8px 32px rgba(27,32,32,.11);
    --sombra-l:     0 20px 60px rgba(27,32,32,.16);
    --radio:        16px;
    --radio-sm:     8px;
    --trans:        .3s cubic-bezier(.4,0,.2,1);
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
    font-family: 'Inter', system-ui, sans-serif;
    background: #fff;
    color: var(--texto);
    line-height: 1.65;
    overflow-x: hidden;
}
img  { max-width: 100%; display: block; }
a    { text-decoration: none; color: inherit; }
ul   { list-style: none; }

/* ── Typography ─────────────────────────────────────────────── */
h1,h2,h3,h4 { font-family:'Playfair Display',serif; line-height:1.2; }
em { font-style:italic; color:var(--carbon); }

.section-tag {
    display: inline-block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--brand);
    margin-bottom: 10px;
}
.section-title  { font-size: clamp(1.9rem,4vw,2.9rem); color:var(--carbon); margin-bottom:12px; }
.section-desc   { font-size:1.02rem; color:var(--texto-suave); max-width:560px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:56px; }
.section        { padding:96px 0; }

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ── Buttons ────────────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 13px 30px;
    border-radius: 50px;
    font-family: 'Inter', sans-serif;
    font-size: .9rem;
    font-weight: 600;
    letter-spacing: .02em;
    border: none;
    cursor: pointer;
    transition: var(--trans);
    white-space: nowrap;
}
.btn-primary {
    background: #fff;
    color: var(--carbon);
    border: 1.5px solid rgba(64,78,80,.18);
    box-shadow: 0 4px 20px rgba(0,0,0,.18);
}
.btn-primary:hover { background:var(--acento); color:var(--carbon); border-color:transparent; transform:translateY(-2px); box-shadow:0 8px 28px rgba(0,0,0,.22); }

.btn-glass {
    background: rgba(255,255,255,.15);
    color: #fff;
    border: 1.5px solid rgba(255,255,255,.5);
    backdrop-filter: blur(8px);
}
.btn-glass:hover { background:rgba(255,255,255,.25); }

.btn-outline-brand {
    background: transparent;
    color: var(--brand);
    border: 2px solid var(--brand);
}
.btn-outline-brand:hover { background:var(--brand); color:#fff; }

.btn-full { width:100%; justify-content:center; }

/* ══════════════════════════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════════════════════════ */
.navbar {
    position: fixed; top:0; left:0; right:0; z-index:1000;
    padding: 16px 0;
    transition: var(--trans);
}
.navbar.scrolled {
    background: rgba(244,242,238,.97);
    backdrop-filter: blur(14px);
    padding: 10px 0;
    box-shadow: 0 1px 20px rgba(64,78,80,.1);
}

.nav-container {
    max-width:1200px; margin:0 auto; padding:0 24px;
    display:flex; align-items:center; justify-content:space-between;
}

.nav-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.nav-logo-name {
    font-family:'Playfair Display', serif;
    font-size:1.15rem; font-weight:700;
    color:#fff;
    letter-spacing:.01em;
    transition:var(--trans);
    text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.navbar.scrolled .nav-logo-name { color:var(--carbon); text-shadow:none; }
.logo-img {
    transition: var(--trans);
    height: 54px;
    width: auto;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,.35));
}
.navbar.scrolled .logo-img {
    filter: drop-shadow(0 1px 4px rgba(0,0,0,.15));
}

.nav-links {
    display:flex; align-items:center; gap:28px;
    list-style:none;
}
.nav-links a {
    font-size:.875rem; font-weight:600; letter-spacing:.03em;
    color:rgba(255,255,255,.88);
    position:relative; transition:var(--trans);
}
.navbar.scrolled .nav-links a { color:var(--texto-suave); }

.nav-links a::after {
    content:''; position:absolute; bottom:-4px; left:0;
    width:0; height:2px; background:var(--brand); transition:var(--trans);
}
.nav-links a:hover::after, .nav-links a.active-link::after { width:100%; }
.nav-links a:hover { color:rgba(255,255,255,1); }
.navbar.scrolled .nav-links a:hover { color:var(--brand); }

.nav-cta {
    padding:9px 22px !important;
    background: var(--acento) !important;
    color: var(--carbon) !important;
    border-radius:50px;
    box-shadow:0 4px 12px rgba(216,213,202,.4);
    font-weight: 700 !important;
}
.nav-cta:hover { background: var(--acento-claro) !important; color: var(--carbon) !important; }
.nav-cta::after { display:none !important; }

.nav-toggle {
    display:none; flex-direction:column; gap:5px;
    background:none; border:none; cursor:pointer; padding:4px;
}
.nav-toggle span {
    display:block; width:23px; height:2px;
    background:#fff; border-radius:2px; transition:var(--trans);
}
.navbar.scrolled .nav-toggle span { background:var(--carbon); }

/* ══════════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════════ */
.hero {
    min-height: 100svh;
    display: flex; flex-direction:column;
    align-items:center; justify-content:center;
    position: relative;
    text-align: center;
    padding: 120px 24px 80px;
    background:
        linear-gradient(160deg, var(--carbon) 0%, var(--brand) 55%, var(--brand-mid) 100%);
    overflow: hidden;
}

.hero::before {
    content:'';
    position:absolute; inset:0;
    background-image:
        radial-gradient(circle at 15% 25%, rgba(216,213,202,.08) 0%, transparent 50%),
        radial-gradient(circle at 85% 75%, rgba(90,110,112,.12) 0%, transparent 50%);
}

.hero::after {
    content:'CMV';
    position:absolute; bottom:-60px; right:-30px;
    font-family:'Playfair Display',serif;
    font-size:clamp(160px,30vw,320px);
    font-weight:700;
    color:rgba(255,255,255,.025);
    line-height:1;
    pointer-events:none; user-select:none;
}

.hero-content { position:relative; z-index:2; max-width:780px; }

.hero-tag {
    display:inline-block;
    font-size:.75rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
    color:var(--acento-claro);
    border:1px solid rgba(216,213,202,.4);
    background:rgba(216,213,202,.1);
    padding:6px 18px; border-radius:50px;
    margin-bottom:24px;
}

.hero-title {
    font-size:clamp(2.8rem,6.5vw,5.2rem);
    color:#fff; margin-bottom:20px;
    text-shadow:0 4px 30px rgba(0,0,0,.25);
}
.hero-title em { color:var(--acento-claro); font-style:italic; }

.hero-subtitle {
    font-size:1.1rem; color:rgba(255,255,255,.75);
    max-width:520px; margin:0 auto 40px;
}

.hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:48px; }

.hero-chips {
    display:flex; gap:0; justify-content:center;
    flex-wrap:wrap; align-items:center;
}
.chip {
    font-size:.78rem; font-weight:500;
    color:rgba(255,255,255,.65);
    padding:4px 18px;
    display:flex; align-items:center; gap:6px;
    border-left:1px solid rgba(255,255,255,.2);
}
.chip:first-child { border-left:none; padding-left:4px; }

.hero-scroll {
    position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
    display:flex; flex-direction:column; align-items:center; gap:6px;
    color:rgba(255,255,255,.45); font-size:.72rem; letter-spacing:.12em;
    text-transform:uppercase; z-index:2;
}
.scroll-arrow {
    width:20px; height:20px;
    border-right:2px solid rgba(255,255,255,.4);
    border-bottom:2px solid rgba(255,255,255,.4);
    transform:rotate(45deg);
    animation:bounce 2s infinite;
}
@keyframes bounce { 0%,100%{transform:rotate(45deg) translateY(0)} 50%{transform:rotate(45deg) translateY(6px)} }

/* ══════════════════════════════════════════════════════════════
   STRIP ANIMADO
══════════════════════════════════════════════════════════════ */
.strip { background:var(--brand); padding:18px 0; overflow:hidden; }

.strip-track {
    display:flex; align-items:center; gap:0;
    width:max-content;
    animation:marquee 30s linear infinite;
}
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

.strip-item {
    white-space:nowrap;
    font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
    color:rgba(255,255,255,.85);
    padding:0 28px;
}
.strip-dot { color:var(--acento); font-size:.6rem; }

/* ══════════════════════════════════════════════════════════════
   NOSOTROS
══════════════════════════════════════════════════════════════ */
.nosotros { background:var(--crema); }

.nosotros-grid {
    display:grid; grid-template-columns:1fr 1fr;
    gap:72px; align-items:center;
}

.nosotros-visual { position:relative; }

.visual-main {
    border-radius:var(--radio);
    overflow:hidden;
    aspect-ratio:4/5;
    display:flex; align-items:center; justify-content:center;
    box-shadow:var(--sombra-l);
}
.brand-bg { background: linear-gradient(135deg, var(--carbon) 0%, var(--brand) 100%); }

.visual-badge {
    position:absolute; bottom:-24px; right:-24px;
    background:#fff;
    border-radius:var(--radio-sm);
    padding:20px 24px;
    box-shadow:var(--sombra-m);
    text-align:center;
}
.visual-badge strong {
    display:block;
    font-family:'Playfair Display',serif;
    font-size:2rem; color:var(--brand);
}
.visual-badge span { font-size:.75rem; color:var(--texto-suave); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }

.nosotros-copy p { color:var(--texto-suave); margin-bottom:16px; }

.stats-row {
    display:flex; gap:0;
    background:#fff; border-radius:var(--radio);
    box-shadow:var(--sombra-s);
    margin:32px 0;
    overflow:hidden;
}
.stat-box {
    flex:1; padding:24px 20px; text-align:center;
    border-right:1px solid var(--borde);
}
.stat-box:last-child { border-right:none; }
.stat-box strong {
    display:block;
    font-family:'Playfair Display',serif;
    font-size:1.7rem; color:var(--brand); margin-bottom:4px;
}
.stat-box span { font-size:.75rem; color:var(--texto-suave); font-weight:600; text-transform:uppercase; letter-spacing:.04em; }

/* ══════════════════════════════════════════════════════════════
   MENÚ
══════════════════════════════════════════════════════════════ */
.menu-section { background:#fff; }

.menu-tabs {
    display:flex; gap:8px; justify-content:center;
    flex-wrap:wrap; margin-bottom:48px;
}
.tab-btn {
    display:flex; align-items:center; gap:6px;
    padding:10px 26px;
    border-radius:50px;
    border:2px solid var(--borde);
    background:#fff;
    color:var(--texto-suave);
    font-family:'Inter',sans-serif;
    font-size:.875rem; font-weight:600;
    cursor:pointer; transition:var(--trans);
}
.tab-btn:hover { border-color:var(--brand-light); color:var(--brand); }
.tab-btn.active {
    background:var(--brand); border-color:var(--brand);
    color:#fff;
    box-shadow:0 4px 14px rgba(64,78,80,.3);
}

.menu-panel {
    display:none;
    grid-template-columns:repeat(2,1fr);
    gap:24px;
}
.menu-panel.active { display:grid; }

.empty-msg { text-align:center; color:var(--texto-suave); grid-column:1/-1; padding:40px; }

.menu-card {
    background:#fff;
    border-radius:var(--radio);
    overflow:hidden;
    box-shadow:0 2px 16px rgba(0,0,0,.07);
    transition:var(--trans);
    display:flex;
    flex-direction:column;
}
.menu-card:hover {
    box-shadow:0 8px 32px rgba(0,0,0,.13);
    transform:translateY(-4px);
}

.mc-img {
    height:240px;
    overflow:hidden;
    flex-shrink:0;
    position:relative;
}
.mc-img img { width:100%; height:100%; object-fit:cover; display:block; }

.mc-body {
    padding:20px 22px 22px;
    display:flex;
    flex-direction:column;
    flex:1;
}

.mc-emoji {
    font-size:3rem;
    text-align:center;
    padding:32px 0 16px;
}

.mc-tag {
    position:absolute; top:12px; right:12px;
    background:rgba(0,0,0,.55); color:#fff;
    backdrop-filter:blur(4px);
    font-size:.62rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase;
    padding:4px 10px; border-radius:50px;
}

.menu-card h3 { font-size:1.08rem; color:var(--carbon); margin-bottom:8px; }
.menu-card p  { font-size:.85rem; color:var(--texto-suave); line-height:1.55; margin-bottom:auto; padding-bottom:16px; flex:1; }
.mc-footer    { margin-top:auto; }

.mc-footer { display:flex; align-items:center; justify-content:space-between; }
.mc-precio {
    font-family:'Playfair Display',serif;
    font-size:1.3rem; font-weight:700; color:var(--brand);
}

.btn-add {
    background:var(--arena);
    border:none;
    padding:7px 16px;
    border-radius:50px;
    font-size:.8rem; font-weight:600;
    color:var(--brand);
    cursor:pointer; transition:var(--trans);
}
.btn-add:hover { background:var(--brand); color:#fff; }

/* ══════════════════════════════════════════════════════════════
   INSTAGRAM FEED
══════════════════════════════════════════════════════════════ */
.ig-section { background:var(--crema); }

.ig-grid {
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:6px;
    margin-bottom:32px;
}

.ig-item {
    aspect-ratio:4/5;
    position:relative;
    overflow:hidden;
    display:block;
    background:var(--arena);
    border-radius:4px;
    text-decoration:none;
}
.ig-item img {
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    transition:transform .4s ease;
}
@media (hover: hover) {
    .ig-item:hover img { transform:scale(1.06); }
    .ig-item:hover .ig-overlay { opacity:1; }
}

.ig-placeholder {
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    font-size:2.8rem;
}

.ig-overlay {
    position:absolute; inset:0;
    background:rgba(27,32,32,.55);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    gap:8px;
    padding:16px;
    opacity:0;
    transition:opacity .25s ease;
}

.ig-icon {
    width:28px; height:28px; fill:#fff;
    filter:drop-shadow(0 1px 4px rgba(0,0,0,.3));
    flex-shrink:0;
}
.ig-caption {
    color:#fff; font-size:.78rem; text-align:center;
    line-height:1.4;
    display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
    overflow:hidden;
}

.ig-cta { text-align:center; }
.ig-follow-btn {
    display:inline-flex; align-items:center; gap:9px;
    padding:13px 28px;
    border-radius:50px;
    border:1.5px solid var(--brand);
    color:var(--brand);
    font-size:.9rem; font-weight:600;
    text-decoration:none;
    transition:var(--trans);
}
.ig-follow-btn:hover {
    background:var(--brand); color:#fff;
}

/* ══════════════════════════════════════════════════════════════
   INFO — HORARIOS / MAPA / CONTACTO
══════════════════════════════════════════════════════════════ */
.info-section { background:var(--carbon); padding:80px 0; }

.info-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }

.info-card {
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.1);
    border-radius:var(--radio);
    padding:36px;
}
.info-center { text-align:center; }

.ic-icon { font-size:2.4rem; margin-bottom:14px; }
.info-card h3 { font-size:1.3rem; color:var(--acento); margin-bottom:18px; }
.info-card p  { color:rgba(255,255,255,.65); font-size:.9rem; margin-bottom:16px; }

.horarios-list { display:flex; flex-direction:column; gap:12px; }
.horarios-list li {
    display:flex; justify-content:space-between; align-items:center;
    font-size:.875rem; padding-bottom:12px;
    border-bottom:1px solid rgba(255,255,255,.08);
}
.horarios-list li:last-child { border-bottom:none; padding-bottom:0; }
.horarios-list span { color:rgba(255,255,255,.55); }
.horarios-list strong { color:var(--acento); font-weight:600; }
.cerrado { color:#f87171 !important; }

.mapa-btn, .mapa-placeholder {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(64,78,80,.3);
    border:1px solid rgba(216,213,202,.3);
    color:var(--acento);
    padding:14px 20px; border-radius:var(--radio-sm);
    font-size:.875rem; font-weight:600;
    cursor:pointer; transition:var(--trans);
    text-decoration:none;
    flex-direction:column;
    width:100%;
    justify-content:center;
}
.mapa-btn:hover { background:rgba(64,78,80,.5); }
.mapa-placeholder small { color:rgba(255,255,255,.45); font-size:.78rem; }

.contact-list { display:flex; flex-direction:column; gap:14px; }
.contact-list li { display:flex; align-items:center; gap:10px; font-size:.875rem; color:rgba(255,255,255,.75); }
.contact-list a:hover { color:var(--acento); }

/* ══════════════════════════════════════════════════════════════
   RESERVACIONES
══════════════════════════════════════════════════════════════ */
.reserva-section {
    background:linear-gradient(135deg, var(--brand) 0%, var(--carbon) 100%);
    padding:100px 0;
    position:relative; overflow:hidden;
}
.reserva-section::before {
    content:'';
    position:absolute; inset:0;
    background:radial-gradient(ellipse 70% 70% at 0% 50%, rgba(216,213,202,.06) 0%, transparent 60%);
}

.reserva-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; z-index:2; }

.reserva-copy { display:flex; flex-direction:column; gap:20px; }

.reserva-card {
    background:#fff;
    border-radius:var(--radio);
    padding:40px;
    box-shadow:var(--sombra-l);
}

/* ── Forms ─────────────────────────────────────────────────── */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-row:has(.fg:nth-child(3)) { grid-template-columns:1fr 1fr 1fr; }

.fg { display:flex; flex-direction:column; gap:5px; margin-bottom:18px; }
.fg label {
    font-size:.72rem; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
    color:var(--texto-suave);
}
.fg input,
.fg select,
.fg textarea {
    width:100%;
    padding:11px 15px;
    border:1.5px solid var(--borde);
    border-radius:var(--radio-sm);
    font-family:'Inter',sans-serif; font-size:.9rem; color:var(--texto);
    background:#fff; outline:none; resize:none;
    transition:var(--trans);
}
.fg input:focus,
.fg select:focus,
.fg textarea:focus {
    border-color:var(--brand);
    box-shadow:0 0 0 3px rgba(64,78,80,.1);
}

/* ── Alerts ────────────────────────────────────────────────── */
.alert {
    padding:14px 18px; border-radius:var(--radio-sm);
    margin-bottom:20px; font-size:.875rem; font-weight:600;
}
.alert-ok  { background:#D1FAE5; color:#065F46; border:1px solid #A7F3D0; }
.alert-err { background:#FEE2E2; color:#991B1B; border:1px solid #FECACA; }

/* ══════════════════════════════════════════════════════════════
   GOOGLE REVIEWS
══════════════════════════════════════════════════════════════ */
.reviews-section { background:var(--crema); }

/* ── Carrusel contenedor ─────────────────────────────────── */
.rv-carousel-outer {
    position:relative;
    padding:0 28px;      /* espacio para las flechas */
}
.rv-track-wrap { overflow:hidden; }
.rv-track {
    display:flex;
    gap:20px;
    will-change:transform;
}
.rv-track .rv-card {
    flex:0 0 calc((100% - 40px) / 3);   /* (ancho - 2 gaps) / 3 visible */
    min-width:0;
}

/* Flechas de navegación */
.rv-arrow {
    position:absolute;
    top:50%; transform:translateY(-60%);
    width:42px; height:42px; border-radius:50%;
    border:2px solid var(--borde);
    background:#fff; cursor:pointer; font-size:22px; font-weight:300;
    display:flex; align-items:center; justify-content:center;
    z-index:2; transition:var(--trans); color:var(--carbon);
    line-height:1; padding:0;
}
.rv-arrow:hover { background:var(--brand); border-color:var(--brand); color:#fff; }
.rv-prev { left:0; }
.rv-next { right:0; }

/* Puntos de posición */
.rv-dots { display:flex; justify-content:center; gap:8px; margin-top:22px; flex-wrap:wrap; }
.rv-dot {
    width:8px; height:8px; border-radius:4px;
    border:none; background:var(--borde); cursor:pointer; padding:0;
    transition:var(--trans);
}
.rv-dot:hover { background:var(--carbon); }
.rv-dot-active { background:var(--brand); width:22px; }

.rv-card {
    background:#fff;
    border-radius:var(--radio);
    padding:24px;
    box-shadow:var(--sombra-s);
    transition:var(--trans);
    display:flex; flex-direction:column; gap:12px;
}
.rv-card:hover { transform:translateY(-3px); box-shadow:var(--sombra-m); }

.rv-header {
    display:flex; align-items:center; gap:10px;
}
.rv-avatar-img {
    width:40px; height:40px; border-radius:50%; object-fit:cover; flex-shrink:0;
}
.rv-avatar-letter {
    width:40px; height:40px; border-radius:50%; flex-shrink:0;
    background:linear-gradient(135deg,var(--brand),var(--brand-mid));
    color:#fff; font-weight:700; font-size:1rem;
    display:flex; align-items:center; justify-content:center;
}
.rv-meta { flex:1; min-width:0; }
.rv-meta strong { display:block; font-size:.88rem; color:var(--carbon); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rv-meta span    { font-size:.75rem; color:var(--texto-suave); }
.rv-google-logo  { width:20px; height:20px; flex-shrink:0; }

.rv-stars { display:flex; gap:2px; }

.rv-texto {
    font-size:.86rem; color:var(--texto-suave);
    font-style:italic; line-height:1.6;
    margin:0;
    flex:1;
}

/* ══════════════════════════════════════════════════════════════
   CONTACTO
══════════════════════════════════════════════════════════════ */
.contacto-section { background:#fff; }

.contacto-wrap {
    max-width:700px; margin:0 auto;
    background:var(--crema);
    border-radius:var(--radio);
    padding:48px;
    box-shadow:var(--sombra-m);
}

.contact-form .form-row { grid-template-columns:1fr 1fr; }

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
.footer { background:var(--carbon); color:rgba(255,255,255,.6); padding:80px 0 0; }

.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,.08); }

.footer-logo-img { filter:brightness(0) invert(1); margin-bottom:16px; }
.footer-brand p  { font-size:.86rem; line-height:1.7; margin-bottom:24px; }

.footer-social { display:flex; gap:10px; }
.footer-social a {
    width:38px; height:38px; border-radius:50%;
    background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
    display:flex; align-items:center; justify-content:center;
    color:#fff; transition:var(--trans);
}
.footer-social a:hover { background:var(--brand); border-color:var(--brand); }

.footer-links h4,
.footer-info h4 {
    font-family:'Inter',sans-serif;
    font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color:#fff; margin-bottom:18px;
}
.footer-links li, .footer-info li { margin-bottom:10px; font-size:.86rem; }
.footer-links a:hover { color:var(--acento); }
.footer-info li { display:flex; gap:8px; align-items:flex-start; }

.footer-bottom {
    display:flex; justify-content:space-between; align-items:center;
    padding:24px 0; font-size:.78rem;
}

/* ══════════════════════════════════════════════════════════════
   WHATSAPP FLOTANTE
══════════════════════════════════════════════════════════════ */
.wa-float {
    position:fixed; bottom:28px; right:28px; z-index:999;
    width:56px; height:56px; border-radius:50%;
    background:#25D366;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 20px rgba(37,211,102,.45);
    transition:var(--trans);
}
.wa-float:hover { transform:scale(1.1); box-shadow:0 10px 30px rgba(37,211,102,.55); }

/* ══════════════════════════════════════════════════════════════
   REVEAL ANIMATION
══════════════════════════════════════════════════════════════ */
.reveal {
    opacity:0;
    transform:translateY(28px);
    transition:opacity .6s ease, transform .6s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media (max-width:1024px) {
    .nosotros-grid    { grid-template-columns:1fr; gap:48px; }
    .visual-badge     { position:static; display:inline-block; margin-top:16px; }
    .menu-panel       { grid-template-columns:repeat(2,1fr); }
    .ig-grid          { grid-template-columns:repeat(3,1fr); }
    .info-grid        { grid-template-columns:1fr; }
    .reserva-grid     { grid-template-columns:1fr; }
    .rv-track .rv-card { flex:0 0 calc((100% - 20px) / 2); }  /* 2 visibles en tablet */
    .footer-grid      { grid-template-columns:1fr 1fr; }
}

@media (max-width:768px) {
    .nav-links {
        display:none; flex-direction:column; gap:0;
        position:absolute; top:100%; left:0; right:0;
        background:rgba(244,242,238,.98);
        backdrop-filter:blur(14px);
        padding:12px 0;
        box-shadow:var(--sombra-m);
    }
    .nav-links.open   { display:flex; }
    .nav-links li     { width:100%; }
    .nav-links a      { display:block; padding:12px 24px; color:var(--texto); }
    .nav-links a:hover{ background:var(--crema); color:var(--brand); }
    .nav-cta          { margin:8px 24px; text-align:center; }
    .nav-toggle       { display:flex; }

    .hero-title    { font-size:2.6rem; }
    .hero-actions  { flex-direction:column; align-items:center; }

    .menu-panel    { grid-template-columns:1fr; }
    .form-row      { grid-template-columns:1fr; }
    .form-row:has(.fg:nth-child(3)) { grid-template-columns:1fr; }
    .nosotros-grid { gap:40px; }

    /* Instagram: 3 columnas cuadradas en móvil, sin overlay */
    .ig-grid       { grid-template-columns:repeat(3,1fr); gap:3px; }
    .ig-item       { aspect-ratio:1; }
    .ig-overlay    { display:none; }

    /* Reviews: 1 visible en móvil */
    .rv-carousel-outer { padding:0 14px; }
    .rv-track .rv-card { flex:0 0 100%; }
    .rv-card       { padding:18px 16px; }
    .rv-texto      { font-size:.83rem; }

    .footer-grid   { grid-template-columns:1fr; gap:32px; }
    .footer-bottom { flex-direction:column; gap:8px; text-align:center; }
    .stats-row     { flex-direction:column; }
    .stat-box      { border-right:none; border-bottom:1px solid var(--borde); }
    .stat-box:last-child { border-bottom:none; }
    .contacto-wrap { padding:32px 20px; }
    .reserva-card  { padding:28px 20px; }
}

@media (max-width:480px) {
    .section    { padding:64px 0; }
    .hero       { padding:100px 16px 60px; }
    .hero-chips { flex-wrap:wrap; gap:4px; }
    .chip { border-left:none; padding:2px 8px; }
    .ig-grid    { grid-template-columns:repeat(3,1fr); gap:2px; }
}
