﻿/* ═══════════════════════════════════════════
   YOANDRIS FUENTES — Swiss Design System
   Light Mode · Strict Grid · DM Sans
   ═══════════════════════════════════════════ */

/* --- RESET --- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --white:#ffffff;--black:#000000;--blue:#002366;
  --gray-100:#f7f7f7;--gray-200:#ebebeb;--gray-300:#d4d4d4;
  --gray-500:#888;--gray-700:#444;--gray-900:#111;
  --font:'DM Sans',Helvetica,Arial,sans-serif;
  --max-w:1320px;--col-gap:32px;
  --section-py:clamp(80px,12vw,160px);
  --header-h:72px;
  --radius:10px;
}

html{font-size:16px}
body{font-family:var(--font);background:var(--white);color:var(--gray-700);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;cursor:none}
body.loading{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:var(--font);cursor:pointer}

/* --- TYPOGRAPHY --- */
h1,h2,h3,h4,h5{font-family:var(--font);color:var(--black);font-weight:700;line-height:1.08;letter-spacing:-.03em}
h1{font-size:clamp(2.4rem,5vw,4.2rem)}
h2{font-size:clamp(2.2rem,5vw,4.5rem)}
h3{font-size:clamp(1.4rem,2.5vw,2rem)}
h4{font-size:clamp(1.1rem,1.5vw,1.4rem)}
p{max-width:600px;font-weight:400;font-size:clamp(.92rem,1vw,1.05rem)}
.eyebrow{font-size:clamp(.75rem,1.2vw,.8rem);font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--blue);margin-bottom:.8rem}

/* --- LAYOUT --- */
.container{width:88%;max-width:var(--max-w);margin:0 auto}
.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--col-gap)}
.section{padding:var(--section-py) 0;position:relative}

/* --- REVEAL ANIMATIONS --- */
.reveal{opacity:0;transform:translateY(40px);filter:blur(6px);transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94),filter .8s cubic-bezier(.25,.46,.45,.94)}
.reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* Image parallax expansion */
.img-expand{overflow:hidden;border-radius:var(--radius)}
.img-expand img{transform:scale(.82);transition:transform 1.2s cubic-bezier(.25,.46,.45,.94);transform-origin:center center}
.img-expand.visible img{transform:scale(1)}

/* --- HEADER --- */
.site-header{position:fixed;top:0;left:0;width:100%;height:var(--header-h);z-index:100;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:border-color .3s}
.site-header.scrolled{border-bottom-color:var(--gray-200)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:var(--black);display:flex;align-items:center;gap:.4rem}
.logo span{color:var(--blue)}
.nav-links{display:flex;gap:2.2rem;align-items:center}
.nav-links a{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-700);transition:color .3s}
.nav-links a:hover{color:var(--black)}
.nav-cta{background:var(--blue);color:var(--white)!important;padding:.55rem 1.5rem;border-radius:var(--radius);font-size:.72rem!important;letter-spacing:.12em!important;transition:background .3s,transform .25s!important}
.nav-cta:hover{background:var(--black);transform:scale(1.03)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:200}
.hamburger span{width:24px;height:2px;background:var(--black);transition:transform .3s,opacity .3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* --- BUTTONS --- */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 2.2rem;border-radius:var(--radius);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;border:none;cursor:pointer;position:relative;overflow:hidden;transition:color .4s,transform .25s}
.btn::before{content:'';position:absolute;inset:0;transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.25,.46,.45,.94);z-index:0}
.btn>*{position:relative;z-index:1}

.btn-primary{background:var(--blue);color:var(--white)}
.btn-primary::before{background:var(--black)}
.btn-primary:hover::before{transform:scaleX(1)}
.btn-primary:hover{color:var(--white)}

.btn-outline{background:transparent;color:var(--black);border:1.5px solid var(--black);border-radius:var(--radius)}
.btn-outline::before{background:var(--black)}
.btn-outline:hover{color:var(--white)}
.btn-outline:hover::before{transform:scaleX(1)}

.btn .arrow{transition:transform .3s}
/* Focus visible — keyboard accessibility */
.btn:focus-visible,a:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:2px}
.btn:hover .arrow{transform:translateX(5px)}

/* --- HERO (full-bleed bg) --- */
.hero{min-height:100vh;display:flex;align-items:flex-end;padding-bottom:clamp(60px,8vw,120px);padding-top:calc(var(--header-h) + 60px);position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.82) 0%,rgba(0,0,0,.65) 55%,rgba(0,0,0,.2) 100%)}
.hero-content{position:relative;z-index:2;max-width:720px;margin-left:0!important;margin-right:auto!important;text-align:left;padding-left:clamp(0px,3.5vw,64px)}
.hero h1{color:var(--white)}
/* Hero element animations — more dramatic than generic .reveal */
.hero-content .reveal{
  opacity:0;
  transform:translateX(-36px) translateY(16px);
  filter:blur(10px);
  transition:opacity 1s cubic-bezier(.22,.61,.36,1),transform 1s cubic-bezier(.22,.61,.36,1),filter .9s cubic-bezier(.22,.61,.36,1)
}
.hero-content .reveal.visible{opacity:1;transform:translateX(0) translateY(0);filter:blur(0)}
.hero-content .reveal-delay-1{transition-delay:.18s}
.hero-content .reveal-delay-2{transition-delay:.34s}
.hero-content .reveal-delay-3{transition-delay:.5s}
.hero-content .reveal-delay-4{transition-delay:.66s}
.hero-subtitle{margin:1.5rem 0 2.5rem;font-size:clamp(.95rem,1.1vw,1.1rem);line-height:1.8;color:rgba(255,255,255,.8)}
.hero-meta{display:flex;gap:3rem;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.2)}
.hero-meta-item .number{font-weight:700;font-size:2.4rem;color:var(--white);letter-spacing:-.03em;line-height:1}
.hero-meta-item .label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.55);margin-top:.3rem}

/* --- SERVICES STRIP (Home) --- */
.services-strip{background:var(--gray-100);border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200)}
.services-strip-grid{grid-template-columns:repeat(3,1fr)}
.services-strip-4col{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--col-gap)}
.strip-card{padding:clamp(2rem,4vw,3.5rem) 0;border-right:1px solid var(--gray-200);padding-right:var(--col-gap)}
.strip-card:last-child{border-right:none}
.strip-card .card-number{font-weight:700;font-size:4rem;color:var(--blue);line-height:1;letter-spacing:-.04em;margin-bottom:1rem}
.strip-card h4{margin-bottom:.6rem}
.strip-card p{font-size:.88rem;color:var(--gray-500);line-height:1.7}
.strip-card .card-link{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-top:1rem;transition:gap .3s}
.strip-card:hover .card-link{gap:.6rem}

/* --- ABOUT BLOCK (Home) --- */
.about-block .about-grid{align-items:center}
.about-img-col{grid-column:1/6}
.about-txt-col{grid-column:7/13}
.about-txt-col blockquote{font-size:clamp(1.2rem,2vw,1.6rem);font-weight:600;color:var(--black);line-height:1.35;letter-spacing:-.02em;margin:1.5rem 0;border-left:3px solid var(--blue);padding-left:1.5rem}

/* --- CTA BANNER --- */
.cta-banner{background:var(--black);color:var(--white);padding:clamp(60px,8vw,100px) 0;text-align:center;border-radius:var(--radius)}
.cta-banner h2{color:var(--white)}
.cta-banner p{color:var(--gray-300);margin:1rem auto 2rem}
.cta-banner .btn-primary{background:var(--blue)}
.cta-banner .btn-primary::before{background:var(--white)}
.cta-banner .btn-primary:hover{color:var(--black)}

/* --- SERVICES PAGE --- */
.service-detail{border-bottom:1px solid var(--gray-200)}
.service-detail:last-child{border-bottom:none}
.service-detail-grid{align-items:center}
.service-img{grid-column:1/7}
.service-img.right{grid-column:7/13}
.service-txt{grid-column:7/13}
.service-txt.left{grid-column:1/7}
.service-txt h2{margin-bottom:1rem}
.service-txt p{margin-bottom:1rem}
.service-features{margin-top:1.5rem}
.service-features li{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;padding:.5rem 0;color:var(--gray-700)}
.service-features li::before{content:'';width:8px;height:8px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:.45rem}

/* --- SERVICES PAGE SCROLL LINE --- */
.services-area{position:relative}
.svc-scroll-line{position:absolute;left:50%;top:0;width:2px;height:100%;transform:translateX(-50%);background:var(--gray-200);z-index:0;pointer-events:none;overflow:hidden}
.svc-scroll-line-fill{position:absolute;top:0;left:0;width:100%;height:0%;background:var(--blue);will-change:height}
@media(max-width:1024px){.svc-scroll-line{display:none}}

/* --- NOSOTROS PAGE --- */
.story-section .story-grid{align-items:center}
.story-img{grid-column:1/6}
.story-txt{grid-column:7/13}
.story-txt p{margin-bottom:1rem}
.values-grid{grid-template-columns:repeat(3,1fr);margin-top:3rem;gap:2rem}
.value-card{padding:2rem 0;border-top:2px solid var(--black)}
.value-card h4{margin:.8rem 0 .5rem}
.value-card p{font-size:.88rem;color:var(--gray-500)}
.value-number{font-weight:700;font-size:3rem;color:var(--gray-200);line-height:1;letter-spacing:-.04em}
/* --- TIMELINE ANIMATED --- */
.timeline-v2{margin-top:4rem;padding-top:3rem;border-top:1px solid var(--gray-200)}
.tl-track{position:relative;padding-left:4rem;max-width:860px;margin:0 auto}
.tl-line{position:absolute;left:1.1rem;top:.5rem;bottom:.5rem;width:2px;background:var(--gray-200);overflow:hidden}
.tl-line-fill{position:absolute;top:0;left:0;width:100%;height:0%;background:var(--blue);transition:height .6s cubic-bezier(.25,.46,.45,.94)}
.tl-item{position:relative;padding:2.2rem 0;opacity:0;transform:translateX(-32px);transition:opacity .75s cubic-bezier(.22,.61,.36,1),transform .75s cubic-bezier(.22,.61,.36,1)}
.tl-item.tl-visible{opacity:1;transform:translateX(0)}
.tl-dot{position:absolute;left:-3rem;top:2.8rem;width:18px;height:18px;border-radius:50%;background:var(--gray-300);border:3px solid var(--white);box-shadow:0 0 0 2px var(--gray-200);transition:background .4s,transform .4s,box-shadow .4s}
.tl-item.tl-visible .tl-dot{background:var(--blue);transform:scale(1.15);box-shadow:0 0 0 4px rgba(0,35,102,.15)}
.tl-year{font-weight:700;font-size:2rem;color:var(--blue);letter-spacing:-.03em;margin-bottom:.4rem;line-height:1}
.tl-content h4{margin-bottom:.4rem;font-size:clamp(1.1rem,1.6vw,1.4rem)}
.tl-content p{font-size:.95rem;color:var(--gray-500);line-height:1.75}
/* keep legacy timeline classes for any reference */
.timeline{margin-top:4rem;border-top:1px solid var(--gray-200);padding-top:3rem}
.timeline-item{display:grid;grid-template-columns:120px 1fr;gap:2rem;padding:1.5rem 0;border-bottom:1px solid var(--gray-200)}
.timeline-year{font-weight:700;font-size:1.6rem;color:var(--blue);letter-spacing:-.02em}
.timeline-text h4{margin-bottom:.3rem}
.timeline-text p{font-size:.88rem;color:var(--gray-500)}

