/* ===========================================================
   VIAJES EN COMPAÑÍA · hoja de estilos del sitio
   =========================================================== */
:root{
  --sky:#009EDB; --navy:#075E80; --navy-2:#05485F; --teal:#0E9AD4; --teal-soft:#7DC1D6;
  --coral:#F2A65A; --coral-dark:#E0902F; --gold:#E8B765;
  --cream:#F4FAFC; --cream-2:#E6F4F9; --ink:#14303A; --muted:#5A7682;
  --line:rgba(7,94,128,.16); --shadow:0 18px 50px -20px rgba(7,94,128,.42);
  --r:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Manrope',system-ui,sans-serif;color:var(--ink);background:var(--cream);
  font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Fredoka',sans-serif;line-height:1.08;font-weight:600;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1180px,92%);margin-inline:auto}
.eyebrow{font-family:'Manrope';font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--coral)}
.center{text-align:center;margin-inline:auto}
.pad{padding:clamp(4rem,9vw,7rem) 0}

.btn{display:inline-flex;align-items:center;gap:.55em;font-family:'Manrope';font-weight:700;font-size:1rem;
  padding:.95em 1.7em;border-radius:999px;cursor:pointer;border:none;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;white-space:nowrap}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 12px 28px -10px rgba(242,166,90,.55)}
