/* =========================================================
   PAREJA 5 — CSS romántico (crema, burdeos, blush, dorado)
   Tipos: Inter (UI) + Playfair Display (títulos)
   ========================================================= */

/* ============ Variables de color y medidas ============ */
:root{
    /* Paleta romántica */
    --bg: #f6efe7;            /* crema base */
    --paper: #fff9f3;         /* crema clara para tarjetas */
    --text: #2a2320;          /* texto principal */
    --muted: #6d5f58;         /* texto secundario */
  
    --burdeos: #7e3333;       /* acento romántico */
    --burdeos-700:#682a2a;
    --blush: #f3d9cf;         /* blush */
    --gold: #c6a15b;          /* dorado suave */
    --gold-700:#b18d4c;
  
    --line: #eadfce;          /* líneas sutiles */
    --shadow: 0 18px 48px rgba(17,10,8,.12);
  
    /* radios y ritmo */
    --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;
  
    /* contenedor */
    --container: min(1100px, 92vw);
  }
  
  /* ============ Base ============ */
  *{ 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", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif;
    line-height:1.55;
  }
  
  /* Titulares románticos */
  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; letter-spacing:.2px; }
  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); color:var(--text); }
  a{ color:inherit; text-decoration:none; }
  img,video{ max-width:100%; display:block; }
  
  /* Utilidades */
  .container{ width:var(--container); margin-inline:auto; }
  .muted{ color:var(--muted); }
  .paper{ background:var(--paper); }
  
  /* ============ Header pegajoso ============ */
  .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;
    padding:12px 0;
    gap:16px;
  }
  .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 (imagen o video) ============ */
  .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{
    /* velo romántico */
    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);
  }
  .subhead{
    margin-top:12px; font-size:clamp(16px,1.8vw,18px);
    color:var(--muted);
  }
  
  /* ============ Meta bar (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); }
  
  /* ============ Layout principal ============ */
  .main{
    width:var(--container); margin-inline:auto; display:grid;
    grid-template-columns: 1.1fr .9fr; gap: clamp(18px, 3vw, 32px);
    align-items:start;
  }
  
  /* Columna izquierda (itinerario) */
  .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); }
  
  /* Título secundario */
  .section h2{
    margin-bottom: var(--space-2);
  }
  
  /* Lista día a día (romántica) */
  .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;
  }
  
  /* Listas con icono */
  .kv{ display:grid; gap:12px; margin-top:10px; }
  .kv-item{
    display:flex; align-items:flex-start; gap:12px;
    padding:10px 0; border-bottom:1px dashed var(--line);
  }
  .kv-item:last-child{ border-bottom:none; }
  .kv-item .ico{
    width:36px; height:36px; border-radius:10px;
    display:grid; place-items:center; color:#fff;
    background:var(--burdeos-700); flex:0 0 auto;
  }
  .kv-item .txt strong{ display:block; font-weight:800; }
  
  /* Columna derecha (precio/CTA y galería) */
  .aside{ display:grid; gap: var(--space-4); }
  
  /* Caja de precio & CTA */
  .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); }
  
  /* Lista de “incluye” */
  .include{
    margin-top: var(--space-2);
    display:grid; gap:8px;
  }
  .include li{
    list-style:none; padding-left:24px; position:relative; color:#3d332e;
  }
  .include li::before{
    content:"✓"; position:absolute; left:0; top:0; color:var(--burdeos);
    font-weight:900;
  }
  
  /* Galería */
  .gallery{
    border:1px solid var(--line); background:var(--paper);
    border-radius: var(--r-lg); padding: var(--space-3);
    box-shadow: var(--shadow);
  }
  /* ===== 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; /* ← espacio entre imágenes */
  }
  
  .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 ease, box-shadow .25s ease;
  }
  
  .gallery-grid img:hover{
    transform: scale(1.03);
    box-shadow: 0 14px 35px rgba(17,10,8,.15);
  }
  .gallery-grid img{
    width:100%; aspect-ratio: 4/3; object-fit:cover; border-radius:12px;
    box-shadow:0 8px 20px rgba(17,10,8,.08);
  }
  
  /* ============ Footer ============ */
  .site-footer{
    margin: var(--space-6) 0 var(--space-5);
    color:var(--muted); text-align:center;
  }
  
  /* ============ Estados de foco/accesibilidad ============ */
  a:focus-visible, button:focus-visible{
    outline:3px solid var(--gold); outline-offset:2px; border-radius:10px;
  }
  
  /* ============ Breakpoints ============ */
  @media (max-width:1100px){
    .main{ grid-template-columns: 1fr; }
    .aside{ order:-1; }      /* Precio/CTA arriba en móvil grande */
    .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%; }
  }
  
  /* ============ Helpers opcionales ============ */
  .leading-tight{ line-height:1.25; }
  .center{ text-align:center; }
  .no-margin{ margin:0!important; }
  .small{ font-size:13px; color:var(--muted); }
  hr.soft{
    border:none; height:1px; background:var(--line);
    margin: var(--space-3) 0;
  }