/* ===================================================
   Valora Soluciones Hipotecarias - styles.css
   Versión optimizada - generado automáticamente
   =================================================== */

/* ── PERFORMANCE: content-visibility for off-screen sections ── */
#problema,#solucion,#recorrido,#casos,#galeria,#porque,#testimonios,#faq,#quiz{
  content-visibility:auto;
  contain-intrinsic-size:0 500px;
}

/* ── PERFORMANCE: font smoothing ── */
*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

:root{
  --navy:#1B3A6B;--nd:#0F2345;--nm:#1E4080;
  --green:#3DB54A;--gd:#2D9438;--gl:#5DCF6A;--gp:#EBF8EC;
  --white:#FFFFFF;--off:#F8FAF8;--n100:#E8EDE8;--n600:#566056;
  --text:#1A2A1A;--muted:#6B7B6B;--border:rgba(27,58,107,.10);
  --sans:'Nunito',system-ui,sans-serif;--serif:'Fraunces',Georgia,serif;
  --r:14px;--rl:22px;--rxl:32px;
  --wa:#25D366;--wa2:#1DAA54;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--text);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}

nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 5%;height:74px;background:rgba(255,255,255,.98);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);box-shadow:0 2px 20px rgba(27,58,107,.08)}
.nav-logo img{height:52px;width:auto;object-fit:contain}
.nav-links{display:flex;gap:24px;list-style:none;align-items:center}
.nav-links a{color:var(--navy);text-decoration:none;font-size:13.5px;font-weight:700;transition:color .2s}
.nav-links a:hover{color:var(--green)}
.nav-cta{background:var(--green)!important;color:#fff!important;padding:9px 18px;border-radius:50px;display:inline-flex!important;align-items:center;gap:7px;box-shadow:0 4px 14px rgba(61,181,74,.3);transition:all .2s!important}
.nav-cta:hover{background:var(--gd)!important;transform:translateY(-1px)}

#hero{min-height:100vh;background:linear-gradient(150deg,var(--nd) 0%,var(--navy) 55%,var(--nm) 100%);display:flex;align-items:center;padding:130px 6% 80px;position:relative;overflow:hidden}
#hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 75% 25%,rgba(61,181,74,.14) 0%,transparent 55%),radial-gradient(circle at 15% 75%,rgba(61,181,74,.08) 0%,transparent 45%);pointer-events:none}
.hero-in{max-width:1100px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.badge{display:inline-flex;align-items:center;gap:8px;background:rgba(61,181,74,.15);border:1px solid rgba(61,181,74,.4);color:#76E086;font-size:11px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;padding:8px 16px;border-radius:50px;margin-bottom:26px;width:fit-content}
.badge-dot{width:7px;height:7px;background:#76E086;border-radius:50%;animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-h1{font-family:var(--serif);font-size:clamp(34px,4vw,56px);font-weight:700;color:#fff;line-height:1.1;margin-bottom:20px}
.hero-h1 em{font-style:normal;color:#76E086}
.hero-sub{font-size:16px;color:rgba(255,255,255,.65);max-width:470px;margin-bottom:40px;line-height:1.8}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:52px}
.btn-wa{display:inline-flex;align-items:center;gap:10px;background:var(--wa);color:#fff;font-family:var(--sans);font-weight:800;font-size:15px;padding:15px 28px;border-radius:50px;text-decoration:none;box-shadow:0 8px 24px rgba(37,211,102,.35);transition:all .25s}
.btn-wa:hover{background:var(--wa2);transform:translateY(-2px);box-shadow:0 12px 30px rgba(37,211,102,.45)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;font-family:var(--sans);font-weight:600;font-size:15px;padding:15px 26px;border-radius:50px;text-decoration:none;border:1.5px solid rgba(255,255,255,.28);transition:all .2s}
.btn-ghost:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.08)}
.hero-stats{display:flex;gap:36px;padding-top:36px;border-top:1px solid rgba(255,255,255,.1)}
.hs-num{font-family:var(--serif);font-size:30px;font-weight:700;color:#76E086;line-height:1}
.hs-lbl{font-size:11px;color:rgba(255,255,255,.42);font-weight:500;margin-top:5px}

.hero-imgs{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:10px}
.hi-main{grid-column:1/-1;border-radius:var(--rl);overflow:hidden;height:220px}
.hi-main img{width:100%;height:100%;object-fit:cover}
.hi-sm{border-radius:var(--r);overflow:hidden;height:148px;position:relative}
.hi-sm img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.hi-sm:hover img{transform:scale(1.05)}
.hi-badge{position:absolute;bottom:8px;left:8px;right:8px;background:rgba(15,35,69,.82);backdrop-filter:blur(6px);border-radius:7px;padding:7px 10px;color:#fff;font-size:11px;font-weight:700;text-align:center;border:1px solid rgba(255,255,255,.12)}

.trust-bar{background:var(--nd);padding:16px 6%;display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.6);font-size:12px;font-weight:700;padding:8px 18px;border-right:1px solid rgba(255,255,255,.07)}
.ti:last-child{border-right:none}
.ti-dot{width:7px;height:7px;background:var(--green);border-radius:50%;flex-shrink:0}

.sp{padding:92px 0}
.si{max-width:1100px;margin:0 auto;padding:0 6%}
.stag{font-size:11px;font-weight:900;color:var(--gd);letter-spacing:3px;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.stag::before{content:'';width:22px;height:2px;background:var(--green);border-radius:2px;display:block}
.stag-w{color:var(--gl)}
.stag-w::before{background:var(--gl)}
.sh2{font-family:var(--serif);font-size:clamp(26px,3vw,42px);font-weight:700;color:var(--navy);line-height:1.2;margin-bottom:16px}
.sh2 em{font-style:normal;color:var(--gd)}
.sh2-w{color:#fff}
.sp-intro{font-size:16px;color:var(--muted);max-width:540px;line-height:1.8;margin-bottom:48px}
.sp-intro-w{color:rgba(255,255,255,.52)}

#problema{background:var(--off)}
.prob-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px}
.prob-card{background:var(--white);border-radius:var(--rl);padding:26px 22px;border:1px solid var(--n100);position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}
.prob-card:hover{box-shadow:0 8px 28px rgba(27,58,107,.10);transform:translateY(-2px)}
.prob-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--gl))}
.prob-emoji{font-size:26px;margin-bottom:14px;display:block}
.prob-t{font-weight:800;font-size:15px;color:var(--navy);margin-bottom:8px}
.prob-p{font-size:13px;color:var(--muted);line-height:1.7}

#solucion{background:var(--white)}
.proceso-w{position:relative;margin-top:52px}
.proceso-line{position:absolute;top:37px;left:calc(12.5% + 18px);right:calc(12.5% + 18px);height:2px;background:linear-gradient(90deg,var(--green),var(--gl));z-index:0}
.proceso-g{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;position:relative;z-index:1}
.paso{text-align:center;padding:0 10px}
.paso-tag{display:inline-block;background:var(--gp);color:var(--gd);font-size:10px;font-weight:900;letter-spacing:1px;padding:3px 10px;border-radius:50px;margin-bottom:12px}
.paso-c{width:74px;height:74px;background:var(--white);border:3px solid var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:26px;font-weight:700;color:var(--navy);margin:0 auto 20px;box-shadow:0 4px 16px rgba(61,181,74,.2)}
.paso-t{font-weight:800;font-size:14px;color:var(--navy);margin-bottom:8px}
.paso-p{font-size:13px;color:var(--muted);line-height:1.6}

#casos{background:var(--nd)}

.casos-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px}
.ctab{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.6);font-family:var(--sans);font-size:13px;font-weight:700;padding:9px 18px;border-radius:50px;cursor:pointer;transition:all .2s}
.ctab.active,.ctab:hover{background:var(--green);border-color:var(--green);color:#fff}
.caso-panel{display:none}
.caso-panel.active{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border-radius:var(--rl);overflow:hidden;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1)}
.caso-gallery{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:3px}
.caso-gallery img{width:100%;height:100%;object-fit:cover}
.caso-gallery .main-img{grid-column:1/-1;height:280px}
.caso-gallery .sub-img{height:180px}
.caso-info{padding:36px 32px;display:flex;flex-direction:column;justify-content:center}
.ci-zona{font-size:10px;font-weight:900;color:var(--gl);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:8px}
.ci-name{font-family:var(--serif);font-size:24px;font-weight:700;color:#fff;margin-bottom:20px;line-height:1.2}
.ci-solved{display:inline-flex;align-items:center;gap:6px;background:rgba(61,181,74,.15);border:1px solid rgba(61,181,74,.3);color:var(--gl);font-size:11px;font-weight:800;letter-spacing:1px;padding:5px 14px;border-radius:50px;margin-bottom:20px;width:fit-content}
.ci-dlbl{font-size:11px;color:rgba(255,255,255,.4);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.ci-dval{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--gl);margin-bottom:20px}
.ci-chips{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:28px}
.chip{background:rgba(61,181,74,.12);color:var(--gl);font-size:11px;font-weight:800;padding:4px 12px;border-radius:50px}
.casos-cta{text-align:center;margin-top:48px;display:flex;flex-direction:column;align-items:center;gap:14px}
.casos-cta p{font-size:15px;color:rgba(255,255,255,.55)}

#galeria{background:var(--navy)}
.gal-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.gal-item{position:relative;overflow:hidden;height:260px}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gal-item:hover img{transform:scale(1.07)}
.gal-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,35,69,.85) 0%,rgba(15,35,69,.05) 60%);display:flex;align-items:flex-end;padding:16px;opacity:0;transition:opacity .3s}
.gal-item:hover .gal-ov{opacity:1}
.gal-txt{color:#fff;font-size:12px;font-weight:700;line-height:1.4}

#porque{background:var(--off)}
.pq-layout{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.pq-visual{background:var(--white);border-radius:var(--rxl);padding:36px;border:1px solid var(--n100);box-shadow:0 20px 60px rgba(27,58,107,.08)}
.pq-logo{text-align:center;margin-bottom:24px}
.pq-logo img{height:58px}
.pq-div{height:1px;background:var(--n100);margin:18px 0}
.pq-metric{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid #F4F6F4}
.pq-metric:last-child{border-bottom:none}
.pq-ico{width:42px;height:42px;flex-shrink:0;background:var(--gp);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px}
.pq-mnum{font-family:var(--serif);font-size:21px;font-weight:700;color:var(--navy)}
.pq-mlbl{font-size:12px;color:var(--muted)}
.pq-list{display:flex;flex-direction:column;gap:26px}
.pq-item{display:flex;gap:16px;align-items:flex-start}
.pq-iico{width:46px;height:46px;flex-shrink:0;background:var(--gp);border:1px solid rgba(61,181,74,.2);border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-top:2px}
.pq-it{font-weight:800;font-size:15px;color:var(--navy);margin-bottom:4px}
.pq-ip{font-size:14px;color:var(--muted);line-height:1.7}

#testimonios{background:var(--white)}
.test-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.test-card{background:var(--off);border-radius:var(--rl);padding:28px 24px;border:1px solid var(--n100);transition:box-shadow .2s}
.test-card:hover{box-shadow:0 8px 28px rgba(27,58,107,.08)}
.test-stars{color:#F0B429;font-size:13px;margin-bottom:12px;letter-spacing:2px}
.test-q{font-family:var(--serif);font-size:38px;color:var(--green);line-height:.7;margin-bottom:12px;display:block}
.test-p{font-size:14px;color:var(--n600);line-height:1.75;margin-bottom:22px;font-style:italic}
.test-auth{display:flex;align-items:center;gap:12px}
.test-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--navy));display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:16px;font-weight:700;color:#fff;flex-shrink:0}
.test-name{font-weight:800;font-size:13px;color:var(--navy)}
.test-det{font-size:11px;color:var(--muted)}

#faq{background:var(--nd)}
.faq-list{border:1px solid rgba(255,255,255,.08);border-radius:var(--rl);overflow:hidden}
.faq-item{border-bottom:1px solid rgba(255,255,255,.06)}
.faq-item:last-child{border-bottom:none}
.faq-btn{width:100%;text-align:left;background:transparent;border:none;padding:20px 26px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;color:#fff;font-family:var(--sans);font-size:15px;font-weight:700;gap:14px;transition:background .2s}
.faq-btn:hover{background:rgba(255,255,255,.03)}
.faq-plus{width:28px;height:28px;flex-shrink:0;border:1.5px solid rgba(61,181,74,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--green);font-size:18px;transition:transform .3s}
.faq-body{padding:0 26px;max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-body-in{padding-bottom:20px;font-size:14px;color:rgba(255,255,255,.52);line-height:1.78}
.faq-item.open .faq-plus{transform:rotate(45deg)}
.faq-item.open .faq-body{max-height:280px}

#contacto{background:linear-gradient(135deg,var(--gd) 0%,var(--green) 55%,var(--gl) 100%);padding:92px 6%;text-align:center;position:relative;overflow:hidden}
#contacto::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:700px;height:700px;background:rgba(255,255,255,.06);border-radius:50%;pointer-events:none}
.cta-h2{font-family:var(--serif);font-size:clamp(30px,4vw,50px);font-weight:700;color:#fff;line-height:1.15;margin-bottom:16px;position:relative;z-index:1}
.cta-sub{font-size:16px;color:rgba(255,255,255,.78);max-width:500px;margin:0 auto 40px;line-height:1.75;position:relative;z-index:1}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.btn-white{display:inline-flex;align-items:center;gap:9px;background:#fff;color:var(--gd);font-family:var(--sans);font-weight:800;font-size:15px;padding:17px 32px;border-radius:50px;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.15);transition:all .2s}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.2)}
.btn-wa-out{display:inline-flex;align-items:center;gap:9px;background:transparent;color:#fff;font-family:var(--sans);font-weight:700;font-size:15px;padding:17px 32px;border-radius:50px;text-decoration:none;border:2px solid rgba(255,255,255,.65);transition:all .2s}
.btn-wa-out:hover{background:rgba(255,255,255,.12);border-color:#fff}
.cta-promise{font-size:12px;color:rgba(255,255,255,.6);margin-top:22px;position:relative;z-index:1}

footer{background:var(--nd);padding:60px 6% 28px}
.ft{display:grid;grid-template-columns:2fr 1fr 1fr;gap:56px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:28px}
.fl img{height:46px;width:auto;margin-bottom:16px}
.fd{font-size:13px;color:rgba(255,255,255,.32);line-height:1.8;max-width:290px}
.fs{display:flex;gap:10px;margin-top:22px}
.fsb{width:36px;height:36px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:9px;display:flex;align-items:center;justify-content:center;text-decoration:none;color:rgba(255,255,255,.36);font-size:15px;transition:all .2s}
.fsb:hover{background:rgba(61,181,74,.15);color:var(--gl);border-color:rgba(61,181,74,.3)}
.fct{font-size:10px;font-weight:900;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:18px}
.flinks{list-style:none;display:flex;flex-direction:column;gap:11px}
.flinks a{color:rgba(255,255,255,.32);text-decoration:none;font-size:13px;transition:color .2s}
.flinks a:hover{color:var(--gl)}
.fb{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:rgba(255,255,255,.22);flex-wrap:wrap;gap:10px}

.wa-float{position:fixed;bottom:26px;right:26px;z-index:200;width:60px;height:60px;background:var(--wa);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.45);text-decoration:none;transition:transform .2s;animation:waf 4s ease-in-out 3s infinite}
@keyframes waf{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.wa-float:hover{transform:scale(1.08)!important;animation:none}
.wa-pill{position:absolute;right:70px;background:var(--nd);color:#fff;font-size:12px;font-weight:700;padding:8px 14px;border-radius:50px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;border:1px solid rgba(255,255,255,.1)}
.wa-float:hover .wa-pill{opacity:1}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

@media(max-width:960px){
  .hero-in,.pq-layout{grid-template-columns:1fr}
  .hero-imgs{display:none}
  .proceso-g{grid-template-columns:repeat(2,1fr);gap:28px}.proceso-line{display:none}
  .caso-panel.active{grid-template-columns:1fr}
  .caso-gallery{display:grid;grid-template-columns:1fr 1fr;gap:3px}.caso-gallery .main-img{grid-column:1/-1;height:200px;display:block}.caso-gallery .sub-img{height:120px;display:block}
  .test-g{grid-template-columns:1fr}
  .gal-strip{grid-template-columns:repeat(3,1fr)}.gal-item:nth-child(n+4){display:none}
  .ft{grid-template-columns:1fr;gap:32px}
  .nav-links{display:none}
}

#video-valora { background: var(--navy-dark); padding: 0; }
.video-hero-wrap {
  display: grid; grid-template-columns: 1fr 1fr;
  max-width: 1100px; margin: 0 auto; padding: 80px 6%;
  gap: 72px; align-items: center;
}
.video-left { position: relative; }
.video-phone {
  width: 280px; margin: 0 auto;
  background: #111; border-radius: 36px;
  padding: 8px; box-shadow: 0 30px 80px rgba(0,0,0,0.6);
  border: 2px solid rgba(255,255,255,0.1);
  position: relative;
}
.video-phone::before {
  content: ''; position: absolute; top: 16px; left: 50%; transform: translateX(-50%);
  width: 60px; height: 6px; background: #222; border-radius: 3px; z-index: 2;
}
.video-phone video {
  width: 100%; border-radius: 28px; display: block;
  aspect-ratio: 9/16; object-fit: cover;
}
.video-mute-btn {
  position: absolute; bottom: 24px; right: -16px;
  width: 44px; height: 44px; background: var(--green);
  border-radius: 50%; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(61,181,74,0.4); transition: all .2s; z-index: 3;
}
.video-mute-btn:hover { transform: scale(1.1); background: var(--green-dark); }
.video-right { }
.video-right .stag { color: var(--green-light); }
.video-right .stag::before { background: var(--green-light); }
.video-right .sh2 { color: #fff; }
.video-right .sh2 em { color: var(--green-light); }
.video-right p { font-size: 16px; color: rgba(255,255,255,.6); line-height: 1.8; margin-bottom: 32px; }
.video-features { list-style: none; display: flex; flex-direction: column; gap: 16px; margin-bottom: 36px; }
.video-features li { display: flex; align-items: center; gap: 12px; color: rgba(255,255,255,.7); font-size: 15px; font-weight: 600; }
.video-features li::before { content: '✓'; width: 26px; height: 26px; background: rgba(61,181,74,.2); border: 1px solid rgba(61,181,74,.4); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--green-light); font-size: 13px; font-weight: 900; flex-shrink: 0; }

#recorrido { background: var(--off); }
.recorrido-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.recorrido-video-wrap { position: relative; }
/* recorrido-phone — see definitive rules at end of file */
.rec-play-overlay {
  position: absolute; inset: 8px; border-radius: 28px;
  background: rgba(27,58,107,.4); display: flex; align-items: center;
  justify-content: center; cursor: pointer; transition: background .2s;
}
.rec-play-overlay:hover { background: rgba(27,58,107,.2); }
.rec-play-btn {
  width: 64px; height: 64px; background: rgba(255,255,255,.95);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 24px; box-shadow: 0 8px 24px rgba(0,0,0,.3);
  transition: transform .2s;
}
.rec-play-overlay:hover .rec-play-btn { transform: scale(1.1); }
.recorrido-info { }
.recorrido-chips-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 28px; }
.rec-chip { background: var(--white); border: 1px solid var(--n100); border-radius: var(--r); padding: 16px; text-align: center; box-shadow: 0 2px 8px rgba(27,58,107,.06); }
.rec-chip-num { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--navy); }
.rec-chip-lbl { font-size: 12px; color: var(--muted); margin-top: 2px; }

@media(max-width:960px) {
  .video-hero-wrap, .recorrido-layout { grid-template-columns: 1fr; gap: 40px; }
}

#caso-sucre .caso-gallery-sucre {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto auto;
  gap: 3px;
}
#caso-sucre .caso-gallery-sucre .sg-hero {
  grid-column: 1/-1; height: 220px; overflow: hidden;
}
#caso-sucre .caso-gallery-sucre .sg-hero img {
  width:100%; height:100%; object-fit:cover; transition:transform .4s;
}
#caso-sucre .caso-gallery-sucre .sg-hero:hover img { transform:scale(1.04); }
#caso-sucre .caso-gallery-sucre .sg-sm { height:130px; overflow:hidden; }
#caso-sucre .caso-gallery-sucre .sg-sm img { width:100%;height:100%;object-fit:cover;transition:transform .4s; }
#caso-sucre .caso-gallery-sucre .sg-sm:hover img { transform:scale(1.05); }

.sucre-thumbs {
  display:flex; gap:4px; margin-top:4px;
}
.sucre-thumbs img {
  height:60px; flex:1; object-fit:cover; border-radius:4px;
  cursor:pointer; transition:opacity .2s;
}
.sucre-thumbs img:hover { opacity:.8; }

.sucre-video-pill {
  margin-top:16px; background:rgba(61,181,74,.12);
  border:1px solid rgba(61,181,74,.3); border-radius:12px;
  padding:12px 16px; display:flex; align-items:center; gap:12px;
  cursor:pointer; transition:background .2s;
}
.sucre-video-pill:hover { background:rgba(61,181,74,.2); }
.sucre-video-pill-icon {
  width:40px;height:40px;background:var(--green);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:#fff;flex-shrink:0;
}
.sucre-video-pill-txt { color:var(--gl); font-weight:700; font-size:14px; }
.sucre-video-pill-sub { color:rgba(255,255,255,.45); font-size:12px; }

.vid-modal {
  display:none; position:fixed; inset:0; z-index:500;
  background:rgba(0,0,0,.92); align-items:center; justify-content:center;
}
.vid-modal.open { display:flex; }
.vid-modal-inner {
  width:min(380px,90vw); position:relative;
}
.vid-modal-inner video {
  width:100%; border-radius:20px; display:block;
}
.vid-modal-close {
  position:absolute; top:-44px; right:0;
  background:rgba(255,255,255,.12); border:none; color:#fff;
  width:36px;height:36px;border-radius:50%;font-size:20px;
  cursor:pointer; display:flex;align-items:center;justify-content:center;
}

.nav-mobile-btn {
  display: none;
  background: none; border: none; cursor: pointer;
  flex-direction: column; gap: 5px; padding: 4px;
}
.nav-mobile-btn span {
  display: block; width: 24px; height: 2px;
  background: var(--navy); border-radius: 2px; transition: all .3s;
}
.nav-mobile-menu {
  display: none;
  position: fixed; top: 70px; left: 0; right: 0;
  background: rgba(255,255,255,.98); backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  flex-direction: column; padding: 16px 6%; gap: 0;
  z-index: 99; box-shadow: 0 8px 24px rgba(27,58,107,.10);
}
.nav-mobile-menu.open { display: flex; }
.nav-mobile-menu a {
  color: var(--navy); text-decoration: none; font-size: 15px;
  font-weight: 700; padding: 14px 0;
  border-bottom: 1px solid var(--border); display: block;
}
.nav-mobile-menu a:last-child { border-bottom: none; }
.nav-mobile-menu .nav-cta {
  margin-top: 12px; text-align: center;
  justify-content: center; padding: 14px;
}

@media (max-width: 960px) {

  .nav-links { display: none !important; }
  .nav-mobile-btn { display: flex; }

  #hero { padding: 100px 5% 60px; min-height: auto; }
  .hero-in { grid-template-columns: 1fr; gap: 0; }
  .hero-imgs { display: none; }
  .hero-h1 { font-size: clamp(28px, 7vw, 42px); }
  .hero-sub { font-size: 15px; max-width: 100%; }
  .hero-stats { gap: 20px; flex-wrap: wrap; }
  .hs-num { font-size: 24px; }
  .hero-btns { flex-direction: column; }
  .btn-wa, .btn-ghost { justify-content: center; text-align: center; width: 100%; }

  .trust-bar { gap: 0; flex-direction: column; padding: 12px 5%; }
  .ti { border-right: none; border-bottom: 1px solid rgba(255,255,255,.06); width: 100%; padding: 10px 0; }
  .ti:last-child { border-bottom: none; }

  .sp { padding: 60px 0; }
  .si { padding: 0 5%; }
  .sh2 { font-size: clamp(22px, 6vw, 34px); }
  .sp-intro { font-size: 15px; max-width: 100%; margin-bottom: 36px; }

  .prob-grid { grid-template-columns: 1fr; gap: 14px; }

  .proceso-g { grid-template-columns: repeat(2,1fr); gap: 24px; }
  .proceso-line { display: none; }
  .paso-c { width: 60px; height: 60px; font-size: 22px; }

  .video-hero-wrap { grid-template-columns: 1fr; padding: 52px 5%; gap: 36px; }
  .video-features li { font-size: 14px; }

  .recorrido-layout { grid-template-columns: 1fr; gap: 36px; }
  .recorrido-chips-grid { grid-template-columns: 1fr 1fr; }

  .casos-tabs { gap: 6px; }
  .ctab { font-size: 12px; padding: 7px 12px; }
  .caso-panel.active { grid-template-columns: 1fr; }
  .caso-gallery { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; }
  .caso-gallery .main-img { grid-column: 1/-1; height: 200px; }
  .caso-gallery .sub-img { height: 120px; }
  .sucre-thumbs img { height: 50px; }
  .caso-info { padding: 20px; }
  .ci-name { font-size: 18px; }
  .ci-dval { font-size: 20px; }

  .caso-gallery-sucre .sg-hero { height: 200px; }
  .caso-gallery-sucre .sg-sm { height: 110px; }

  .gal-strip { grid-template-columns: repeat(2,1fr); }
  .gal-item { height: 160px; }
  .gal-item:nth-child(n+3) { display: none; }

  .pq-layout { grid-template-columns: 1fr; gap: 36px; }
  .pq-visual { padding: 24px; }
  .pq-logo img { height: 46px; }

  .test-g { grid-template-columns: 1fr; gap: 16px; }

  .faq-btn { font-size: 14px; padding: 16px 18px; }
  .faq-body { padding: 0 18px; }

  #contacto { padding: 60px 5%; }
  .cta-h2 { font-size: clamp(26px, 7vw, 40px); }
  .cta-sub { font-size: 15px; }
  .cta-btns { flex-direction: column; align-items: center; }
  .btn-white, .btn-wa-out { width: 100%; justify-content: center; max-width: 340px; }

  .ft { grid-template-columns: 1fr; gap: 28px; }
  .fl img { height: 38px; }

  .wa-float { bottom: 18px; right: 18px; width: 52px; height: 52px; }
  .wa-pill { font-size: 11px; padding: 7px 12px; right: 62px; }

  .vid-modal-inner { width: 92vw; }
}

@media (max-width: 480px) {
  .hero-stats { gap: 16px; }
  .proceso-g { grid-template-columns: 1fr; }
  .ctab { font-size: 11px; padding: 6px 10px; }
  .recorrido-chips-grid { grid-template-columns: 1fr 1fr; }
  .casos-tabs { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 8px; }
  .casos-tabs::-webkit-scrollbar { height: 3px; }
  .casos-tabs::-webkit-scrollbar-thumb { background: var(--green); border-radius: 2px; }
}

#scroll-progress {
  position: fixed; top: 70px; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--green) 0%, var(--green-light) 100%);
  transform-origin: left; transform: scaleX(0);
  z-index: 101; transition: transform 0.1s linear;
}

.wa-toast {
  position: fixed; bottom: 100px; right: 26px; z-index: 199;
  background: var(--white); border-radius: 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,.15);
  padding: 16px 20px; max-width: 260px;
  border: 1px solid rgba(37,211,102,.2);
  display: flex; gap: 12px; align-items: flex-start;
  transform: translateY(20px); opacity: 0;
  transition: all .4s ease; pointer-events: none;
}
.wa-toast.show { transform: translateY(0); opacity: 1; pointer-events: all; }
.wa-toast-ico {
  width: 36px; height: 36px; background: var(--wa);
  border-radius: 50%; display: flex; align-items: center;
  justify-content: center; flex-shrink: 0;
}
.wa-toast-title { font-weight: 800; font-size: 13px; color: var(--navy); margin-bottom: 2px; }
.wa-toast-sub { font-size: 12px; color: var(--muted); line-height: 1.4; }
.wa-toast-close {
  position: absolute; top: 8px; right: 10px;
  background: none; border: none; color: var(--muted);
  font-size: 16px; cursor: pointer; line-height: 1;
}
@media(max-width:960px) {
  .wa-toast { bottom: 86px; right: 14px; max-width: 220px; padding: 12px 14px; }
}