/* --- CLIENTES / TESTIMONIALS (Spotlight Carousel) --- */
.testimonial-carousel{position:relative;overflow:hidden;padding:1rem 0 2rem}
.carousel-track{display:flex;gap:1.5rem;transition:transform .55s cubic-bezier(.25,.46,.45,.94);align-items:center;will-change:transform}
.testimonial-slide{flex:0 0 65%;background:var(--gray-100);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.5rem);transform:scale(0.88);opacity:0.4;transition:transform .55s cubic-bezier(.25,.46,.45,.94),opacity .55s,box-shadow .55s,border-color .55s;border-left:4px solid transparent;cursor:pointer}
.testimonial-slide.active{transform:scale(1);opacity:1;box-shadow:0 24px 60px rgba(0,35,102,.13);border-left-color:var(--blue)}
.testimonial-slide blockquote{font-size:clamp(1rem,1.8vw,1.6rem);font-weight:600;color:var(--black);line-height:1.4;letter-spacing:-.02em}
.testimonial-slide .author{margin-top:2rem;display:flex;align-items:center;gap:1rem}
.testimonial-slide .author-avatar{width:52px;height:52px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:var(--blue)}
.testimonial-slide .author-name{font-weight:700;color:var(--black);font-size:.9rem}
.testimonial-slide .author-role{font-size:.78rem;color:var(--gray-500)}
.carousel-controls{display:flex;gap:1rem;margin-top:2rem}
.carousel-btn{width:48px;height:48px;border:1.5px solid var(--black);border-radius:var(--radius);background:transparent;display:flex;align-items:center;justify-content:center;transition:background .3s,color .3s}
.carousel-btn:hover{background:var(--black);color:var(--white)}
.carousel-btn svg{width:18px;height:18px}
.carousel-dots{display:flex;gap:.5rem;align-items:center;margin-left:1rem}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-300);transition:background .3s,transform .3s}
.carousel-dot.active{background:var(--blue);transform:scale(1.3)}

/* --- CONTACT FORM --- */
.contact-hero{padding:calc(var(--header-h) + clamp(40px,6vw,80px)) 0 clamp(40px,6vw,80px);border-bottom:1px solid var(--gray-200)}
.contact-grid{grid-template-columns:5fr 7fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-info h3{margin-bottom:1rem}
.contact-info p{margin-bottom:2rem;color:var(--gray-500)}
.contact-detail{display:flex;align-items:center;gap:.8rem;font-size:.9rem;padding:.7rem 0;border-bottom:1px solid var(--gray-200);color:var(--gray-700)}
.contact-detail svg{width:18px;height:18px;color:var(--blue);flex-shrink:0}
.form-card{background:var(--gray-100);padding:clamp(2rem,4vw,3rem);border-radius:var(--radius)}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--black);margin-bottom:.5rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.85rem 1rem;background:var(--white);border:1.5px solid var(--gray-200);border-radius:8px;font-family:var(--font);font-size:.92rem;color:var(--black);outline:none;transition:border-color .3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue)}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.form-group textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;justify-content:center}
.form-success{display:none;text-align:center;padding:3rem 1rem}
.form-success.show{display:block}
.form-success h3{color:var(--blue);margin-bottom:.5rem}

/* --- FOOTER --- */
.site-footer{border-top:1px solid var(--gray-200);padding:clamp(40px,6vw,80px) 0 0}
.footer-grid{grid-template-columns:3fr 2fr 2fr 2fr;gap:2rem}
.footer-brand p{font-size:.85rem;color:var(--gray-500);margin-top:.8rem;max-width:280px}
.footer-col h4{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--black);margin-bottom:1rem}
.footer-col a{display:block;font-size:.85rem;padding:.25rem 0;color:var(--gray-500);transition:color .3s}
.footer-col a:hover{color:var(--blue)}
.footer-social{display:flex;gap:.8rem;margin-top:1.2rem}
.footer-social a{width:38px;height:38px;border:1.5px solid var(--gray-200);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:border-color .3s,background .3s}
.footer-social a:hover{border-color:var(--blue);background:var(--blue)}
.footer-social a:hover svg{color:var(--white)}
.footer-social a svg{width:16px;height:16px;color:var(--gray-700);transition:color .3s}
.footer-disclaimer{margin-top:clamp(2rem,4vw,3rem);padding:1.5rem 0;border-top:1px solid var(--gray-200);font-size:.78rem;line-height:1.9;color:var(--gray-500)}
.footer-bottom{text-align:center;padding:1.2rem 0;border-top:1px solid var(--gray-200);font-size:.72rem;color:var(--gray-500)}

/* --- RESPONSIVE --- */
@media(max-width:1024px){
  .hero-text{grid-column:1/13}
  .hero-image-col{display:none}
  .about-img-col{grid-column:1/13}
  .about-txt-col{grid-column:1/13}
  .service-img,.service-img.right{grid-column:1/13}
  .service-txt,.service-txt.left{grid-column:1/13}
  .story-img{grid-column:1/13}
  .story-txt{grid-column:1/13}
  .contact-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .services-strip-grid{grid-template-columns:1fr}
  .strip-card{border-right:none;border-bottom:1px solid var(--gray-200);padding-bottom:2rem;margin-bottom:2rem}
  .strip-card:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
  .values-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{position:fixed;top:0;right:-100%;width:80%;height:100vh;background:var(--white);flex-direction:column;justify-content:center;gap:2rem;padding:2rem;transition:right .4s;box-shadow:-10px 0 30px rgba(0,0,0,.05);z-index:150}
  .nav-links.open{right:0}
  .hamburger{display:flex}
  .hero{min-height:70vh;padding:calc(var(--header-h) + 40px) 0 40px}
  .hero-overlay{background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.5) 60%,rgba(0,0,0,.3) 100%)}
  .hero-meta{flex-direction:column;gap:1.5rem}
  .footer-grid{grid-template-columns:1fr}
  .testimonial-slide{flex:0 0 85%}
}

/* ═══════════════════════════════════════════
   NEW HOMEPAGE SECTIONS
   ═══════════════════════════════════════════ */

/* --- PROCESS / HOW IT WORKS --- */
.process{background:var(--gray-100);border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-top:3rem}
.process-step{position:relative;padding:2rem 1.5rem;background:var(--white);border-radius:var(--radius);border:1px solid var(--gray-200);transition:border-color .3s,box-shadow .3s}
.process-step:hover{border-color:var(--blue);box-shadow:0 8px 30px rgba(0,35,102,.06)}
.process-step-num{font-weight:700;font-size:3.5rem;color:var(--gray-200);line-height:1;letter-spacing:-.04em;margin-bottom:1rem}
.process-step h4{margin-bottom:.5rem}
.process-step p{font-size:.85rem;color:var(--gray-500);line-height:1.7}
.process-connector{display:none}

/* --- FEATURED FULL IMAGE --- */
.featured-img{padding:0}
.featured-img .img-expand{aspect-ratio:21/9;width:calc(100% - 6%);margin:0 auto;border-radius:var(--radius)}
.featured-img .img-expand img{width:100%;height:100%;object-fit:cover;object-position:center top}

/* --- HOME TESTIMONIALS PREVIEW --- */
.testimonials-home{background:var(--white)}
.testimonials-home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:3rem}
.testi-card{background:var(--gray-100);border-radius:var(--radius);padding:2rem;position:relative;transition:transform .3s}
.testi-card:hover{transform:translateY(-4px)}
.testi-card .quote-mark{font-size:3rem;font-weight:700;color:var(--blue);opacity:.2;line-height:1;margin-bottom:.5rem}
.testi-card p{font-size:.9rem;line-height:1.7;color:var(--gray-700);margin-bottom:1.5rem}
.testi-card .testi-author{display:flex;align-items:center;gap:.8rem}
.testi-card .testi-avatar{width:42px;height:42px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:var(--blue)}
.testi-card .testi-name{font-weight:600;font-size:.82rem;color:var(--black)}
.testi-card .testi-role{font-size:.72rem;color:var(--gray-500)}
.testi-stars{color:#e8b931;font-size:.85rem;margin-bottom:.8rem}

/* --- FAQ ACCORDION --- */
.faq-list{max-width:800px;margin:3rem auto 0}
.faq-item{border-bottom:1px solid var(--gray-200)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.4rem 0;background:none;border:none;font-family:var(--font);font-size:1.05rem;font-weight:600;color:var(--black);text-align:left;cursor:pointer;transition:color .3s}
.faq-question:hover{color:var(--blue)}
.faq-question .faq-icon{width:24px;height:24px;position:relative;flex-shrink:0}
.faq-question .faq-icon::before,.faq-question .faq-icon::after{content:'';position:absolute;background:var(--black);transition:transform .3s}
.faq-question .faq-icon::before{width:14px;height:1.5px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-question .faq-icon::after{width:1.5px;height:14px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-item.open .faq-question .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer p{padding-bottom:1.4rem;font-size:.92rem;color:var(--gray-500);line-height:1.8}

/* --- RESPONSIVE NEW SECTIONS --- */
@media(max-width:1024px){
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-home-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .process-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════
   PRELOADER
   ═══════════════════════════════════════════ */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--white);display:flex;align-items:center;justify-content:center;transition:opacity .6s,visibility .6s}
.preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-content{text-align:center}
.preloader-lock{margin:0 auto 1.5rem;display:block;overflow:visible}
.lock-shackle{animation:lockClose 1.2s cubic-bezier(.4,0,.2,1) forwards;transform-origin:32px 36px}
@keyframes lockClose{
  0%{transform:translateY(-12px)}
  60%{transform:translateY(-12px)}
  100%{transform:translateY(0)}
}
.lock-body{animation:lockPulse 1.2s cubic-bezier(.4,0,.2,1) forwards}
@keyframes lockPulse{
  0%,60%{opacity:.5}
  100%{opacity:1}
}
.preloader-logo{font-family:var(--font);font-weight:700;font-size:1.6rem;color:var(--black);letter-spacing:-.02em;margin-bottom:.8rem}
.preloader-logo span{color:var(--blue)}
.preloader-text{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--gray-500)}

/* ═══════════════════════════════════════════
   CUSTOM CURSOR
   ═══════════════════════════════════════════ */
.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;background:var(--blue);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .1s}
.cursor-ring{position:fixed;top:0;left:0;width:36px;height:36px;border:1.5px solid var(--blue);border-radius:50%;pointer-events:none;z-index:9997;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s,background .3s}
.cursor-ring.hover{width:56px;height:56px;background:rgba(0,35,102,.06);border-color:var(--blue)}
.cursor-ring.click{transform:translate(-50%,-50%) scale(.8)}
@media(max-width:768px){.cursor-dot,.cursor-ring{display:none}body{cursor:auto}}

/* ═══════════════════════════════════════════
   GLOBE SECTION
   ═══════════════════════════════════════════ */
.globe-section{overflow:hidden}
.globe-wrapper{position:relative;width:100%;max-width:700px;margin:0 auto;aspect-ratio:1/1}
#globeCanvas{width:100%;height:100%;cursor:grab;border-radius:var(--radius)}
#globeCanvas:active{cursor:grabbing}
.globe-review-card{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius);padding:1.8rem;max-width:360px;width:90%;box-shadow:0 16px 48px rgba(0,0,0,.1);z-index:10;opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s}
.globe-review-card.show{transform:translate(-50%,-50%) scale(1);opacity:1}
.globe-review-close{position:absolute;top:.8rem;right:.8rem;width:28px;height:28px;border:none;background:var(--gray-100);border-radius:50%;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-500);transition:background .2s}
.globe-review-close:hover{background:var(--gray-200)}

/* ═══════════════════════════════════════════
   HERO V2 — dark hero with family photo
   ═══════════════════════════════════════════ */
