/* CSS Document */
/* ===== Google Fonts: Playfair Display (Regular) ===== */
@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400&display=swap");
@charset "UTF-8";
/* ===== Reset y variables ===== */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{
  --accent:#f4dda3;          /* puedes mantenerlo (arena) para botones/acordeones */
  --ink:#000;               /* negro principal */
  --muted:#000;             /* FORZADO a negro para que párrafos no queden gris */
  --bg:#ffffff; --white:#ffffff;
  --maxw:1100px; --radius:16px; --header-h:64px; --footer-h:64px;

  /* NUEVOS COLORES DE TITULARES */
  --h2:#0172ac;             /* azul */
  --h3:#4baf00;             /* verde */
}

/* Fuente base */
body{
  font-family:"Century Gothic","CenturyGothic","Avant Garde",Arial,Helvetica,sans-serif;
  color:var(--ink); background:var(--bg); line-height:1.55
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(100% - 32px,var(--maxw));margin-inline:auto}

/* ===== Header & nav ===== */
.site-header{background:var(--white);border-bottom:1px solid #ececec}
.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:700}
.brand-logo{width:46px;height:46px;border-radius:8px;object-fit:contain}

/* Nombre del header con Playfair Display Regular */
.brand span{
  font-family:"Playfair Display", serif;
  font-weight:400;
  letter-spacing:.02em;
}

nav ul{list-style:none;display:flex;gap:1.25rem;padding:0;margin:0}
nav a{padding:.5rem .25rem;border-radius:10px}
nav a:hover,nav a:focus-visible{background:#f4f4f4;outline:none}

/* Top notice (línea superior como en la web) */
.noticebar{
  background:#f7f7f7;
  border-bottom:1px solid #ececec;
  font-size:.95rem;
}
.noticebar .container{
  padding:10px 0;
  text-align:center;
  color:#000;
}
.noticebar a{font-weight:700}

/* Hamburguesa */
.burger{background:transparent;border:0;width:40px;height:40px;display:grid;place-items:center;border-radius:10px}
.burger svg{width:24px;height:24px;stroke:var(--ink);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.burger:focus-visible{outline:2px solid var(--ink);outline-offset:2px}

/* Menú móvil */
.mobile-menu{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--white);
  border-bottom:1px solid #ececec;transform:translateY(-8px);opacity:0;pointer-events:none;
  transition:transform .2s ease,opacity .2s ease}
.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}
.mobile-menu[hidden]{display:none!important}
.mobile-menu ul{list-style:none;padding:8px 16px 12px;margin:0;display:grid;gap:6px}
.mobile-menu a{display:block;padding:12px;border-radius:12px}
.mobile-menu a:hover,.mobile-menu a:focus-visible{background:#f4f4f4;outline:none}

/* ===== Hero ===== */
.hero{position:relative}
.hero-img{width:100%;height:clamp(260px,60vh,520px);object-fit:cover}
.hero-overlay{position:absolute;inset:auto 0 24px 0;display:grid;gap:12px}

/* Títulos con Playfair Display Regular */
h1,h2,h3,.split-title{
  font-family:"Playfair Display", serif;
  font-weight:400;
}

.hero-overlay h1{
  color:#fff;
  font-size:clamp(1.6rem,1rem + 2.2vw,2.8rem);
  margin:0;
  text-shadow:0 6px 22px rgba(0,0,0,.35);
}

/* Subtítulo en hero */
.hero-sub{
  color:#fff;
  margin:0;
  max-width:68ch;
  text-shadow:0 6px 22px rgba(0,0,0,.35);
  font-size:1rem;
  letter-spacing:.02em;
}

/* Botón */
.cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:999px;border:1px solid #000;background:#000;color:#fff}
.btn.secondary{background:var(--accent);color:#000;border-color:var(--accent)}

/* ===== Secciones & tarjetas ===== */
.section{padding-block:40px}
h1,h2,h3{margin:0 0 8px;line-height:1.2}

/* COLORES PEDIDOS */
h2{font-size:clamp(2rem,1rem + 1vw,2.4rem);color:var(--h2)}
h3{color:var(--h3)}

/* Párrafos SIEMPRE NEGRO */
p{color:#000}

.card{background:var(--white);border-radius:var(--radius);padding:24px}
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(1,1fr)}
.grid.cols-4{grid-template-columns:repeat(1,1fr)}
.bullets{padding-left:1rem}
.bullets li{margin:.25rem 0}
.bullets.two-cols{columns:1}

/* ===== Mini cards hero (iconos) ===== */
.icon-cards{margin-top:-28px}
.icon-card{
  background:#fff;
  border-radius:14px;
  padding:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  box-shadow:0 16px 32px rgba(0,0,0,.08);
  border:1px solid rgba(0,0,0,.06);
  text-align:center;
  min-height:110px;
}
.icon-card svg{width:34px;height:34px;stroke:var(--h2);fill:none;stroke-width:2}
.icon-card strong{font-size:1.05rem}

/* ===== Split (foto + caja) ===== */
.split{position:relative;padding-block:clamp(0px,6vw,25px)}
.split .container{display:grid;gap:24px}
.split-card{text-align:left;background:var(--white);border-radius:var(--radius);padding:clamp(18px,2.2vw,32px)}
.split-title{font-size:clamp(1.6rem,1.2rem + 1.4vw,2.2rem);letter-spacing:.02em;margin:0 0 .6rem;color:var(--h2)}
.split-lead{color:#000;margin:0 0 1rem;max-width:58ch;line-height:1.7}

.split-media{position:relative;overflow:hidden;border-radius:12px}
.split-media img{width:100%;object-fit:cover;border-radius:12px;transition:transform .4s ease}
.split-media:hover img{transform:scale(1.03)}

.card-split{display:grid;gap:16px}
.card-media img{border-radius:12px}

/* ===== Precios (listado tipo tabla) ===== */
.price-grid{
  display:grid;
  gap:18px;
  margin-top:18px;
}
.price-box{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  padding:18px;
}
.price-box h3{margin-bottom:12px}
.price-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.price-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.price-item span{max-width:70%}
.price-item b{font-weight:700}

/* ===== Footer simple ===== */
.site-footer{
  background:#0a3b63;
  color:#fff;
  padding:18px 0;
  text-align:center;
  margin-top:30px;
}

/* ===== Mapa a ancho completo fuera del container ===== */
#mapa{
  width:100vw;
  position:relative;
  left:50%;
  right:50%;
  margin-left:-50vw;
  margin-right:-50vw;
  margin-top:1.25rem;
  margin-bottom:0;
}
#mapa iframe{
  width:100%;
  height:400px;
  border:0;
  display:block;
}

/* ===== Responsive ===== */
@media (max-width:899px){
  body{padding-top:var(--header-h);padding-bottom:0}
  .site-header{position:fixed;left:0;right:0;top:0;z-index:50}
  nav.desktop{display:none}
  .burger{display:inline-grid}
}
@media (min-width:900px){
  :root{--header-h:76px}
  .burger{display:none}
  .mobile-menu{display:none}
  .split .container{grid-template-columns:1fr 1fr;align-items:center}
  .grid.cols-3{grid-template-columns:repeat(3,1fr)}
  .grid.cols-4{grid-template-columns:repeat(4,1fr)}
  .bullets.two-cols{columns:2}
  .price-grid{grid-template-columns:repeat(4, 1fr)}
}

/* Accesibilidad */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}