.blog-featured {
  background: var(--white); border-radius: var(--rxl); border: 1px solid var(--n100);
  padding: 32px; margin-bottom: 36px; box-shadow: 0 4px 24px rgba(27,58,107,.06);
}
.blog-feat-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: #FFF7ED; color: #C2410C; font-size: 11px; font-weight: 800;
  letter-spacing: 1px; padding: 5px 14px; border-radius: 50px; margin-bottom: 20px;
}
.blog-feat-grid { display: grid; grid-template-columns: 200px 1fr; gap: 28px; align-items: start; }
.blog-feat-img {
  background: linear-gradient(135deg, var(--nd), var(--navy));
  border-radius: var(--rl); height: 220px; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px; position: relative;
}
.blog-feat-icon { font-size: 52px; }
.blog-feat-cat {
  position: absolute; bottom: 12px; left: 12px; right: 12px;
  background: rgba(61,181,74,.15); border: 1px solid rgba(61,181,74,.3);
  color: var(--gl); font-size: 11px; font-weight: 800; letter-spacing: 1px;
  padding: 5px 10px; border-radius: 7px; text-align: center;
}
.blog-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.blog-cat-pill {
  font-size: 10px; font-weight: 800; padding: 3px 10px; border-radius: 50px;
  background: var(--gp); color: var(--gd);
}
.blog-read-time { font-size: 11px; color: var(--muted); }
.blog-feat-h3 { font-family: var(--serif); font-size: clamp(17px,2vw,22px); font-weight: 700; color: var(--navy); line-height: 1.3; margin-bottom: 12px; }
.blog-feat-p { font-size: 14px; color: var(--muted); line-height: 1.75; margin-bottom: 20px; }
.blog-feat-steps { display: flex; flex-direction: column; gap: 10px; margin-bottom: 24px; }
.blog-feat-step { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--n600); }
.bfs-n {
  width: 22px; height: 22px; background: var(--navy); color: #fff;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; flex-shrink: 0; margin-top: 1px;
}
.blog-cta-inline {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  background: var(--gp); border-radius: var(--r); padding: 14px 18px;
  border: 1px solid rgba(61,181,74,.2);
}
.blog-cta-txt { font-size: 13px; font-weight: 700; color: var(--navy); }
.blog-cta-btn {
  background: var(--green); color: #fff; font-size: 13px; font-weight: 800;
  padding: 8px 18px; border-radius: 50px; text-decoration: none;
  transition: background .2s; white-space: nowrap;
}
.blog-cta-btn:hover { background: var(--gd); }

