    @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');
	    :root {
	      --navy:       #0d2137;
	      --ocean:      #1a5276;
	      --turquoise:  #1abc9c;
	      --aqua:       #48c9b0;
	      --ibiza:      #b5179e;   /* Ibiza accent — magenta/fuchsia */
	      --ibiza-dk:   #7b0d6b;
	      --ibiza-lt:   #f9a8d4;
	      --sunset:     #f97316;
	      --sunset-dk:  #c2410c;
	      --vedra:      #166534;   /* Es Vedrà green */
	      --sand:       #f5efe6;
	      --cream:      #fdfaf6;
	      --gold:       #c8a84b;
	      --coral:      #e74c3c;
	      --text-dark:  #0d1b2a;
	      --text-mid:   #2c4a5a;
	      --text-muted: #6b8896;
	      --white:      #ffffff;
	      --border:     rgba(181,23,158,0.12);
	      --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--ibiza  { background: linear-gradient(135deg, #1a0212, #4a0340, #b5179e); }
	    .section--sunset { background: linear-gradient(135deg, #1c0a02, #7c2d12, #f97316); }
	    .section--dark h2,.section--dark h3,.section--dark h4,
	    .section--ibiza h2,.section--ibiza h3,.section--ibiza h4,
	    .section--sunset h2,.section--sunset h3,.section--sunset h4 { color: var(--white); }
	    .section--dark p,.section--ibiza p,.section--sunset p { color: rgba(255,255,255,.8); }
	    .section--ibiza strong  { color: var(--ibiza-lt); }
	    .section--sunset strong { color: #fde68a; }
	
	    .badge { display:inline-block; background:var(--ibiza); 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--vedra  { background: var(--vedra); }
	    .badge--sunset { background: var(--sunset); }
	    .badge--ocean  { background: var(--ocean); }
	    .badge--aqua   { background: var(--turquoise); }
	
	    .section-intro { max-width: 720px; 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:85vh; display:flex; align-items:flex-end; position:relative; overflow:hidden;
	      background:linear-gradient(160deg,#0d0212 0%,#2d0426 50%,#b5179e 100%); }
	    .hero::before { content:''; position:absolute; inset:0;
	      background: radial-gradient(ellipse 70% 55% at 70% 40%, rgba(249,163,212,.14) 0%, transparent 70%),
	                  radial-gradient(ellipse 40% 35% at 15% 65%, rgba(249,115,22,.08) 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(249,163,212,.15); border:1px solid rgba(249,163,212,.35); color:var(--ibiza-lt); font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; padding:5px 14px; border-radius:50px; }
	    .hero-chip.sunset { background:rgba(249,115,22,.2); border-color:rgba(253,230,138,.4); color:#fde68a; }
	    .hero h1 { color:var(--white); margin-bottom:16px; max-width:860px; }
	    .hero h1 em { font-style:italic; color:var(--ibiza-lt); }
	    .hero h1 em.warm { color:#fde68a; }
	    .hero-sub { font-size:1.08rem; color:rgba(255,255,255,.72); max-width:640px; 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(--ibiza-lt); 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(--ibiza); color:var(--white); }
	    .btn-primary:hover { background:var(--ibiza-dk); }
	    .btn-outline { background:transparent; color:var(--white); border:1.5px solid rgba(255,255,255,.4); }
	    .btn-outline:hover { border-color:var(--ibiza-lt); color:var(--ibiza-lt); }
	    .hero-wave { position:absolute; bottom:-2px; left:0; right:0; pointer-events:none; z-index:3; }
	
	    /* ── 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:680px){ .three-col{ grid-template-columns:1fr; } }
	
	    /* ── 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,#fdf2ff,#fce7f3); border-left:4px solid var(--ibiza); border-radius:0 var(--radius-md) var(--radius-md) 0; padding:18px 20px; margin:24px 0; }
	    .tip-box h4 { color:var(--ibiza); 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(--gold); 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; }
	    .sunset-box { background:linear-gradient(135deg,#fff7ed,#ffedd5); border-left:4px solid var(--sunset); border-radius:0 var(--radius-md) var(--radius-md) 0; padding:18px 20px; margin:22px 0; }
	    .sunset-box h4 { color:var(--sunset-dk); margin-bottom:8px; font-size:.95rem; }
	    .sunset-box ul { padding-left:18px; font-size:.9rem; color:#7c2d12; line-height:1.8; }
	
	    /* ── 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(--ibiza); 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; }
	
	    /* ── TURNOS ── */
	    .turno-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
	    @media(max-width:600px){ .turno-grid{ grid-template-columns:1fr; } }
	    .turno-card { border-radius:var(--radius-lg); padding:32px 28px; border:2px solid var(--border); }
	    .turno-card.dia    { background:linear-gradient(135deg,#fdf2ff,#fce7f3); border-color:rgba(181,23,158,.3); }
	    .turno-card.sunset { background:linear-gradient(135deg,#fff7ed,#ffedd5); border-color:rgba(249,115,22,.4); }
	    .turno-card__emoji { font-size:2.4rem; margin-bottom:12px; }
	    .turno-card__name  { font-family:var(--ff-display); font-size:1.6rem; font-weight:700; color:var(--navy); margin-bottom:4px; }
	    .turno-card__time  { font-size:1.05rem; font-weight:700; margin-bottom:16px; }
	    .turno-card.dia    .turno-card__time { color:var(--ibiza); }
	    .turno-card.sunset .turno-card__time { color:var(--sunset-dk); }
	    .turno-card table  { width:100%; border-collapse:collapse; font-size:.87rem; }
	    .turno-card td     { padding:7px 0; color:var(--text-mid); border-bottom:1px solid rgba(0,0,0,.06); }
	    .turno-card td:first-child { color:var(--text-muted); width:55%; }
	    .turno-card td:last-child   { font-weight:600; color:var(--navy); }
	    .turno-card tr:last-child td{ border-bottom:none; }
	
	    /* ── 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(--ibiza),var(--sunset)); border-radius:2px; }
	    .timeline-item { position:relative; margin-bottom:26px; }
	    .timeline-item:last-child { margin-bottom:0; }
	    .timeline-dot { position:absolute; left:-28px; top:4px; width:18px; height:18px; border-radius:50%; background:var(--ibiza); border:3px solid var(--cream); box-shadow:0 0 0 2px var(--ibiza); 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.m { background:var(--turquoise); box-shadow:0 0 0 2px var(--turquoise); }
	    .timeline-dot.p { background:var(--gold); box-shadow:0 0 0 2px var(--gold); border-color:var(--sand); }
	    .timeline-dot.sun { background:var(--sunset); box-shadow:0 0 0 2px var(--sunset); }
	    .timeline-dot.e { background:var(--vedra); box-shadow:0 0 0 2px var(--vedra); }
	    .timeline-item h4 { color:var(--navy); margin-bottom:6px; font-size:1rem; }
	    .timeline-item p  { font-size:.9rem; margin-bottom:0; }
	
	    /* ── CALA CARDS ── */
	    .cala-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:18px; }
	    .cala-card { background:var(--white); border-radius:var(--radius-md); border:1px solid var(--border); box-shadow:var(--shadow-sm); padding:22px 18px; transition:transform .2s,box-shadow .2s; }
	    .cala-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
	    .cala-card.star { border-color:var(--ibiza); background:linear-gradient(135deg,#fdf2ff,#fce7f3); }
	    .cala-card__icon { font-size:1.8rem; margin-bottom:10px; }
	    .cala-card__name { font-family:var(--ff-display); font-size:1.25rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
	    .cala-card__tag  { display:inline-block; font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.07em; padding:2px 8px; border-radius:50px; margin-bottom:8px; }
	    .tag-stop  { background:#fdf2ff; color:var(--ibiza); }
	    .tag-view  { background:#f0fdf4; color:var(--vedra); }
	    .tag-swim  { background:#e0f2fe; color:var(--ocean); }
	    .cala-card__desc { font-size:.87rem; color:var(--text-muted); line-height:1.6; }
	
	    /* ── ACT GRID DARK ── */
	    .act-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(148px,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(249,163,212,.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); }
	
	    /* ── MENU BUFFET ── */
	    .menu-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:16px; }
	    .menu-card { background:var(--white); border-radius:var(--radius-md); border:1px solid var(--border); padding:20px; box-shadow:var(--shadow-sm); }
	    .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(--ibiza); font-weight:700; }
	
	    /* ── 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:#fdf2ff; color:var(--ibiza); font-size:.75rem; font-weight:600; padding:3px 9px; border-radius:50px; }
	    .row-star td { background:linear-gradient(90deg,rgba(181,23,158,.06),transparent)!important; }
	
	    /* ── 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); }
	
	    /* ── CTA BANNER ── */
	    .cta-banner { background:linear-gradient(135deg,var(--ibiza),var(--ibiza-dk)); 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; }
	    .cta-banner.sunset-cta { background:linear-gradient(135deg,var(--sunset-dk),var(--sunset)); }
	    .btn-white { background:var(--white); color:var(--ibiza); 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); }
	    .btn-white.sunset { color:var(--sunset-dk); }
	
	    /* ── 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(--ibiza); 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; } .turno-card{ padding:24px; } }
  