    @import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@300;400;500;600&display=swap');

    /* --------------------------------------
       DESIGN TOKENS
    -------------------------------------- */
    :root {
      --navy:      #0d2137;
      --ocean:     #1a5276;
      --turquoise: #1abc9c;
      --aqua:      #48c9b0;
      --sand:      #f5efe6;
      --cream:     #fdfaf6;
      --gold:      #c8a84b;
      --coral:     #e74c3c;
      --sun:       #f39c12;
      --text-dark: #0d1b2a;
      --text-mid:  #2c4a5a;
      --text-muted:#6b8896;
      --white:     #ffffff;
      --border:    rgba(26,82,118,0.14);
      --shadow-sm: 0 2px 12px rgba(13,33,55,0.08);
      --shadow-md: 0 8px 32px rgba(13,33,55,0.14);
      --shadow-lg: 0 20px 60px rgba(13,33,55,0.18);
      --radius-md: 12px;
      --radius-lg: 20px;
      --ff-display:'Cormorant Garamond', Georgia, serif;
      --ff-body:   'DM Sans', sans-serif;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; font-size: 16px; }
    body { font-family: var(--ff-body); background: var(--cream); color: var(--text-dark); line-height: 1.7; overflow-x: hidden; }
    img { max-width: 100%; display: block; }
    a { color: inherit; text-decoration: none; }
    strong { font-weight: 600; color: var(--navy); }
    h1,h2,h3,h4 { font-family: var(--ff-display); line-height: 1.2; color: var(--navy); }
    h1 { font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 700; }
    h2 { font-size: clamp(1.6rem, 3vw, 2.3rem); font-weight: 600; }
    h3 { font-size: clamp(1.15rem, 2vw, 1.5rem); font-weight: 600; }
    h4 { font-size: 1.05rem; font-weight: 600; }
    p  { font-size: 1rem; color: var(--text-mid); margin-bottom: 1rem; line-height: 1.75; }
    p:last-child { margin-bottom: 0; }

    .container { max-width: 1100px; margin: 0 auto; padding: 0 24px; }
    .section    { padding: 72px 0; }
    .section--alt  { background: var(--sand); }
    .section--dark { background: var(--navy); }
    .section--dark h2,.section--dark h3,.section--dark h4 { color: var(--white); }
    .section--dark p { color: rgba(255,255,255,.8); }
    .section--dark strong { color: var(--aqua); }

    .badge { display:inline-block; background:var(--turquoise); color:var(--white); font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; padding:4px 12px; border-radius:50px; margin-bottom:14px; }
    .badge--gold  { background: var(--gold); }
    .badge--coral { background: var(--coral); }
    .badge--sun   { background: var(--sun); }

    .section-intro { max-width: 700px; margin: 0 auto 52px; text-align: center; }
    .section-intro p { font-size: 1.05rem; }

    /* -- HEADER -- */
    .site-header { position:fixed; top:0; left:0; right:0; z-index:100; padding:16px 0; transition:background .3s,box-shadow .3s; }
    .site-header.scrolled { background:rgba(13,33,55,.97); backdrop-filter:blur(12px); box-shadow:var(--shadow-md); }
    .header-inner { display:flex; align-items:center; justify-content:space-between; }
    .site-logo { font-family:var(--ff-display); font-size:1.35rem; font-weight:700; color:var(--white); display:flex; align-items:center; gap:8px; }
    .site-nav { display:flex; gap:28px; list-style:none; }
    .site-nav a { color:rgba(255,255,255,.85); font-size:.88rem; font-weight:500; transition:color .2s; }
    .site-nav a:hover { color:var(--aqua); }
    .nav-cta { background:var(--turquoise); color:var(--white)!important; padding:7px 18px; border-radius:50px; font-weight:600!important; }
    .nav-cta:hover { background:var(--aqua)!important; }

    /* -- BREADCRUMB -- */
    .breadcrumb { padding:100px 0 0; font-size:.82rem; color:rgba(255,255,255,.6); }
    .breadcrumb a { color:rgba(255,255,255,.6); transition:color .2s; }
    .breadcrumb a:hover { color:var(--aqua); }
    .breadcrumb span { margin:0 6px; }

    /* -- HERO -- */
    .hero { min-height:82vh; display:flex; align-items:flex-end; position:relative; overflow:hidden;
      background:linear-gradient(160deg,#0b1e32 0%,#1e4060 45%,#0a3d2f 100%); }
    .hero::before { content:''; position:absolute; inset:0;
      background: radial-gradient(ellipse 65% 55% at 70% 45%,rgba(26,188,156,.14) 0%,transparent 70%),
                  radial-gradient(ellipse 40% 35% at 20% 70%,rgba(243,156,18,.07) 0%,transparent 60%);
      pointer-events:none; }
    .hero-content { position:relative; z-index:2; padding:0 20px 56px 20px; width:100%; }
    .hero-meta { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
    .hero-chip { display:inline-flex; align-items:center; gap:6px; background:rgba(26,188,156,.15); border:1px solid rgba(26,188,156,.35); color:var(--aqua); font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; padding:5px 14px; border-radius:50px; }
    .hero h1 { color:var(--white); margin-bottom:16px; max-width:820px; }
    .hero h1 em { font-style:italic; color:var(--aqua); }
    .hero-sub { font-size:1.08rem; color:rgba(255,255,255,.72); max-width:620px; margin-bottom:36px; }
    .hero-quick { display:flex; gap:28px; flex-wrap:wrap; background:rgba(13,33,55,.55); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-md); padding:20px 28px; margin-bottom:32px; width:fit-content; }
    .quick-item { text-align:center; }
    .quick-item__val { font-family:var(--ff-display); font-size:1.5rem; font-weight:700; color:var(--aqua); line-height:1; }
    .quick-item__key { font-size:.75rem; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:.06em; margin-top:4px; }
    .hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }
    .btn { display:inline-flex; align-items:center; gap:8px; font-family:var(--ff-body); font-size:.93rem; font-weight:600; padding:13px 26px; border-radius:50px; cursor:pointer; transition:transform .15s,box-shadow .15s,background .2s; border:none; }
    .btn:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
    .btn-primary { background:var(--turquoise); color:var(--white); }
    .btn-primary:hover { background:#17a589; }
    .btn-outline { background:transparent; color:var(--white); border:1.5px solid rgba(255,255,255,.4); }
    .btn-outline:hover { border-color:var(--aqua); color:var(--aqua); }
    .hero-wave { position:absolute; bottom:-2px; left:0; right:0; pointer-events:none; }

    /* -- LAYOUT -- */
    .two-col { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
    @media(max-width:720px){ .two-col{ grid-template-columns:1fr; gap:28px; } }
    .three-col { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
    @media(max-width:700px){ .three-col{ grid-template-columns:1fr; } }

    /* -- CARDS & BOXES -- */
    .info-box { background:var(--white); border-radius:var(--radius-md); border:1px solid var(--border); box-shadow:var(--shadow-sm); padding:24px; }
    .info-box h4 { margin-bottom:12px; color:var(--navy); }

    .tip-box { background:linear-gradient(135deg,#eaf7f4,#f0faf8); border-left:4px solid var(--turquoise); border-radius:0 var(--radius-md) var(--radius-md) 0; padding:18px 20px; margin:24px 0; }
    .tip-box h4 { color:var(--turquoise); margin-bottom:8px; font-size:.95rem; }
    .tip-box ul { padding-left:18px; font-size:.9rem; color:var(--text-mid); line-height:1.8; }

    .gold-box { background:linear-gradient(135deg,#fef9e7,#fdf2d0); border-left:4px solid var(--gold); border-radius:0 var(--radius-md) var(--radius-md) 0; padding:18px 20px; margin:22px 0; }
    .gold-box h4 { color:var(--gold); margin-bottom:8px; font-size:.95rem; }
    .gold-box ul { padding-left:18px; font-size:.9rem; color:#6d5000; line-height:1.8; }

    .warning-box { background:#fff8e1; border-left:4px solid var(--sun); border-radius:0 var(--radius-md) var(--radius-md) 0; padding:16px 20px; margin:20px 0; font-size:.9rem; color:#6d5000; }
    .warning-box strong { color:#6d5000; }

    /* -- FEATURE LIST -- */
    .feat-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
    .feat-list li { display:flex; align-items:flex-start; gap:10px; font-size:.93rem; color:var(--text-mid); line-height:1.6; }
    .feat-list .chk { flex-shrink:0; width:20px; height:20px; border-radius:50%; background:var(--turquoise); color:#fff; font-size:.65rem; display:flex; align-items:center; justify-content:center; margin-top:2px; }
    .feat-list .no  { flex-shrink:0; width:20px; height:20px; border-radius:50%; background:#fdecea; color:#c0392b; font-size:.65rem; display:flex; align-items:center; justify-content:center; margin-top:2px; }

    /* -- TIMELINE -- */
    .timeline { position:relative; padding-left:32px; }
    .timeline::before { content:''; position:absolute; left:9px; top:8px; bottom:8px; width:2px; background:linear-gradient(to bottom,var(--turquoise),var(--sun)); border-radius:2px; }
    .timeline-item { position:relative; margin-bottom:28px; }
    .timeline-item:last-child { margin-bottom:0; }
    .timeline-dot { position:absolute; left:-28px; top:4px; width:18px; height:18px; border-radius:50%; background:var(--turquoise); border:3px solid var(--cream); box-shadow:0 0 0 2px var(--turquoise); display:flex; align-items:center; justify-content:center; font-size:.55rem; color:#fff; font-weight:700; }
    .timeline-dot.s { background:var(--navy); box-shadow:0 0 0 2px var(--navy); }
    .timeline-dot.e { background:var(--sun); box-shadow:0 0 0 2px var(--sun); }
    .timeline-item h4 { color:var(--navy); margin-bottom:6px; font-size:1rem; }
    .timeline-item p  { font-size:.9rem; margin-bottom:0; }

    /* -- HORARIO PILLS -- */
    .horario-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
    @media(max-width:480px){ .horario-grid{ grid-template-columns:1fr; } }
    .horario-card { border-radius:var(--radius-md); padding:22px; text-align:center; border:1px solid var(--border); }
    .horario-card.mañana { background:linear-gradient(135deg,#e8f4f8,#d6eef5); }
    .horario-card.tarde  { background:linear-gradient(135deg,#fef3e2,#fde8c8); }
    .horario-card__emoji { font-size:2rem; margin-bottom:8px; }
    .horario-card__title { font-family:var(--ff-display); font-size:1.2rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
    .horario-card__time  { font-size:1rem; font-weight:600; color:var(--ocean); margin-bottom:6px; }
    .horario-card__note  { font-size:.82rem; color:var(--text-muted); }

    /* -- TABLA -- */
    .table-wrap { overflow-x:auto; border-radius:var(--radius-md); box-shadow:var(--shadow-sm); border:1px solid var(--border); }
    .data-table { width:100%; border-collapse:collapse; font-size:.91rem; background:var(--white); }
    .data-table thead { background:var(--navy); color:var(--white); }
    .data-table thead th { font-family:var(--ff-body); font-weight:600; font-size:.82rem; text-transform:uppercase; letter-spacing:.06em; padding:14px 16px; text-align:left; }
    .data-table tbody tr { border-bottom:1px solid var(--border); transition:background .15s; }
    .data-table tbody tr:hover { background:var(--sand); }
    .data-table tbody tr:last-child { border-bottom:none; }
    .data-table td { padding:13px 16px; color:var(--text-mid); vertical-align:middle; }
    .data-table td:first-child { font-weight:600; color:var(--navy); }
    .pill-y { display:inline-block; background:#d5f5e3; color:#1e8449; font-size:.75rem; font-weight:600; padding:3px 9px; border-radius:50px; }
    .pill-n { display:inline-block; background:#fdecea; color:#c0392b; font-size:.75rem; font-weight:600; padding:3px 9px; border-radius:50px; }
    .pill-m { display:inline-block; background:#fef9e7; color:#d4ac0d; font-size:.75rem; font-weight:600; padding:3px 9px; border-radius:50px; }
    .pill-s { display:inline-block; background:#eaf2ff; color:#2471a3; font-size:.75rem; font-weight:600; padding:3px 9px; border-radius:50px; }
    .highlight-row { background:linear-gradient(90deg,rgba(26,188,156,.07),transparent)!important; }

    /* -- ACTIVIDADES DARK -- */
    .act-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; }
    .act-card { background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.11); border-radius:var(--radius-md); padding:22px 14px; text-align:center; transition:background .2s,transform .2s; }
    .act-card:hover { background:rgba(26,188,156,.13); transform:translateY(-4px); }
    .act-card__icon { font-size:1.8rem; margin-bottom:8px; }
    .act-card__name { font-weight:600; font-size:.87rem; color:var(--white); margin-bottom:4px; }
    .act-card__note { font-size:.75rem; color:rgba(255,255,255,.5); }

    /* -- MENÚ BARBACOA -- */
    .menu-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
    @media(max-width:520px){ .menu-grid{ grid-template-columns:1fr; } }
    .menu-card { background:var(--white); border-radius:var(--radius-md); border:1px solid var(--border); box-shadow:var(--shadow-sm); padding:20px; }
    .menu-card__icon { font-size:1.6rem; margin-bottom:8px; }
    .menu-card__title { font-weight:700; color:var(--navy); font-size:.95rem; margin-bottom:8px; }
    .menu-card ul { list-style:none; font-size:.87rem; color:var(--text-mid); line-height:1.9; }
    .menu-card ul li::before { content:"• "; color:var(--turquoise); font-weight:700; }

    /* -- OPINIONES -- */
    .opinion-card { background:var(--white); border-radius:var(--radius-md); border:1px solid var(--border); box-shadow:var(--shadow-sm); padding:24px; }
    .stars { color:#f0b429; font-size:.95rem; letter-spacing:2px; }
    .opinion-text { font-size:.93rem; color:var(--text-mid); font-style:italic; line-height:1.7; margin:8px 0; }
    .opinion-author { font-size:.8rem; font-weight:600; color:var(--text-muted); }

    /* -- RUTA MAP -- */
    .route-map { background:linear-gradient(135deg,#e8f4f8,#d6eef5); border-radius:var(--radius-lg); border:1px solid var(--border); padding:28px; position:relative; overflow:hidden; }
    .route-map::before { content:'???'; position:absolute; right:16px; top:16px; font-size:2.5rem; opacity:.15; }
    .route-stops { display:flex; flex-direction:column; gap:5px; }
    .route-stop { display:flex; align-items:center; gap:12px; font-size:.88rem; font-weight:500; color:var(--text-mid); }
    .route-dot { width:10px; height:10px; border-radius:50%; background:var(--turquoise); flex-shrink:0; }
    .route-dot.s { background:var(--navy); }
    .route-dot.e { background:var(--sun); }
    .route-line { width:2px; height:14px; background:var(--border); margin-left:4px; }

    /* -- PRECIOS -- */
    .precio-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
    @media(max-width:600px){ .precio-grid{ grid-template-columns:1fr; } }
    .precio-card { background:var(--white); border-radius:var(--radius-md); border:2px solid var(--border); padding:24px 20px; text-align:center; transition:border-color .2s,transform .2s; }
    .precio-card:hover { border-color:var(--turquoise); transform:translateY(-4px); }
    .precio-card.featured { border-color:var(--turquoise); background:linear-gradient(135deg,#eafaf4,#f0faf8); }
    .precio-card__label { font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); margin-bottom:8px; }
    .precio-card__price { font-family:var(--ff-display); font-size:2.5rem; font-weight:700; color:var(--navy); line-height:1; margin-bottom:6px; }
    .precio-card__sub { font-size:.82rem; color:var(--text-muted); margin-bottom:12px; }
    .precio-card__badge { display:inline-block; background:var(--turquoise); color:var(--white); font-size:.72rem; font-weight:600; padding:3px 10px; border-radius:50px; }

    /* -- CTA BANNER -- */
    .cta-banner { background:linear-gradient(135deg,var(--turquoise),var(--ocean)); border-radius:var(--radius-lg); padding:44px 40px; display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; box-shadow:var(--shadow-lg); }
    .cta-banner h3 { color:var(--white); margin-bottom:8px; }
    .cta-banner p  { color:rgba(255,255,255,.8); max-width:520px; }
    .btn-white { background:var(--white); color:var(--ocean); font-weight:700; padding:13px 30px; border-radius:50px; display:inline-flex; align-items:center; gap:8px; flex-shrink:0; transition:transform .15s,box-shadow .15s; }
    .btn-white:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(13,33,55,.22); }

    /* -- FAQ -- */
    .faq-list { display:flex; flex-direction:column; gap:10px; max-width:840px; margin:0 auto; }
    details { background:var(--white); border:1px solid var(--border); border-radius:var(--radius-md); overflow:hidden; }
    details[open] { box-shadow:var(--shadow-sm); }
    summary { display:flex; align-items:center; justify-content:space-between; padding:17px 22px; cursor:pointer; font-weight:600; color:var(--navy); font-size:.95rem; list-style:none; user-select:none; transition:background .15s; }
    summary:hover { background:var(--sand); }
    summary::-webkit-details-marker { display:none; }
    .faq-icon { font-size:1.1rem; color:var(--turquoise); transition:transform .2s; flex-shrink:0; margin-left:10px; }
    details[open] .faq-icon { transform:rotate(45deg); }
    .faq-body { padding:0 22px 18px; font-size:.91rem; color:var(--text-mid); line-height:1.75; border-top:1px solid var(--border); }
    .faq-body p { margin-top:14px; }

    /* -- FOOTER -- */
    .site-footer { background:var(--navy); color:rgba(255,255,255,.55); padding:0 0 32px; }
    .footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:36px; margin-bottom:44px; }
    @media(max-width:768px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
    @media(max-width:480px){ .footer-grid{ grid-template-columns:1fr; } }
    .footer-brand p { font-size:.87rem; line-height:1.7; margin-top:10px; color:rgba(255,255,255,.45); }
    .footer-col h4 { color:var(--white); font-size:.83rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; margin-bottom:12px; }
    .footer-col ul { list-style:none; }
    .footer-col li { margin-bottom:7px; }
    .footer-col a  { font-size:.87rem; color:rgba(255,255,255,.48); transition:color .2s; }
    .footer-col a:hover { color:var(--aqua); }
    .footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding-top:22px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; font-size:.78rem; }
    .footer-legal { display:flex; gap:18px; }
    .footer-legal a { color:rgba(255,255,255,.38); transition:color .2s; }
    .footer-legal a:hover { color:var(--white); }

    /* -- ANIMATIONS -- */
    .fade-in { opacity:0; transform:translateY(22px); transition:opacity .6s ease,transform .6s ease; }
    .fade-in.visible { opacity:1; transform:none; }

    @media(max-width:768px){ .section{ padding:52px 0; } .site-nav{ display:none; } .cta-banner{ padding:28px 22px; } .hero-quick{ gap:18px; padding:16px 20px; } }
  