.hero-v2{min-height:100vh;background:#080e1f;display:flex;align-items:center;padding-top:var(--header-h);position:relative;overflow:hidden}
.hv2-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.hv2-glow{position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none}
.hv2-glow-1{width:clamp(300px,45vw,600px);height:clamp(300px,45vw,600px);background:rgba(74,158,255,.11);right:-8%;top:-10%}
.hv2-glow-2{width:clamp(200px,30vw,420px);height:clamp(200px,30vw,420px);background:rgba(34,211,165,.08);left:-4%;bottom:5%}
.hv2-glow-3{width:clamp(150px,20vw,280px);height:clamp(150px,20vw,280px);background:rgba(251,191,36,.06);right:30%;bottom:-5%}
.hv2-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px}
.hv2-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,5rem);align-items:center;padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(40px,6vw,80px);position:relative;z-index:1}
.hv2-left{display:flex;flex-direction:column;padding-left:clamp(0px,3.5vw,64px)}
.hv2-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:100px;padding:.4rem 1.1rem;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.65);margin-bottom:2rem;width:fit-content}
.hv2-badge-dot{width:7px;height:7px;background:#22d3a5;border-radius:50%;flex-shrink:0;animation:hv2BadgePulse 2.2s ease-in-out infinite}
@keyframes hv2BadgePulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hv2-title{font-size:clamp(2.8rem,5.5vw,4.8rem);font-weight:800;color:var(--white);line-height:1.05;letter-spacing:-.04em;margin-bottom:1.5rem}
.hw{display:inline-block;opacity:0;transform:translateY(28px);filter:blur(8px);animation:hv2WordIn .85s cubic-bezier(.22,.61,.36,1) forwards;animation-delay:var(--d,0s)}
.hw-gold{color:#fbbf24}
@keyframes hv2WordIn{to{opacity:1;transform:translateY(0);filter:blur(0)}}
.hv2-sub{font-size:clamp(.92rem,1.15vw,1.05rem);color:rgba(255,255,255,.58);line-height:1.8;max-width:500px;margin-bottom:2.5rem}
.hv2-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hv2-btn-primary{background:var(--blue);color:var(--white);border:none}
.hv2-btn-primary::before{background:rgba(255,255,255,.15)}
.hv2-btn-ghost{background:transparent;color:rgba(255,255,255,.82);border:1.5px solid rgba(255,255,255,.22);border-radius:var(--radius)}
.hv2-btn-ghost::before{background:rgba(255,255,255,.07)}
.hv2-btn-ghost:hover{color:var(--white)}
.hv2-stats{display:flex;gap:clamp(1rem,2.5vw,2.2rem);padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);align-items:center}
.hv2s-item{display:flex;flex-direction:column;gap:.25rem}
.hv2s-num{font-size:clamp(1.3rem,2.2vw,1.8rem);font-weight:700;color:var(--white);letter-spacing:-.03em;line-height:1}
.hv2s-lbl{font-size:.63rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.38);white-space:nowrap}
.hv2s-sep{width:1px;height:2.5rem;background:rgba(255,255,255,.1);flex-shrink:0}
/* ─── RIGHT ─── */
.hv2-right{position:relative;height:clamp(420px,55vw,600px);overflow:hidden}
.hv2-photo-wrap{position:absolute;inset:0;border-radius:var(--radius);overflow:hidden}
.hv2-photo{width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:brightness(.55) saturate(.85)}
.hv2-photo-fade{position:absolute;inset:0;background:linear-gradient(to right,#080e1f 0%,rgba(8,14,31,.35) 35%,transparent 65%),linear-gradient(to top,#080e1f 0%,transparent 45%)}
/* ─── METRIC CARDS ─── */
.hv2-cards{position:absolute;right:clamp(12px,2vw,24px);bottom:clamp(2.5rem,4vw,3.5rem);width:clamp(200px,28%,260px);height:clamp(220px,32%,280px)}
.hv2c{position:absolute;inset:0;background:rgba(8,14,31,.72);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:clamp(.9rem,1.8vw,1.4rem);display:flex;flex-direction:column;gap:.65rem;opacity:0;transform:translateX(40px) scale(.97);transition:opacity .55s cubic-bezier(.25,.46,.45,.94),transform .55s cubic-bezier(.25,.46,.45,.94);pointer-events:none}
.hv2c.hv2c-active{opacity:1;transform:translateX(0) scale(1);pointer-events:auto}
.hv2c.hv2c-exit{opacity:0;transform:translateX(-40px) scale(.97)}
.hv2c-head{display:flex;align-items:center;gap:.45rem}
.hv2c-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.hv2c-title{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.5)}
.hv2c-val{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:800;color:var(--white);letter-spacing:-.05em;line-height:1}
.hv2c-bars{display:flex;align-items:flex-end;gap:5px;height:clamp(40px,6vw,60px);margin-top:auto}
.hv2c-bar-wrap{flex:1;background:rgba(255,255,255,.05);border-radius:4px;overflow:hidden;position:relative}
.hv2c-bar{position:absolute;bottom:0;left:0;right:0;background:var(--clr,#22d3a5);border-radius:4px;transform:scaleY(0);transform-origin:bottom}
.hv2c.hv2c-active .hv2c-bar{animation:hv2BarUp .65s var(--d,0s) cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes hv2BarUp{to{transform:scaleY(1)}}
.hv2c-chart-wrap{flex:1;position:relative;min-height:45px;border-radius:6px;overflow:hidden;margin-top:auto}
.hv2c-line-bg,.hv2c-line-svg{position:absolute;inset:0;width:100%;height:100%}
.hv2c-chart-clip{position:absolute;inset:0;clip-path:inset(0 100% 0 0)}
.hv2c.hv2c-active .hv2c-chart-clip{animation:hv2LineIn .95s .12s cubic-bezier(.25,.46,.45,.94) forwards}
@keyframes hv2LineIn{to{clip-path:inset(0 0% 0 0)}}
.hv2c-radial-wrap{position:relative;width:clamp(65px,9vw,95px);height:clamp(65px,9vw,95px);margin:auto;margin-top:.3rem}
.hv2c-radial{width:100%;height:100%}
.hv2c-radial-arc{transition:none}
.hv2c.hv2c-active .hv2c-radial-arc{animation:hv2RadialIn 1.3s .25s cubic-bezier(.25,.46,.45,.94) forwards}
@keyframes hv2RadialIn{to{stroke-dashoffset:5.8}}
.hv2c-radial-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:clamp(1rem,1.8vw,1.4rem);font-weight:800;color:var(--white)}
.hv2c-badge{font-size:.62rem;color:rgba(255,255,255,.5);background:rgba(255,255,255,.06);border-radius:5px;padding:.25rem .55rem;width:fit-content;font-weight:600;letter-spacing:.04em}
.hv2-dots{position:absolute;bottom:.6rem;right:clamp(8px,2vw,20px);width:clamp(180px,26%,240px);display:flex;justify-content:center;gap:.45rem;z-index:2}
.hv2-dot{width:6px;height:6px;border-radius:50%;border:none;background:rgba(255,255,255,.25);cursor:pointer;transition:background .3s,transform .3s;padding:0}
.hv2-dot.active{background:var(--white);transform:scale(1.35)}
@media(max-width:1024px){
  .hv2-layout{grid-template-columns:1fr}
  .hv2-right{height:340px}
  .hv2-left{padding-left:0}
  .hv2-cards{width:210px;height:240px;right:12px}
  .hv2-dots{width:210px;right:12px}
}
@media(max-width:768px){
  .hv2-right{height:280px}
  .hv2-cards{width:180px;height:210px;right:8px;bottom:2rem}
  .hv2-dots{width:180px;right:8px}
}

/* ═══════════════════════════════════════════
   AGENDA / TYPEFORM PAGE
   ═══════════════════════════════════════════ */
/* ═══ AGENDA PAGE — FULL-SCREEN SPLIT LAYOUT ═══ */
.agenda-page{background:var(--white)}
.agenda-progress-bar{width:100%;height:3px;background:var(--gray-200);position:fixed;top:var(--header-h);left:0;z-index:99}
.agenda-progress-fill{height:100%;background:var(--blue);transition:width .5s cubic-bezier(.25,.46,.45,.94)}

/* Main wrapper */
.agenda-main{padding-top:var(--header-h)}

/* Each step = exact viewport height, 2 columns */
.agenda-step{
  display:none;
  height:calc(100vh - var(--header-h) - 3px);
  grid-template-columns:1fr 1fr;
  animation:stepIn .5s cubic-bezier(.25,.46,.45,.94) forwards;
  overflow:hidden;
}
.agenda-step.active{display:grid}
@keyframes stepIn{
  from{opacity:0;transform:translateX(36px)}
  to{opacity:1;transform:translateX(0)}
}

/* Left: form column — scrolls internally if content overflows */
.agenda-form-col{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(2rem,5vw,4.5rem) clamp(2rem,5vw,6rem);
  max-width:640px;
  height:100%;
  overflow-y:auto;
}
.agenda-form-col--wide{max-width:none}
.agenda-form-col--scroll{justify-content:flex-start;padding-top:clamp(1.5rem,3vw,3rem)}

.agenda-step-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--blue);margin-bottom:1.2rem}
.agenda-question{font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700;color:var(--black);line-height:1.1;letter-spacing:-.03em;margin-bottom:2.5rem}
.agenda-input{width:100%;font-size:clamp(1.2rem,2vw,1.8rem);font-weight:400;color:var(--black);background:transparent;border:none;border-bottom:2px solid var(--gray-300);padding:.6rem 0;outline:none;transition:border-color .3s;font-family:var(--font)}
.agenda-input:focus{border-bottom-color:var(--blue)}
.agenda-input::placeholder{color:var(--gray-300)}
.agenda-textarea{width:100%;font-size:1rem;font-weight:400;color:var(--black);background:var(--gray-100);border:2px solid var(--gray-200);border-radius:var(--radius);padding:1rem 1.2rem;outline:none;resize:vertical;min-height:150px;transition:border-color .3s;font-family:var(--font)}
.agenda-textarea:focus{border-color:var(--blue)}

/* Actions group */
.agenda-actions{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;margin-top:2.5rem}
.agenda-enter-hint{font-size:.75rem;color:var(--gray-500);margin:0}
.agenda-next-btn{display:inline-flex;align-items:center;gap:.6rem;padding:.9rem 2.4rem;background:var(--blue);color:var(--white);border:none;border-radius:var(--radius);font-family:var(--font);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;cursor:pointer;transition:background .3s,transform .25s}
.agenda-next-btn:hover{background:var(--black);transform:translateY(-1px)}
.agenda-next-btn:disabled{opacity:.4;pointer-events:none}
.agenda-back-link{background:none;border:none;font-family:var(--font);font-size:.78rem;color:var(--gray-500);cursor:pointer;padding:0;display:flex;align-items:center;gap:.3rem;transition:color .3s}
.agenda-back-link:hover{color:var(--black)}

/* Service cards (step 4) */
.agenda-service-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:.5rem}
.agenda-service-card{position:relative;border:2px solid var(--gray-200);border-radius:var(--radius);padding:1.6rem 1rem 1.2rem;cursor:pointer;transition:border-color .3s,background .3s,transform .25s;text-align:center}
.agenda-service-card:hover{border-color:var(--blue);transform:translateY(-3px)}
.agenda-service-card.selected{border-color:var(--blue);background:rgba(0,35,102,.05)}
.agenda-service-card-icon{font-size:2rem;margin-bottom:.6rem}
.agenda-service-card h4{font-size:.9rem;margin-bottom:.3rem}
.agenda-service-card p{font-size:.78rem;color:var(--gray-500);max-width:none}
.asc-popular{
  display:inline-block;margin-top:.6rem;
  font-size:.65rem;font-weight:700;letter-spacing:.06em;
  background:rgba(251,191,36,.15);color:#b45309;
  padding:.2rem .55rem;border-radius:5px;
}

/* Right: media column — locked to step height = viewport */
.agenda-media-col{
  position:relative;
  overflow:hidden;
  height:100%;
}
.agenda-media-img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  transition:transform 8s ease-out;
}
.agenda-step.active .agenda-media-img{transform:scale(1.04)}

/* Gradient overlay */
.agenda-media-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,10,30,.75) 0%,rgba(0,10,30,.2) 50%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(1.5rem,3vw,2.5rem);
  gap:1rem;
}

