/* =====================================================================
   VIAJAR — estilos
   Paleta: azul/celeste (cielo, rutas) + verde (naturaleza) + naranja (CTA)
   ===================================================================== */
:root{
  --brand:#0d6efd;
  --brand-2:#0aa2c0;       /* celeste */
  --ink:#14233b;           /* azul tinta */
  --ink-soft:#46566e;
  --green:#16a34a;
  --accent:#ff7a18;        /* naranja CTA */
  --accent-2:#ffb703;      /* amarillo */
  --sky-1:#eaf4ff;
  --sky-2:#d9ecff;
  --paper:#f6f9fc;
  --card-radius:18px;
  --shadow-soft:0 10px 30px rgba(20,35,59,.08);
  --shadow-card:0 6px 20px rgba(20,35,59,.07);
}

*{scroll-behavior:smooth;}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  font-size:1.02rem;
}
h1,h2,h3,h4,.display-font{
  font-family:'Fraunces',Georgia,serif;
  letter-spacing:-.01em;
}

a{color:var(--brand);text-decoration:none;}
a:hover{text-decoration:underline;}

/* ---------- Brand ---------- */
.brand{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;text-decoration:none;}
.brand-mark{
  width:38px;height:38px;border-radius:12px;
  display:grid;place-items:center;color:#fff;font-size:1.15rem;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  box-shadow:0 6px 16px rgba(13,110,253,.35);
}
.brand-text{font-family:'Fraunces',serif;font-size:1.28rem;color:var(--ink);}
.navbar .nav-link{font-weight:600;color:var(--ink-soft);}
.navbar .nav-link:hover{color:var(--brand);text-decoration:none;}