.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-bottom: 36px; }
.blog-card {
  background: var(--white); border-radius: var(--rl); border: 1px solid var(--n100);
  overflow: hidden; transition: box-shadow .2s, transform .2s;
}
.blog-card:hover { box-shadow: 0 8px 28px rgba(27,58,107,.10); transform: translateY(-3px); }
.blog-card-top {
  height: 140px; display: flex; align-items: center; justify-content: center;
  position: relative;
}
.blog-card-emoji { font-size: 44px; }
.blog-card-cat {
  position: absolute; bottom: 12px; right: 12px;
  background: rgba(255,255,255,.15); color: #fff;
  font-size: 10px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 50px;
}
.blog-card-body { padding: 22px; }
.blog-card-h3 { font-family: var(--serif); font-size: 16px; font-weight: 700; color: var(--navy); line-height: 1.35; margin-bottom: 10px; }
.blog-card-p { font-size: 13px; color: var(--muted); line-height: 1.7; margin-bottom: 14px; }
.blog-card-list { list-style: none; display: flex; flex-direction: column; gap: 7px; margin-bottom: 18px; }
.blog-card-list li { font-size: 12px; color: var(--n600); padding-left: 16px; position: relative; }
.blog-card-list li::before { content: '→'; position: absolute; left: 0; color: var(--green); font-weight: 700; }
.blog-read-link { font-size: 13px; font-weight: 800; color: var(--gd); text-decoration: none; }
.blog-read-link:hover { color: var(--green); }