/* Media cards */
.agenda-media-card{
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  padding:1.2rem 1.4rem;
  color:var(--white);
}
/* Stat variant */
.amc-num{font-size:clamp(2.2rem,4vw,3.2rem);font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--white)}
.amc-lbl{font-size:.82rem;color:rgba(255,255,255,.75);margin-top:.25rem;line-height:1.4}
.amc-icon{color:rgba(255,255,255,.85);margin-bottom:.6rem}
.agenda-media-card--stats .amc-stat-row{display:flex;align-items:baseline;gap:.7rem}
.amc-stat-num{font-size:clamp(1.8rem,3vw,2.4rem);font-weight:800;letter-spacing:-.04em;color:var(--white)}
.amc-stat-lbl{font-size:.8rem;color:rgba(255,255,255,.7);line-height:1.35}
.amc-divider{height:1px;background:rgba(255,255,255,.15);margin:.7rem 0}
/* Quote variant */
.amc-stars{font-size:1rem;color:#fbbf24;letter-spacing:.1em;margin-bottom:.5rem}
.amc-quote{font-size:.88rem;color:rgba(255,255,255,.9);line-height:1.6;font-style:italic;margin-bottom:.5rem}
.amc-author{font-size:.75rem;color:rgba(255,255,255,.55);font-weight:600}
/* Features variant */
.agenda-media-card--features{display:flex;flex-direction:column;gap:.55rem}
.amcf-item{display:flex;align-items:center;gap:.55rem;font-size:.84rem;color:rgba(255,255,255,.85);font-weight:500}
.amcf-item svg{flex-shrink:0;color:rgba(74,222,128,.9)}

/* Badge at bottom */
.agenda-media-badge{
  display:inline-flex;align-items:center;gap:.45rem;
  background:rgba(0,35,102,.7);
  backdrop-filter:blur(8px);
  border:1px solid rgba(74,158,255,.3);
  border-radius:8px;padding:.5rem 1rem;
  font-size:.76rem;font-weight:700;
  color:rgba(255,255,255,.9);
  width:fit-content;
}

/* Calendar */
.agenda-calendar{margin-top:.5rem}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.cal-nav-btn{width:36px;height:36px;border:1.5px solid var(--gray-200);border-radius:8px;background:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .3s,background .3s}
.cal-nav-btn:hover{border-color:var(--blue);background:rgba(0,35,102,.04)}
.cal-month-title{font-weight:700;font-size:1rem;color:var(--black)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-weekday{text-align:center;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-500);padding:.4rem 0}
.cal-day{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:.88rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s;border:2px solid transparent}
.cal-day:hover:not(.cal-day-disabled):not(.cal-day-empty){background:rgba(0,35,102,.08);color:var(--blue)}
.cal-day.cal-day-selected{background:var(--blue);color:var(--white);font-weight:700}
.cal-day.cal-day-disabled{color:var(--gray-300);cursor:not-allowed}
.cal-day.cal-day-empty{cursor:default}
.cal-day.cal-day-today{border-color:var(--blue)}
.time-slots-label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gray-500);margin:1.5rem 0 .8rem}
.time-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.time-slot{padding:.7rem .5rem;border:1.5px solid var(--gray-200);border-radius:8px;text-align:center;font-size:.82rem;font-weight:600;cursor:pointer;transition:border-color .3s,background .3s,color .3s}
.time-slot:hover{border-color:var(--blue);color:var(--blue)}
.time-slot.selected{background:var(--blue);border-color:var(--blue);color:var(--white)}

/* Success screen */
.agenda-success{
  display:none;text-align:center;
  height:calc(100vh - var(--header-h) - 3px);
  align-items:center;justify-content:center;
  flex-direction:column;padding:4rem 2rem;
  animation:stepIn .6s cubic-bezier(.25,.46,.45,.94) forwards;
}
.agenda-success.show{display:flex}
.success-check{width:80px;height:80px;background:rgba(0,35,102,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 2rem;animation:successPop .6s .2s cubic-bezier(.34,1.56,.64,1) both}
@keyframes successPop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.success-check svg{width:40px;height:40px;color:var(--blue)}
.agenda-success h2{font-size:clamp(2rem,4vw,3rem);color:var(--black);margin-bottom:1rem}
.agenda-success p{color:var(--gray-500);margin:0 auto 2rem;font-size:1.05rem}

/* Responsive */
@media(max-width:900px){
  .agenda-step{grid-template-columns:1fr}
  .agenda-media-col{display:none}
  .agenda-form-col,.agenda-form-col--wide{
    max-width:600px;margin:0 auto;width:100%;
    padding:clamp(2rem,5vw,3.5rem) clamp(1.2rem,5vw,2.5rem);
    justify-content:flex-start;padding-top:clamp(2.5rem,6vw,4rem);
  }
  .agenda-service-cards{grid-template-columns:1fr}
  .time-slots{grid-template-columns:repeat(2,1fr)}
  .agenda-question{font-size:clamp(1.5rem,6vw,2.2rem)}
}
@media(max-width:480px){.cal-day{font-size:.75rem}}

/* ─── HOW IT WORKS ─── */
.hiw-section{
  padding:var(--section-py) 0;
  position:relative;
  overflow:hidden;
  background:var(--white);
}
/* Gradient blobs — shift per step */
.hiw-glow{
  position:absolute;inset:0;pointer-events:none;z-index:0;
}
.hiw-glow::before,.hiw-glow::after{
  content:'';position:absolute;border-radius:50%;
  filter:blur(90px);
  transition:background .9s cubic-bezier(.25,.46,.45,.94),
             left .9s cubic-bezier(.25,.46,.45,.94),
             top .9s cubic-bezier(.25,.46,.45,.94);
  width:55vw;height:55vw;
}
.hiw-glow::before{top:-15%;left:-8%}
.hiw-glow::after {bottom:-15%;right:-8%}
/* Step 0: blue/lavender */
.hiw-section.step-0 .hiw-glow::before{background:rgba(100,120,255,.13)}
.hiw-section.step-0 .hiw-glow::after {background:rgba(200,180,255,.10)}
/* Step 1: navy/teal */
.hiw-section.step-1 .hiw-glow::before{background:rgba(0,35,102,.10)}
.hiw-section.step-1 .hiw-glow::after {background:rgba(34,211,165,.13)}
/* Step 2: gold/navy */
.hiw-section.step-2 .hiw-glow::before{background:rgba(251,191,36,.13)}
.hiw-section.step-2 .hiw-glow::after {background:rgba(0,35,102,.10)}

.hiw-container{position:relative;z-index:1}
.hiw-header{text-align:center;margin-bottom:3.5rem}
.hiw-header .eyebrow{margin-bottom:.6rem}
.hiw-header h2{margin:0 auto}

/* Step nav */
.hiw-nav{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;margin-bottom:4rem;
}
.hiw-nav-item{
  padding:0 clamp(1rem,2.5vw,2.5rem);
  border-left:1px solid var(--gray-200);
  cursor:pointer;
  transition:opacity .3s;
}
.hiw-nav-item:first-child{border-left:none;padding-left:0}
.hiw-nav-item:last-child{padding-right:0}
.hiw-nav-item:not(.active){opacity:.55}
.hiw-nav-item:not(.active):hover{opacity:.8}

.hiw-num-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;
  border:1.5px solid var(--gray-300);
  border-radius:10px;
  font-size:.72rem;font-weight:700;letter-spacing:.08em;
  color:var(--gray-500);
  margin-bottom:.9rem;
  transition:border-color .3s,color .3s,background .3s;
}
.hiw-nav-item.active .hiw-num-badge{
  border-color:var(--blue);color:var(--blue);
  background:rgba(0,35,102,.05);
}

/* Progress bar */
.hiw-bar-track{
  height:2px;background:var(--gray-200);
  border-radius:1px;margin-bottom:1.1rem;overflow:hidden;
}
.hiw-bar{height:100%;width:0%;background:var(--blue);border-radius:1px;transition:none}
.hiw-nav-item.is-filled .hiw-bar{width:100%;transition:none}
.hiw-nav-item.is-animating .hiw-bar{width:100%;transition:width 5s linear}

.hiw-step-title{
  font-size:.75rem;text-transform:uppercase;
  letter-spacing:.18em;color:var(--gray-500);
  margin-bottom:.5rem;font-weight:700;
  transition:color .3s;
}
.hiw-nav-item.active .hiw-step-title{color:var(--black)}
.hiw-step-desc{font-size:.88rem;color:var(--gray-500);line-height:1.65;max-width:100%}

/* Center visual */
.hiw-visual-wrap{
  position:relative;
  display:flex;justify-content:center;align-items:center;
}
/* Concentric rings (like reference site) */
.hiw-rings{
  position:absolute;top:50%;left:50%;
  pointer-events:none;z-index:0;
}
.hiw-rings span{
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(0,35,102,.07);
  transform:translate(-50%,-50%) scaleY(.28);
}
.hiw-rings span:nth-child(1){width:600px;height:600px}
.hiw-rings span:nth-child(2){width:860px;height:860px}
.hiw-rings span:nth-child(3){width:1120px;height:1120px}

