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

/* ============ Variables de color y medidas ============ */
:root{
    --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;
    --gold: #c6a15b;
    --gold-700:#b18d4c;
  
    --line: #eadfce;          /* líneas sutiles */
    --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);
  }
  
  /* ============ 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; }
  
  /* Utils */
  .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 con overlay y texto encima) ============ */
  .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);
  }
  .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 (2 columnas) ============ */
  .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 */
  .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);
  }
  
  /* Lista día a día */
  .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;
  }
  
  /* ------ NUEVO: formato del día como en tu captura ------ */
  .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;
  }
  .day p strong{
    font-weight:800;
  }
  
  /* Columna derecha (aside con precio / restaurantes / etc.) */
  .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 tipo check */
.include{
    margin-top: var(--space-2);
    display: grid;
    gap: 12px;              /* un poco más de aire entre puntos */
  }
  
  .include li{
    list-style: none;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    color: #3d332e;
    line-height: 1.5;
    font-size: 1rem;
    font-weight: 500;
    text-align: left;       /* nos aseguramos que quede alineado a la izquierda */
  }
  
  .include li::before{
    content: "✓";
    color: var(--burdeos);
    font-weight: 900;
    line-height: 1.2;
    flex-shrink: 0;         /* para que el ícono no se mueva si la línea salta */
    font-size: 1rem;
  }
  
  /* ===== 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 ease, box-shadow .25s ease;
  }
  .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 foco */
  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 */
  .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;
  }