.blog-bottom-cta {
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
  background: var(--white); border-radius: var(--rl); padding: 28px 32px;
  border: 1px solid var(--n100); box-shadow: 0 4px 20px rgba(27,58,107,.06);
}
.blog-bottom-icon { font-size: 40px; flex-shrink: 0; }
.blog-bottom-h4 { font-family: var(--serif); font-size: 19px; font-weight: 700; color: var(--navy); margin-bottom: 4px; }
.blog-bottom-p { font-size: 14px; color: var(--muted); margin: 0; }

@media(max-width:960px) {
  .blog-feat-grid { grid-template-columns: 1fr; }
  .blog-feat-img { height: 160px; }
  .blog-grid { grid-template-columns: 1fr; gap: 16px; }
  .blog-bottom-cta { flex-direction: column; align-items: flex-start; }
}

#quiz {
  background: #F7F9FC;
  padding: 96px 0;
  position: relative;
}
.quiz-inner { max-width: 600px; margin: 0 auto; padding: 0 6%; }

.quiz-header { text-align: center; margin-bottom: 40px; }
.quiz-tag {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--gp); border: 1px solid rgba(61,181,74,.3);
  color: var(--gd); font-size: 11px; font-weight: 800; letter-spacing: 2px;
  text-transform: uppercase; padding: 7px 18px; border-radius: 50px; margin-bottom: 18px;
}
.quiz-h2 {
  font-family: var(--serif); font-size: clamp(24px,4vw,38px);
  font-weight: 700; color: var(--navy); line-height: 1.2; margin-bottom: 12px;
}
.quiz-h2 span { color: var(--gd); }
.quiz-sub { font-size: 15px; color: var(--muted); line-height: 1.7; max-width: 480px; margin: 0 auto; }