.hiw-visual{
  position:relative;
  width:min(460px,88vw);
  height:clamp(380px,55vw,480px);
  z-index:1;
}
.hiw-card{
  position:absolute;inset:0;
  background:var(--white);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 28px 80px rgba(0,35,102,.12),0 4px 16px rgba(0,0,0,.06);
  opacity:0;
  transform:translateY(18px) scale(.97);
  transition:opacity .55s cubic-bezier(.25,.46,.45,.94),
             transform .55s cubic-bezier(.25,.46,.45,.94);
  pointer-events:none;
}
.hiw-card.active{
  opacity:1;transform:translateY(0) scale(1);pointer-events:auto;
}
.hiw-card-chip{
  position:absolute;top:.9rem;left:.9rem;z-index:2;
  background:rgba(255,255,255,.88);backdrop-filter:blur(8px);
  border-radius:6px;padding:.28rem .65rem;
  font-size:.68rem;font-weight:700;letter-spacing:.1em;color:var(--blue);
  border:1px solid rgba(0,35,102,.1);
}
.hiw-card img{
  width:100%;height:calc(100% - 68px);object-fit:cover;display:block;
}
.hiw-card-footer{
  height:68px;padding:0 1.2rem;
  display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--gray-200);
}
.hiw-card-label{
  display:flex;align-items:center;gap:.45rem;
  font-size:.84rem;font-weight:600;color:var(--gray-700);
}
.hiw-card-badge{
  font-size:.68rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;padding:.28rem .7rem;
  border-radius:6px;background:var(--gray-100);color:var(--gray-500);
}
.hiw-badge-green{background:rgba(34,197,94,.1);color:#16a34a}

@media(max-width:900px){
  .hiw-step-desc{display:none}
  .hiw-nav-item{padding:0 1rem}
  .hiw-nav-item:first-child{padding-left:0}
  .hiw-nav-item:last-child{padding-right:0}
}
@media(max-width:600px){
  .hiw-nav{grid-template-columns:repeat(3,1fr);gap:0}
  .hiw-step-title{font-size:.65rem;letter-spacing:.1em}
  .hiw-num-badge{width:36px;height:36px;font-size:.65rem;border-radius:8px}
  .hiw-rings{display:none}
}

/* ─── VIDEO TESTIMONIAL ─── */
.tv-section{
  padding:var(--section-py) 0;
  position:relative;
  overflow:hidden;
  background:#06091a;
  color:var(--white);
}
/* BG elements */
.tv-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.tv-blob{
  position:absolute;border-radius:50%;
  filter:blur(100px);
  will-change:transform;
  transition:transform .05s linear;
}
.tv-blob-1{
  width:55vw;height:55vw;
  top:-20%;left:-10%;
  background:radial-gradient(circle,rgba(0,35,102,.75),transparent 70%);
}
.tv-blob-2{
  width:45vw;height:45vw;
  bottom:-15%;right:-5%;
  background:radial-gradient(circle,rgba(74,158,255,.35),transparent 70%);
}
.tv-grid-lines{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
}
/* Decorative quote */
.tv-quote-deco{
  position:absolute;
  top:clamp(30px,6vw,80px);
  left:clamp(20px,5vw,80px);
  font-size:clamp(160px,20vw,280px);
  line-height:1;
  font-family:Georgia,serif;
  color:rgba(255,255,255,.04);
  pointer-events:none;
  z-index:0;
  will-change:transform;
  user-select:none;
}
/* Container */
.tv-container{position:relative;z-index:1}
/* Header */
.tv-eyebrow-wrap{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-bottom:.8rem}
.tv-dot{width:6px;height:6px;border-radius:50%;background:rgba(74,158,255,.8);display:block}
.tv-eyebrow{color:rgba(74,158,255,.9)!important;margin-bottom:0!important}
.tv-header{text-align:center;margin-bottom:clamp(2.5rem,5vw,4rem)}
.tv-title{color:var(--white);font-size:clamp(2rem,4.5vw,3.8rem);line-height:1.08;margin-bottom:1rem}
.tv-title em{font-style:italic;color:rgba(74,158,255,.9)}
.tv-subtitle{color:rgba(255,255,255,.5);font-size:clamp(.9rem,1vw,1.05rem);margin:0 auto;max-width:520px}
/* Stage: 3-column layout */
.tv-stage{
  display:grid;
  grid-template-columns:1fr minmax(0,420px) 1fr;
  gap:clamp(1.5rem,3vw,3.5rem);
  align-items:center;
}
/* Side columns */
.tv-side{display:flex;flex-direction:column;gap:1.4rem}
.tv-stars-big{font-size:1.4rem;color:#fbbf24;letter-spacing:.15em}
.tv-side-text{
  font-size:clamp(1.1rem,1.8vw,1.5rem);
  font-weight:600;line-height:1.4;
  color:var(--white);font-style:italic;
  border-left:2px solid rgba(74,158,255,.5);
  padding-left:1rem;
}
.tv-tag{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.45rem .9rem;border-radius:8px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  font-size:.78rem;font-weight:600;
  color:rgba(255,255,255,.75);
  width:fit-content;
  backdrop-filter:blur(6px);
}
.tv-side-right .tv-stat{padding-bottom:1.2rem;border-bottom:1px solid rgba(255,255,255,.08)}
.tv-side-right .tv-stat:last-of-type{border-bottom:none}
.tv-stat-num{font-size:clamp(2rem,3.5vw,3rem);font-weight:800;color:var(--white);letter-spacing:-.04em;line-height:1}
.tv-stat-lbl{font-size:.8rem;color:rgba(255,255,255,.45);margin-top:.2rem;line-height:1.4}
.tv-cta{background:var(--blue);color:var(--white)!important;margin-top:.5rem;width:fit-content}
.tv-cta::before{background:rgba(74,158,255,.9)}
/* Video card */
.tv-card-wrap{position:relative}
.tv-card-glow{
  position:absolute;
  inset:-30px;border-radius:36px;
  background:radial-gradient(ellipse at center,rgba(74,158,255,.18),transparent 70%);
  pointer-events:none;z-index:-1;
  filter:blur(20px);
}
.tv-card{
  background:#0e1628;
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 40px 100px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.04);
  will-change:transform;
  transition:transform .12s ease-out,box-shadow .12s ease-out;
  transform-style:preserve-3d;
}
.tv-video-box{position:relative;overflow:hidden;background:#000;cursor:pointer}
.tv-video-box video{width:100%;display:block;aspect-ratio:9/16;object-fit:cover}
/* Overlay */
.tv-overlay{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.35);
  transition:background .3s,opacity .3s;
}
.tv-overlay.hidden{opacity:0;pointer-events:none}
.tv-play-btn{
  width:72px;height:72px;border-radius:50%;
  background:rgba(255,255,255,.92);
  border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  transition:transform .2s,background .2s;
}
.tv-play-btn:hover{transform:scale(1.1);background:var(--white)}
/* Progress bar */
.tv-progress-track{
  position:absolute;bottom:0;left:0;right:0;
  height:3px;background:rgba(255,255,255,.15);cursor:pointer;
}
.tv-progress-fill{
  height:100%;width:0%;
  background:linear-gradient(to right,rgba(74,158,255,.9),var(--white));
  transition:width .2s linear;
  pointer-events:none;
}
/* Card footer */
.tv-card-footer{
  padding:1rem 1.2rem;
  display:flex;align-items:center;gap:.9rem;
  border-top:1px solid rgba(255,255,255,.07);
}
.tv-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),rgba(74,158,255,.7));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1rem;color:var(--white);flex-shrink:0;
}
.tv-info{flex:1}
.tv-name{font-weight:700;font-size:.92rem;color:var(--white)}
.tv-role{font-size:.75rem;color:rgba(255,255,255,.4);margin-top:.1rem}
.tv-verified{
  display:flex;align-items:center;gap:.3rem;
  font-size:.72rem;font-weight:700;letter-spacing:.06em;
  color:rgba(74,158,255,.9);
  background:rgba(74,158,255,.1);
  border:1px solid rgba(74,158,255,.2);
  padding:.3rem .65rem;border-radius:6px;
}
/* Responsive */
@media(max-width:900px){
  .tv-stage{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .tv-side-left{order:2;flex-direction:row;flex-wrap:wrap;gap:.8rem;justify-content:center;text-align:center}
  .tv-side-left .tv-side-text{display:none}
  .tv-side-right{order:3;flex-direction:row;flex-wrap:wrap;gap:1.5rem;justify-content:center}
  .tv-side-right .tv-stat{border-bottom:none;padding-bottom:0;text-align:center}
  .tv-cta{margin:0 auto}
  .tv-card-wrap{order:1}
}

/* ─── TRUST ARC ─── */
.trust-arc{
  background:var(--white);
  overflow:hidden;
  position:relative;
}
.trust-arc-stage{
  position:relative;
  /* desktop cy=980 → visible arc fits in 700px; mobile cy=420 → 420px */
  height:clamp(420px,65vw,700px);
  width:100%;
  overflow:hidden;
}
/* Fade masks on left/right edges */
.trust-arc-stage::before,
.trust-arc-stage::after{
  content:'';
  position:absolute;
  top:0;bottom:0;width:clamp(60px,8vw,120px);
  z-index:5;pointer-events:none;
}
.trust-arc-stage::before{
  left:0;
  background:linear-gradient(to right,var(--white),transparent);
}
.trust-arc-stage::after{
  right:0;
  background:linear-gradient(to left,var(--white),transparent);
}
.trust-arc-track{
  position:absolute;
  inset:0;
  pointer-events:none;
}
.trust-arc-item{
  position:absolute;
  width:clamp(110px,9vw,148px);
  height:clamp(145px,12vw,196px);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 12px 40px rgba(0,35,102,.13),0 2px 8px rgba(0,0,0,.07);
  will-change:transform;
  backface-visibility:hidden;
  border:3px solid rgba(255,255,255,.95);
}
.trust-arc-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.trust-arc-center{
  position:absolute;
  bottom:clamp(36px,5vw,64px);
  left:50%;
  transform:translateX(-50%);
  text-align:center;
  z-index:10;
  width:min(600px,85vw);
}
.trust-arc-center .eyebrow{margin-bottom:.5rem}
.trust-arc-title{
  font-size:clamp(2rem,4.2vw,3.6rem);
  line-height:1.08;
  letter-spacing:-.03em;
  color:var(--black);
  margin-bottom:1rem;
}
.trust-arc-sub{
  font-size:clamp(.88rem,.95vw,1rem);
  color:var(--gray-500);
  line-height:1.7;
  max-width:100%;
}
.trust-arc-icon{
  display:flex;
  justify-content:center;
  margin-bottom:1rem;
}
@media(max-width:768px){
  .trust-arc-item{border-radius:12px}
}

/* ═══════════════════════════════════════════
   WHATSAPP CTA BUTTON
   ═══════════════════════════════════════════ */
.whatsapp-btn{background:#25D366;color:#fff!important;border:none;display:inline-flex;align-items:center;gap:.55rem}
.whatsapp-btn::before{background:#1ebe5d}
.whatsapp-btn:hover{color:#fff}
.whatsapp-btn svg{flex-shrink:0}

/* ═══════════════════════════════════════════
   NOSOTROS — LOGO PLACEMENT
   ═══════════════════════════════════════════ */
.nos-logo-wrap{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--gray-200)}
.nos-logo{max-width:220px;height:auto;display:block}

/* ═══════════════════════════════════════════
   SERVICIOS — VIDEO EXPLAINER GRID
   ═══════════════════════════════════════════ */
.svc-video-section{background:var(--gray-100);border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200)}
.svc-video-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:3rem}
.svc-vid-card{position:relative;aspect-ratio:9/16;border-radius:var(--radius);overflow:hidden;background:#000;box-shadow:0 16px 48px rgba(0,35,102,.12)}
.svc-vid-card video{width:100%;height:100%;object-fit:cover;display:block}
.svc-vid-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);transition:background .3s,opacity .3s}
.svc-vid-overlay.hidden{opacity:0;pointer-events:none}
.svc-vid-play{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--blue);box-shadow:0 8px 32px rgba(0,0,0,.3);transition:transform .2s,background .2s}
.svc-vid-play:hover{transform:scale(1.1);background:var(--white)}
.svc-vid-caption{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.2rem;background:linear-gradient(to top,rgba(0,0,0,.75),transparent);color:var(--white)}
.svc-vid-caption h4{font-size:.88rem;font-weight:700;color:var(--white);margin-bottom:.2rem}
.svc-vid-caption p{font-size:.72rem;color:rgba(255,255,255,.7);max-width:none}
@media(max-width:768px){.svc-video-grid{grid-template-columns:1fr;max-width:380px;margin:2rem auto 0}}

/* ═══════════════════════════════════════════
   TESTIMONIOS — VIDEO CARDS
   ═══════════════════════════════════════════ */
.vid-card{position:relative;aspect-ratio:9/16;border-radius:16px;overflow:hidden;background:linear-gradient(160deg,#0d1a3a 0%,#06091a 60%,#0a1520 100%);box-shadow:0 16px 48px rgba(0,35,102,.12);cursor:none;transition:transform .3s,box-shadow .3s}
.vid-card:hover{transform:translateY(-6px);box-shadow:0 28px 64px rgba(0,35,102,.2)}
.vid-card video{width:100%;height:100%;object-fit:cover;display:block}
.vid-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);transition:background .3s,opacity .3s}
.vid-overlay.hidden{opacity:0;pointer-events:none}
.vid-play-btn{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--blue);box-shadow:0 8px 32px rgba(0,0,0,.4);transition:transform .2s,background .2s}
.vid-play-btn:hover{transform:scale(1.1);background:var(--white)}
.vid-footer{position:absolute;bottom:0;left:0;right:0;padding:.8rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent)}
.vid-footer-name{font-size:.8rem;font-weight:700;color:var(--white)}
.vid-footer-tag{font-size:.68rem;color:rgba(255,255,255,.6)}
/* Mouse-trail dots — injected by JS */
.vid-trail-dot{position:absolute;width:7px;height:7px;border-radius:50%;background:var(--blue);pointer-events:none;transform:translate(-50%,-50%);opacity:0;z-index:20;will-change:left,top}

