/* ===========================================================
   TRANSPORTES DANES — Landing page
   Cochamó · Estuario de Reloncaví · Patagonia norte de Chile
   =========================================================== */

:root{
  /* Paleta */
  --navy:        #073B5C;
  --navy-deep:   #04293F;
  --blue:        #159BD3;
  --blue-light:  #4FBDE8;
  --blue-pale:   #DCEEF8;
  --green:       #2E7D32;
  --green-soft:  #6BAE45;
  --bg:          #F5FAFC;
  --bg-alt:      #EAF3F8;
  --ink:         #0C2A3C;   /* texto fuerte */
  --gray:        #4A5568;   /* texto secundario */
  --gray-soft:   #7B8794;
  --line:        #E2EBF1;
  --white:       #FFFFFF;
  --whatsapp:    #25D366;
  --whatsapp-dk: #1EB855;

  /* Tipos */
  --display: "Montserrat", system-ui, sans-serif;
  --body:    "Nunito Sans", system-ui, sans-serif;

  /* Sistema */
  --maxw: 1200px;
  --radius: 18px;
  --radius-sm: 12px;
  --radius-lg: 28px;
  --shadow-sm: 0 2px 10px rgba(7,59,92,.06);
  --shadow:    0 14px 40px -18px rgba(7,59,92,.28);
  --shadow-lg: 0 30px 70px -30px rgba(7,59,92,.45);
  --ease: cubic-bezier(.16,.84,.44,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; scroll-padding-top:84px; }

body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3,h4{ font-family:var(--display); line-height:1.08; color:var(--navy); font-weight:800; letter-spacing:-.01em; }
p{ text-wrap:pretty; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
ul{ list-style:none; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px; }

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--display); font-weight:700; font-size:15.5px;
  padding:15px 26px; border-radius:999px; border:0; cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .2s;
  white-space:nowrap; line-height:1;
}
.btn svg{ width:19px; height:19px; flex:none; }
.btn:active{ transform:translateY(1px); }