.quiz-trust {
  display: flex; justify-content: center; gap: 24px; flex-wrap: wrap;
  margin-top: 18px;
}
.quiz-trust-item {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--muted); font-weight: 700;
}
.quiz-trust-item svg { color: var(--green); flex-shrink: 0; }

.quiz-steps-bar {
  display: flex; align-items: center; justify-content: center;
  gap: 0; margin-bottom: 36px;
}
.quiz-step-dot {
  width: 44px; height: 44px; border-radius: 50%;
  background: #E8EEF6; border: 2px solid #D0DAE8;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; transition: all .3s; flex-shrink: 0;
  position: relative; z-index: 1;
}
.quiz-step-dot.active {
  background: var(--navy); border-color: var(--navy);
  box-shadow: 0 4px 16px rgba(27,58,107,.3);
}
.quiz-step-dot.done {
  background: var(--green); border-color: var(--green);
}
.quiz-step-dot.active .qsd-icon, .quiz-step-dot.done .qsd-icon { filter: brightness(0) invert(1); }
.quiz-step-connector {
  height: 2px; width: 40px; background: #D0DAE8; flex-shrink: 0;
  transition: background .3s;
}
.quiz-step-connector.done { background: var(--green); }

.quiz-progress { margin-bottom: 32px; }
.quiz-progress-labels {
  display: flex; justify-content: space-between;
  font-size: 11px; color: var(--muted); font-weight: 700; letter-spacing: .5px;
  margin-bottom: 8px;
}
.quiz-progress-labels span:last-child { color: var(--gd); }
.quiz-progress-bar {
  height: 4px; background: #E0E8F0; border-radius: 4px; overflow: hidden;
}
.quiz-progress-fill {
  height: 100%; background: linear-gradient(90deg, var(--green), var(--gl));
  border-radius: 4px; transition: width .4s ease;
}