/* ═══════════════════════════════════════════
   HOME TESTIMONIAL CAROUSEL
═══════════════════════════════════════════ */
.home-testi{padding:5rem 0;background:#f4f7ff;overflow:hidden}
.ht-header{text-align:center;margin-bottom:3rem}
.ht-sub{color:#6b7280;max-width:520px;margin:.75rem auto 0;font-size:1.05rem}
.ht-stage{display:flex;align-items:center;gap:1rem;max-width:1340px;margin:0 auto;padding:0 1.5rem}
.ht-viewport{flex:1;overflow:hidden;padding:2rem 0}
.ht-track{display:flex;gap:1.5rem;transition:transform .55s cubic-bezier(.25,.46,.45,.94);will-change:transform}
/* Override vid-card hover & scale for carousel context */
.vid-card.ht-card{cursor:pointer !important;flex-shrink:0;transition:transform .45s ease,opacity .45s ease,box-shadow .45s ease !important;transform:scale(.88) !important;opacity:.5 !important;box-shadow:none !important}
.vid-card.ht-card.ht-active{transform:scale(1) !important;opacity:1 !important;box-shadow:0 24px 64px rgba(0,35,102,.22) !important}
.vid-card.ht-card:hover{transform:scale(.88) !important} /* cancel base hover */
.vid-card.ht-card.ht-active:hover{transform:scale(1.02) !important}
.ht-arrow{flex-shrink:0;width:48px;height:48px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#111;transition:background .2s,border-color .2s,color .2s}
.ht-arrow svg{stroke:currentColor;transition:stroke .2s}
.ht-arrow:hover{background:#002366;border-color:#002366;color:#fff}
.ht-arrow:disabled{opacity:.3;pointer-events:none}
.ht-dots{display:flex;gap:4px;justify-content:center;margin-top:1.5rem}
.ht-dot{width:8px;height:8px;border-radius:4px;background:#d1d5db;border:none;cursor:pointer;padding:18px 8px;box-sizing:content-box;transition:background .3s,width .3s,border-radius .3s}
.ht-dot.active{background:#002366;width:24px}
@media(max-width:900px){
  .ht-stage{gap:.4rem;padding:0 .4rem}
  .ht-arrow{width:36px;height:36px}
}

/* ═══════════════════════════════════════════
   ONBOARDING FORM PAGE
   ═══════════════════════════════════════════ */
.onboarding-hero{padding:calc(var(--header-h) + clamp(40px,6vw,80px)) 0 clamp(40px,6vw,80px);border-bottom:1px solid var(--gray-200)}
.onboarding-form-wrap{max-width:860px;margin:clamp(2.5rem,5vw,4rem) auto 0}
.onboarding-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--blue);margin-bottom:1.2rem;padding-bottom:.6rem;border-bottom:2px solid var(--blue);display:inline-block}
.onboarding-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.onboarding-form-grid .form-group{margin-bottom:0}
.form-group--full{grid-column:1/-1}
.form-radio-group{display:flex;gap:1.5rem;margin-top:.3rem}
.form-radio-label{display:flex;align-items:center;gap:.5rem;font-size:.92rem;color:var(--gray-700);cursor:pointer}
.form-radio-label input{width:18px;height:18px;accent-color:var(--blue);cursor:pointer}
.onboarding-privacy{background:rgba(0,35,102,.04);border:1px solid rgba(0,35,102,.12);border-radius:var(--radius);padding:1rem 1.2rem;font-size:.78rem;color:var(--gray-500);line-height:1.7;margin-bottom:1.5rem}
.onboarding-section{margin-bottom:2.5rem}
@media(max-width:768px){.onboarding-form-grid{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════
   RECLUTAMIENTO PAGE
   ═══════════════════════════════════════════ */
.recruit-hero{padding:calc(var(--header-h) + clamp(40px,6vw,80px)) 0 clamp(40px,6vw,80px);border-bottom:1px solid var(--gray-200)}
.recruit-layout{display:grid;grid-template-columns:5fr 7fr;gap:clamp(2rem,5vw,4rem);align-items:start;padding:clamp(2.5rem,5vw,4rem) 0}
.recruit-sidebar h3{margin-bottom:1rem}
.recruit-sidebar p{font-size:.92rem;color:var(--gray-500);line-height:1.75;margin-bottom:1.5rem}
.recruit-perks{display:flex;flex-direction:column;gap:.8rem;margin-bottom:2rem}
.recruit-perk{display:flex;align-items:flex-start;gap:.7rem;font-size:.9rem;color:var(--gray-700)}
.recruit-perk-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:.45rem}
.recruit-whatsapp{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1.8rem;background:#25D366;color:#fff;border-radius:var(--radius);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;transition:background .3s,transform .25s}
.recruit-whatsapp:hover{background:#1ebe5d;transform:translateY(-1px)}
@media(max-width:900px){.recruit-layout{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════
   FLOATING WHATSAPP BUTTON
═══════════════════════════════════════════ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:9990;width:52px;height:52px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.45),0 1px 6px rgba(0,0,0,.15);text-decoration:none;transition:transform .2s,box-shadow .2s}
.wa-float:hover{transform:scale(1.12);box-shadow:0 8px 32px rgba(37,211,102,.55),0 2px 8px rgba(0,0,0,.18)}
.wa-float svg{display:block}

/* Calendly embed step */
.agenda-step--calendly .agenda-form-col{max-width:100%;width:100%}
#calendlyInline{border-radius:12px;overflow:hidden}
@media(max-width:600px){.wa-float{bottom:16px;right:16px;width:46px;height:46px}}

/* ═══════════════════════════════════════════
   COMPREHENSIVE MOBILE RESPONSIVE FIXES
   ═══════════════════════════════════════════ */

/* ─── GLOBAL TEXT OVERFLOW PREVENTION ─── */
@media(max-width:768px){
  h1,h2,h3,h4,h5{word-wrap:break-word;overflow-wrap:break-word;hyphens:auto}
  p{max-width:100%}
  .container{width:92%}
  .btn{padding:.85rem 1.6rem;font-size:.72rem;letter-spacing:.08em}
}
@media(max-width:480px){
  .container{width:94%}
  /* Prevent buttons from overflowing on small screens */
  .btn{padding:.75rem 1.1rem;font-size:.68rem;gap:.4rem;white-space:normal;word-break:break-word;min-width:0;max-width:100%}
}
/* Global: never let any section cause horizontal scroll */
section,footer{ max-width:100%;overflow-x:hidden }
/* Qualify CTA button wraps on mobile */
@media(max-width:480px){
  .qualify-cta{ font-size:.82rem;padding:.8rem 1.4rem }
  .qualify-layout{ gap:2rem }
  .qualify-title{ font-size:clamp(1.7rem,6vw,2.4rem) }
}

/* ─── HEADER / NAV ─── */
@media(max-width:768px){
  .nav-links{z-index:200;padding:3rem 2rem}
  .nav-links a{font-size:.92rem;padding:.6rem 0}
  .nav-cta{width:100%;text-align:center;margin-top:1rem}
  .logo{font-size:1rem}
}

/* ─── HERO V2 (index) ─── */
@media(max-width:768px){
  .hero-v2{min-height:auto;padding-top:calc(var(--header-h) + 20px);padding-bottom:0}
  .hv2-layout{padding-top:2rem;padding-bottom:2rem}
  .hv2-title{font-size:clamp(2rem,8vw,2.8rem)}
  .hv2-sub{font-size:.88rem;margin-bottom:1.5rem}
  .hv2-ctas{flex-direction:column;gap:.75rem}
  .hv2-ctas .btn{width:100%;justify-content:center;text-align:center}
  .hv2-stats{flex-wrap:wrap;gap:1rem;justify-content:flex-start}
  .hv2s-lbl{white-space:normal;font-size:.6rem}
  .hv2s-sep{display:none}
  .hv2-badge{font-size:.62rem;padding:.35rem .8rem}
}
@media(max-width:480px){
  .hv2-title{font-size:clamp(1.8rem,7vw,2.2rem)}
  .hv2-right{height:240px}
  .hv2-cards{width:160px;height:190px;right:6px;bottom:1.5rem}
  .hv2c-val{font-size:clamp(1.2rem,3vw,1.6rem)}
  .hv2c-bars{height:clamp(28px,5vw,40px)}
  .hv2c-radial-wrap{width:55px;height:55px}
  .hv2c-badge{font-size:.55rem;padding:.2rem .4rem}
  .hv2c-title{font-size:.52rem}
  .hv2c-head{gap:.3rem}
}

/* ─── HOME TESTIMONIAL CAROUSEL ─── */
@media(max-width:900px){
  /* On tablet hide arrows — swipe works */
  .ht-arrow{display:none !important}
  .ht-stage{padding:0 1rem}
}
@media(max-width:600px){
  .home-testi{padding:3rem 0}
  .ht-header h2{font-size:clamp(1.8rem,6vw,2.4rem)}
  .ht-sub{font-size:.88rem}
  .ht-stage{padding:0 .5rem}
  /* Cards fill width and use constrained height — optimizes space on mobile */
  .home-testi .vid-card{
    aspect-ratio:auto !important;
    height:min(58vh,380px) !important;
  }
  .home-testi .vid-card video{
    width:100% !important;
    height:100% !important;
    object-fit:cover !important;
  }
}

/* ─── SERVICES STRIP (4-col grid on index.html) ─── */
@media(max-width:1024px){
  .services-strip-4col{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:600px){
  .services-strip-4col{
    grid-template-columns:1fr;
  }
  .strip-card{padding:1.5rem 0}
  .strip-card .card-number{font-size:2.8rem}
  .strip-card h4{font-size:1rem}
}

/* ─── ABOUT BLOCK ─── */
@media(max-width:768px){
  .about-block .about-grid{gap:2rem}
  .about-txt-col blockquote{font-size:1.1rem;padding-left:1rem}
}

/* ─── HOW IT WORKS ─── */
@media(max-width:768px){
  .hiw-section{padding:clamp(3rem,8vw,5rem) 0}
  .hiw-header h2{font-size:clamp(1.6rem,5vw,2.2rem)}
  .hiw-nav{gap:0;margin-bottom:2rem}
  .hiw-nav-item{padding:0 .6rem}
  .hiw-step-title{font-size:.6rem;letter-spacing:.06em;white-space:normal}
  .hiw-num-badge{width:32px;height:32px;font-size:.6rem;margin-bottom:.5rem}
  .hiw-visual{width:min(360px,88vw);height:clamp(280px,50vw,380px)}
  .hiw-card img{height:calc(100% - 56px)}
  .hiw-card-footer{height:56px;padding:0 .8rem}
  .hiw-card-label{font-size:.72rem;gap:.3rem}
  .hiw-card-badge{font-size:.6rem;padding:.2rem .5rem}
  .hiw-card-chip{font-size:.6rem;padding:.2rem .5rem}
}

/* ─── GLOBE SECTION ─── */
@media(max-width:600px){
  .globe-wrapper{max-width:100%;aspect-ratio:1/1}
  .globe-review-card{max-width:280px;padding:1.2rem;font-size:.85rem}
}

/* ─── VIDEO TESTIMONIAL (TV Section) ─── */
@media(max-width:600px){
  .tv-section{padding:clamp(3rem,8vw,5rem) 0}
  .tv-title{font-size:clamp(1.6rem,5vw,2.2rem)}
  .tv-subtitle{font-size:.82rem}
  .tv-stage{max-width:320px}
  .tv-play-btn{width:56px;height:56px}
  .tv-card{border-radius:16px}
  .tv-card-footer{padding:.8rem 1rem;gap:.6rem;flex-wrap:wrap}
  .tv-avatar{width:34px;height:34px;font-size:.85rem}
  .tv-name{font-size:.82rem}
  .tv-role{font-size:.68rem}
  .tv-verified{font-size:.62rem;padding:.2rem .45rem}
  .tv-side-left .tv-tag{font-size:.68rem;padding:.35rem .7rem}
  .tv-stars-big{font-size:1.1rem}
  .tv-stat-num{font-size:clamp(1.4rem,4vw,2rem)}
  .tv-stat-lbl{font-size:.72rem}
  .tv-cta{font-size:.7rem;padding:.7rem 1.4rem}
}

/* ═══════════════════════════════════════════
   REVIEWS / RESEÑAS SECTION
   ═══════════════════════════════════════════ */
.rv-section{background:linear-gradient(180deg,#f4f7ff 0%,#fff 60%)}
.rv-summary{display:flex;align-items:center;gap:clamp(2rem,5vw,5rem);background:#fff;border:1px solid var(--gray-200);border-radius:20px;padding:clamp(1.5rem,3vw,2.5rem);margin:3rem 0;box-shadow:0 4px 24px rgba(0,35,102,.07)}
.rv-score-col{display:flex;flex-direction:column;align-items:center;gap:.3rem;flex-shrink:0}
.rv-big-num{font-size:clamp(3.5rem,7vw,5rem);font-weight:800;color:var(--blue);letter-spacing:-.04em;line-height:1}
.rv-stars-row{color:#f59e0b;font-size:1.5rem;letter-spacing:.08em}
.rv-count-txt{font-size:.78rem;color:var(--gray-500);white-space:nowrap}
.rv-verified-badge{display:inline-flex;align-items:center;gap:.35rem;margin-top:.4rem;background:rgba(34,211,165,.1);border:1px solid rgba(34,211,165,.25);border-radius:100px;padding:.25rem .65rem;font-size:.65rem;font-weight:700;color:#0d9488;letter-spacing:.06em}
.rv-bars-col{flex:1;display:flex;flex-direction:column;gap:.55rem}
.rv-bar-row{display:flex;align-items:center;gap:.65rem}
.rv-bar-lbl{font-size:.72rem;color:#f59e0b;font-weight:700;width:28px;text-align:right;flex-shrink:0}
.rv-bar-track{flex:1;height:9px;background:var(--gray-200);border-radius:5px;overflow:hidden}
.rv-bar-fill{height:100%;background:linear-gradient(90deg,var(--blue),#4a9eff);border-radius:5px;width:0;transition:width 1.1s cubic-bezier(.25,.46,.45,.94)}
.rv-bar-pct{font-size:.68rem;color:var(--gray-500);width:30px;flex-shrink:0}
.rv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:.5rem}
.rv-card{background:#fff;border:1px solid var(--gray-200);border-radius:16px;padding:1.5rem;box-shadow:0 2px 12px rgba(0,35,102,.05);display:flex;flex-direction:column;gap:.75rem;transition:transform .25s,box-shadow .25s;animation:rvFadeIn .4s ease both}
@keyframes rvFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.rv-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,35,102,.1)}
.rv-card-head{display:flex;align-items:center;gap:.85rem}
.rv-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;color:#fff;flex-shrink:0}
.rv-card-stars{color:#f59e0b;font-size:.88rem;letter-spacing:.04em;margin-bottom:.1rem}
.rv-card-name{font-size:.88rem;font-weight:700;color:var(--black);line-height:1.2}
.rv-card-role{font-size:.7rem;color:var(--gray-500)}
.rv-card-text{font-size:.88rem;color:var(--gray-700);line-height:1.68;flex:1}
.rv-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:.2rem}
.rv-card-date{font-size:.68rem;color:var(--gray-300)}
.rv-verified-chip{display:inline-flex;align-items:center;gap:.3rem;font-size:.62rem;font-weight:700;color:#0d9488}
.rv-grid-footer{text-align:center;margin-top:1.75rem}
.rv-load-more{background:transparent;border:1.5px solid var(--gray-200);border-radius:100px;padding:.65rem 2.2rem;font-family:var(--font);font-size:.78rem;font-weight:600;color:var(--gray-500);cursor:pointer;transition:border-color .2s,color .2s,box-shadow .2s}
.rv-load-more:hover{border-color:var(--blue);color:var(--blue);box-shadow:0 2px 8px rgba(0,35,102,.1)}
.rv-submit-wrap{margin-top:4rem;max-width:640px;margin-left:auto;margin-right:auto}
.rv-submit-card{background:linear-gradient(135deg,var(--blue) 0%,#1a3a80 100%);border-radius:24px;padding:clamp(2rem,4vw,3rem);box-shadow:0 24px 64px rgba(0,35,102,.3)}
.rv-submit-card h3{font-size:clamp(1.3rem,2.5vw,1.7rem);color:#fff;margin-bottom:.4rem}
.rv-submit-card>p{color:rgba(255,255,255,.65);font-size:.88rem;margin-bottom:1.75rem}
.rv-picker-label{font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.6rem}
.rv-star-picker{display:flex;gap:.3rem;margin-bottom:.5rem}
.rv-star{background:none;border:none;font-size:2rem;color:rgba(255,255,255,.2);cursor:pointer;padding:.15rem;transition:color .12s,transform .12s;line-height:1}
.rv-star.active,.rv-star.hover{color:#fbbf24;transform:scale(1.18)}
.rv-star-label{font-size:.78rem;color:rgba(255,255,255,.5);margin-bottom:1.4rem;min-height:1.2em}
.rv-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:.85rem}
.rv-field{display:flex;flex-direction:column;gap:.4rem}
.rv-field label{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.rv-field input,.rv-field textarea,.rv-fields textarea{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:.72rem .95rem;font-family:var(--font);font-size:.92rem;color:#fff;outline:none;width:100%;transition:border-color .2s,background .2s}
.rv-field input::placeholder,.rv-field textarea::placeholder,.rv-fields textarea::placeholder{color:rgba(255,255,255,.38)}
.rv-field input:focus,.rv-field textarea:focus,.rv-fields textarea:focus{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.15)}
.rv-fields{display:flex;flex-direction:column;gap:.85rem;margin-bottom:1.5rem}
.rv-fields textarea{resize:vertical;min-height:100px}
.rv-submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.6rem;background:#fff;color:var(--blue);border:none;border-radius:100px;padding:.85rem 1.5rem;font-family:var(--font);font-size:.88rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(0,0,0,.15)}
.rv-submit-btn:hover{background:#f0f4ff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.rv-submit-btn:disabled{opacity:.5;pointer-events:none}
.rv-success-msg{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:1.5rem 0 .5rem}
.rv-success-msg svg{color:#22d3a5}
.rv-success-msg h4{font-size:1.2rem;color:#fff}
.rv-success-msg p{color:rgba(255,255,255,.65);font-size:.88rem}
@media(max-width:900px){.rv-grid{grid-template-columns:repeat(2,1fr)}.rv-summary{flex-direction:column;align-items:flex-start;gap:1.5rem}.rv-score-col{flex-direction:row;align-items:center;gap:1rem}}
@media(max-width:560px){.rv-grid{grid-template-columns:1fr}.rv-field-row{grid-template-columns:1fr}}

/* ═══════════════════════════════════════════
   TVC — TESTIMONIAL VIDEO CARDS GRID
   ═══════════════════════════════════════════ */
.tvc-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,260px));
  gap:1.5rem;
  justify-content:center;
  margin-top:3rem;
}
.tvc-card{
  position:relative;
  aspect-ratio:9/16;
  max-height:460px;
  border-radius:16px;
  overflow:hidden;
  background:linear-gradient(160deg,#0d1a3a 0%,#06091a 100%);
  box-shadow:0 16px 48px rgba(0,35,102,.14);
  cursor:pointer;
  transition:transform .3s,box-shadow .3s;
}
.tvc-card:hover{transform:translateY(-5px);box-shadow:0 24px 64px rgba(0,35,102,.22)}
.tvc-card video{
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.tvc-overlay{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.28);
  transition:opacity .3s;
}
.tvc-overlay.hidden{opacity:0;pointer-events:none}
.tvc-play{
  width:62px;height:62px;border-radius:50%;
  background:rgba(255,255,255,.92);border:none;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);cursor:pointer;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  transition:transform .2s,background .2s;
}
.tvc-play:hover{transform:scale(1.1);background:#fff}
.tvc-footer{
  position:absolute;bottom:0;left:0;right:0;
  padding:.85rem 1rem;
  background:linear-gradient(to top,rgba(0,0,0,.82),transparent);
}
.tvc-name{font-size:.82rem;font-weight:700;color:#fff;margin-bottom:.2rem}
.tvc-tag{font-size:.68rem;color:rgba(255,255,255,.65)}

@media(max-width:900px){
  .tvc-grid{grid-template-columns:repeat(2,minmax(0,260px))}
}
@media(max-width:560px){
  .tvc-grid{grid-template-columns:minmax(0,300px)}
}

/* ═══════════════════════════════════════════
   LANGUAGE SWITCH — compact segmented control
   ═══════════════════════════════════════════ */
.lang-toggle{
  display:inline-flex;align-items:center;
  background:rgba(0,0,0,.08);
  border:none;border-radius:100px;
  padding:3px;gap:2px;
  cursor:pointer;flex-shrink:0;
}
.lsw-opt{
  display:inline-flex;align-items:center;gap:5px;
  padding:.28rem .55rem;
  border-radius:100px;
  font-family:var(--font);
  font-size:.66rem;font-weight:600;
  color:#666;
  background:transparent;
  transition:background .2s,color .2s,box-shadow .2s;
  white-space:nowrap;user-select:none;line-height:1;
}
.lsw-opt--on{
  background:#fff;color:var(--blue);font-weight:700;
  box-shadow:0 1px 4px rgba(0,0,0,.14);
}
.lsw-txt{line-height:1}

/* ─── Hide ALL Google Translate UI including spinner ─── */
.goog-te-banner-frame,.goog-te-banner-frame.skiptranslate{display:none!important}
.goog-te-gadget,.goog-te-gadget-simple,.goog-te-menu-frame{display:none!important}
.goog-te-spinner-pos,.goog-te-spinner-pos *{display:none!important;visibility:hidden!important}
.VIpgJd-ZVi9od-aZ2wEe-wOHMyf,.VIpgJd-ZVi9od-aZ2wEe-wOHMyf-ti6hGc{display:none!important}
#goog-gt-tt,.goog-tooltip,.goog-tooltip:hover{display:none!important}
body{top:0!important}
iframe.skiptranslate{display:none!important}
body.translated-ltr,body.translated-rtl{margin-top:0!important;top:0!important}

/* ─── Mobile: aún más compacto ─── */
@media(max-width:768px){
  .lsw-opt{padding:.24rem .48rem;gap:4px;font-size:.62rem}
}

/* ─── FAQ ─── */
@media(max-width:600px){
  .faq-list{margin-top:2rem}
  .faq-question{font-size:.88rem;padding:1.1rem 0;gap:.5rem}
  .faq-question span{flex:1;min-width:0}
  .faq-answer p{font-size:.82rem;padding-bottom:1rem}
}

/* ─── CTA BANNER ─── */
@media(max-width:768px){
  .cta-banner{padding:clamp(3rem,8vw,5rem) 0;border-radius:0}
  .cta-banner h2{font-size:clamp(1.6rem,5vw,2.4rem)}
  .cta-banner p{font-size:.88rem}
}
@media(max-width:480px){
  .cta-banner .btn{width:100%;justify-content:center;text-align:center}
}

/* ─── FOOTER ─── */
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr !important;gap:2rem}
  .footer-brand{max-width:100%}
  .footer-brand p{max-width:100%}
  .footer-col{padding-bottom:1rem;border-bottom:1px solid var(--gray-200)}
  .footer-col:last-child{border-bottom:none}
  .footer-disclaimer{font-size:.72rem}
  .footer-disclaimer p{max-width:100%}
  .footer-bottom{font-size:.65rem}
}

/* ─── SERVICES PAGE ─── */
@media(max-width:768px){
  .service-detail .service-detail-grid{gap:2rem}
  .service-txt h2{font-size:clamp(1.6rem,5vw,2.2rem)}
  .service-features li{font-size:.82rem}
  .service-features li::before{margin-top:.35rem;width:6px;height:6px}
}

/* ─── SERVICIOS VIDEO GRID ─── */
@media(max-width:480px){
  .svc-video-grid{max-width:300px}
  .svc-vid-play{width:48px;height:48px}
  .svc-vid-caption h4{font-size:.78rem}
  .svc-vid-caption p{font-size:.65rem}
}

/* ─── NOSOTROS PAGE ─── */
@media(max-width:768px){
  .story-section .story-grid{gap:2rem}
  .story-txt h2{font-size:clamp(1.6rem,5vw,2.2rem)}
  .story-txt p{font-size:.88rem}
  .nos-logo-wrap{text-align:center}
  .nos-logo{margin:0 auto}
}
@media(max-width:600px){
  .values-grid{gap:1.5rem}
  .value-card{padding:1.5rem 0}
  .value-number{font-size:2rem}
  .value-card h4{font-size:1rem}
  .value-card p{font-size:.82rem}
}

/* ─── TIMELINE ─── */
@media(max-width:600px){
  .tl-track{padding-left:3rem}
  .tl-dot{left:-2.2rem;width:14px;height:14px;top:2.4rem}
  .tl-year{font-size:1.4rem}
  .tl-content h4{font-size:1rem}
  .tl-content p{font-size:.82rem}
  .tl-item{padding:1.5rem 0}
}

/* ─── TESTIMONIOS PAGE ─── */
@media(max-width:768px){
  /* Stats strip in testimonios */
  .services-strip .grid-12.services-strip-grid{grid-template-columns:1fr !important}
  .services-strip .strip-card[style*="border-right"]{border-right:none !important}
}
@media(max-width:600px){
  .vid-gallery{gap:1rem}
  .vid-card{border-radius:12px}
  .vid-play-btn{width:48px;height:48px}
  .vid-footer{padding:.6rem .8rem}
  .vid-footer-name{font-size:.72rem}
  .vid-footer-tag{font-size:.62rem}
}

/* ─── TESTIMONIOS CAROUSEL ─── */
@media(max-width:768px){
  .testimonial-slide{flex:0 0 92%;padding:1.5rem}
  .testimonial-slide blockquote{font-size:.95rem}
  .carousel-controls{margin-top:1.5rem}
  .carousel-btn{width:40px;height:40px}
}
@media(max-width:600px){
  .testimonial-slide{flex:0 0 100%;transform:scale(.95) !important}
  .testimonial-slide.active{transform:scale(1) !important}
}

/* ─── RECLUTAMIENTO PAGE ─── */
@media(max-width:768px){
  .recruit-hero h1{font-size:clamp(1.6rem,5vw,2.2rem)}
  .recruit-layout{gap:2rem}
  .recruit-sidebar h3{font-size:clamp(1.2rem,4vw,1.6rem)}
  .recruit-perks{gap:.6rem}
  .recruit-perk{font-size:.82rem}
}
@media(max-width:600px){
  .form-card{padding:1.5rem}
  .onboarding-form-grid{gap:1rem}
  .form-radio-group{flex-direction:column;gap:.75rem}
  .form-radio-label{font-size:.82rem}
  .form-group label{font-size:.65rem}
  .form-group input,.form-group select,.form-group textarea{font-size:.85rem;padding:.7rem .8rem}
  .recruit-whatsapp{font-size:.7rem;padding:.7rem 1.4rem;width:100%;justify-content:center}
}

/* ─── ONBOARDING PAGE ─── */
@media(max-width:600px){
  .onboarding-form-wrap{padding:0 .5rem}
  .onboarding-section-label{font-size:.62rem}
  .onboarding-privacy{font-size:.72rem;padding:.8rem}
}

/* ─── PAGE HERO SECTIONS (all inner pages) ─── */
@media(max-width:768px){
  .recruit-hero,.contact-hero,.onboarding-hero{
    padding-top:calc(var(--header-h) + 30px);
    padding-bottom:clamp(20px,4vw,40px);
  }
}
@media(max-width:480px){
  section[style*="padding-top:calc(var(--header-h) + 60px)"] h1{
    font-size:clamp(1.6rem,6vw,2.2rem) !important;
  }
}

/* ─── WHATSAPP BUTTON (all page variants) ─── */
@media(max-width:480px){
  .whatsapp-btn{font-size:.68rem;padding:.7rem 1.2rem}
  .whatsapp-btn span{display:inline}
}

/* ─── GENERAL BUTTON CONTAINERS ─── */
@media(max-width:480px){
  div[style*="display:flex"][style*="gap:1rem"]{
    flex-direction:column !important;
    align-items:stretch !important;
  }
  div[style*="display:flex"][style*="gap:1rem"] .btn{
    width:100%;justify-content:center;text-align:center;
  }
}

/* ─── PRELOADER ─── */
@media(max-width:480px){
  .preloader-logo{font-size:1.2rem}
  .preloader-text{font-size:.62rem;letter-spacing:.12em;padding:0 1rem}
  .preloader-lock{width:48px;height:72px}
}

/* ─── AGENDAMIENTO (Calendly page) ─── */
@media(max-width:480px){
  .book-title{font-size:1.8rem !important;line-height:1.15}
  .book-sub{font-size:.88rem}
  .book-trust{gap:.5rem 1rem;padding-top:1.5rem;margin-top:2rem}
  .book-trust-item{font-size:.7rem}
}

/* ─── CONTACTO FORM PAGE (old funnel) ─── */
@media(max-width:480px){
  .agenda-question{font-size:clamp(1.3rem,5vw,1.8rem) !important}
  .agenda-input{font-size:clamp(1rem,3vw,1.4rem)}
  .agenda-service-cards{gap:.75rem}
  .agenda-service-card{padding:1.2rem .8rem 1rem}
  .agenda-service-card h4{font-size:.82rem}
  .agenda-service-card p{font-size:.72rem}
  .agenda-service-card-icon{font-size:1.6rem}
  .asc-popular{font-size:.58rem}
  .agenda-next-btn{width:100%;justify-content:center;font-size:.72rem;padding:.8rem 1.6rem}
  .cal-day{font-size:.7rem}
  .time-slots{grid-template-columns:repeat(2,1fr);gap:.4rem}
  .time-slot{font-size:.75rem;padding:.55rem .35rem}
  .agenda-success h2{font-size:clamp(1.6rem,5vw,2rem)}
  .agenda-success p{font-size:.88rem}
}




/* ═══════════════════════════════════════════
   PITCH VIDEO SECTION
   ═══════════════════════════════════════════ */
.pitch-section{position:relative;padding:var(--section-py) 0;background:#fdf6e8;overflow:hidden}
.pitch-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.pitch-glow{position:absolute;border-radius:50%;filter:blur(120px);opacity:.55}
.pitch-glow-1{width:60vw;height:60vw;top:-20%;left:-10%;background:radial-gradient(circle,rgba(251,191,36,.38),transparent 70%)}
.pitch-glow-2{width:40vw;height:40vw;bottom:-15%;right:5%;background:radial-gradient(circle,rgba(0,35,102,.12),transparent 70%)}
.pitch-layout{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,8vw,7rem);align-items:center}
.pitch-eyebrow{display:inline-flex;align-items:center;gap:.55rem;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#002366;margin-bottom:1.6rem}
.pitch-eyebrow-dot{width:8px;height:8px;border-radius:50%;background:#fbbf24;animation:pitchDotPulse 2.2s ease-in-out infinite}
@keyframes pitchDotPulse{0%,100%{box-shadow:0 0 0 0 rgba(251,191,36,.55)}50%{box-shadow:0 0 0 6px rgba(251,191,36,0)}}
.pitch-title{font-size:clamp(2.4rem,4.5vw,4rem);font-weight:800;line-height:1.06;letter-spacing:-.035em;color:#0d0b07;margin-bottom:1.6rem}
.pitch-title-accent{color:#002366;position:relative;display:inline-block}
.pitch-title-accent::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:4px;background:linear-gradient(90deg,#fbbf24,rgba(251,191,36,0));border-radius:2px}
.pitch-lead{font-size:clamp(.95rem,1.4vw,1.1rem);color:#3d3520;line-height:1.75;margin-bottom:2rem;max-width:42ch}
.pitch-bullets{display:flex;flex-direction:column;gap:.9rem;margin-bottom:2.5rem}
.pitch-bullets li{display:flex;align-items:flex-start;gap:.75rem;font-size:.95rem;color:#3d3520;line-height:1.5}
.pitch-check{flex-shrink:0;width:22px;height:22px;background:#002366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;margin-top:.1rem}
.pitch-cta{background:#002366;color:#fff;padding:.9rem 1.9rem;border-radius:100px;font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:.6rem;transition:background .25s,transform .2s,box-shadow .25s;box-shadow:0 4px 20px rgba(0,35,102,.25)}
.pitch-cta:hover{background:#001a4d;transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,35,102,.35)}
.pitch-cta .arrow{transition:transform .2s}
.pitch-cta:hover .arrow{transform:translateX(4px)}
.pitch-video-wrap{display:flex;justify-content:center}
.pitch-video-card{position:relative;cursor:pointer;transform-style:preserve-3d;transform:perspective(900px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));transition:transform .18s ease,box-shadow .25s ease;border-radius:20px;box-shadow:0 16px 48px rgba(0,0,0,.1)}
.pitch-video-card:hover{box-shadow:0 24px 64px rgba(251,191,36,.22),0 8px 32px rgba(0,0,0,.14)}
.pitch-video-inner{width:min(320px,72vw);aspect-ratio:9/16;overflow:hidden;border-radius:20px;background:linear-gradient(160deg,#1a1206,#0d0b07)}
.pitch-video{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.pitch-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:rgba(13,11,7,.35);border-radius:20px;transition:opacity .3s ease;z-index:2}
.pitch-overlay.hidden{opacity:0;pointer-events:none}
.pitch-play-ring{width:72px;height:72px;border-radius:50%;border:2px solid rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);transition:transform .2s,background .2s,border-color .2s}
.pitch-video-card:hover .pitch-play-ring{transform:scale(1.1);background:rgba(251,191,36,.25);border-color:#fbbf24}
.pitch-play-btn{background:none;border:none;color:#fff;display:flex;align-items:center;justify-content:center;padding-left:4px}
.pitch-play-label{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.pitch-pause-hint{position:absolute;top:14px;right:14px;display:none;align-items:center;gap:.4rem;background:rgba(0,0,0,.55);color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:.35rem .7rem;border-radius:100px;backdrop-filter:blur(6px);z-index:3}
.pitch-pause-hint.visible{display:flex}
.pitch-vid-badge{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.75rem;font-weight:600;padding:.38rem .9rem;border-radius:100px;white-space:nowrap;z-index:3}
.pitch-vid-badge-dot{width:7px;height:7px;border-radius:50%;background:#22d3a5;animation:pitchDotPulse 2.2s ease-in-out infinite}
@media(max-width:900px){.pitch-layout{grid-template-columns:1fr;gap:3rem}.pitch-video-wrap{order:-1}.pitch-title{font-size:clamp(2rem,6vw,3rem)}}
@media(max-width:480px){.pitch-video-inner{width:min(280px,85vw)}.pitch-title{font-size:clamp(1.8rem,7vw,2.6rem)}}

/* ═══════════════════════════════════════════
   QUALIFY CTA SECTION (index.html)
   ═══════════════════════════════════════════ */
.qualify-section{
  position:relative;
  padding:var(--section-py) 0;
  background:#080e1f;
  overflow:hidden;
  color:#fff;
}
.qualify-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.qualify-glow-1{
  position:absolute;width:55vw;height:55vw;top:-20%;left:-10%;border-radius:50%;
  filter:blur(100px);opacity:.55;
  background:radial-gradient(circle,rgba(0,35,102,.8),transparent 70%);
}
.qualify-glow-2{
  position:absolute;width:40vw;height:40vw;bottom:-15%;right:-5%;border-radius:50%;
  filter:blur(100px);opacity:.4;
  background:radial-gradient(circle,rgba(251,191,36,.35),transparent 70%);
}
.qualify-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
}
.qualify-layout{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,7vw,6rem);align-items:center;
}

/* Badge */
.qualify-badge{
  display:inline-flex;align-items:center;gap:.55rem;
  background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.25);
  border-radius:100px;padding:.4rem 1.1rem;
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#fbbf24;margin-bottom:1.5rem;
}
.qualify-badge-dot{
  width:7px;height:7px;border-radius:50%;background:#fbbf24;
  animation:pitchDotPulse 2.2s ease-in-out infinite;
}
.qualify-title{
  font-size:clamp(2rem,4vw,3.2rem);font-weight:800;
  line-height:1.1;letter-spacing:-.03em;color:#fff;
  margin-bottom:1.2rem;
}
.qualify-title-gold{color:#fbbf24}
.qualify-lead{
  font-size:clamp(.9rem,1.3vw,1rem);color:rgba(255,255,255,.65);
  line-height:1.75;max-width:44ch;margin-bottom:1.8rem;
}
.qualify-list{
  display:flex;flex-direction:column;gap:.65rem;margin-bottom:2.2rem;
}
.qualify-list li{
  display:flex;align-items:center;gap:.65rem;
  font-size:.9rem;color:rgba(255,255,255,.8);
}
.qualify-check{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;
  background:#22d3a5;color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.65rem;font-weight:800;
}
.qualify-cta{
  background:#fbbf24;color:#0d0b07;
  padding:.9rem 2rem;border-radius:100px;font-weight:700;font-size:.95rem;
  display:inline-flex;align-items:center;gap:.6rem;
  transition:background .25s,transform .2s,box-shadow .25s;
  box-shadow:0 4px 24px rgba(251,191,36,.35);
}
.qualify-cta:hover{
  background:#f59e0b;transform:translateY(-2px);
  box-shadow:0 8px 36px rgba(251,191,36,.45);
}
.qualify-cta .arrow{transition:transform .2s}
.qualify-cta:hover .arrow{transform:translateX(4px)}

/* Cards grid */
.qualify-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
}
.qualify-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:16px;padding:1.5rem 1.2rem;
  transition:background .25s,border-color .25s,transform .25s;
}
.qualify-card:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(251,191,36,.3);
  transform:translateY(-3px);
}
.qualify-card-icon{font-size:1.8rem;margin-bottom:.75rem}
.qualify-card-title{font-weight:700;font-size:.95rem;color:#fff;margin-bottom:.3rem}
.qualify-card-desc{font-size:.78rem;color:rgba(255,255,255,.55);line-height:1.5}

@media(max-width:900px){
  .qualify-layout{grid-template-columns:1fr;gap:3rem}
  .qualify-cards{order:-1}
}
@media(max-width:480px){
  .qualify-cards{grid-template-columns:1fr 1fr}
  .qualify-card{padding:1rem}
  .qualify-card-icon{font-size:1.4rem}
}