.btn--wa{ background:var(--whatsapp); color:#fff; box-shadow:0 10px 26px -10px rgba(37,211,102,.7); }
.btn--wa:hover{ background:var(--whatsapp-dk); transform:translateY(-2px); box-shadow:0 16px 32px -12px rgba(37,211,102,.75); }

.btn--primary{ background:var(--blue); color:#fff; box-shadow:0 10px 26px -12px rgba(21,155,211,.8); }
.btn--primary:hover{ background:#1187bb; transform:translateY(-2px); }

.btn--ghost{ background:rgba(255,255,255,.12); color:#fff; border:1.5px solid rgba(255,255,255,.55); backdrop-filter:blur(6px); }
.btn--ghost:hover{ background:rgba(255,255,255,.22); transform:translateY(-2px); }

.btn--outline{ background:#fff; color:var(--navy); border:1.5px solid var(--line); box-shadow:var(--shadow-sm); }
.btn--outline:hover{ border-color:var(--blue); color:var(--blue); transform:translateY(-2px); }

.btn--lg{ padding:17px 32px; font-size:16.5px; }

/* ---------- Header / Navbar ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  transition:background .3s, box-shadow .3s, padding .3s;
  padding:14px 0;
}
.nav__inner{ display:flex; align-items:center; gap:22px; }
.nav__brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.nav__logo{
  width:46px; height:46px; border-radius:12px; object-fit:cover;
  background:#fff; box-shadow:0 4px 14px rgba(0,0,0,.18);
}
.nav__name{ display:flex; flex-direction:column; line-height:1; }
.nav__name b{ font-family:var(--display); font-weight:800; font-size:18px; letter-spacing:.02em; color:#fff; transition:color .3s; }
.nav__name span{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.8); transition:color .3s; font-weight:600; }

.nav__links{ display:flex; align-items:center; gap:4px; }
.nav__links a{
  font-family:var(--display); font-weight:600; font-size:14.5px; color:rgba(255,255,255,.92);
  padding:9px 12px; border-radius:9px; transition:color .2s, background .2s; white-space:nowrap;
}
.nav__links a:hover{ background:rgba(255,255,255,.14); color:#fff; }

.nav__cta{ margin-left:6px; }

/* estado al hacer scroll */
.nav.scrolled{ background:rgba(255,255,255,.92); backdrop-filter:blur(14px); box-shadow:0 6px 24px -14px rgba(7,59,92,.4); padding:9px 0; }
.nav.scrolled .nav__name b{ color:var(--navy); }
.nav.scrolled .nav__name span{ color:var(--blue); }
.nav.scrolled .nav__links a{ color:var(--navy); }
.nav.scrolled .nav__links a:hover{ background:var(--blue-pale); color:var(--navy); }
.nav.scrolled .nav__burger span{ background:var(--navy); }

.nav__burger{ display:none; width:46px; height:46px; border:0; background:rgba(255,255,255,.14); border-radius:11px; cursor:pointer; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.nav__burger span{ width:22px; height:2.4px; background:#fff; border-radius:2px; transition:.3s; }
.nav.scrolled .nav__burger{ background:var(--bg-alt); }

/* menú móvil */
.mobile{
  position:fixed; inset:0 0 0 auto; width:min(360px,86vw); z-index:70;
  background:var(--white); transform:translateX(100%); transition:transform .4s var(--ease);
  box-shadow:-20px 0 60px -20px rgba(0,0,0,.4); padding:26px 24px; display:flex; flex-direction:column;
}
.mobile.open{ transform:translateX(0); }
.mobile__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.mobile__head b{ font-family:var(--display); color:var(--navy); font-size:18px; }
.mobile__close{ width:42px; height:42px; border:0; background:var(--bg-alt); border-radius:11px; font-size:22px; color:var(--navy); cursor:pointer; }
.mobile a.ml{ font-family:var(--display); font-weight:600; font-size:17px; color:var(--navy); padding:15px 12px; border-radius:12px; border-bottom:1px solid var(--line); }
.mobile a.ml:hover{ background:var(--bg-alt); }
.mobile .btn{ margin-top:18px; }
.scrim{ position:fixed; inset:0; background:rgba(4,30,46,.5); z-index:65; opacity:0; pointer-events:none; transition:opacity .35s; backdrop-filter:blur(2px); }
.scrim.show{ opacity:1; pointer-events:auto; }

/* ---------- HERO ---------- */
.hero{ position:relative; min-height:100svh; display:flex; align-items:center; color:#fff; isolation:isolate; padding:120px 0 60px; }
.hero__bg{ position:absolute; inset:0; z-index:-2; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; object-position:center 42%; }
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(4,30,46,.58) 0%, rgba(4,30,46,.34) 35%, rgba(4,30,46,.64) 100%),
    linear-gradient(100deg, rgba(7,59,92,.82) 0%, rgba(7,59,92,.34) 55%, rgba(7,59,92,.05) 100%);
}
.hero__inner{ max-width:680px; }
.hero__kicker{
  display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:700;
  font-size:13px; letter-spacing:.14em; text-transform:uppercase;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3);
  padding:8px 16px; border-radius:999px; backdrop-filter:blur(6px); margin-bottom:22px;
}
.hero__kicker .dot{ width:8px; height:8px; border-radius:50%; background:var(--green-soft); box-shadow:0 0 0 4px rgba(107,174,69,.3); }
.hero h1{ color:#fff; font-size:clamp(2.6rem, 6.5vw, 4.6rem); font-weight:800; letter-spacing:-.02em; line-height:.98; text-shadow:0 2px 24px rgba(4,30,46,.35); }
.hero h1 .thin{ display:block; font-weight:700; font-size:.42em; letter-spacing:.12em; text-transform:uppercase; color:#EAF6FC; margin-bottom:12px; text-shadow:0 1px 14px rgba(4,30,46,.5); }
.hero__slogan{ font-family:var(--display); font-weight:700; font-size:clamp(1.15rem,2.4vw,1.55rem); margin-top:18px; color:#fff; }
.hero__support{ font-size:18px; color:rgba(255,255,255,.92); margin-top:14px; max-width:560px; text-shadow:0 1px 12px rgba(4,30,46,.45); }
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }

.hero__stats{ display:flex; flex-wrap:wrap; gap:12px; margin-top:38px; }
.chip{
  display:flex; align-items:center; gap:12px;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.26);
  backdrop-filter:blur(8px); padding:13px 18px; border-radius:14px;
}
.chip__ic{ width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background:rgba(255,255,255,.16); flex:none; }
.chip__ic svg{ width:20px; height:20px; stroke:#fff; }
.chip b{ font-family:var(--display); font-weight:800; font-size:16px; color:#fff; display:block; line-height:1.1; }
.chip span{ font-size:13px; color:rgba(255,255,255,.82); }

.hero__scroll{ position:absolute; bottom:22px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:6px; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.7); }
.hero__scroll .mouse{ width:24px; height:38px; border:2px solid rgba(255,255,255,.6); border-radius:14px; position:relative; }
.hero__scroll .mouse::after{ content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%); width:4px; height:7px; border-radius:2px; background:#fff; animation:scrollwheel 1.8s infinite; }
@keyframes scrollwheel{ 0%{opacity:0;transform:translate(-50%,0)} 40%{opacity:1} 80%{opacity:0;transform:translate(-50%,12px)} 100%{opacity:0} }

/* ---------- Secciones genéricas ---------- */
.section{ padding:96px 0; position:relative; }
.section--alt{ background:var(--bg-alt); }
.section--navy{ background:var(--navy); color:#fff; }
.section--navy h2,.section--navy h3{ color:#fff; }

.eyebrow{
  display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:700;
  font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); margin-bottom:14px;
}
.eyebrow::before{ content:""; width:26px; height:2.5px; border-radius:2px; background:var(--green-soft); }
.section--navy .eyebrow{ color:var(--blue-light); }

.section__head{ max-width:680px; margin-bottom:52px; }
.section__head.center{ margin-inline:auto; text-align:center; }
.section__head.center .eyebrow{ justify-content:center; }
.section h2{ font-size:clamp(2rem,4vw,2.9rem); }
.section__head p{ font-size:18.5px; color:var(--gray); margin-top:16px; }
.section--navy .section__head p{ color:rgba(255,255,255,.82); }

/* ---------- Servicios ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.svc{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:30px 28px;
  box-shadow:var(--shadow-sm); transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  position:relative; overflow:hidden;
}
.svc::before{ content:""; position:absolute; top:0; left:0; width:100%; height:4px; background:linear-gradient(90deg,var(--blue),var(--green-soft)); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease); }
.svc:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.svc:hover::before{ transform:scaleX(1); }
.svc__ic{ width:56px; height:56px; border-radius:15px; display:grid; place-items:center; background:linear-gradient(145deg,var(--blue-pale),#fff); border:1px solid var(--line); margin-bottom:20px; }
.svc__ic svg{ width:28px; height:28px; stroke:var(--blue); fill:none; stroke-width:1.7; }
.svc h3{ font-size:20px; margin-bottom:9px; }
.svc p{ color:var(--gray); font-size:15.5px; }

/* ---------- Ruta Verano ---------- */
.ruta{ position:relative; overflow:hidden; }
.ruta__card{
  background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); overflow:hidden;
  display:grid; grid-template-columns:1.05fr .95fr;
}
.ruta__media{ position:relative; min-height:420px; }
.ruta__media img{ width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }
.ruta__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(160deg, rgba(7,59,92,.15), rgba(7,59,92,.65)); }
.ruta__badge{
  position:absolute; top:22px; left:22px; z-index:2; display:inline-flex; align-items:center; gap:8px;
  background:var(--green); color:#fff; font-family:var(--display); font-weight:700; font-size:13px;
  letter-spacing:.04em; padding:9px 16px; border-radius:999px; box-shadow:0 8px 20px -8px rgba(46,125,50,.7);
}
.ruta__future{
  position:absolute; bottom:22px; left:22px; right:22px; z-index:2; color:#fff;
  background:rgba(4,30,46,.45); border:1px solid rgba(255,255,255,.2); backdrop-filter:blur(8px);
  padding:14px 18px; border-radius:14px; font-size:14px;
}
.ruta__future b{ font-family:var(--display); }
.ruta__body{ padding:42px 40px; }
.ruta__body h2{ font-size:clamp(1.7rem,2.6vw,2.3rem); }
.ruta__body > p{ color:var(--gray); margin-top:14px; font-size:16.5px; }

/* línea de ruta visual */
.route-line{ margin:30px 0 6px; }
.stop{ display:flex; gap:16px; position:relative; padding-bottom:26px; }
.stop:last-child{ padding-bottom:0; }
.stop__rail{ display:flex; flex-direction:column; align-items:center; flex:none; }
.stop__node{ width:34px; height:34px; border-radius:50%; display:grid; place-items:center; flex:none; z-index:1; }
.stop__node svg{ width:18px; height:18px; stroke:#fff; fill:none; stroke-width:2; }
.stop--a .stop__node{ background:var(--blue); }
.stop--m .stop__node{ background:var(--blue-light); }
.stop--b .stop__node{ background:var(--green); }
.stop__rail::after{ content:""; width:3px; flex:1; background:repeating-linear-gradient(var(--blue) 0 7px, transparent 7px 14px); margin:4px 0; }
.stop:last-child .stop__rail::after{ display:none; }
.stop__txt small{ font-family:var(--display); font-weight:700; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray-soft); }
.stop__txt b{ display:block; font-family:var(--display); font-size:17px; color:var(--navy); margin-top:2px; }

.ruta__feats{ display:grid; grid-template-columns:1fr 1fr; gap:10px 18px; margin:26px 0 28px; }
.ruta__feats li{ display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--gray); font-weight:600; }
.ruta__feats svg{ width:18px; height:18px; stroke:var(--green); flex:none; }

/* ---------- Vehículo ---------- */
.veh{ display:grid; grid-template-columns:1.1fr .9fr; gap:46px; align-items:center; }
.veh__media{ position:relative; }
.placeholder{
  position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line);
  background:
    repeating-linear-gradient(45deg, #E8F1F7 0 14px, #DEEBF4 14px 28px);
  display:grid; place-items:center; min-height:340px; box-shadow:var(--shadow);
}
.placeholder__tag{
  display:flex; flex-direction:column; align-items:center; gap:8px; text-align:center; padding:24px;
}
.placeholder__tag .pic{ width:60px; height:60px; border-radius:14px; background:#fff; display:grid; place-items:center; box-shadow:var(--shadow-sm); }
.placeholder__tag .pic svg{ width:30px; height:30px; stroke:var(--blue); fill:none; stroke-width:1.6; }
.placeholder__tag code{ font-family:"SF Mono",ui-monospace,Menlo,monospace; font-size:12.5px; color:var(--gray); background:#fff; padding:6px 12px; border-radius:8px; border:1px solid var(--line); }
.placeholder__tag b{ font-family:var(--display); color:var(--navy); font-size:16px; }
.veh__note{ display:inline-flex; align-items:center; gap:8px; margin-top:14px; font-size:13.5px; color:var(--gray-soft); font-style:italic; }
.veh__note svg{ width:16px; height:16px; stroke:var(--gray-soft); flex:none; }

.veh__feats{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:26px; }
.vf{ display:flex; align-items:center; gap:12px; background:#fff; border:1px solid var(--line); border-radius:12px; padding:14px 16px; box-shadow:var(--shadow-sm); }
.vf svg{ width:22px; height:22px; stroke:var(--green); fill:none; stroke-width:1.8; flex:none; }
.vf span{ font-size:14.5px; font-weight:600; color:var(--navy); }

/* ---------- Destinos ---------- */
.dest-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.dest{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5; box-shadow:var(--shadow-sm); cursor:pointer; }
.dest img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.dest__ph{ position:absolute; inset:0; background:linear-gradient(155deg,#1c75a6 0%,#0b3a57 78%); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; }
.dest__ph svg{ width:54px; height:54px; stroke:rgba(255,255,255,.9); fill:none; stroke-width:1.4; stroke-linecap:round; stroke-linejoin:round; }
.dest__ph .ph-note{ font-family:var(--display); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.72); background:rgba(255,255,255,.14); padding:5px 12px; border-radius:999px; }
.dest__ref{ position:absolute; top:14px; left:14px; z-index:3; font-family:var(--display); font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:#fff; background:rgba(4,30,46,.55); border:1px solid rgba(255,255,255,.28); backdrop-filter:blur(4px); padding:5px 11px; border-radius:999px; }
.dest-note{ text-align:center; max-width:780px; margin:32px auto 0; font-size:15px; color:var(--gray); }
.dest-group{ display:flex; align-items:center; gap:11px; font-size:15px; font-family:var(--display); font-weight:800; letter-spacing:.02em; text-transform:uppercase; color:var(--navy); margin:8px 0 20px; }
.dest-group:not(:first-of-type){ margin-top:44px; }
.dest-group i{ color:var(--blue); font-size:16px; }
.dest-group::after{ content:""; flex:1; height:1px; background:var(--line); }
.dest::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 35%, rgba(4,30,46,.82) 100%); transition:background .4s; }
.dest:hover::after{ background:linear-gradient(180deg, rgba(21,155,211,.25) 0%, rgba(7,59,92,.85) 100%); }
.dest:hover img{ transform:scale(1.08); }
.dest__txt{ position:absolute; left:0; right:0; bottom:0; padding:24px 22px; z-index:2; color:#fff; }
.dest__txt h3{ color:#fff; font-size:20px; }
.dest__txt p{ font-size:13.5px; color:rgba(255,255,255,.88); margin-top:5px; opacity:0; max-height:0; transform:translateY(6px); transition:.4s var(--ease); }
.dest:hover .dest__txt p{ opacity:1; max-height:80px; transform:translateY(0); }
@media (hover:none){ .dest__txt p{ opacity:1; max-height:220px; transform:none; } .dest::after{ background:linear-gradient(180deg, transparent 28%, rgba(4,30,46,.86) 100%); } }
.dest__pin{ display:inline-flex; align-items:center; gap:6px; font-family:var(--display); font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--blue-light); margin-bottom:6px; }
.dest__pin svg{ width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2; }

/* ---------- Nosotros ---------- */
.about{ display:grid; grid-template-columns:.95fr 1.05fr; gap:50px; align-items:center; }
.about__media{ position:relative; }
.about__media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); width:100%; aspect-ratio:4/4.4; object-fit:cover; }
.about__media .stamp{
  position:absolute; bottom:-22px; right:-14px; background:#fff; border-radius:18px; padding:18px 22px;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:14px; border:1px solid var(--line);
}
.about__media .stamp .n{ font-family:var(--display); font-weight:800; font-size:34px; color:var(--blue); line-height:1; }
.about__media .stamp small{ font-size:13px; color:var(--gray); font-weight:600; }
.driver-card{
  position:absolute; bottom:-26px; left:-14px; background:#fff; border-radius:18px; padding:14px 18px 14px 14px;
  box-shadow:var(--shadow); display:flex; align-items:center; gap:14px; border:1px solid var(--line); max-width:300px;
}
.driver-card__avatar{ width:66px !important; height:66px !important; border-radius:50% !important; object-fit:cover !important; aspect-ratio:1 !important; box-shadow:none !important; border:3px solid var(--blue-pale); flex:none; }
.driver-card__txt{ display:flex; flex-direction:column; line-height:1.25; }
.driver-card__txt b{ font-family:var(--display); font-weight:800; font-size:16px; color:var(--navy); }
.driver-card__txt span{ font-size:12.5px; color:var(--blue); font-weight:700; font-family:var(--display); }
.driver-card__txt small{ font-size:12px; color:var(--gray); margin-top:2px; }
.about__lead{ font-size:19px; color:var(--gray); }
.about__lead strong{ color:var(--navy); }
.about p + p{ margin-top:16px; }
.about__cards{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:28px; }
.ac{ display:flex; align-items:center; gap:12px; background:var(--bg); border:1px solid var(--line); border-radius:13px; padding:14px 16px; }
.ac svg{ width:24px; height:24px; stroke:var(--green); fill:none; stroke-width:1.8; flex:none; }
.ac b{ font-family:var(--display); font-size:14.5px; color:var(--navy); font-weight:700; }

/* ---------- Confianza ---------- */
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.trust{ text-align:left; padding:6px 2px; }
.trust__ic{ width:60px; height:60px; border-radius:16px; display:grid; place-items:center; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); margin-bottom:18px; }
.trust__ic svg{ width:30px; height:30px; stroke:var(--blue-light); fill:none; stroke-width:1.6; }
.trust h3{ font-size:19px; margin-bottom:8px; }
.trust p{ color:rgba(255,255,255,.78); font-size:15px; }

/* ---------- Contacto ---------- */
.contact{ display:grid; grid-template-columns:1fr 1.05fr; gap:46px; align-items:start; }
.contact__info .ci{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--line); }
.contact__info .ci:first-of-type{ padding-top:0; }
.contact__info .ci__ic{ width:50px; height:50px; border-radius:13px; background:var(--blue-pale); display:grid; place-items:center; flex:none; }
.contact__info .ci__ic svg{ width:24px; height:24px; stroke:var(--blue); fill:none; stroke-width:1.8; }
.contact__info .ci small{ font-family:var(--display); font-weight:700; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray-soft); }
.contact__info .ci b{ display:block; font-family:var(--display); font-size:18px; color:var(--navy); }
.contact__info .ci a{ color:var(--navy); }
.contact__info .ci a:hover{ color:var(--blue); }
.ci__map{ display:inline-flex; align-items:center; gap:7px; margin-top:6px; font-family:var(--display); font-weight:700; font-size:13px; color:var(--blue); }
.ci__map:hover{ color:var(--navy); text-decoration:underline; }
.ci__map i{ font-size:13px; }
.contact__actions{ display:flex; flex-wrap:wrap; gap:12px; margin:24px 0 28px; }
.contact__map{ position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); min-height:200px;
  background:linear-gradient(160deg,#dcebf5,#cfe6ce); box-shadow:var(--shadow-sm); }
.contact__map .mapgrid{ position:absolute; inset:0; background-image:linear-gradient(rgba(7,59,92,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(7,59,92,.07) 1px,transparent 1px); background-size:34px 34px; }
.contact__map .road{ position:absolute; inset:0; }
.contact__map .pinwrap{ position:absolute; top:50%; left:50%; transform:translate(-50%,-100%); text-align:center; }
.contact__map .pin{ width:44px; height:44px; }
.contact__map .lbl{ background:#fff; padding:6px 13px; border-radius:999px; font-family:var(--display); font-weight:700; font-size:13px; color:var(--navy); box-shadow:var(--shadow-sm); white-space:nowrap; margin-top:-6px; display:inline-block; }
.contact__map .maplink{ position:absolute; bottom:12px; right:12px; background:#fff; padding:9px 15px; border-radius:10px; font-family:var(--display); font-weight:700; font-size:13px; color:var(--blue); box-shadow:var(--shadow-sm); display:inline-flex; gap:7px; align-items:center; }

/* Formulario */
.form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px 32px; box-shadow:var(--shadow); }
.form h3{ font-size:22px; margin-bottom:6px; }
.form > p{ color:var(--gray); font-size:15px; margin-bottom:22px; }
.form__grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field.full{ grid-column:1/-1; }
.field label{ font-family:var(--display); font-weight:700; font-size:13px; color:var(--navy); }
.field input,.field select,.field textarea{
  font-family:var(--body); font-size:15px; color:var(--ink); background:var(--bg);
  border:1.5px solid var(--line); border-radius:11px; padding:13px 15px; width:100%; transition:border-color .2s, box-shadow .2s;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:0; border-color:var(--blue); box-shadow:0 0 0 4px rgba(21,155,211,.14); background:#fff; }
.form .btn{ width:100%; margin-top:20px; }
.form__hint{ text-align:center; font-size:13px; color:var(--gray-soft); margin-top:12px; }

/* ---------- Footer ---------- */
.footer{ background:var(--navy-deep); color:rgba(255,255,255,.8); padding:64px 0 28px; }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.12); }
.footer__brand{ display:flex; align-items:center; gap:14px; margin-bottom:16px; }
.footer__brand img{ width:54px; height:54px; border-radius:13px; background:#fff; }
.footer__brand b{ font-family:var(--display); font-weight:800; font-size:21px; color:#fff; }
.footer__brand span{ font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--blue-light); }
.footer p{ font-size:15px; max-width:330px; }
.footer h4{ color:#fff; font-size:15px; letter-spacing:.04em; margin-bottom:16px; }
.footer__col a, .footer__col li{ display:block; font-size:15px; color:rgba(255,255,255,.72); padding:6px 0; }
.footer__col a:hover{ color:var(--blue-light); }
.footer__seo{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.footer__seo span{ font-size:12px; color:rgba(255,255,255,.55); background:rgba(255,255,255,.06); padding:5px 11px; border-radius:999px; }
.footer__bottom{ display:flex; flex-wrap:wrap; gap:10px; justify-content:space-between; align-items:center; padding-top:24px; font-size:13.5px; color:rgba(255,255,255,.55); }
.footer__bottom .legal{ font-family:var(--display); }

/* ---------- WhatsApp flotante ---------- */
.wa-float{ position:fixed; right:22px; bottom:22px; z-index:80; display:flex; align-items:center; gap:0; }
.wa-float a{
  display:flex; align-items:center; gap:0; background:var(--whatsapp); color:#fff; border-radius:999px;
  box-shadow:0 14px 34px -10px rgba(37,211,102,.7); overflow:hidden; transition:gap .3s var(--ease), padding .3s var(--ease), transform .3s;
  padding:0;
}
.wa-float a:hover{ transform:scale(1.04); }
.wa-float .ic{ width:62px; height:62px; display:grid; place-items:center; flex:none; }
.wa-float .ic svg{ width:32px; height:32px; }
.wa-float .lab{ max-width:0; opacity:0; white-space:nowrap; font-family:var(--display); font-weight:700; font-size:15px; transition:max-width .35s var(--ease), opacity .25s, padding .3s; padding-right:0; }
.wa-float a:hover .lab{ max-width:230px; opacity:1; padding-right:22px; }
.wa-float .pulse{ position:absolute; right:0; bottom:0; width:62px; height:62px; border-radius:50%; background:var(--whatsapp); animation:wapulse 2.4s infinite; z-index:-1; }
@keyframes wapulse{ 0%{transform:scale(1);opacity:.6} 70%{transform:scale(1.7);opacity:0} 100%{opacity:0} }

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }
.reveal.d4{ transition-delay:.32s; } .reveal.d5{ transition-delay:.4s; } .reveal.d6{ transition-delay:.48s; }

/* ---------- Wave divider ---------- */
.wave{ display:block; width:100%; height:60px; }
.wave--up{ transform:rotate(180deg); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .dest-grid{ grid-template-columns:repeat(2,1fr); }
  .trust-grid{ grid-template-columns:repeat(2,1fr); }
  .ruta__card{ grid-template-columns:1fr; }
  .ruta__media{ min-height:280px; }
  .veh{ grid-template-columns:1fr; gap:30px; }
  .about{ grid-template-columns:1fr; gap:60px; }
  .about__media{ max-width:460px; }
  .contact{ grid-template-columns:1fr; gap:32px; }
  .footer__top{ grid-template-columns:1fr 1fr; }
}

@media (max-width:820px){
  .nav__links{ display:none; }
  .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
}

@media (max-width:680px){
  body{ font-size:16px; }
  .section{ padding:64px 0; }
  .wrap{ padding-inline:18px; }
  .hero{ text-align:center; padding-top:110px; }
  .hero__inner{ margin-inline:auto; }
  .hero__kicker{ margin-inline:auto; }
  .hero__stats{ justify-content:center; }
  .hero__actions{ justify-content:center; }
  .hero__actions .btn{ flex:1 1 100%; }
  .chip{ flex:1 1 100%; }
  .hero__bg img{ object-position:center 38%; }
  .hero__scroll{ display:none; }
  .svc-grid{ grid-template-columns:1fr; }
  .dest-grid{ grid-template-columns:1fr; }
  .trust-grid{ grid-template-columns:1fr; }
  .ruta__feats{ grid-template-columns:1fr; }
  .veh__feats{ grid-template-columns:1fr; }
  .form__grid{ grid-template-columns:1fr; }
  .about__cards{ grid-template-columns:1fr; }
  .footer__top{ grid-template-columns:1fr; gap:28px; }
  .ruta__body{ padding:30px 24px; }
  .form{ padding:26px 20px; }
  .about__media .stamp{ right:0; }
  .driver-card{ left:50%; right:auto; transform:translateX(-50%); bottom:-30px; width:calc(100% - 24px); max-width:340px; }
  .wa-float .ic{ width:56px; height:56px; }
}

@media (max-width:380px){
  .hero h1{ font-size:2.3rem; }
}

/* =========================================================
   FONT AWESOME — icon sizing (single icon library)
   ========================================================= */
.btn i{ font-size:18px; line-height:1; }
.btn--lg i{ font-size:19px; }
.chip__ic i{ font-size:18px; color:#fff; }
.svc__ic i{ font-size:26px; color:var(--blue); line-height:1; }
.ruta__badge i{ font-size:14px; }
.stop__node i{ color:#fff; font-size:14px; line-height:1; }
.ruta__feats li i{ color:var(--green); font-size:15px; width:18px; text-align:center; flex:none; }
.placeholder__tag .pic i{ font-size:30px; color:var(--blue); }
.veh__note i{ color:var(--gray-soft); font-size:15px; flex:none; }
.veh__cta{ margin-top:26px; }
.vf i{ font-size:19px; color:var(--green); width:24px; text-align:center; flex:none; }
.dest__pin i{ font-size:12px; }
.dest__ph i{ font-size:50px; color:rgba(255,255,255,.92); }
.ac i{ font-size:20px; color:var(--green); width:24px; text-align:center; flex:none; }
.trust__ic i{ font-size:27px; color:var(--blue-light); }
.ci__ic i{ font-size:21px; color:var(--blue); }
.contact__map .maplink i{ font-size:13px; }
.wa-float .ic i{ font-size:30px; color:#fff; }
.eng-line{ font-size:14.5px; color:rgba(255,255,255,.7); margin-top:10px; font-style:italic; }
@media (max-width:680px){ .eng-line{ font-size:13.5px; } }

/* =========================================================
   RUTA DE VERANO — full-bleed (estilo destacado)
   ========================================================= */
.ruta2{ position:relative; isolation:isolate; padding:100px 0; color:#fff; overflow:hidden; }
.ruta2__bg{ position:absolute; inset:0; z-index:-2; }
.ruta2__bg img{ width:100%; height:100%; object-fit:cover; object-position:center 55%; }
.ruta2__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(4,30,46,.84) 0%, rgba(7,59,92,.72) 45%, rgba(4,30,46,.9) 100%); }
.ruta2__inner{ max-width:940px; margin-inline:auto; text-align:center; }
.ruta2__top{ display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:700; font-size:13px; letter-spacing:.14em; text-transform:uppercase; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3); padding:8px 18px; border-radius:999px; backdrop-filter:blur(6px); margin-bottom:22px; }
.ruta2__top i{ color:#FFD166; }
.ruta2 h2{ color:#fff; font-size:clamp(1.7rem,3.6vw,2.7rem); line-height:1.1; max-width:880px; margin-inline:auto; text-shadow:0 2px 20px rgba(4,30,46,.5); }
.ruta2 h2 .arrow{ color:var(--blue-light); padding:0 4px; }
.ruta2__lead{ max-width:700px; margin:18px auto 0; color:rgba(255,255,255,.92); font-size:17.5px; text-shadow:0 1px 12px rgba(4,30,46,.5); }
.ruta2__route{ display:flex; align-items:stretch; justify-content:center; gap:10px; margin:38px auto 0; }
.rnode{ flex:1 1 0; max-width:250px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.22); backdrop-filter:blur(8px); border-radius:18px; padding:22px 16px; display:flex; flex-direction:column; align-items:center; gap:5px; }
.rnode__ic{ width:54px; height:54px; border-radius:15px; display:grid; place-items:center; background:var(--blue); margin-bottom:6px; box-shadow:0 8px 20px -8px rgba(21,155,211,.7); }
.rnode__ic--green{ background:var(--green); box-shadow:0 8px 20px -8px rgba(46,125,50,.7); }
.rnode__ic i{ font-size:22px; color:#fff; }
.rnode small{ font-family:var(--display); text-transform:uppercase; letter-spacing:.12em; font-size:11px; color:var(--blue-light); font-weight:700; }
.rnode b{ font-family:var(--display); font-size:15px; color:#fff; line-height:1.32; }
.rconn{ display:flex; align-items:center; color:var(--blue-light); font-size:24px; flex:none; }
.ruta2__badges{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:32px auto 0; max-width:840px; }
.cap{ display:inline-flex; align-items:center; gap:9px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.24); border-radius:999px; padding:10px 17px; font-size:13.5px; font-weight:600; }
.cap i{ color:var(--green-soft); font-size:13px; }
.ruta2__cta{ display:flex; flex-direction:column; align-items:center; gap:18px; margin-top:34px; }
.ruta2__future{ display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:700; font-size:12.5px; letter-spacing:.04em; text-transform:uppercase; color:#fff; background:rgba(46,125,50,.9); border:1px solid rgba(255,255,255,.2); padding:9px 18px; border-radius:999px; }

/* =========================================================
   PASO EL LEÓN
   ========================================================= */
.paso__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:42px; align-items:start; }
.paso__media{ display:flex; flex-direction:column; gap:14px; }
.paso__main{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); }
.paso__main img{ width:100%; height:100%; object-fit:cover; aspect-ratio:16/11; display:block; }
.paso__wcard{ display:flex; align-items:center; gap:14px; background:var(--blue-pale); border:1px solid #C3E1F2; border-radius:14px; padding:15px 17px; }
.paso__wcard-ic{ width:46px; height:46px; border-radius:12px; background:#fff; display:grid; place-items:center; flex:none; box-shadow:var(--shadow-sm); }
.paso__wcard-ic i{ font-size:20px; color:var(--blue); }
.paso__wcard b{ display:block; font-family:var(--display); font-size:15px; color:var(--navy); line-height:1.2; }
.paso__wcard span{ font-size:13px; color:var(--gray); }
.paso__tag{ position:absolute; bottom:14px; left:14px; right:14px; display:inline-flex; align-items:center; gap:8px; font-size:12.5px; font-family:var(--body); font-weight:600; color:#fff; background:rgba(4,30,46,.55); border:1px solid rgba(255,255,255,.22); backdrop-filter:blur(6px); padding:9px 14px; border-radius:10px; }
.paso__body > p{ color:var(--gray); font-size:16.5px; }
.paso__body > p + p{ margin-top:14px; }
.paso__note{ display:flex; gap:14px; align-items:flex-start; background:var(--blue-pale); border:1px solid #C3E1F2; border-left:4px solid var(--blue); border-radius:12px; padding:16px 18px; margin:22px 0; }
.paso__note i{ color:var(--blue); font-size:20px; margin-top:2px; flex:none; }
.paso__note p{ font-size:14.5px; color:var(--navy); margin:0; line-height:1.55; }
.paso__route{ display:flex; flex-wrap:wrap; align-items:center; gap:8px; margin:22px 0; }
.pstop{ display:inline-flex; align-items:center; gap:7px; background:#fff; border:1px solid var(--line); border-radius:10px; padding:9px 13px; font-family:var(--display); font-weight:600; font-size:13.5px; color:var(--navy); box-shadow:var(--shadow-sm); }
.pstop i{ color:var(--blue); font-size:13px; }
.pstop--end{ background:var(--navy); color:#fff; border-color:var(--navy); }
.pstop--end i{ color:var(--green-soft); }
.paso__route .sep{ color:var(--gray-soft); font-size:12px; }
.paso__chips{ display:flex; flex-wrap:wrap; gap:10px; margin:24px 0 28px; }
.chip2{ display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--line); border-radius:999px; padding:9px 16px; font-size:13.5px; font-weight:700; font-family:var(--display); color:var(--navy); box-shadow:var(--shadow-sm); }
.chip2 i{ color:var(--green); font-size:13px; }

/* Vehículo — foto real */
.veh__photo{ position:relative; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); }
.veh__photo img{ width:100%; height:100%; object-fit:cover; object-position:center; aspect-ratio:4/3; display:block; }

@media (max-width:900px){
  .ruta2__route{ flex-direction:column; align-items:center; gap:6px; }
  .rnode{ width:100%; max-width:360px; flex:none; }
  .rconn{ transform:rotate(90deg); font-size:20px; }
  .paso__grid{ grid-template-columns:1fr; gap:26px; }
  .paso__media img{ aspect-ratio:16/10; }
}
@media (max-width:680px){
  .ruta2{ padding:64px 0; }
  .ruta2__route{ margin-top:28px; }
  .rnode{ max-width:none; width:100%; padding:18px 18px; }
  .rnode b{ font-size:16px; }
  .cap{ font-size:13px; padding:11px 16px; }
  .ruta2__badges{ gap:9px; }
  .ruta2__cta .btn{ width:100%; }
  .dest-group{ font-size:14px; }
}