.quiz-card {
  background: #fff;
  border-radius: 20px;
  padding: 40px 36px;
  box-shadow: 0 4px 32px rgba(27,58,107,.10);
  border: 1px solid #E8EEF6;
}
.quiz-step { display: none; }
.quiz-step.active { display: block; animation: fadeSlide .3s ease; }
@keyframes fadeSlide {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.quiz-step-num {
  font-size: 11px; font-weight: 900; color: var(--muted);
  letter-spacing: 2px; text-transform: uppercase; margin-bottom: 10px;
}
.quiz-q {
  font-family: var(--serif); font-size: clamp(18px,3vw,24px);
  font-weight: 700; color: var(--navy); margin-bottom: 8px; line-height: 1.3;
}
.quiz-q span { color: var(--gd); }
.quiz-hint { font-size: 13px; color: var(--muted); margin-bottom: 24px; line-height: 1.5; }

.quiz-options { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.quiz-options.single-col { grid-template-columns: 1fr; }
.quiz-opt {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; text-align: center;
  background: #fff; border: 2px solid #D8E4F0;
  border-radius: 14px; padding: 20px 16px; cursor: pointer;
  transition: all .2s; font-family: var(--sans); width: 100%;
  min-height: 100px;
}
.quiz-opt:hover {
  border-color: var(--navy); background: #F0F5FF;
  transform: translateY(-2px); box-shadow: 0 4px 16px rgba(27,58,107,.12);
}
.quiz-opt.selected {
  border-color: var(--green); background: var(--gp);
  box-shadow: 0 4px 16px rgba(61,181,74,.20);
}
.quiz-opt-icon {
  width: 48px; height: 48px; border-radius: 50%;
  background: #EEF3FA; display: flex; align-items: center;
  justify-content: center; font-size: 22px; transition: all .2s;
  flex-shrink: 0;
}
.quiz-opt.selected .quiz-opt-icon { background: rgba(61,181,74,.15); }
.quiz-opt-body { display: flex; flex-direction: column; gap: 2px; }
.quiz-opt-title { font-size: 13px; font-weight: 800; color: var(--navy); line-height: 1.3; }
.quiz-opt.selected .quiz-opt-title { color: var(--gd); }
.quiz-opt-desc { font-size: 11px; color: var(--muted); line-height: 1.4; }
.quiz-opt-check { display: none; }

.quiz-options.full-opts { grid-template-columns: 1fr; gap: 10px; }
.quiz-options.full-opts .quiz-opt {
  flex-direction: row; text-align: left; min-height: auto;
  padding: 16px 20px; justify-content: flex-start; gap: 14px;
}
.quiz-options.full-opts .quiz-opt-body { flex: 1; }
.quiz-options.full-opts .quiz-opt-icon { width: 42px; height: 42px; font-size: 20px; flex-shrink: 0; }
.quiz-opt-badge {
  margin-left: auto; font-size: 10px; font-weight: 800; padding: 3px 10px;
  border-radius: 50px; background: rgba(239,68,68,.1); color: #DC2626;
  white-space: nowrap; flex-shrink: 0;
}
.quiz-opt.selected .quiz-opt-badge { background: rgba(61,181,74,.15); color: var(--gd); }

.quiz-nav { display: flex; gap: 12px; margin-top: 28px; align-items: center; }
.quiz-btn-next {
  flex: 1; background: var(--navy); color: #fff;
  font-family: var(--sans); font-size: 15px; font-weight: 800;
  padding: 15px 28px; border-radius: 10px; border: none; cursor: pointer;
  transition: all .2s; display: flex; align-items: center; justify-content: center; gap: 8px;
}
.quiz-btn-next:hover { background: var(--nd); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(27,58,107,.25); }
.quiz-btn-next:disabled { background: #C8D4E0; cursor: not-allowed; transform: none; box-shadow: none; }
.quiz-btn-back {
  background: transparent; color: var(--muted);
  font-family: var(--sans); font-size: 14px; font-weight: 700;
  padding: 15px 20px; border-radius: 10px;
  border: 2px solid #D8E4F0; cursor: pointer; transition: all .2s;
}
.quiz-btn-back:hover { color: var(--navy); border-color: var(--navy); background: #F0F5FF; }

.quiz-result { display: none; }
.quiz-result.active { display: block; animation: fadeSlide .35s ease; }
.result-icon {
  width: 72px; height: 72px; background: var(--gp);
  border: 2px solid var(--green); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 32px; margin: 0 auto 20px;
}
.result-title {
  font-family: var(--serif); font-size: clamp(20px,4vw,28px);
  font-weight: 700; color: var(--navy); text-align: center; margin-bottom: 10px;
}
.result-sub {
  font-size: 14px; color: var(--muted);
  text-align: center; margin-bottom: 24px; line-height: 1.75;
}
.result-score-wrap { margin: 16px 0 24px; }
.result-score-label { font-size: 11px; color: var(--muted); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px; }
.result-score-bar { height: 8px; background: #E8EEF6; border-radius: 8px; overflow: hidden; margin-bottom: 6px; }
.result-score-fill { height: 100%; border-radius: 8px; transition: width 1s ease; }
.result-score-txt { font-size: 13px; font-weight: 800; }
.quiz-wa-btn {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  background: var(--wa); color: #fff; font-family: var(--sans);
  font-weight: 800; font-size: 16px; padding: 18px 32px;
  border-radius: 12px; text-decoration: none; width: 100%;
  box-shadow: 0 8px 24px rgba(37,211,102,.35); transition: all .2s;
}
.quiz-wa-btn:hover { background: var(--wa2); transform: translateY(-2px); }
.quiz-restart {
  text-align: center; margin-top: 14px; display: block;
  font-size: 13px; color: var(--muted); cursor: pointer;
  text-decoration: underline; background: none; border: none;
}
.quiz-restart:hover { color: var(--navy); }

@media(max-width:960px) {
  #quiz { padding: 64px 0; }
  .quiz-card { padding: 28px 20px; border-radius: 16px; }
  .quiz-options { grid-template-columns: 1fr; }
  .quiz-step-connector { width: 24px; }
  .quiz-step-dot { width: 38px; height: 38px; font-size: 16px; }
}

/* ══ RECORRIDO PHONE — definitive clean rule ══ */
.recorrido-phone {
  width: 300px;
  margin: 0 auto;
  background: #1a1a1a;
  border-radius: 36px;
  padding: 8px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  border: 2px solid #e0e0e0;
  position: relative;
  overflow: hidden;
}
.recorrido-phone::before {
  content: '';
  position: absolute;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 6px;
  background: #333;
  border-radius: 3px;
  z-index: 3;
}
.recorrido-phone video {
  width: 100%;
  display: block;
  border-radius: 28px;
  aspect-ratio: 9/16;
  object-fit: cover;
}
.rec-play-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.35);
  border-radius: 28px;
  cursor: pointer;
}

/* ══ VIDEO CENTERED section ══ */
.video-centered {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  max-width: 380px;
}
#video-valora .si {
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}

/* ══ LOGO NAV / FOOTER ══ */

.pq-logo img  { height: 56px; width: auto; max-width: 220px; object-fit: contain; }

/* ══ PROCESO 3 pasos ══ */
.proceso-g { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 768px) { .proceso-g { grid-template-columns: 1fr; } }

/* ══ RESPONSIVE recorrido-phone ══ */
@media (max-width: 768px) {
  .recorrido-phone { width: 240px; }
  .video-phone { width: 240px; }
}
@media (max-width: 480px) {
  .recorrido-phone { width: 210px; }
  .video-phone { width: 210px; }
}

/* ══════════════════════════════════════════════════
   MOBILE FIXES — consolidated clean overrides
   ══════════════════════════════════════════════════ */

/* Nav mobile button — make it prominent */
.nav-mobile-btn {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  flex-direction: column;
  gap: 6px;
  padding: 8px;
  z-index: 200;
}
.nav-mobile-btn span {
  display: block;
  width: 28px;
  height: 3px;
  background: var(--navy);
  border-radius: 3px;
  transition: all .3s;
}

/* Mobile menu panel */
#mobile-menu {
  display: none;
  position: fixed;
  top: 70px; left: 0; right: 0;
  background: rgba(255,255,255,.98);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 2px solid var(--n100);
  flex-direction: column;
  padding: 0 6% 20px;
  z-index: 99;
  box-shadow: 0 8px 30px rgba(0,0,0,.12);
}
#mobile-menu.open { display: flex; }

#mobile-menu a {
  color: var(--navy);
  text-decoration: none;
  font-size: 16px;
  font-weight: 700;
  padding: 16px 0;
  border-bottom: 1px solid var(--n100);
  display: block;
  letter-spacing: -.01em;
}
#mobile-menu a:last-child { border-bottom: none; }

