/* =========================================================
   Visa2Trip — Design System
   Clean · Minimal · Modern
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root{
  /* Brand */
  --navy:#0F2A4A;
  --blue:#2563EB;
  --blue-dark:#1D4ED8;
  --teal:#14B8A6;
  --accent-grad:linear-gradient(120deg,#2563EB 0%,#14B8A6 100%);

  /* Neutrals */
  --ink:#0F172A;
  --muted:#5B6B82;
  --line:#E5EAF1;
  --bg:#FFFFFF;
  --bg-soft:#F5F8FC;
  --bg-soft-2:#EEF3FA;

  /* Feedback */
  --green:#10B981;
  --amber:#F59E0B;
  --red:#EF4444;

  /* Shape */
  --r-sm:10px;
  --r:16px;
  --r-lg:24px;
  --shadow-sm:0 1px 2px rgba(15,42,74,.06),0 1px 3px rgba(15,42,74,.05);
  --shadow:0 10px 30px -12px rgba(15,42,74,.18);
  --shadow-lg:0 24px 60px -20px rgba(15,42,74,.28);

  --container:1140px;
  --nav-h:72px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Plus Jakarta Sans','Segoe UI',system-ui,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{line-height:1.15;color:var(--navy);margin:0 0 .5em;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.6rem,3vw,2.3rem);font-weight:800}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 30px}
.section{padding:84px 0}
.section-sm{padding:56px 0}
.center{text-align:center}
.muted{color:var(--muted)}
.eyebrow{
  display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--blue);margin-bottom:14px;
}
.lead{font-size:1.15rem;color:var(--muted);max-width:620px}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-weight:700;font-size:1rem;border:0;border-radius:999px;
  padding:14px 28px;transition:.18s ease;white-space:nowrap;
}
.btn-primary{background:var(--accent-grad);color:#fff;box-shadow:0 10px 24px -10px rgba(37,99,235,.7)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(37,99,235,.7)}
.btn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-light{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn-light:hover{background:rgba(255,255,255,.25)}
.btn-lg{padding:17px 36px;font-size:1.08rem}
.btn-block{width:100%}
.btn-sm{padding:10px 18px;font-size:.92rem}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line);
}
.nav{height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-logo img{height:34px}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:600;color:var(--navy);font-size:.96rem;transition:.15s}
.nav-links a:hover{color:var(--blue)}
.nav-actions{display:flex;align-items:center;gap:14px}
.lang-toggle{
  display:inline-flex;border:1.5px solid var(--line);border-radius:999px;overflow:hidden;background:#fff;
}
.lang-toggle button{
  background:transparent;border:0;padding:7px 13px;font-weight:700;font-size:.82rem;color:var(--muted);
}
.lang-toggle button.active{background:var(--navy);color:#fff}
.nav-toggle{display:none;background:none;border:0;padding:8px}
.nav-toggle span{display:block;width:24px;height:2.5px;background:var(--navy);border-radius:2px;margin:5px 0;transition:.2s}

@media(max-width:900px){
  .nav-links,.nav-actions .desktop-only{display:none}
  .nav-toggle{display:block}
  .nav-links.open{
    display:flex;flex-direction:column;position:absolute;top:var(--nav-h);left:0;right:0;
    background:#fff;padding:18px 24px;gap:18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
  }
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 520px at 85% -10%,#E8F0FE 0%,rgba(232,240,254,0) 60%),
  radial-gradient(900px 480px at 0% 110%,#E2F7F3 0%,rgba(226,247,243,0) 60%),#fff;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:72px 30px 84px}
.hero h1 .hl{background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.trust-row{display:flex;align-items:center;gap:18px;margin-top:30px;flex-wrap:wrap}
.stars{color:#FBBF24;letter-spacing:2px;font-size:1.05rem}
.trust-row small{color:var(--muted);font-weight:600}

/* Visa picker card */
.picker{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);padding:30px;
}
.picker h3{margin-bottom:6px}
.picker .muted{font-size:.94rem;margin-bottom:18px}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.86rem;color:var(--navy);margin-bottom:7px}
.field .req{color:var(--red)}
select,input,textarea{
  width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:13px 14px;background:#fff;transition:.15s;
}
select:focus,input:focus,textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.dest-options{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.dest-opt{
  display:flex;align-items:center;gap:10px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  padding:13px;font-weight:700;color:var(--navy);transition:.15s;background:#fff;
}
.dest-opt:hover{border-color:var(--blue)}
.dest-opt.selected{border-color:var(--blue);background:#F2F7FF;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.dest-opt .flag{font-size:1.4rem;line-height:1}

/* ---------- Logos / press strip ---------- */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-soft)}
.strip .container{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:22px;padding-bottom:22px}
.strip span{font-weight:700;color:#9AA8BC;font-size:1.05rem;letter-spacing:.02em}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;
  box-shadow:var(--shadow-sm);transition:.2s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.icon-badge{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:16px;
  background:#EAF1FE;color:var(--blue);font-size:1.5rem;
}
.icon-badge.teal{background:#E2F7F3;color:var(--teal)}

/* Stats */
.stats{background:var(--navy);color:#fff;border-radius:var(--r-lg)}
.stats .grid-4{padding:48px 0}
.stat{text-align:center;color:#fff}
.stat .num{font-size:2.6rem;font-weight:800;background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{color:#B9C6DA;font-weight:600;font-size:.95rem}

/* How it works */
.steps{counter-reset:step}
.step{position:relative;padding-left:0}
.step .n{
  width:46px;height:46px;border-radius:50%;background:var(--accent-grad);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:1.1rem;margin-bottom:16px;
}

/* Comparison */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.compare .col{border-radius:var(--r);padding:30px;border:1px solid var(--line)}
.compare .col.bad{background:var(--bg-soft)}
.compare .col.good{background:linear-gradient(180deg,#F2F7FF, #fff);border-color:#CFE0FF}
.compare ul{list-style:none;margin:14px 0 0;padding:0}
.compare li{display:flex;gap:12px;padding:10px 0;border-top:1px dashed var(--line);color:var(--ink)}
.compare li:first-child{border-top:0}
.compare .x{color:var(--red);font-weight:800}
.compare .ok{color:var(--green);font-weight:800}

/* Testimonials */
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow-sm)}
.quote .stars{font-size:.95rem}
.quote p{font-size:1rem;color:var(--ink);margin:12px 0}
.quote .who{font-weight:700;color:var(--navy);font-size:.92rem}

/* FAQ */
.faq-item{border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;background:#fff;overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:20px 22px;font-weight:700;color:var(--navy);
  font-size:1.04rem;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q .chev{transition:.2s;color:var(--blue);font-size:1.3rem;flex:0 0 auto}
.faq-item.open .faq-q .chev{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;padding:0 22px}
.faq-item.open .faq-a{max-height:420px;padding-bottom:20px}

/* CTA band */
.cta-band{background:var(--accent-grad);border-radius:var(--r-lg);padding:56px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.9);max-width:560px;margin:0 auto 26px}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:#C6D2E4;padding:64px 0 28px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
.site-footer h4{color:#fff;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px}
.site-footer a{display:block;color:#A9B8CE;padding:6px 0;font-size:.95rem;transition:.15s}
.site-footer a:hover{color:#fff}
.footer-brand img{height:34px;margin-bottom:14px;filter:brightness(0) invert(1)}
.footer-brand p{color:#90A0B8;font-size:.92rem;max-width:280px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:40px;padding-top:22px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:#8194AD;font-size:.86rem}
.footer-bottom a{display:inline;color:#A9B8CE}

/* Badges */
.pill{display:inline-flex;align-items:center;gap:8px;background:#EAF1FE;color:var(--blue-dark);
  font-weight:700;font-size:.84rem;padding:7px 14px;border-radius:999px}
.pill.teal{background:#E2F7F3;color:#0E8A7E}
.pill.amber{background:#FEF3E2;color:#B97309}

/* ---------- Landing page specifics ---------- */
.page-hero{background:
  radial-gradient(900px 420px at 90% -20%,#E8F0FE,rgba(255,255,255,0) 60%),var(--bg-soft);
  padding:56px 0;border-bottom:1px solid var(--line)}
.breadcrumb{font-size:.86rem;color:var(--muted);margin-bottom:14px}
.breadcrumb a:hover{color:var(--blue)}
.info-grid{display:grid;grid-template-columns:1.7fr 1fr;gap:40px;align-items:start}
.spec-card{position:sticky;top:96px;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow);overflow:hidden;background:#fff}
.spec-card .head{background:var(--navy);color:#fff;padding:22px 24px}
.spec-card .head h3{color:#fff;margin:0}
.spec-card .body{padding:22px 24px}
.spec-row{display:flex;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.spec-row:last-of-type{border-bottom:0}
.spec-row .k{color:var(--muted);font-weight:600}
.spec-row .v{color:var(--navy);font-weight:700;text-align:right}
.prose h2{margin-top:38px}
.prose ul{padding-left:20px}
.prose li{margin:8px 0}
.req-list{list-style:none;padding:0;margin:0}
.req-list li{display:flex;gap:12px;padding:12px 0;border-top:1px solid var(--line)}
.req-list li:first-child{border-top:0}
.req-list .tick{color:var(--green);font-weight:800;flex:0 0 auto}

.speed-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0}
.speed{border:1.5px solid var(--line);border-radius:var(--r);padding:18px;text-align:center}
.speed.featured{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.speed .t{font-weight:800;color:var(--navy)}
.speed .pr{font-size:1.3rem;font-weight:800;color:var(--blue);margin:6px 0}
.speed .d{font-size:.85rem;color:var(--muted)}

/* ---------- Application form ---------- */
.apply-wrap{background:var(--bg-soft);min-height:calc(100vh - var(--nav-h))}
.apply-inner{max-width:760px;margin:0 auto;padding:40px 24px 80px}
.progress{display:flex;gap:8px;margin-bottom:30px}
.progress .seg{flex:1;height:6px;border-radius:999px;background:var(--line);overflow:hidden}
.progress .seg.done{background:var(--accent-grad)}
.progress .seg.current{background:var(--blue)}
.step-head{margin-bottom:8px}
.step-head .count{font-weight:700;color:var(--blue);font-size:.85rem;letter-spacing:.06em;text-transform:uppercase}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:32px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
@media(max-width:560px){.form-row,.form-row.three{grid-template-columns:1fr}}
.hint{font-size:.82rem;color:var(--muted);margin-top:6px}
.err{border-color:var(--red)!important}
.err-msg{color:var(--red);font-size:.82rem;margin-top:6px;display:none}
.err-msg.show{display:block}
.form-nav{display:flex;justify-content:space-between;gap:14px;margin-top:28px}
.choice-group{display:flex;gap:10px}
.choice{flex:1;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:12px;text-align:center;font-weight:700;color:var(--navy);background:#fff}
.choice.sel{border-color:var(--blue);background:#F2F7FF}
.yesno{display:flex;gap:10px;max-width:220px}
.uploader{border:2px dashed var(--line);border-radius:var(--r);padding:24px;text-align:center;color:var(--muted);background:var(--bg-soft);cursor:pointer;transition:.15s}
.uploader:hover{border-color:var(--blue);color:var(--blue)}
.uploader.has-file{border-color:var(--green);color:var(--green);background:#F0FBF6}
.summary-table{width:100%;border-collapse:collapse;margin-top:8px}
.summary-table td{padding:10px 0;border-bottom:1px solid var(--line);font-size:.95rem}
.summary-table td:first-child{color:var(--muted);font-weight:600}
.summary-table td:last-child{text-align:right;font-weight:700;color:var(--navy)}
.price-box{background:var(--navy);color:#fff;border-radius:var(--r);padding:22px;margin-top:20px}
.price-box .line{display:flex;justify-content:space-between;padding:7px 0;color:#C6D2E4}
.price-box .total{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.2);margin-top:10px;padding-top:14px;font-size:1.3rem;font-weight:800;color:#fff}
.alert{background:#EAF1FE;border:1px solid #CFE0FF;border-radius:var(--r-sm);padding:14px 16px;color:var(--navy);font-size:.92rem;display:flex;gap:10px}
.checkbox-row{display:flex;gap:12px;align-items:flex-start;margin-top:14px}
.checkbox-row input{width:auto;margin-top:4px}
.traveler-tag{display:inline-flex;align-items:center;gap:8px;background:#EAF1FE;color:var(--blue-dark);font-weight:700;padding:6px 14px;border-radius:999px;font-size:.85rem;margin-bottom:16px}
.success-screen{text-align:center;padding:40px 20px}
.success-screen .check{width:84px;height:84px;border-radius:50%;background:#E6F9F1;color:var(--green);display:grid;place-items:center;font-size:2.4rem;margin:0 auto 20px}

/* Responsive */
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .info-grid{grid-template-columns:1fr}
  .spec-card{position:static}
  .grid-4{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:1fr}
  .compare,.footer-grid{grid-template-columns:1fr}
  .speed-grid{grid-template-columns:1fr}
  .section{padding:60px 0}
}
@media(max-width:560px){
  .grid-2,.grid-4{grid-template-columns:1fr}
  .dest-options{grid-template-columns:1fr}
  .cta-band{padding:36px 22px}
  .form-card{padding:22px}
}

/* language blocks (for long prose pages) — scoped a descendientes para que
   la clase de estado .lang-en del propio <body> NO oculte la página entera */
body .lang-en{display:none}
body.lang-en .lang-en{display:block}
body.lang-en .lang-es{display:none}

[hidden]{display:none!important}
.fade-in{animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---- Banner de consentimiento de cookies ---- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:9999;background:var(--navy);color:#fff;box-shadow:0 -4px 24px rgba(0,0,0,.22)}
.cookie-inner{max-width:1120px;margin:0 auto;padding:14px 22px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:space-between}
.cookie-inner p{margin:0;font-size:.9rem;line-height:1.45;flex:1;min-width:240px}
.cookie-inner a{color:#9DC3FF;text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie-banner .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.cookie-banner .btn-ghost:hover{background:rgba(255,255,255,.12)}
/* Banner de cookies en móvil: apilar y mostrar los dos botones legibles a ancho completo */
@media(max-width:560px){
  .cookie-inner{flex-direction:column;align-items:stretch;gap:12px;padding:14px 18px}
  .cookie-inner p{min-width:0}
  .cookie-btns{width:100%}
  .cookie-btns .btn{flex:1}
  .btn{white-space:normal}
}
/* bloque legal de texto largo */
.legal{max-width:820px;margin:0 auto;padding:0 24px}
.legal h2{margin-top:32px}
.legal h3{margin-top:22px}
.legal p,.legal li{color:var(--ink);line-height:1.7}
.legal ul{padding-left:22px}.legal li{margin:6px 0}
.legal .updated{color:var(--muted);font-size:.9rem}
.legal table{width:100%;border-collapse:collapse;margin:16px 0}
.legal th,.legal td{border:1px solid var(--line);padding:10px 12px;text-align:left;font-size:.93rem;vertical-align:top}
.legal th{background:var(--bg-soft);color:var(--navy)}

/* ---- Selector de nacionalidad con banderas ---- */
.flagdd{position:relative}
.flagdd-trigger{width:100%;display:flex;align-items:center;gap:9px;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:11px 12px;font:inherit;font-size:1rem;color:var(--navy);cursor:pointer;text-align:left;transition:border-color .15s}
.flagdd-trigger:hover{border-color:var(--blue)}
.flagdd-trigger.ph{color:var(--muted)}
.flagdd-trigger .flagdd-caret{margin-left:auto;color:var(--muted);font-size:.8rem}
.flagdd-flag{width:22px;height:16px;object-fit:cover;border-radius:2px;box-shadow:0 0 0 1px rgba(15,42,74,.12);flex:0 0 auto}
.flagdd-menu{position:absolute;z-index:60;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lg);padding:8px;max-height:300px;display:flex;flex-direction:column}
.flagdd-search{width:100%;border:1px solid var(--line);border-radius:var(--r-sm);padding:9px 11px;font:inherit;margin-bottom:6px;outline:none}
.flagdd-search:focus{border-color:var(--blue)}
.flagdd-list{overflow-y:auto}
.flagdd-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-sm);cursor:pointer;color:var(--navy);font-size:.96rem}
.flagdd-item:hover{background:var(--bg-soft)}

/* =========================================================
   Ajustes responsive (móvil y tablet) — revisión jun 2026
   ========================================================= */
/* Evita desbordes horizontales por palabras, emails o URLs largas */
body{overflow-wrap:break-word}
h1,h2,h3{overflow-wrap:break-word}
img,svg,video{max-width:100%;height:auto}

/* Tablet (561–900px): aprovechar mejor el ancho que una sola columna */
@media(min-width:561px) and (max-width:900px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}

/* Móvil (≤560px) */
@media(max-width:560px){
  h1{font-size:clamp(1.9rem,7vw,2.4rem)}
  .hero-grid{padding:26px 0 42px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .trust-row{justify-content:center;text-align:center}
  .section{padding:48px 0}
  .section-sm{padding:40px 0}
  .cta-band{padding:34px 20px}
  .picker{padding:22px}
  .form-card{padding:20px}
  .form-nav .btn{padding:13px 18px}
  .stats .grid-4{padding:34px 0}
  /* Tablas de páginas legales: scroll horizontal en vez de desbordar la pantalla */
  .legal table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .summary-table td{font-size:.9rem}
}

/* Móvil pequeño (≤360px): botones grandes un poco más compactos */
@media(max-width:360px){
  .btn-lg{padding:15px 22px;font-size:1rem}
  .nav-logo img{height:30px}
}