.btn-primary:hover{background:var(--coral-dark);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.5);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.24);transform:translateY(-2px)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--coral-dark)}
.btn-light:hover{transform:translateY(-2px)}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--sky);color:#ffffff;font-size:.82rem;font-weight:500}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0;flex-wrap:wrap}
.topbar a{display:inline-flex;align-items:center;gap:.4em;opacity:.92}
.topbar a:hover{opacity:1;color:#fff}
.topbar .tb-left{display:flex;gap:1.4rem;flex-wrap:wrap;align-items:center}
.topbar .tb-social{display:flex;gap:1.1rem;align-items:center}
.topbar svg{width:15px;height:15px;fill:currentColor}

/* ---------- HEADER ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(244,250,252,.9);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);transition:box-shadow .3s}
header.site.scrolled{box-shadow:0 10px 30px -18px rgba(15,58,77,.4)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:.7rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand .logo-mark{width:46px;height:46px;flex:none}
.brand .logo-txt{display:flex;flex-direction:column;line-height:1}
.brand .logo-txt b{font-family:'Quicksand',sans-serif;font-weight:700;font-size:1.18rem;color:var(--navy);letter-spacing:0}
.brand .logo-txt span{font-family:'Manrope';font-weight:700;font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--coral);margin-top:3px}
.menu{display:flex;align-items:center;gap:1.7rem;font-weight:600;font-size:.96rem}
.menu a{position:relative;color:var(--ink);padding:.3em 0;transition:color .2s}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--coral);transition:width .25s}
.menu a:hover,.menu a.active{color:var(--coral)}
.menu a:hover::after,.menu a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--navy);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-position:center 30%;background-size:cover;background-repeat:no-repeat;transform:scale(1.06);animation:slowzoom 18s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,44,59,.35) 0%,rgba(11,44,59,.15) 38%,rgba(11,44,59,.82) 100%)}
.hero-inner{position:relative;z-index:2;padding-bottom:clamp(3rem,7vh,6rem);padding-top:4rem}
.hero .eyebrow{color:#ffd9c8}
.hero h1{font-size:clamp(2.6rem,6.4vw,5.1rem);font-weight:600;max-width:16ch;margin:.5rem 0 1.1rem;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 em{font-style:normal;color:#ffc9b3}
.hero p.lead{font-size:clamp(1.05rem,2vw,1.32rem);max-width:46ch;color:#eef4f6;font-weight:500}
.hero-cta{display:flex;gap:1rem;margin-top:2rem;flex-wrap:wrap}
.hero-badges{position:absolute;right:4%;top:clamp(6rem,12vh,8rem);z-index:3;display:flex;flex-direction:column;gap:.65rem;align-items:flex-end;text-align:right}
.hbadge{background:rgba(255,255,255,.14);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);border-radius:14px;padding:.7rem 1rem;font-size:.85rem;font-weight:600}
.hbadge b{font-family:'Fredoka';font-size:1.5rem;display:block;line-height:1}

/* ---------- PAGE HERO (interior) ---------- */
.phero{position:relative;color:#fff;display:flex;align-items:flex-end;min-height:clamp(340px,52vh,480px);overflow:hidden}
.phero-bg{position:absolute;inset:0;background-position:center;background-size:cover}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,44,59,.3),rgba(11,44,59,.85))}
.phero .wrap{position:relative;z-index:2;padding-bottom:clamp(2rem,5vh,3.5rem);padding-top:3rem}
.phero h1{font-size:clamp(2.2rem,5vw,3.8rem);margin:.4rem 0 .6rem;text-shadow:0 2px 24px rgba(0,0,0,.25)}
.phero p{font-size:clamp(1.05rem,2vw,1.25rem);color:#eef4f6;max-width:52ch;font-weight:500}
.crumbs{font-size:.85rem;color:#bcd1d9;font-weight:600;margin-bottom:.4rem}
.crumbs a:hover{color:#fff}

/* ---------- STATS ---------- */
.stats{background:var(--navy);color:#fff;padding:2.6rem 0}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat b{font-family:'Fredoka';font-size:clamp(2.2rem,4vw,3.1rem);font-weight:600;color:var(--gold);display:block;line-height:1}
.stat span{font-size:.92rem;color:#bcd1d9;font-weight:600;letter-spacing:.02em}

/* ---------- SECTION HEAD ---------- */
.sec-head{max-width:62ch}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.2rem);margin:.6rem 0 1rem;color:var(--navy)}
.sec-head p{color:var(--muted);font-size:1.1rem}

/* PILARES */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.pillar{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem 1.8rem;transition:transform .3s,box-shadow .3s}
.pillar:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pillar .pico{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:var(--cream-2);margin-bottom:1.2rem}
.pillar .pico svg{width:30px;height:30px;stroke:var(--coral);fill:none;stroke-width:1.8}
.pillar h3{font-size:1.4rem;color:var(--navy);margin-bottom:.5rem}
.pillar p{color:var(--muted);font-size:1rem}

/* COMO FUNCIONA */
.how{background:var(--cream-2)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:3rem;counter-reset:s}
.step{background:#fff;border-radius:var(--r);padding:2rem 1.5rem;position:relative;border:1px solid var(--line)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Fredoka';font-size:2.6rem;color:var(--coral);opacity:.28;font-weight:600;line-height:1;display:block;margin-bottom:.6rem}
.step h4{font-size:1.18rem;color:var(--navy);margin-bottom:.4rem}
.step p{font-size:.95rem;color:var(--muted)}

/* VIAJES grid */
.trips{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.trip{position:relative;border-radius:var(--r);overflow:hidden;min-height:380px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;box-shadow:var(--shadow);isolation:isolate}
.trip .tbg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease;z-index:-2}
.trip:hover .tbg{transform:scale(1.08)}
.trip::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,44,59,0) 30%,rgba(11,44,59,.88) 100%);z-index:-1}
.trip .tcontent{padding:1.7rem}
.trip .ttag{display:inline-block;background:var(--coral);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.3em .8em;border-radius:999px;margin-bottom:.7rem}
.trip h3{font-size:1.75rem;font-weight:600}
.trip .tmeta{font-size:.92rem;color:#dceaef;font-weight:600;margin-top:.3rem}
.trip .tarrow{margin-top:1rem;font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;gap:.4em;color:#ffd9c8}
.trip.gradient-1 .tbg{background:linear-gradient(150deg,#0A6E94,#075E80 70%)}
.trip.gradient-2 .tbg{background:linear-gradient(150deg,#9c3b3b,#5e1f24 70%)}
.trip.gradient-3 .tbg{background:linear-gradient(150deg,#0E9AD4,#075E80 70%)}
.trip.gradient-4 .tbg{background:linear-gradient(150deg,#3a6b4f,#10302a 70%)}
.trip.gradient-5 .tbg{background:linear-gradient(150deg,#7a5a8c,#3a2a47 70%)}
.trip .placeholder-note{position:absolute;top:1rem;left:1rem;z-index:1;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);font-size:.68rem;font-weight:700;letter-spacing:.04em;padding:.3em .7em;border-radius:999px;color:#fff}
.trips-foot{text-align:center;margin-top:2.6rem}

/* SPLIT (experiencia) */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:var(--navy)}
.split.rev{grid-template-columns:.95fr 1.05fr}
.split.rev .ximg{order:2}
.split .ximg{background-size:cover;background-position:center;min-height:420px}
.split .xtext{padding:clamp(2.2rem,4vw,3.4rem);color:#fff;display:flex;flex-direction:column;justify-content:center}
.split .xtext .eyebrow{color:var(--gold)}
.split .xtext h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.7rem);margin:.6rem 0 1rem}
.split .xtext p{color:#cddde3;font-size:1.05rem;margin-bottom:1rem}
.checklist{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-top:.5rem}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;font-weight:600;color:#eaf2f4}
.checklist svg{width:22px;height:22px;flex:none;margin-top:2px;stroke:var(--coral);fill:none;stroke-width:2}

/* BENEFICIOS band */
.benefits{background:linear-gradient(135deg,var(--coral),var(--coral-dark));color:#fff;border-radius:var(--r);padding:clamp(2.5rem,5vw,4rem);text-align:center;overflow:hidden;position:relative}
.benefits::before{content:"";position:absolute;width:340px;height:340px;background:rgba(255,255,255,.1);border-radius:50%;top:-120px;right:-80px}
.benefits::after{content:"";position:absolute;width:240px;height:240px;background:rgba(255,255,255,.08);border-radius:50%;bottom:-110px;left:-60px}
.benefits .inner{position:relative;z-index:2}
.benefits .eyebrow{color:#ffe6db}
.benefits h2{color:#fff;font-size:clamp(1.9rem,4vw,2.9rem);margin:.5rem auto 1rem;max-width:18ch}
.benefits p{max-width:52ch;margin:0 auto 1.8rem;font-size:1.1rem;color:#fff;opacity:.95}

/* TESTIMONIOS — grid estático (Nosotros y otras páginas internas) */
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.testi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem 1.8rem;position:relative}
.testi .quote{font-family:'Fredoka';font-size:3.5rem;color:var(--coral);opacity:.25;line-height:.7;position:absolute;top:1.2rem;left:1.4rem}
.testi p{font-size:1.05rem;color:var(--ink);margin:1.4rem 0 1.3rem;position:relative}
.testi .who{display:flex;align-items:center;gap:.8rem}
.testi .av{width:46px;height:46px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;font-family:'Fredoka';font-weight:600;color:var(--navy);font-size:1.1rem}
.testi .who b{display:block;font-size:.98rem;color:var(--navy)}
.testi .who span{font-size:.85rem;color:var(--muted)}
.stars{color:var(--gold);font-size:1rem;letter-spacing:2px}

/* TESTIMONIOS — carrusel (Home) */
.testis-wrap{position:relative;margin-top:3rem}
.testis-viewport{overflow:hidden;border-radius:4px}
.testis-wrap .testis{display:flex!important;gap:1.5rem;margin-top:0;transition:transform .48s cubic-bezier(.4,0,.2,1);will-change:transform;grid-template-columns:unset}
.testis-wrap .testi{flex-shrink:0;min-width:0;/* ancho seteado por JS */}
/* Flechas nav */
.tn-prev,.tn-next{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border-radius:50%;background:#fff;border:1.5px solid var(--line);cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 20px -8px rgba(7,94,128,.28);transition:background .22s,border-color .22s,transform .22s}
.tn-prev{left:-23px}
.tn-next{right:-23px}
.tn-prev:hover,.tn-next:hover{background:var(--coral);border-color:var(--coral);transform:translateY(-50%) scale(1.1)}
.tn-prev svg,.tn-next svg{width:18px;height:18px;stroke:var(--navy);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:stroke .22s}
.tn-prev:hover svg,.tn-next:hover svg{stroke:#fff}
.tn-prev:disabled,.tn-next:disabled{opacity:.3;cursor:default;pointer-events:none}
/* Dots */
.testis-dots{display:flex;gap:.5rem;justify-content:center;margin-top:1.8rem}
.testis-dots span{width:8px;height:8px;border-radius:50%;background:rgba(7,94,128,.18);cursor:pointer;transition:background .25s,transform .25s}
.testis-dots span.active{background:var(--coral);transform:scale(1.3)}
/* Ocultar flechas en móvil muy pequeño (swipe alcanza) */
@media(max-width:460px){.tn-prev{left:-14px}.tn-next{right:-14px}}

/* FAQ */
.faq-wrap{max-width:840px;margin:3rem auto 0}
.faq{border-bottom:1px solid var(--line)}
.faq button{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1.4rem .3rem;font-family:'Manrope';font-weight:700;font-size:1.12rem;color:var(--navy)}
.faq .ficon{flex:none;width:30px;height:30px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;transition:.3s;position:relative}
.faq .ficon::before,.faq .ficon::after{content:"";position:absolute;background:var(--coral);border-radius:2px}
.faq .ficon::before{width:13px;height:2.5px}
.faq .ficon::after{width:2.5px;height:13px;transition:transform .3s}
.faq.open .ficon{background:var(--coral)}
.faq.open .ficon::before,.faq.open .ficon::after{background:#fff}
.faq.open .ficon::after{transform:rotate(90deg);opacity:0}
.faq .ans{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq .ans p{padding:0 .3rem 1.4rem;color:var(--muted);font-size:1.02rem}

/* CONTACTO */
.contact{background:var(--navy);color:#fff}
.contact .grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start}
.contact .eyebrow{color:var(--gold)}
.contact h2{color:#fff;font-size:clamp(2rem,4vw,2.9rem);margin:.5rem 0 1rem}
.contact .clead{color:#bcd1d9;font-size:1.08rem;margin-bottom:2rem;max-width:42ch}
.cinfo{display:flex;flex-direction:column;gap:1.3rem}
.cinfo .ci{display:flex;gap:1rem;align-items:flex-start}
.cinfo .ci .cic{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.1);display:grid;place-items:center;flex:none}
.cinfo .ci svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:1.8}
.cinfo .ci b{display:block;font-family:'Manrope';font-weight:700;font-size:1rem}
.cinfo .ci span,.cinfo .ci a{color:#bcd1d9;font-size:.98rem}
.cinfo .ci a:hover{color:#fff}
.cform{background:#fff;border-radius:var(--r);padding:clamp(1.8rem,3vw,2.6rem);color:var(--ink)}
.cform h3{color:var(--navy);font-size:1.5rem;margin-bottom:1.3rem}
.field{margin-bottom:1.05rem}
.field label{display:block;font-weight:700;font-size:.85rem;color:var(--navy);margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;padding:.85em 1em;border:1.5px solid var(--line);border-radius:12px;font-family:'Manrope';font-size:1rem;color:var(--ink);background:var(--cream);transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(226,116,79,.15)}
.field textarea{resize:vertical;min-height:90px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cform .btn{width:100%;justify-content:center;margin-top:.4rem}
.cnote{font-size:.8rem;color:var(--muted);margin-top:.9rem;text-align:center}

/* ---------- NOSOTROS ---------- */
.story{display:grid;grid-template-columns:1.15fr .85fr;gap:3.5rem;align-items:center}
.story h2{font-size:clamp(1.9rem,4vw,2.8rem);color:var(--navy);margin-bottom:1.2rem}
.story p{color:var(--ink);margin-bottom:1.1rem;font-size:1.06rem}
.story .lead-q{font-family:'Fredoka';font-style:normal;font-size:1.3rem;color:var(--coral-dark);line-height:1.35;margin:1.4rem 0;padding-left:1.2rem;border-left:3px solid var(--coral)}
.story-img{position:relative}
.story-img .ph{aspect-ratio:4/5;border-radius:var(--r);background-size:cover;background-position:center;box-shadow:var(--shadow)}
.story-img .cap{position:absolute;bottom:-18px;left:50%;transform:translateX(-50%);background:#fff;border:1px solid var(--line);border-radius:14px;padding:.7rem 1.3rem;box-shadow:var(--shadow);text-align:center;white-space:nowrap}
.story-img .cap b{font-family:'Fredoka';color:var(--navy);display:block;font-size:1.05rem}
.story-img .cap span{font-size:.82rem;color:var(--muted)}
.portrait-fallback{aspect-ratio:4/5;border-radius:var(--r);background:linear-gradient(150deg,var(--teal),var(--navy));display:grid;place-items:center;box-shadow:var(--shadow)}
.portrait-fallback span{font-family:'Fredoka';font-size:5rem;color:rgba(255,255,255,.9)}

.values{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:3rem}
.value{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.6rem 1.3rem;text-align:center}
.value .vico{font-size:1.8rem;margin-bottom:.5rem}
.value b{display:block;font-family:'Fredoka';color:var(--navy);font-size:1.15rem;margin-bottom:.3rem}
.value span{font-size:.9rem;color:var(--muted)}

.timeline{max-width:760px;margin:3rem auto 0;position:relative;padding-left:2rem}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl{position:relative;padding:0 0 2rem 1.5rem}
.tl::before{content:"";position:absolute;left:-2rem;top:4px;width:16px;height:16px;border-radius:50%;background:var(--coral);border:3px solid var(--cream);transform:translateX(-1px)}
.tl b{font-family:'Fredoka';color:var(--navy);font-size:1.25rem;display:block;margin-bottom:.2rem}
.tl span{color:var(--muted)}

.team{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.member{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2rem;text-align:center}
.member .mav{width:84px;height:84px;border-radius:50%;margin:0 auto 1rem;background:linear-gradient(150deg,var(--coral),var(--coral-dark));display:grid;place-items:center;font-family:'Fredoka';font-size:1.8rem;color:#fff}
.member b{font-family:'Fredoka';color:var(--navy);font-size:1.25rem;display:block}
.member .role{color:var(--coral);font-weight:700;font-size:.85rem;letter-spacing:.04em;margin:.2rem 0 .6rem}
.member p{color:var(--muted);font-size:.95rem}

/* ---------- FICHA DE VIAJE ---------- */
.trip-bar{background:var(--cream-2);border-bottom:1px solid var(--line)}
.trip-bar .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.6rem 0}
.tb-item{display:flex;gap:.8rem;align-items:center}
.tb-item .ico{width:42px;height:42px;border-radius:12px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;flex:none}
.tb-item svg{width:20px;height:20px;stroke:var(--coral);fill:none;stroke-width:1.8}
.tb-item b{display:block;color:var(--navy);font-size:1rem;font-family:'Manrope';font-weight:700}
.tb-item span{font-size:.82rem;color:var(--muted)}

.trip-layout{display:grid;grid-template-columns:1fr 360px;gap:3rem;align-items:start}
.itin{position:relative}
.itin h2{color:var(--navy);font-size:clamp(1.8rem,3.5vw,2.5rem);margin-bottom:.4rem}
.itin .isub{color:var(--muted);margin-bottom:2rem}
.day{display:grid;grid-template-columns:auto 1fr;gap:1.3rem;padding:1.4rem 0;border-bottom:1px solid var(--line)}
.day .dnum{font-family:'Fredoka';color:#fff;background:var(--navy);width:54px;height:54px;border-radius:14px;display:grid;place-items:center;text-align:center;line-height:1.05;font-size:.7rem;font-weight:600;flex:none}
.day .dnum b{font-size:1.3rem;display:block}
.day h4{color:var(--navy);font-size:1.2rem;margin-bottom:.3rem}
.day p{color:var(--muted);font-size:.98rem}
.day .dtag{display:inline-block;background:var(--cream-2);color:var(--coral-dark);font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.25em .7em;border-radius:999px;margin-top:.5rem}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:3rem 0}
.gallery .g{border-radius:16px;overflow:hidden;aspect-ratio:4/3}
.gallery .g img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery .g:hover img{transform:scale(1.07)}
.gallery .g.wide{grid-column:span 2;aspect-ratio:auto}

.price-card{position:sticky;top:90px;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.price-card .pc-top{background:var(--navy);color:#fff;padding:1.8rem;text-align:center}
.price-card .pc-top .from{font-size:.82rem;color:#bcd1d9;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.price-card .pc-top .amount{font-family:'Fredoka';font-size:2.8rem;font-weight:600;line-height:1;margin:.3rem 0}
.price-card .pc-top .per{font-size:.85rem;color:#bcd1d9}
.price-card .pc-body{padding:1.6rem 1.8rem}
.price-card ul{list-style:none;display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.4rem}
.price-card li{display:flex;gap:.6rem;align-items:flex-start;font-size:.93rem;color:var(--ink)}
.price-card li svg{width:18px;height:18px;flex:none;margin-top:3px;stroke:var(--coral);fill:none;stroke-width:2.2}
.price-card .single{font-size:.85rem;color:var(--muted);text-align:center;margin-bottom:1.2rem;padding-top:1rem;border-top:1px dashed var(--line)}
.price-card .btn{width:100%;justify-content:center}
.deadline{background:var(--cream-2);border-radius:14px;padding:1rem;text-align:center;margin-bottom:1.4rem}
.deadline span{font-size:.78rem;color:var(--muted);font-weight:700;letter-spacing:.05em;text-transform:uppercase;display:block}
.deadline b{font-family:'Fredoka';color:var(--coral-dark);font-size:1.3rem}

/* ---------- FOOTER ---------- */
footer.site{background:var(--navy-2);color:#9fb8c1;padding:3.5rem 0 2rem;font-size:.92rem}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
footer.site h5{font-family:'Manrope';color:#fff;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem;font-weight:800}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
footer.site a:hover{color:#fff}
.fbrand .brand .logo-txt b{color:#fff}
.fbrand p{margin-top:1rem;max-width:30ch;line-height:1.6}
.fsocial{display:flex;gap:.8rem;margin-top:1.2rem}
.fsocial a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:.25s}
.fsocial a:hover{background:var(--coral)}
.fsocial svg{width:17px;height:17px;fill:#fff}
.fbot{display:flex;justify-content:space-between;gap:1rem;padding-top:1.8rem;flex-wrap:wrap;font-size:.82rem;color:#7a96a0}
.evt{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.06);padding:.4rem .8rem;border-radius:8px;font-weight:600}

/* WHATSAPP FLOAT */
.wa{position:fixed;right:20px;bottom:20px;z-index:80;width:60px;height:60px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 10px 30px -6px rgba(37,211,102,.45);transition:transform .25s;animation:wa-pulse 2.2s ease-in-out infinite}
.wa:hover{transform:scale(1.08);animation:none}
.wa svg{width:32px;height:32px;fill:#fff}
/* ── WhatsApp float mejorado + scroll-to-top ─────────────────────────────── */
@keyframes wa-pulse{0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}}
.to-top{position:fixed;right:20px;bottom:92px;z-index:79;width:44px;height:44px;border-radius:50%;background:var(--navy);border:none;cursor:pointer;display:grid;place-items:center;box-shadow:0 4px 14px -4px rgba(7,94,128,.45);transition:opacity .3s,transform .3s;opacity:0;pointer-events:none;transform:translateY(8px)}
.to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.to-top:hover{background:var(--navy-2);transform:translateY(-2px)}
.to-top svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}


/* REVEAL (degradación elegante: sin JS el contenido se ve igual) */
.reveal{transition:opacity .7s ease,transform .7s ease}
.js .reveal{opacity:0;transform:translateY(26px)}
.js .reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .pillars,.testis,.team{grid-template-columns:1fr 1fr}
  .steps,.values{grid-template-columns:1fr 1fr}
  .trips{grid-template-columns:1fr 1fr}
  .split,.split.rev{grid-template-columns:1fr}
  .split.rev .ximg{order:0}
  .story{grid-template-columns:1fr;gap:2.5rem}
  .contact .grid{grid-template-columns:1fr;gap:2.2rem}
  .trip-layout{grid-template-columns:1fr;gap:2rem}
  .price-card{position:static}
  .trip-bar .wrap{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .hero-badges{display:none}
}
@media(max-width:680px){
  body{font-size:17px}
  header.site{backdrop-filter:none;-webkit-backdrop-filter:none;background:var(--cream)}
  .menu{position:fixed;inset:0 0 0 auto;width:min(82%,330px);background:var(--cream);flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:5.5rem 2rem 2rem;gap:1.4rem;transform:translateX(100%);transition:transform .35s ease;box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);z-index:90}
  .menu.open{transform:none}
  .menu a{font-size:1.15rem}
  .burger{display:flex;z-index:95}
  .wa{z-index:50}
  .nav-cta .btn{display:none}
  .pillars,.testis,.steps,.trips,.team,.gallery{grid-template-columns:1fr}
  .values{grid-template-columns:1fr 1fr}
  .stats .grid{grid-template-columns:1fr 1fr;gap:2rem 1rem}
  .frow{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr;gap:1.8rem}
  .trip-bar .wrap{grid-template-columns:1fr}
  .gallery .g.wide{grid-column:span 1}
  .topbar .tb-left{font-size:.74rem;gap:.9rem}
  .hero h1{font-size:2.5rem}
}

/* ============ PÁGINAS INTERNAS ADICIONALES ============ */
/* Próximos viajes: etiqueta de año */
.year-label{display:flex;align-items:center;gap:1rem;margin:2.6rem 0 1.6rem}
.year-label h3{font-family:'Fredoka',sans-serif;color:var(--navy);font-size:1.7rem;white-space:nowrap}
.year-label::after{content:"";flex:1;height:1px;background:var(--line)}

/* Beneficios: cómo se gana */
.earn{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.earn .e{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem 1.8rem;text-align:center}
.earn .e .en{width:54px;height:54px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;margin:0 auto 1.1rem;font-family:'Fredoka';font-size:1.4rem;color:var(--coral);font-weight:600}
.earn .e h4{color:var(--navy);font-size:1.25rem;margin-bottom:.4rem}
.earn .e p{color:var(--muted);font-size:.96rem}

/* Beneficios: niveles */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem;align-items:start}
.tier{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:2.2rem 1.9rem;position:relative;transition:transform .3s,box-shadow .3s}
.tier:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tier.feat{border-color:var(--coral);box-shadow:0 18px 50px -24px rgba(226,116,79,.5)}
.tier .badge{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--navy);padding:.3em .9em;border-radius:999px;margin-bottom:1rem}
.tier.feat .badge{background:var(--coral)}
.tier h3{font-family:'Fredoka',sans-serif;color:var(--navy);font-size:1.6rem;margin-bottom:.2rem}
.tier .tsub{color:var(--muted);font-size:.9rem;margin-bottom:1.4rem}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.tier li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink)}
.tier li svg{width:18px;height:18px;flex:none;margin-top:3px;stroke:var(--coral);fill:none;stroke-width:2.2}

/* Tours en Buenos Aires */
.tours-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:3rem}
.tourcard{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.tourcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tourcard .timg{height:230px;background-size:cover;background-position:center;position:relative;display:flex;align-items:flex-end;padding:1.3rem}
.tourcard .timg.g-barolo{background:linear-gradient(150deg,#0E9AD4,#075E80)}
.tourcard .timg.g-bencich{background:linear-gradient(150deg,#c95c38,#7a2f1c)}
.tourcard .timg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,44,59,.5))}
.tourcard .timg .ph-note{position:absolute;top:1rem;right:1rem;z-index:2;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);font-size:.66rem;font-weight:700;padding:.3em .7em;border-radius:999px;color:#fff}
.tourcard .timg h3{position:relative;z-index:2;color:#fff;font-size:1.8rem;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.tourcard .tbody{padding:1.7rem 1.9rem;flex:1;display:flex;flex-direction:column}
.tourcard .tbody p{color:var(--muted);font-size:1rem;margin-bottom:1.3rem;flex:1}
.tourcard .tmeta-row{display:flex;gap:1.3rem;font-size:.85rem;color:var(--navy);font-weight:700;margin-bottom:1.3rem;flex-wrap:wrap}
.tourcard .tmeta-row span{display:inline-flex;align-items:center;gap:.4em}
.tourcard .tmeta-row svg{width:16px;height:16px;stroke:var(--coral);fill:none;stroke-width:2}

/* Mapa */
.map-embed{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);min-height:360px}
.map-embed iframe{width:100%;height:100%;min-height:360px;border:0;display:block;filter:grayscale(.2)}

/* CTA band */
.cta-band{background:var(--navy);color:#fff;border-radius:var(--r);padding:clamp(2.2rem,4vw,3.4rem);text-align:center}
.cta-band .eyebrow{color:var(--gold)}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3.5vw,2.5rem);margin:.5rem 0 .7rem}
.cta-band p{color:#bcd1d9;max-width:50ch;margin:0 auto 1.7rem}

@media(max-width:980px){.tiers,.tours-grid,.earn{grid-template-columns:1fr}}
@media(max-width:680px){.tiers,.tours-grid,.earn{grid-template-columns:1fr}}

/* ============ GALERÍA DE VIAJES (mosaico) ============ */
.photo-gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:190px;grid-auto-flow:dense;gap:12px;margin-top:3rem}
.photo-gallery .pg{overflow:hidden;border-radius:16px;position:relative;cursor:pointer}
.photo-gallery .pg img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.photo-gallery .pg:hover img{transform:scale(1.07)}
.photo-gallery .pg::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(11,44,59,.55),transparent 45%);opacity:.5;transition:opacity .3s}
.photo-gallery .pg:hover::after{opacity:.9}
.photo-gallery .pg .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:1rem 1.1rem;color:#fff;font-weight:700;font-size:.92rem;text-shadow:0 1px 8px rgba(0,0,0,.4);transform:translateY(6px);opacity:0;transition:.3s}
.photo-gallery .pg:hover .cap{transform:none;opacity:1}
.photo-gallery .pg .cap span{display:block;font-weight:600;font-size:.76rem;color:#ffd9c8}
.photo-gallery .pg.tall{grid-row:span 2}
.photo-gallery .pg.wide{grid-column:span 2}
@media(max-width:860px){.photo-gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}.photo-gallery .pg.wide{grid-column:span 2}.photo-gallery .pg .cap{opacity:1;transform:none}}
@media(max-width:520px){.photo-gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:130px}}

/* ===== Carrusel de videos (Lu en TV / VEC en video) ===== */
.vtabs{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;margin:0 0 34px}
.vtab{appearance:none;border:1px solid var(--line);background:#fff;color:var(--navy);
  font-family:inherit;font-weight:600;font-size:.92rem;padding:9px 20px;border-radius:999px;
  cursor:pointer;transition:.2s}
.vtab:hover{border-color:var(--teal);color:var(--teal)}
.vtab.active{background:var(--navy);border-color:var(--navy);color:#fff}
.vcarousel{position:relative}
.vtrack{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;
  scroll-behavior:smooth;padding:6px 4px 18px;-ms-overflow-style:none;scrollbar-width:none}
.vtrack::-webkit-scrollbar{display:none}
.vcard{flex:0 0 330px;max-width:330px;scroll-snap-align:start;background:#fff;border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.vcard.hide{display:none}
.vthumb{position:relative;aspect-ratio:16/9;background-size:cover;background-position:center;
  cursor:pointer;background-color:var(--navy-2)}
.vthumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(11,44,59,.45));
  opacity:.6;transition:.2s}
.vthumb.playing::after,.vthumb.playing:hover::after{display:none;pointer-events:none}
.vthumb:hover::after{opacity:.85}
.vplay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:60px;height:60px;
  border:none;border-radius:50%;background:var(--coral);color:#fff;cursor:pointer;display:grid;
  place-items:center;box-shadow:0 8px 22px -6px rgba(226,116,79,.7);transition:.2s;z-index:1}
.vthumb:hover .vplay{transform:translate(-50%,-50%) scale(1.08);background:var(--coral-dark)}
.vplay svg{width:26px;height:26px;fill:#fff;margin-left:3px}
.vthumb iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vclose{position:absolute;top:8px;right:8px;z-index:10;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.6);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.vclose:hover{background:rgba(0,0,0,.85)}
.vclose svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2.5}
.vmeta{padding:16px 18px 20px;display:flex;flex-direction:column;gap:7px}
.vtag{font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--teal)}
.vmeta h4{font-family:'Fredoka',sans-serif;font-weight:600;font-size:1.05rem;line-height:1.25;
  color:var(--navy);margin:0}
.vnav{position:absolute;top:calc(50% - 30px);transform:translateY(-50%);width:46px;height:46px;
  border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--navy);cursor:pointer;
  display:grid;place-items:center;box-shadow:var(--shadow);z-index:3;transition:.2s}
.vnav:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.vnav svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2.4;
  stroke-linecap:round;stroke-linejoin:round}
.vnav.prev{left:-10px}.vnav.next{right:-10px}
.vfoot{text-align:center;margin-top:30px}
@media(max-width:720px){
  .vcard{flex-basis:78vw;max-width:78vw}
  .vnav{display:none}
  .vtrack{padding-left:16px;padding-right:16px}
}

/* ================================================
   CARRUSEL DE FOTOS — páginas de destino
   (Asunción, China, Países Nórdicos)
   ================================================ */
.carousel{position:relative;width:100%;border-radius:14px;overflow:hidden;background:#0a2a35;aspect-ratio:16/9;margin-bottom:1.5rem}
.carousel-track{display:flex;height:100%;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.carousel-track img{min-width:100%;height:100%;object-fit:cover;display:block}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.18);backdrop-filter:blur(6px);border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s}
.carousel-btn:hover{background:rgba(255,255,255,.35)}
.carousel-btn svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.5}
.carousel-btn.prev{left:12px}
.carousel-btn.next{right:12px}
.carousel-dots{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);display:flex;gap:6px}
.carousel-dots span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:background .2s}
.carousel-dots span.active{background:#fff}

/* ================================================
   MAPA DE RECORRIDO — páginas de destino
   ================================================ */
.trip-map{margin:2rem 0 1.5rem}
.trip-map .map-label{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}
.trip-map .map-label svg{width:18px!important;height:18px!important;stroke:var(--sky);fill:none;stroke-width:2;flex-shrink:0}
.trip-map .map-label span{font-family:var(--ff-head);font-size:1rem;font-weight:600;color:var(--navy)}
.trip-map iframe{width:100%;height:420px;border:none;border-radius:14px;box-shadow:0 4px 24px rgba(7,94,128,.13)}
.trip-map .map-full{display:block;text-align:right;margin-top:.5rem;font-size:.82rem;color:var(--sky);text-decoration:none;font-weight:600}
.trip-map .map-full:hover{text-decoration:underline}
@media(max-width:700px){.trip-map iframe{height:280px}}


/* ================================================
   TICKETS / TOURS EN BUENOS AIRES
   ================================================ */
/* ── Tickets section ─────────────────────────────────── */
.tickets-intro{text-align:center;margin-bottom:2.5rem}
.season-toggle{display:inline-flex;background:var(--cream-2);border:1px solid var(--line);border-radius:999px;padding:.3rem;gap:.3rem;margin:1.5rem auto 0;justify-content:center}
.season-toggle button{border:none;background:transparent;font-family:'Manrope';font-weight:700;font-size:.88rem;padding:.55em 1.4em;border-radius:999px;cursor:pointer;color:var(--muted);transition:all .2s}
.season-toggle button.active{background:var(--navy);color:#fff;box-shadow:0 4px 12px -4px rgba(7,94,128,.4)}
.ticket-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-top:2rem}
.ticket-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.ticket-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.ticket-card .tc-img{height:190px;background-size:cover;background-position:center;position:relative}
.ticket-card .tc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(7,50,75,.65))}
.ticket-card .tc-img .tc-badge{position:absolute;top:1rem;left:1rem;z-index:2;background:var(--coral);color:#fff;font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.3em .85em;border-radius:999px}
.ticket-card .tc-img h3{position:absolute;bottom:1rem;left:1.2rem;right:1.2rem;z-index:2;color:#fff;font-size:1.35rem;font-family:'Fredoka';font-weight:600;line-height:1.2;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.ticket-body{padding:1.5rem 1.6rem;flex:1;display:flex;flex-direction:column;gap:.9rem}
.ticket-meta{display:flex;flex-wrap:wrap;gap:.7rem}
.ticket-meta span{display:inline-flex;align-items:center;gap:.35em;font-size:.82rem;font-weight:700;color:var(--navy)}
.ticket-meta svg{width:14px;height:14px;stroke:var(--coral);fill:none;stroke-width:2;flex-shrink:0}
.ticket-desc{color:var(--muted);font-size:.93rem;line-height:1.55;flex:1}
.ticket-prices{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem}
.ticket-prices .tp-label{font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:.28rem 0}
.price-row+.price-row{border-top:1px solid var(--line)}
.price-row .pr-name{font-size:.85rem;color:var(--ink);font-weight:600}
.price-row .pr-val{font-family:'Fredoka';font-size:1.15rem;font-weight:600;color:var(--navy)}
.ticket-actions{display:flex;flex-direction:column;gap:.6rem;margin-top:.2rem}
.btn-paypal{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:'Manrope';font-weight:700;font-size:.95rem;padding:.75em 1.4em;border-radius:999px;background:#003087;color:#fff;text-decoration:none;transition:all .2s;border:none;cursor:pointer;width:100%}
.btn-paypal:hover{background:#001f5e;transform:translateY(-2px)}
.btn-paypal svg{width:18px;height:18px;fill:#009cde}
.btn-mp{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:'Manrope';font-weight:700;font-size:.95rem;padding:.75em 1.4em;border-radius:999px;background:#009ee3;color:#fff;text-decoration:none;transition:all .2s;border:none;cursor:pointer;width:100%}
.btn-mp:hover{background:#007ab8;transform:translateY(-2px)}
.btn-mp svg{width:18px;height:18px;fill:#fff}
.ticket-note{font-size:.75rem;color:var(--muted);text-align:center;margin-top:.1rem}
/* Aviso temporada */
.season-notice{display:inline-flex;align-items:center;gap:.5em;background:var(--cream-2);border:1px solid var(--line);border-radius:8px;font-size:.8rem;font-weight:700;color:var(--navy);padding:.45em 1em;margin-top:.8rem}
.season-notice svg{width:14px;height:14px;stroke:var(--coral);fill:none;stroke-width:2;flex-shrink:0}
/* Info general */
.tours-info{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.2rem;margin-top:2.5rem}
.ti-item{display:flex;align-items:flex-start;gap:.9rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.2rem 1.3rem}
.ti-icon{width:36px;height:36px;border-radius:10px;background:var(--cream-2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ti-icon svg{width:18px;height:18px;stroke:var(--navy);fill:none;stroke-width:2}
.ti-item strong{display:block;font-size:.88rem;color:var(--navy);margin-bottom:.15rem}
.ti-item span{font-size:.82rem;color:var(--muted)}
@media(max-width:680px){.ticket-grid{grid-template-columns:1fr}.tours-info{grid-template-columns:1fr 1fr}}
@media(max-width:420px){.tours-info{grid-template-columns:1fr}}
/* Spinner cantidad */
.qty-block{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:.75rem 1.1rem;gap:.5rem}
.qty-label{font-size:.82rem;font-weight:700;color:var(--navy)}
.qty-ctrl{display:flex;align-items:center;gap:.5rem}
.qty-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);background:#fff;color:var(--navy);font-size:1.1rem;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}
.qty-btn:hover{background:var(--sky);border-color:var(--sky);color:#fff}
.qty-num{font-family:'Fredoka';font-size:1.2rem;font-weight:600;color:var(--ink);min-width:1.6rem;text-align:center}
.qty-total{font-size:.78rem;font-weight:700;color:var(--muted);margin-top:-.3rem;text-align:right;min-height:1em}
/* Formulario de fecha */
.date-form{background:var(--cream);border:1.5px solid var(--sky);border-radius:14px;padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.75rem}
.date-form .df-title{font-size:.76rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--sky)}
.date-form label{font-size:.83rem;font-weight:700;color:var(--navy);display:flex;flex-direction:column;gap:.3rem}
.date-form input[type=date],.date-form input[type=text]{font-family:'Manrope';font-size:.88rem;border:1.5px solid var(--line);border-radius:8px;padding:.45em .7em;color:var(--ink);background:#fff;width:100%;box-sizing:border-box}
.date-form input:focus{outline:none;border-color:var(--sky)}
.btn-wa-reserva{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:'Manrope';font-weight:700;font-size:.91rem;padding:.7em 1.2em;border-radius:999px;background:#25D366;color:#fff;border:none;cursor:pointer;width:100%;text-decoration:none;transition:all .2s;box-sizing:border-box}
.btn-wa-reserva:hover{background:#1ebe5d;transform:translateY(-2px)}
.btn-wa-reserva svg{width:16px;height:16px;fill:#fff;flex-shrink:0}
/* Botón reserva WP */
.btn-wp-reserva{display:inline-flex;align-items:center;justify-content:center;gap:.55em;font-family:'Manrope';font-weight:700;font-size:.91rem;padding:.7em 1.2em;border-radius:999px;background:var(--navy);color:#fff;border:none;cursor:pointer;width:100%;text-decoration:none;transition:all .2s;box-sizing:border-box}
.btn-wp-reserva:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-wp-reserva svg{width:15px;height:15px;stroke:#fff;fill:none;flex-shrink:0}
/* Select dentro del date-form */
.df-select{font-family:'Manrope';font-size:.88rem;border:1.5px solid var(--line);border-radius:8px;padding:.45em .7em;color:var(--ink);background:#fff;width:100%;box-sizing:border-box;appearance:none;-webkit-appearance:none;cursor:pointer}
.df-select:focus{outline:none;border-color:var(--sky)}

/* Inputs de texto/tel/email dentro del date-form */
.df-input{font-family:'Manrope';font-size:.88rem;border:1.5px solid var(--line);border-radius:8px;padding:.45em .7em;color:var(--ink);background:#fff;width:100%;box-sizing:border-box}
.df-input:focus{outline:none;border-color:var(--sky)}
/* Botón Confirmar mi reserva */
.reserva-btn{width:100%;justify-content:center;font-size:.88rem;padding:.7em 1.2em}
.reserva-btn svg{width:16px;height:16px;stroke:#fff;fill:none;flex-shrink:0}
/* Confirmación de reserva enviada */
.reserva-ok{display:flex;align-items:center;gap:.6rem;background:#e8f8e8;border:1.5px solid #4caf50;border-radius:10px;padding:.75rem 1rem;color:#2e7d32}
.reserva-ok svg{width:20px;height:20px;stroke:#4caf50;fill:none;flex-shrink:0}
.reserva-ok p{margin:0;font-size:.84rem;font-weight:600}
/* Mini Calendario */
.mini-cal{background:#fff;border-radius:10px;padding:.75rem;border:1px solid rgba(7,94,128,.15)}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}
.cal-month-label{font-size:.82rem;font-weight:700;color:var(--navy);text-align:center;flex:1}
.cal-nav{background:none;border:none;cursor:pointer;color:var(--sky);font-size:1.25rem;padding:0;line-height:1;border-radius:50%;transition:background .15s;display:flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0}
.cal-nav:hover{background:rgba(0,158,219,.12)}
.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:3px}
.cal-dow-row span{font-size:.67rem;font-weight:700;color:#8a9eb5;text-align:center;padding:.2em 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-day{font-size:.78rem;text-align:center;padding:.35em 0;border-radius:6px;border:none;cursor:default;background:none;color:#ccc;display:flex;align-items:center;justify-content:center;min-height:1.6rem}
button.cal-day.avail{background:rgba(0,158,219,.1);color:var(--navy);cursor:pointer;font-weight:600;transition:background .15s}
button.cal-day.avail:hover{background:rgba(0,158,219,.25)}
.cal-day.sel,.cal-day.sel:hover{background:var(--sky)!important;color:#fff!important;font-weight:700}
.cal-empty{background:none}
.cal-selected-label{font-size:.79rem;color:#a0b2c0;margin-top:.4rem;text-align:center;padding:.3rem 0}
.cal-selected-label.has-date{color:var(--navy);font-weight:700}
/* Separador Bencich */
.section-divider{display:flex;align-items:center;gap:1.2rem;margin:3.5rem 0 2.5rem}
.section-divider::before,.section-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.section-divider-inner{text-align:center;flex-shrink:0}
.section-divider-inner .eyebrow{margin-bottom:.3rem}
.section-divider-inner h2{margin:0;font-size:1.5rem}

/* ═══════════════════════════════════════════════════════════════════
   BLOG — Listado (home.php) y entrada individual (single.php)
═══════════════════════════════════════════════════════════════════ */
.blog-grid{padding:clamp(3rem,7vw,5rem) 0}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:3rem}
.post-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px rgba(7,94,128,.08);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(7,94,128,.16)}
.post-card-img{aspect-ratio:16/9;overflow:hidden;background:var(--cream)}
.post-card-img a{display:block;height:100%}
.post-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.post-card:hover .post-card-img img{transform:scale(1.05)}
.post-card-img .no-thumb{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(135deg,var(--sky) 0%,var(--navy) 100%)}
.post-card-img .no-thumb svg{width:48px;height:48px;stroke:rgba(255,255,255,.45);fill:none}
.post-card-body{padding:1.4rem 1.6rem;display:flex;flex-direction:column;flex:1}
.post-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.7rem;flex-wrap:wrap}
.post-cat{background:var(--sky);color:#fff;font-size:.68rem;font-weight:700;padding:.22rem .7rem;border-radius:99px;text-transform:uppercase;letter-spacing:.06em;text-decoration:none;transition:background .2s}
.post-cat:hover{background:var(--navy);color:#fff}
.post-date{font-size:.78rem;color:var(--navy);opacity:.55;font-weight:600}
.post-card-body h2{font-family:var(--ff-head);font-size:1.15rem;font-weight:600;color:var(--navy);margin:0 0 .55rem;line-height:1.3}
.post-card-body h2 a{color:inherit;text-decoration:none}
.post-card-body h2 a:hover{color:var(--sky)}
.post-excerpt{font-size:.88rem;color:var(--muted);line-height:1.6;flex:1;margin-bottom:1rem}
.post-read{display:inline-flex;align-items:center;gap:.35rem;color:var(--sky);font-weight:700;font-size:.85rem;text-decoration:none;transition:gap .2s,color .2s}
.post-read:hover{color:var(--navy);gap:.55rem}
.post-read svg{width:15px;height:15px;flex-shrink:0}
/* Estado vacío */
.blog-empty{text-align:center;padding:5rem 0}
.blog-empty svg{width:56px;height:56px;color:var(--sky);opacity:.3;margin:0 auto 1rem;display:block}
.blog-empty h3{font-family:var(--ff-head);color:var(--navy);font-size:1.6rem;margin-bottom:.5rem}
.blog-empty p{color:var(--muted);max-width:400px;margin:0 auto 1.8rem}
/* Paginación */
.blog-nav{display:flex;justify-content:center;gap:.4rem;padding:.5rem 0 1rem;flex-wrap:wrap}
.blog-nav .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 .6rem;border-radius:8px;font-size:.9rem;font-weight:700;text-decoration:none;color:var(--navy);background:var(--cream);transition:background .2s,color .2s}
.blog-nav .page-numbers:hover,.blog-nav .page-numbers.current{background:var(--sky);color:#fff}
.blog-nav .page-numbers.dots{background:none}
/* Entrada individual */
.single-content{padding:clamp(3rem,7vw,5rem) 0}
.single-content .wrap{display:grid;grid-template-columns:1fr min(72ch,100%) 1fr}
.single-content .inner{grid-column:2}
.single-body{font-size:1.05rem;line-height:1.78;color:#2d3748}
.single-body h2,.single-body h3,.single-body h4{font-family:var(--ff-head);color:var(--navy);margin-top:2.2rem;margin-bottom:.6rem}
.single-body h2{font-size:1.6rem}
.single-body h3{font-size:1.28rem}
.single-body p{margin:.9rem 0}
.single-body a{color:var(--sky);font-weight:600}
.single-body a:hover{color:var(--navy)}
.single-body img{max-width:100%;border-radius:10px;margin:1.2rem 0;display:block}
.single-body ul,.single-body ol{padding-left:1.6rem;margin:.8rem 0}
.single-body li{margin-bottom:.4rem}
.single-body blockquote{border-left:4px solid var(--sky);margin:1.8rem 0;padding:.9rem 1.4rem;background:var(--cream);border-radius:0 12px 12px 0;font-style:italic;color:var(--navy)}
.single-footer-meta{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--cream)}
.single-tags{display:flex;gap:.5rem;flex-wrap:wrap}
.single-back{display:inline-flex;align-items:center;gap:.4rem;color:var(--sky);font-weight:700;font-size:.88rem;text-decoration:none;margin-top:2rem;transition:color .2s,gap .2s}
.single-back:hover{color:var(--navy);gap:.6rem}
.single-back svg{width:15px;height:15px}
/* Responsive */
@media(max-width:900px){.post-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.post-grid{grid-template-columns:1fr}}
@media(max-width:720px){
  .single-content .wrap{grid-template-columns:1fr;padding-left:4%;padding-right:4%}
  .single-content .inner{grid-column:1}
}