/* Mobile WA CTA in menu */
#mobile-menu .nav-cta {
  margin-top: 16px;
  background: var(--green);
  color: #fff !important;
  border-radius: 50px;
  padding: 14px 20px;
  text-align: center;
  justify-content: center;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  border-bottom: none !important;
}

@media (max-width: 960px) {
  /* Show hamburger, hide nav links */
  .nav-links { display: none !important; }
  .nav-mobile-btn { display: flex !important; }

  /* Add a floating WA button in nav for mobile */
  nav { padding: 0 4%; }

  /* Hero mobile */
  .hero-in { grid-template-columns: 1fr !important; padding-top: 100px; }
  .hero-imgs { display: none; }
  .hero-h { font-size: clamp(36px, 9vw, 52px); }
  .hero-stats { gap: 20px; }
  .hs-num { font-size: clamp(22px, 6vw, 32px); }

  /* Sections full width */
  .si { padding: 60px 5%; }
  .prob-grid { grid-template-columns: 1fr; gap: 14px; }
  .proceso-g { grid-template-columns: 1fr !important; }
  .paso { flex-direction: row; gap: 16px; }

  /* Casos tabs — horizontal scroll */
  .casos-tabs {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 8px;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .casos-tabs::-webkit-scrollbar { display: none; }
  .ctab { white-space: nowrap; flex-shrink: 0; }

  /* Caso panel — stack vertically */
  .caso-panel.active { grid-template-columns: 1fr !important; }
  /* Gallery: 2-col grid on mobile so all images show */
  .caso-gallery { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto; gap: 3px; }
  .caso-gallery .main-img { grid-column: 1 / -1; height: 200px; display: block; }
  .caso-gallery .sub-img { height: 120px; display: block !important; }
  .caso-gallery-sucre { grid-template-columns: 1fr 1fr; }
  .caso-gallery-sucre .sg-hero { height: 200px; }
  .caso-gallery-sucre .sg-sm { height: 110px; }

  /* Quiz */
  .quiz-card { padding: 24px 18px; border-radius: 16px; }
  .quiz-options { grid-template-columns: 1fr; }
  .quiz-h2 { font-size: clamp(22px, 6vw, 30px); }

  /* Por qué / diferencial */
  .pq-layout { grid-template-columns: 1fr !important; }
  .pq-visual { display: none; }

  /* Video sections */
  .video-hero-wrap { grid-template-columns: 1fr; gap: 32px; }
  .recorrido-layout { grid-template-columns: 1fr; gap: 32px; }
  .recorrido-video-wrap { order: -1; }

  /* FAQ */
  .faq-q { font-size: 15px; }
}

@media (max-width: 480px) {
  .hero-h { font-size: clamp(30px, 8vw, 42px); }
  .hero-stats { flex-direction: column; gap: 12px; align-items: flex-start; }
  .hs-num { font-size: 28px; }
  .sh2 { font-size: clamp(24px, 7vw, 32px); }
  .btn-wa, .btn-white { width: 100%; justify-content: center; max-width: none; }
  .prob-grid { grid-template-columns: 1fr; }
  .quiz-options { grid-template-columns: 1fr; }
}
