/* ============================================================
   GoLatamGo — sistema de diseño
   Identidad: ROJO corporativo + BLANCO. Moderno, limpio.
   >>> Para cambiar el rojo exacto: edita --red y --red-dark.
   >>> Para cambiar la fuente: edita --font (y el <link> de cada HTML).
   ============================================================ */
:root{
  /* color corporativo — ajusta el rojo al de tu logo si difiere */
  --red:#D8232A;
  --red-dark:#AE141A;
  --red-soft:#FDECEC;

  --ink:#17181B;
  --ink-soft:#565961;
  --bg:#F4F5F7;
  --surface:#FFFFFF;
  --line:#E7E8EC;
  --line-soft:#F0F1F4;

  /* alias internos (no tocar) */
  --paper:var(--bg); --paper-2:var(--surface);
  --clay:var(--red); --clay-dark:var(--red-dark);
  --green:var(--red); --green-soft:var(--red-soft);

  --radius:18px; --radius-sm:12px; --pill:999px;
  --shadow:0 1px 2px rgba(23,24,27,.05), 0 12px 32px rgba(23,24,27,.07);
  --shadow-sm:0 1px 2px rgba(23,24,27,.05), 0 6px 18px rgba(23,24,27,.05);
  --shadow-red:0 8px 22px rgba(216,35,42,.28);
  --font:"Poppins", system-ui, -apple-system, "Segoe UI", sans-serif;
  --display:var(--font); --body:var(--font);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.6;font-size:17px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}

/* ---------- tipografía ---------- */
h1,h2,h3{font-weight:600;line-height:1.1;letter-spacing:-.02em}
h1{font-size:clamp(34px,6vw,60px)}
h2{font-size:clamp(27px,4vw,42px)}
h3{font-size:clamp(19px,2.4vw,23px)}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--red);border-radius:2px}
.lead{font-size:clamp(17px,2vw,20px);color:var(--ink-soft);max-width:60ch;font-weight:400}

