/* =========================
   Variables generales / base
========================= */
:root{
  --turquoise:#0FB5B3; --terracotta:#C15A3A; --gold:#C39A33;
  --ivory:#F6F2E9; --charcoal:#222222; --text:#222222; --muted:#6b7280;
  --maxw:1200px; --radius-xl:22px;
  --shadow-md:0 10px 25px rgba(0,0,0,.12); --shadow-sm:0 6px 16px rgba(0,0,0,.10);
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--ivory)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(100%,var(--maxw));margin:0 auto;padding:0 24px}

/* =========================
   Header / Nav
========================= */
header{position:sticky;top:0;z-index:50;background:rgba(246,242,233,.78);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;height:100px}
.brand{display:flex;align-items:center;gap:12px}
.brand-title{font-weight:800;letter-spacing:.5px}
.logo-img{width:90px;height:90px;border-radius:10px;object-fit:contain;box-shadow:var(--shadow-sm);display:block}

nav ul{list-style:none;display:flex;gap:24px;margin:0;padding:0}
nav a{font-weight:700;padding:12px 16px;border-radius:10px;font-size:25px}
nav a:hover{background:#fff;box-shadow:var(--shadow-sm)}

/* Botón hamburguesa (por si activas overlay en el futuro) */
.hamburger{display:none;border:0;background:transparent;width:44px;height:44px;border-radius:10px}
.hamburger:focus{outline:3px solid rgba(15,181,179,.35)}
.hamburger svg{width:26px;height:26px}

/* Menú overlay móvil (OCULTO por defecto) */
.mobile-menu{display:none;} /* desktop/tablet y móvil: oculto hasta que tenga .open */
.mobile-menu.open{display:block;}

/* =========================
   Hero con imagen de fondo CAMBIA FOTO DE PORTADA
========================= */
.hero{position:relative;isolation:isolate}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;background:url('/fotos/barcomarinero.png') center/cover no-repeat;filter:brightness(.72)}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(60% 60% at 30% 20%, rgba(12,181,179,.25), transparent 60%), radial-gradient(40% 40% at 80% 10%, rgba(195,154,51,.18), transparent 60%)}
.hero-inner{padding:100px 0 78px;color:#fff;text-align:center}
.hero h1{font-family:'Marcellus',serif;font-size:clamp(36px,6vw,64px);line-height:1.08;margin:0 0 16px}
.hero p{font-size:clamp(16px,2.6vw,20px);max-width:820px;margin:0 auto 28px;opacity:.98}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* Botones */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 20px;border-radius:999px;font-weight:700;border:0;cursor:pointer;transition:transform .08s ease, box-shadow .2s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(135deg,var(--turquoise),#14d1cf);color:#fff;box-shadow:var(--shadow-sm)}
.btn-outline{border:2px solid var(--turquoise);color:var(--charcoal);background:transparent}

/* Secciones y tarjetas */
section{padding:72px 0}
.section-title{font-family:'Marcellus',serif;font-size:clamp(28px,4.5vw,40px);margin:0 0 10px;text-align:center;color:var(--charcoal)}
.section-sub{text-align:center;color:var(--muted);margin:0 auto 36px;max-width:700px}
.center{text-align:center;margin-top:28px}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}

.menu-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.card{grid-column:span 12;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;min-height:260px}
.card img{width:100%;height:100%;object-fit:cover}
.card-body{padding:22px;display:flex;flex-direction:column;justify-content:center;gap:10px}
.chip{display:inline-flex;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;background:#F2FBFB;color:var(--turquoise);border:1px solid rgba(15,181,179,.25)}
.card h3{margin:4px 0;font-size:22px}
.price{font-weight:700;color:var(--terracotta)}

/* About & Gallery */
.about{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center}
.about .picture{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md)}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.gallery a{grid-column:span 4;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}
.gallery img{aspect-ratio:4/3;object-fit:cover;transition:transform .35s ease}
.gallery a:hover img{transform:scale(1.06)}

/* Contacto */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:24px}
.map{border:0;width:100%;height:350px;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}