/* ---------- Botones ---------- */
.btn-brand{
  --bs-btn-bg:var(--accent);--bs-btn-border-color:var(--accent);
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  border:0;color:#fff;font-weight:700;border-radius:12px;
  box-shadow:0 8px 20px rgba(255,122,24,.35);
}
.btn-brand:hover{color:#fff;filter:brightness(1.04);transform:translateY(-1px);}
.btn-ink{background:var(--ink);color:#fff;border:0;border-radius:12px;font-weight:600;}
.btn-ink:hover{color:#fff;filter:brightness(1.15);}
.btn-outline-brand{border:2px solid var(--brand);color:var(--brand);border-radius:12px;font-weight:600;}
.btn-outline-brand:hover{background:var(--brand);color:#fff;}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:
    radial-gradient(1200px 500px at 80% -10%,rgba(255,183,3,.25),transparent 60%),
    linear-gradient(135deg,#0b3a82 0%,#0d6efd 45%,#0aa2c0 100%);
}
.hero::after{
  content:"";position:absolute;inset:0;opacity:.18;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);
  background-size:26px 26px;
}
.hero .container{position:relative;z-index:1;}
.hero h1{font-size:clamp(2rem,4.5vw,3.4rem);line-height:1.08;}
.hero .lead{color:rgba(255,255,255,.92);font-size:1.12rem;}
.hero-card{
  background:#fff;color:var(--ink);border-radius:var(--card-radius);
  box-shadow:var(--shadow-soft);padding:1.5rem;
}

/* ---------- Cards ---------- */
.card{border:0;border-radius:var(--card-radius);box-shadow:var(--shadow-card);}
.feature-card{transition:transform .2s ease,box-shadow .2s ease;height:100%;}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);}
.feature-ico{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  font-size:1.5rem;color:#fff;margin-bottom:.85rem;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
}
.feature-ico.green{background:linear-gradient(135deg,var(--green),#34d399);}
.feature-ico.orange{background:linear-gradient(135deg,var(--accent),var(--accent-2));}

.destino-card{position:relative;overflow:hidden;border-radius:var(--card-radius);min-height:170px;color:#fff;display:flex;align-items:flex-end;}
.destino-card .ovl{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,58,130,.05),rgba(11,58,130,.78));}
.destino-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s ease;}
.destino-card:hover .bg{transform:scale(1.06);}
.destino-card .meta{position:relative;z-index:1;padding:1rem 1.1rem;width:100%;}

/* ---------- Forms / Wizard ---------- */
.form-control,.form-select{border-radius:12px;padding:.7rem .9rem;border:1.5px solid #dbe5f1;font-size:1.03rem;}
.form-control:focus,.form-select:focus{border-color:var(--brand);box-shadow:0 0 0 .2rem rgba(13,110,253,.15);}
.form-label{font-weight:600;color:var(--ink);}
.input-group-text{border-radius:12px;background:var(--sky-1);border:1.5px solid #dbe5f1;font-weight:600;}

.wizard-steps{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1.5rem;}
.wizard-steps .step{
  flex:1 1 120px;min-width:90px;text-align:center;padding:.6rem .4rem;border-radius:12px;
  background:#fff;border:1.5px solid #e4edf7;color:var(--ink-soft);font-weight:600;font-size:.9rem;
}
.wizard-steps .step.active{background:var(--brand);color:#fff;border-color:var(--brand);}
.wizard-steps .step.done{background:var(--sky-2);color:var(--brand);border-color:var(--sky-2);}
.wizard-steps .step .n{display:block;font-size:1.2rem;font-family:'Fraunces',serif;}

.wizard-panel{display:none;}
.wizard-panel.active{display:block;animation:fade .25s ease;}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* opciones tipo botón (nivel de viaje, transporte) */
.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.6rem;}
.choice{cursor:pointer;}
.choice input{position:absolute;opacity:0;}
.choice .box{
  border:2px solid #e4edf7;border-radius:14px;padding:.9rem .6rem;text-align:center;
  background:#fff;transition:all .15s ease;height:100%;
}
.choice .box i{font-size:1.5rem;color:var(--brand);display:block;margin-bottom:.3rem;}
.choice input:checked + .box{border-color:var(--brand);background:var(--sky-1);box-shadow:0 0 0 .15rem rgba(13,110,253,.12);}

/* ---------- Resultado ---------- */
.result-hero{background:#0b3a82;background:linear-gradient(135deg,#0b3a82,#0d6efd);color:#fff;border-radius:var(--card-radius);}
.result-total{font-family:'Fraunces',serif;font-size:clamp(1.8rem,5vw,2.8rem);font-weight:700;}
.breakdown-row{display:flex;justify-content:space-between;padding:.7rem 0;border-bottom:1px dashed #e2eaf3;}
.breakdown-row:last-child{border-bottom:0;}
.breakdown-row .cat{display:flex;align-items:center;gap:.6rem;color:var(--ink-soft);font-weight:600;}
.breakdown-row .cat i{color:var(--brand);}
.tip{background:var(--sky-1);border-left:4px solid var(--brand);border-radius:10px;padding:.8rem 1rem;}

.disclaimer{background:#fff8ec;border:1px solid #ffe2ad;border-radius:12px;padding:.8rem 1rem;color:#7a5b12;font-size:.92rem;}

/* ---------- Footer ---------- */
.site-footer{background:linear-gradient(135deg,#0b1f3a,#0b3a82);}
.site-footer a{color:rgba(255,255,255,.78);}
.site-footer a:hover{color:#fff;text-decoration:none;}
.site-footer h6{font-family:'Fraunces',serif;margin-bottom:.8rem;}

/* ---------- WhatsApp flotante ---------- */
.wa-float{
  position:fixed;right:18px;bottom:18px;z-index:1000;
  width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;
  display:grid;place-items:center;font-size:1.7rem;box-shadow:0 8px 22px rgba(37,211,102,.45);
}
.wa-float:hover{color:#fff;transform:scale(1.06);}

/* ---------- Banner slots ---------- */
.ad-slot{display:flex;justify-content:center;align-items:center;}
.ad-slot img{max-width:100%;height:auto;border-radius:12px;}

/* ---------- Util ---------- */
.section{padding:3.2rem 0;}
.section-title{font-size:clamp(1.5rem,3.5vw,2.2rem);}
.text-brand{color:var(--brand)!important;}
.bg-sky{background:var(--sky-1);}
.badge-soft{background:var(--sky-1);color:var(--brand);font-weight:600;}

@media (max-width:575.98px){
  body{font-size:1.05rem;}      /* legibilidad para adultos mayores en mobile */
  .section{padding:2.2rem 0;}
}
/* ===== Etapa 2: comparador y cotizaciones ===== */
.compare-table th { vertical-align: middle; }
.compare-table td { vertical-align: middle; }
.compare-table thead th { background: var(--paper, #f8fafc); }
.compare-check { width: 1.15em; height: 1.15em; }
#quoteForm .form-control, #quoteForm .form-select { border-radius: 10px; }
#quoteBlock .result-cta-inner { gap: 0; }
.adm-empty { border: 1px dashed #cbd5e1; }


/* ===== Logo en recuadro blanco (header y footer) ===== */
.brand-logo{
  display:inline-flex;
  align-items:center;
  background:#ffffff;
  border-radius:20px;
  padding:8px 14px;
  text-decoration:none;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.brand-logo-img{
  display:block;
  width:100%;
  max-width:220px;   /* header: máximo 220px de ancho */
  height:auto;
}
.site-footer .brand-logo{
  box-shadow:none;
  padding:10px 16px;
  border-radius:20px;
}
.site-footer .brand-logo-img{
  max-width:240px;   /* footer: máximo 240px de ancho */
}
@media (max-width:576px){
  .brand-logo{padding:6px 10px;border-radius:20px;}
  .brand-logo-img{max-width:170px;}
  .site-footer .brand-logo-img{max-width:200px;}
}

/* ===== Banner CTA registro de agencias ===== */
.agency-cta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  background:#0d6efd;
  background:linear-gradient(135deg, #0d6efd 0%, #07347a 100%);
  color:#fff;
  border-radius:20px;
  padding:32px 36px;
  box-shadow:0 10px 30px rgba(7,52,122,.25);
}
.agency-cta-body{flex:1 1 420px;}
.agency-cta-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.18);
  padding:5px 12px;border-radius:999px;
  font-size:.78rem;font-weight:600;margin-bottom:12px;
}
.agency-cta-title{color:#fff !important;font-size:1.55rem;font-weight:700;margin:0 0 10px;line-height:1.2;}
.agency-cta-text{color:rgba(255,255,255,.92) !important;margin:0 0 14px;font-size:1rem;}
.agency-cta-note{
  background:rgba(255,255,255,.12);
  border-left:3px solid #ffd166;
  border-radius:10px;
  padding:10px 14px;font-size:.9rem;color:#fff;
}
.agency-cta-action{
  flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;
}
.agency-cta-sub{font-size:.78rem;color:rgba(255,255,255,.8);}
@media (max-width:768px){
  .agency-cta{padding:24px;}
  .agency-cta-title{font-size:1.3rem;}
  .agency-cta-action{width:100%;}
  .agency-cta-action .btn{width:100%;}
}

/* ===== Cotizaciones del día (portada) ===== */
.exrate-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:24px 28px;box-shadow:0 6px 20px rgba(2,6,23,.05);}
.exrate-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;}
.exrate-title{font-size:1.2rem;font-weight:700;margin:0;color:#0b3a82;}
.exrate-updated{font-size:.8rem;color:#94a3b8;display:block;margin-top:2px;}
.exrate-source{font-size:.82rem;color:#0d6efd;text-decoration:none;background:#eff6ff;padding:6px 12px;border-radius:999px;white-space:nowrap;}
.exrate-source:hover{background:#dbeafe;}
.exrate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;}
.exrate-item{border:1px solid #eef2f7;border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;background:#fbfdff;}
.exrate-code{font-weight:700;color:#0b3a82;font-size:1.05rem;}
.exrate-vals{display:flex;justify-content:space-between;gap:8px;font-size:.95rem;color:#334155;}
.exrate-vals small{display:block;color:#94a3b8;font-size:.7rem;text-transform:uppercase;}
.exrate-note{font-size:.78rem;color:#94a3b8;margin:14px 0 0;}
.exrate-note a{color:#0d6efd;}