/* ---------- botones chulos ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-family:var(--font);font-size:15.5px;font-weight:600;padding:14px 26px;border-radius:var(--pill);border:1.5px solid transparent;transition:transform .2s cubic-bezier(.2,.7,.2,1), box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease}
.btn svg{width:18px;height:18px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .2s ease}
.btn:hover svg{transform:translateX(4px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn-primary{background:var(--red);color:#fff;box-shadow:var(--shadow-red)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 12px 28px rgba(216,35,42,.34)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--red);color:var(--red);transform:translateY(-2px)}
.btn-light{background:#fff;color:var(--red);box-shadow:0 8px 22px rgba(0,0,0,.12)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.18)}

/* ---------- header ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:flex;align-items:center}
.brand img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:15px;color:var(--ink-soft);font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--red);border-radius:2px;transition:width .25s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:12px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--ink)}
@media(max-width:880px){
  .nav-links{display:none}
  .menu-btn{display:block}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:2px;background:#fff;border-bottom:1px solid var(--line);padding:14px clamp(20px,5vw,40px);box-shadow:var(--shadow-sm)}
  .nav-links.open a{padding:11px 0;width:100%;border-bottom:1px solid var(--line-soft)}
  .nav-links.open a::after{display:none}
}

/* ---------- secciones ---------- */
section{padding:clamp(58px,9vw,108px) 0}
.section-sm{padding:clamp(42px,6vw,72px) 0}
.center{text-align:center}
.center .eyebrow,.center .lead{margin-left:auto;margin-right:auto}
.center .lead{margin-top:14px}
.alt{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- hero ---------- */
.hero{padding:clamp(46px,7vw,86px) 0 clamp(46px,7vw,80px);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,56px);align-items:center}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr}}
.hero h1{max-width:15ch}
.hero .lead{margin-top:22px}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:32px}
.hero-note{margin-top:24px;font-size:14.5px;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:8px 18px}
.hero-note b{color:var(--red);font-weight:600}
.hero-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff;border:1px solid var(--line)}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-media .ribbon{position:absolute;left:18px;bottom:18px;background:var(--red);color:#fff;font-size:13px;font-weight:600;padding:8px 15px;border-radius:var(--pill);box-shadow:var(--shadow-red)}

/* ---------- trust (banda roja) ---------- */
.trust{background:var(--red);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;gap:clamp(18px,4vw,52px);align-items:center;justify-content:center;padding-top:28px;padding-bottom:28px}
.trust .item{display:flex;align-items:center;gap:11px;font-size:15px}
.trust .item b{font-weight:600;font-size:26px;color:#fff;letter-spacing:-.02em}
.trust .item span{color:rgba(255,255,255,.82);max-width:18ch;line-height:1.32}
.trust .sep{width:1px;height:36px;background:rgba(255,255,255,.28)}
@media(max-width:680px){.trust .sep{display:none}}

/* ---------- grids ---------- */
.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.g-3{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.g-2,.g-3{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,30px);box-shadow:var(--shadow-sm);transition:transform .22s cubic-bezier(.2,.7,.2,1), box-shadow .22s ease, border-color .22s ease}
.card .ic{width:50px;height:50px;border-radius:14px;background:var(--red-soft);display:grid;place-items:center;color:var(--red);margin-bottom:18px}
.card .ic svg{width:25px;height:25px;stroke:currentColor;stroke-width:1.6;fill:none}
.card h3{margin-bottom:8px}
.card p{color:var(--ink-soft);font-size:15.5px}

a.route,a.svc{display:flex;flex-direction:column;cursor:pointer}
a.route:hover,a.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--red)}
.route .quote{font-weight:600;font-size:19px;line-height:1.32;color:var(--ink);margin-bottom:12px;letter-spacing:-.01em}
.route small{display:block;color:var(--ink-soft);font-size:14px;margin-bottom:18px}
.route .pack,.svc .more{font-weight:600;color:var(--red);font-size:15px;display:inline-flex;align-items:center;gap:7px;margin-top:auto}
.route .pack svg,.svc .more svg{width:16px;height:16px;stroke:currentColor;stroke-width:2.4;fill:none;transition:transform .2s}
a.route:hover .pack svg,a.svc:hover .more svg{transform:translateX(5px)}
.svc .tagline{font-size:13px;color:var(--red);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.svc p{margin:8px 0 18px;color:var(--ink-soft);font-size:15.5px}
.svc .more{color:var(--ink)}
a.svc:hover .more{color:var(--red)}

/* ---------- pasos ---------- */
.steps{counter-reset:s;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}
@media(max-width:840px){.steps{grid-template-columns:1fr}}
.step-i{position:relative;padding:28px 26px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.step-i::before{counter-increment:s;content:counter(s);width:42px;height:42px;border-radius:12px;background:var(--red);color:#fff;font-weight:600;font-size:19px;display:grid;place-items:center;margin-bottom:16px}
.step-i h3{font-size:20px;margin-bottom:6px}
.step-i p{color:var(--ink-soft);font-size:15px}

/* ---------- video ---------- */
.video-wrap{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16/9;background:#000;max-width:960px;margin:0 auto}
.video-wrap iframe,.video-wrap video{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-poster{position:absolute;inset:0;cursor:pointer}
.video-poster img{width:100%;height:100%;object-fit:cover;opacity:.82}
.video-poster .play{position:absolute;inset:0;display:grid;place-items:center}
.video-poster .play span{width:84px;height:84px;border-radius:50%;background:var(--red);display:grid;place-items:center;box-shadow:var(--shadow-red);transition:transform .2s ease}
.video-poster:hover .play span{transform:scale(1.08)}
.video-poster .play svg{width:30px;height:30px;fill:#fff;margin-left:5px}

/* ---------- bandas color ---------- */
.band{background:var(--red);color:#fff}
.band h2{color:#fff}
.band .lead{color:rgba(255,255,255,.88)}
.band .wrap{text-align:center}
.band-cta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.band .btn-primary{background:#fff;color:var(--red);box-shadow:0 8px 22px rgba(0,0,0,.16)}
.band .btn-primary:hover{background:#fff;color:var(--red-dark);box-shadow:0 12px 28px rgba(0,0,0,.22)}

/* ---------- listas de servicio ---------- */
.feature-list{list-style:none;display:grid;gap:13px;margin-top:6px}
.feature-list.cols2{grid-template-columns:1fr 1fr}
@media(max-width:640px){.feature-list.cols2{grid-template-columns:1fr}}
.feature-list li{display:flex;gap:12px;font-size:16px}
.feature-list li svg{flex:none;width:22px;height:22px;margin-top:2px;stroke:#fff;stroke-width:2.4;fill:none;background:var(--red);border-radius:50%;padding:3px}

/* ---------- callout ---------- */
.callout{background:var(--red-soft);border:1px solid #F3C9CA;border-left:4px solid var(--red);border-radius:var(--radius-sm);padding:24px 26px;margin-top:30px}
.callout h3{font-size:19px;color:var(--red-dark);margin-bottom:7px}
.callout p{color:#7A2A2C;font-size:15.5px}
.callout a{color:var(--red-dark);font-weight:600;text-decoration:underline}

/* ---------- breadcrumb ---------- */
.crumb{font-size:14px;color:var(--ink-soft);padding-top:26px}
.crumb a:hover{color:var(--red)}
.crumb span{margin:0 8px;opacity:.5}

/* ---------- aliados ---------- */
.aliado{display:flex;align-items:center;gap:22px}
.aliado .logo-box{flex:none;width:150px;height:84px;border-radius:14px;display:grid;place-items:center;padding:14px;border:1px solid var(--line);background:#fff}
.aliado .logo-box.dark{background:var(--ink)}
.aliado .logo-box img{max-width:100%;max-height:100%;object-fit:contain;width:auto}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:12px;max-width:800px}
.faq details{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:2px 22px;transition:border-color .2s,box-shadow .2s}
.faq details[open]{border-color:var(--red);box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;list-style:none;font-weight:600;font-size:17px;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:26px;font-weight:400;color:var(--red);transition:transform .2s;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 0 20px;color:var(--ink-soft);font-size:15.5px}

/* ---------- formulario ---------- */
.form{display:grid;gap:15px;max-width:560px}
.form label{font-size:14px;font-weight:600;color:var(--ink);display:block;margin-bottom:6px}
.form input,.form textarea,.form select{width:100%;font-family:var(--font);font-size:16px;color:var(--ink);background:var(--surface);border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:13px 15px;transition:border-color .2s,box-shadow .2s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px var(--red-soft)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:15px}
@media(max-width:560px){.form .row{grid-template-columns:1fr}}
.form .check{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--ink-soft)}
.form .check input{width:auto;margin-top:3px}
.contact-cols{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,60px);align-items:start}
@media(max-width:820px){.contact-cols{grid-template-columns:1fr}}
.contact-side{display:grid;gap:14px}
.contact-side .chip{display:flex;gap:14px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;transition:transform .2s,border-color .2s,box-shadow .2s}
.contact-side .chip:hover{transform:translateY(-2px);border-color:var(--red);box-shadow:var(--shadow-sm)}
.contact-side .chip .ic{width:46px;height:46px;flex:none;border-radius:12px;background:var(--red-soft);display:grid;place-items:center;color:var(--red)}
.contact-side .chip .ic svg{width:21px;height:21px;stroke:currentColor;stroke-width:1.8;fill:none}
.contact-side .chip b{display:block;font-size:15.5px}
.contact-side .chip span{font-size:14px;color:var(--ink-soft)}

/* ---------- footer (claro) ---------- */
.footer{background:var(--surface);color:var(--ink-soft);border-top:1px solid var(--line);padding:clamp(48px,7vw,72px) 0 30px}
.footer h4{color:var(--ink);font-weight:600;font-size:16px;margin-bottom:14px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer a{color:var(--ink-soft);font-size:15px;display:block;padding:5px 0;transition:color .2s}
.footer a:hover{color:var(--red)}
.footer .brand{margin-bottom:14px}
.footer .brand img{height:34px}
.footer .desc{font-size:15px;max-width:34ch;line-height:1.6}
.footer .bottom{border-top:1px solid var(--line);margin-top:40px;padding-top:22px;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;font-size:13.5px}
.footer .bottom a{display:inline}

/* ---------- reveal ---------- */
.rise{opacity:0;transform:translateY(16px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.d1{animation-delay:.05s}.d2{animation-delay:.13s}.d3{animation-delay:.21s}.d4{animation-delay:.29s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.rise{animation:none;opacity:1;transform:none}}
