/* ==== FAMILIA 10 — Costa Atlántica (10d) ==== */
/* Estilo igual al de familia-5: crema/burdeos, Playfair+Inter, chips y viñetas flex */

:root{
    --bg:#f6efe7; --paper:#fff9f3; --text:#2a2320; --muted:#6d5f58;
    --burdeos:#7e3333; --burdeos-700:#682a2a; --gold:#c6a15b; --gold-700:#b18d4c;
    --line:#eadfce; --shadow:0 18px 48px rgba(17,10,8,.12);
    --r-lg:26px; --r-md:18px; --r-sm:12px;
    --space-1:8px; --space-2:12px; --space-3:16px; --space-4:20px; --space-5:28px; --space-6:36px; --space-7:52px;
    --container:min(1100px,92vw);
  }
  *{ box-sizing:border-box; }
  html,body{ height:100%; }
  body{ margin:0; background:var(--bg); color:var(--text); font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif; line-height:1.55; }
  h1,h2,h3{ font-family:"Playfair Display",serif; margin:0 0 var(--space-3); color:#231d1b; }
  h1{ font-size:clamp(36px,5vw,64px); line-height:1.02; }
  h2{ font-size:clamp(28px,3.2vw,40px); line-height:1.08; }
  h3{ font-size:clamp(20px,2.4vw,28px); line-height:1.14; }
  p{ margin:0 0 var(--space-3); }
  a{ color:inherit; text-decoration:none; }
  img,video{ max-width:100%; display:block; }
  .container{ width:var(--container); margin-inline:auto; }
  
  /* Header */
  .site-header{ position:sticky; top:0; z-index:30; backdrop-filter:saturate(1.05) blur(10px); background:color-mix(in oklab,var(--bg) 86%, white 14%); border-bottom:1px solid var(--line); }
  .site-header .wrap{ width:var(--container); margin-inline:auto; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:12px 0; }
  .brand{ display:flex; align-items:center; gap:12px; }
  .brand-badge{ width:56px; height:56px; border-radius:14px; background:#fff; border:1px solid var(--line); display:grid; place-items:center; box-shadow:var(--shadow); overflow:hidden; }
  .brand-badge img{ width:40px; height:auto; }
  .brand-name{ font-family:"Playfair Display",serif; letter-spacing:2.5px; font-size:18px; color:#231d1b; }
  
  /* Hero */
  .hero{ position:relative; border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); margin:var(--space-5) auto; }
  .hero-media{ aspect-ratio:16/7; width:100%; object-fit:cover; filter:saturate(1.05) contrast(1.02); }
  .hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(246,239,231,0.0) 20%, rgba(246,239,231,.55) 64%, rgba(246,239,231,.9) 100%); }
  .hero-content{ position:absolute; inset:0; display:grid; place-items:center; padding:clamp(16px,3vw,32px); text-align:center; }
  .headline{ max-width:min(900px,90%); color:#231d1b; text-shadow:0 1px 0 rgba(255,255,255,.7); }
  
  /* Subtítulo bajo hero */
  .intro-subtext{ width:var(--container); margin:var(--space-4) auto var(--space-5); text-align:center; }
  .intro-subtext p{ font-size:clamp(16px,1.8vw,18px); color:var(--muted); max-width:850px; margin:0 auto; line-height:1.6; }
  
  /* Chips */
  .meta{ margin:var(--space-4) auto var(--space-5); display:flex; gap:10px; flex-wrap:wrap; align-items:center; }
  .chip{ border:1px solid var(--line); background:#fff; padding:10px 14px; border-radius:999px; color:#4a3f3a; box-shadow:0 8px 18px rgba(17,10,8,.06); font-weight:700; letter-spacing:.2px; }
  .chip.badge{ background:var(--burdeos); color:#fff; border-color:transparent; }
  .chip.gold{ background:var(--gold); color:#111; border-color:var(--gold-700); }
  
  /* Grid */
  .main{ width:var(--container); margin-inline:auto; display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(18px,3vw,32px); align-items:start; }
  
  /* Izquierda */
  .section{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(16px,2.2vw,28px); box-shadow:var(--shadow); }
  .section + .section{ margin-top:var(--space-4); }
  .section h2{ margin-bottom:var(--space-2); }
  
  .daylist{ display:grid; gap:12px; margin-top:var(--space-2); }
  .day{ border:1px solid var(--line); background:#fff; border-radius:var(--r-md); padding:16px 18px; box-shadow:0 8px 22px rgba(17,10,8,.06); }
  .pill{ display:inline-block; margin-bottom:8px; background:var(--burdeos); color:#fff; font-weight:800; padding:6px 12px; border-radius:999px; letter-spacing:.3px; }
  
  .day h3{ font-family:"Playfair Display",serif; font-weight:800; font-size:clamp(22px,2.2vw,28px); line-height:1.18; color:#231d1b; margin:0 0 10px; white-space:normal; }
  .day p{ margin:0; line-height:1.6; color:var(--text); white-space:normal; }
  
  /* Derecha */
  .aside{ display:grid; gap:var(--space-4); }
  .pricebox{ border:1px solid var(--line); background:#fff; border-radius:var(--r-lg); padding:var(--space-4); box-shadow:var(--shadow); }
  .pricebox .row{ display:flex; align-items:end; justify-content:space-between; gap:14px; margin-bottom:var(--space-3); }
  .price{ display:grid; gap:6px; }
  .price small{ color:var(--muted); font-weight:600; letter-spacing:.3px; }
  .price .mxn{ font-weight:900; font-size:clamp(20px,2.4vw,26px); }
  .price .eur{ color:var(--muted); font-weight:700; }
  
  .btn{ display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:12px 16px; border-radius:14px; border:1px solid transparent; transition:.18s ease; font-weight:800; letter-spacing:.2px; text-align:center; }
  .btn-primary{ background:var(--burdeos); color:#fff; border-color:var(--burdeos-700); }
  .btn-primary:hover{ filter:saturate(1.08) brightness(1.05); transform:translateY(-1px); }
  .btn-outline{ background:#fff; color:#111; border-color:var(--gold-700); }
  .btn-outline:hover{ background:var(--gold); }
  
  /* Viñetas ✔ */
  .include{ margin-top:var(--space-2); display:grid; gap:12px; }
  .include li{ list-style:none; display:flex; align-items:flex-start; gap:10px; color:#3d332e; line-height:1.5; font-weight:500; text-align:left; }
  .include li::before{ content:"✓"; color:var(--burdeos); font-weight:900; line-height:1.2; flex-shrink:0; }
  
  /* Galería */
  .gallery{ border:1px solid var(--line); background:var(--paper); border-radius:var(--r-lg); padding:var(--space-5); box-shadow:var(--shadow); margin-top:var(--space-5); }
  .gallery h2{ margin-bottom:var(--space-4); }
  .gallery-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
  .gallery-grid img{ width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:20px; box-shadow:0 10px 25px rgba(17,10,8,.08); transition:transform .25s, box-shadow .25s; }
  .gallery-grid img:hover{ transform:scale(1.03); box-shadow:0 14px 35px rgba(17,10,8,.15); }
  
  /* Footer */
  .site-footer{ margin:var(--space-6) 0 var(--space-5); color:var(--muted); text-align:center; }
  
  /* Accesibilidad */
  a:focus-visible,button:focus-visible{ outline:3px solid var(--gold); outline-offset:2px; border-radius:10px; }
  
  /* Responsive */
  @media (max-width:1100px){ .main{ grid-template-columns:1fr; } .aside{ order:-1; } .hero{ border-radius:20px; } }
  @media (max-width:740px){
    .site-header .wrap{ padding:10px 0; }
    .brand-badge{ width:50px; height:50px; border-radius:12px; }
    .brand-name{ font-size:16px; letter-spacing:2px; }
    .meta{ gap:8px; }
    .chip{ padding:9px 12px; font-size:14px; }
    .gallery-grid{ grid-template-columns:1fr 1fr; }
    .pricebox .row{ flex-direction:column; align-items:flex-start; gap:8px; }
    .btn{ width:100%; }
  }