/* Footer */
footer{background:#111;color:#ddd;padding:40px 0;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.footer-grid h5{color:#fff;margin:0 0 14px;font-family:'Marcellus',serif}
.footer-grid a{color:#ddd}
.copy{text-align:center;margin-top:18px;color:#bdbdbd;font-size:14px}

/* Botones flotantes */
.whatsapp{position:fixed;right:18px;bottom:78px;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;background:#25D366;color:white;font-weight:900;box-shadow:var(--shadow-md);z-index:60}
.order-now{position:fixed;left:12px;top:50%;transform:translateY(-50%);z-index:110;writing-mode:vertical-rl;rotate:180deg;background:var(--terracotta);color:#fff;border:0;border-radius:14px;padding:14px 10px;font-weight:800;letter-spacing:.6px;box-shadow:var(--shadow-md);cursor:pointer}
.order-now:hover{filter:brightness(1.05)}
.to-top{position:fixed;left:18px;bottom:78px;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--turquoise);color:white;font-weight:900;box-shadow:var(--shadow-md);z-index:60;opacity:0;pointer-events:none;transition:opacity .2s ease}
.to-top.show{opacity:1;pointer-events:auto}

/* Barra de acciones móvil (Call/WA/Directions) */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:70;background:#fff;border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -10px 20px rgba(0,0,0,.08);display:none}
.mobile-cta .inner{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px 12px;max-width:var(--maxw);margin:0 auto}
.mobile-cta a{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:12px 10px;font-weight:700;box-shadow:var(--shadow-sm)}
.cta-call{background:var(--turquoise);color:#fff}
.cta-wa{background:#25D366;color:#fff}
.cta-map{background:var(--gold);color:#111}

/* =========================
   Responsive
========================= */
@media (max-width:1024px){
  .card{grid-template-columns:1fr}
  .about{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

/* =========================================================
   MENÚ MÓVIL ORIGINAL (OCULTO) + BACKDROP PARA CLIC FUERA
   - Desktop/Tablet: menú normal visible
   - Móvil: se oculta la lista desktop y usamos menú desplegable
========================================================= */

/* Estado base (desktop/tablet): nav normal visible, móvil oculto */
.mobile-menu{ display:none; }
.menu-backdrop{ display:none; }

@media (max-width: 720px){

  /* Oculta la lista de enlaces de desktop en móvil */
  nav ul{ display:none; }

  /* Muestra el botón hamburguesa solo en móvil */
  .hamburger{ display:inline-grid; place-items:center; }

  /* Header fijo y con z-index alto para que el menú se monte encima */
  header{ position: sticky; top:0; z-index: 80; }

  /* Menú móvil: panel bajo el header */
  .mobile-menu{
    position: absolute;
    left: 0; right: 0; top: 100%;
    background: #fff;
    border-bottom: 1px solid rgba(0,0,0,.06);
    box-shadow: 0 16px 40px rgba(0,0,0,.12);
    padding: 10px 14px 14px;
    display: none;                 /* 🔒 Oculto por defecto */
  }
  .mobile-menu a{
    display:block;
    font-weight:700;
    padding: 12px 14px;
    margin-top: 8px;
    border-radius: 12px;
    border: 2px solid var(--turquoise);
    background: #fff;
  }
  .mobile-menu.open{ display:block; }  /* ✅ Se muestra al abrir */

  /* Backdrop: capa detrás del menú para cerrar al tocar fuera */
  .menu-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.25);
    display: none;
    z-index: 70; /* Por debajo del header/menu (80) */
  }
  .menu-backdrop.show{ display:block; }

  /* Ajustes de altura en móvil */
  .container.nav{
    height: 72px;
    padding: 8px 12px;
  }
  .logo-img{ width: 56px; height: 56px; }
  .brand-title{ font-size: 20px; font-weight: 800; }
}

/* ============================
   MENÚ MÓVIL CON ANIMACIÓN
============================ */
.mobile-menu{ display:none; }
.menu-backdrop{ display:none; }

@media (max-width:720px){
  nav ul{ display:none; } /* ocultar menú desktop en móvil */
  .hamburger{ display:inline-grid; }

  .mobile-menu{
    position:absolute;
    top:100%; left:0; right:0;
    background:#fff;
    box-shadow:0 10px 25px rgba(0,0,0,.15);
    border-bottom:1px solid #eee;
    overflow:hidden;

    /* Animación */
    max-height:0;
    opacity:0;
    display:block;          /* siempre presente, pero colapsado */
    transition:max-height .4s ease, opacity .3s ease;
  }
  .mobile-menu.open{
    max-height:500px;       /* ajusta según cantidad de links */
    opacity:1;
  }
  .mobile-menu a{
    display:block;
    padding:14px 18px;
    border-bottom:1px solid #eee;
    font-weight:700;
    color:#222;
  }

  /* Fondo oscuro detrás */
  .menu-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.4);
    z-index:50;
    opacity:0;
    transition:opacity .3s ease;
  }
  .menu-backdrop.show{ display:block; opacity:1; }
}

/* ===============================
   Barra inferior solo para móviles (corregida)
   =============================== */
.mobile-bottom-bar {
  display: none; /* Oculto en pantallas grandes */
}

@media (max-width: 768px) {
  .mobile-bottom-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #0FB5B3;
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding: 12px 0;
    z-index: 10000; /* por encima del contenido pero debajo del menú */
    box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.2);
    border-top: 2px solid #fff;
  }

  .mobile-btn {
    flex: 1;
    text-align: center;
    color: #fff;
    font-weight: 600;
    text-decoration: none;
    font-size: 15px;
    padding: 10px 0;
    border-radius: 4px;
    margin: 0 5px;
    transition: background 0.3s;
  }

  /* Colores individuales */
  .mobile-btn.call { background-color: #009688; }
  .mobile-btn.whatsapp { background-color: #25D366; }
  .mobile-btn.map { background-color: #FFB300; }

  .mobile-btn:hover {
    opacity: 0.85;
  }

  /* Espacio para que no tape contenido */
  body {
    padding-bottom: 70px;
  }
}



/* =========================
   Animaciones de entrada
========================= */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.on{opacity:1;transform:none}
