/* ===== Paleta aproximada del logo (ajústala si tienes PMS exactos)
   --brand-teal: verde/teal oscuro (texto/logotipo)
   --brand-mint: verde agua claro (interiores de la brújula)
   --brand-orange: naranja del globo de chat
   --brand-navy: azul petróleo para contrastes
*/
:root{
  --brand-teal:#0f3b3f;     /* aprox */
  --brand-mint:#c9e6de;     /* aprox */
  --brand-orange:#f47c3c;   /* aprox */
  --brand-navy:#0b2a2e;     /* aprox */
  --bg:#ffffff;
  --ink:#163b40;
  --ink-soft:#325b60;
  --muted:#6d8a8f;
  --card:#f6fbfa;
  --ring: rgba(15,59,63,.2);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
}

/* Layout helpers */
.wrap{width:min(1100px, 92%); margin-inline:auto}
img{max-width:100%; height:auto; display:block}

/* Header */
.site-header{
  background:linear-gradient(180deg, var(--brand-navy), var(--brand-teal));
  color:#fff;
  position:sticky; top:0; z-index:10;
  box-shadow: 0 2px 10px rgba(0,0,0,.15);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0;
}
.brand img{display:block}
.main-nav a{
  color:#e6fffb; text-decoration:none; margin-left:18px; font-weight:600;
}
.main-nav a:hover{color:#fff; text-decoration:underline}

/* Buttons */
.btn{
  display:inline-block; padding:.9rem 1.1rem; border-radius:999px;
  text-decoration:none; font-weight:800; letter-spacing:.2px;
  border:2px solid transparent;
}
.btn--primary{background:var(--brand-orange); color:#fff}
.btn--primary:hover{filter:brightness(.95)}
.btn--secondary{background:#fff; color:var(--brand-teal); border-color:var(--brand-teal)}
.btn--secondary:hover{background:var(--brand-mint)}
.btn--contrast{background:var(--brand-teal); color:#fff}
.btn--whatsapp{background:#25D366; color:#fff}

/* Hero */
.hero{background:linear-gradient(180deg, #ffffff 0%, #f2fbf8 100%)}
.hero-inner{
  display:grid; gap:28px; align-items:center; padding:56px 0;
  grid-template-columns:1.1fr .9fr;
}
.hero h1{font-size:clamp(28px, 4vw, 44px); margin:0 0 8px}
.hero .sub{font-size:1.125rem; color:var(--ink-soft); margin:.2rem 0 1rem}
.hero-art{border-radius:18px; overflow:hidden; box-shadow:0 12px 40px rgba(11,42,46,.18)}

/* Video under title */
.video-wrap{padding-bottom:20px}
.video-embed{position:relative; padding-top:56.25%; border-radius:14px; overflow:hidden; box-shadow:0 10px 30px rgba(0,0,0,.12)}
.video-embed iframe{position:absolute; inset:0; width:100%; height:100%}

/* Value */
.value{padding:56px 0; background:var(--card)}
.value h2{text-align:center; margin:0 0 26px}
.benefits{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; margin:0 0 22px; padding:0; list-style:none;
}
.benefits li{
  background:#fff; border:1px solid #e6f2f0; border-radius:16px; padding:18px; text-align:center;
}
.benefits img{width:72px; margin:0 auto 10px}

/* Steps */
.steps{padding:56px 0}
.steps h2{text-align:center; margin:0 0 28px}
.step-list{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:22px; list-style:none; padding:0; margin:0;
}
.step-list li{
  background:#fff; border:1px solid #e7f0ef; border-radius:16px; padding:18px;
  box-shadow:0 6px 20px rgba(0,0,0,.04);
}
.step-list img{border-radius:10px; margin-bottom:10px}

/* Destinos */
.destinos{padding:56px 0; background:linear-gradient(180deg, #fff, #f6fbfa)}
.destinos .intro{color:var(--ink-soft)}
.cards{display:grid; grid-template-columns:repeat(3, 1fr); gap:18px}
.card{
  background:#fff; border:1px solid #eaf3f2; border-radius:16px; padding:14px;
  box-shadow:0 6px 18px rgba(0,0,0,.04);
}
.card h3{margin:.6rem 0 .2rem}
.tip{
  display:flex; gap:12px; align-items:center; margin-top:18px; background:var(--brand-mint);
  padding:14px 16px; border-left:6px solid var(--brand-teal); border-radius:10px;
}
.tip img{width:40px}

/* Compare */
.compare{padding:56px 0}
.compare-list{columns:2; column-gap:24px; padding-left:18px}
.compare-list li{break-inside:avoid; margin-bottom:.6rem}

/* Itinerarios */
.itins{padding:56px 0}
.cards--itins .card img{border-radius:10px}

/* Testimonials */
.testimonials{padding:56px 0; background:var(--card)}
.quotes{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
blockquote{
  background:#fff; border-left:6px solid var(--brand-orange); padding:16px 18px; border-radius:10px;
}
cite{display:block; margin-top:8px; color:var(--muted)}

/* FAQ */
.faq{padding:56px 0}
details{background:#fff; border:1px solid #eaeff0; border-radius:10px; padding:12px 14px; margin-bottom:10px}
summary{cursor:pointer; font-weight:600}

/* Form */
.form{padding:56px 0; background:linear-gradient(180deg, #f6fbfa, #fff)}
.grid-form{
  display:grid; gap:14px; grid-template-columns:repeat(2, 1fr);
}
.grid-form label{display:flex; flex-direction:column; font-weight:600; font-size:.95rem}
.grid-form input, .grid-form select{
  margin-top:6px; padding:.8rem .9rem; border-radius:10px; border:1px solid #d9e7e5;
  outline:none; box-shadow:0 0 0 0 transparent; transition: box-shadow .15s, border-color .15s;
}
.grid-form input:focus, .grid-form select:focus{border-color:var(--brand-teal); box-shadow:0 0 0 4px var(--ring)}
.grid-form button{grid-column:1/-1; justify-self:start}
.microcopy{font-size:.9rem; color:var(--muted); margin-top:8px}
.wa-cta{margin-top:16px}

/* Footer */
.site-footer{padding:36px 0; background:var(--brand-navy); color:#dff7f3; text-align:center}
.site-footer .btn{margin:10px 0}
.legal{opacity:.8}

/* Responsive */
@media (max-width: 960px){
  .hero-inner{grid-template-columns:1fr}
  .benefits{grid-template-columns:1fr}
  .step-list{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .quotes{grid-template-columns:1fr}
  .grid-form{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
}
