:root {
  --navy:      #1B2D72;
  --navy-dk:   #101D50;
  --navy-lt:   #EAECF7;
  --red:       #C8102E;
  --red-dk:    #A00D25;
  --gray:      #6B6B6B;
  --gray-lt:   #F5F6FA;
  --border:    #E2E5EE;
  --white:     #FFFFFF;
  --black:     #111111;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;color:var(--black);background:var(--white);font-size:16px;line-height:1.6}
[data-lang]{display:none!important}
html[lang="es"] [data-lang="es"],
html[lang="en"] [data-lang="en"],
html[lang="bg"] [data-lang="bg"]{display:revert!important}
[hidden]{display:none!important}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.97);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:80px;backdrop-filter:blur(10px)}
.nav-logo img{height:60px;width:auto;display:block}
.nav-right{display:flex;align-items:center;gap:16px}
.lang-switcher{display:flex;gap:4px}
.lang-btn{background:none;border:1px solid var(--border);padding:5px 11px;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;color:var(--gray);font-family:'DM Sans',sans-serif;transition:all .15s}
.lang-btn:hover,.lang-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.nav-cta{background:var(--red);color:#fff;text-decoration:none;padding:9px 18px;border-radius:6px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:7px;transition:background .15s}
.nav-cta:hover{background:var(--red-dk)}
.nav-cta svg{width:16px;height:16px;fill:#fff;flex-shrink:0}

/* HERO */
.hero{padding-top:80px;min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(16,29,80,.72),rgba(27,45,114,.58),rgba(16,29,80,.68))}
.hero-container{max-width:1100px;margin:0 auto;padding:5rem 2rem 4rem;position:relative;z-index:1;width:100%}
.hero-tag{display:inline-block;background:var(--red);color:#fff;font-size:11px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;padding:5px 14px;border-radius:3px;margin-bottom:1.5rem}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(38px,5vw,66px);font-weight:900;line-height:1.07;letter-spacing:-1.5px;color:#fff;margin-bottom:1.25rem;max-width:720px}
.hero h1 em{color:#FF7A5C;font-style:normal}
.hero-sub{font-size:18px;color:rgba(255,255,255,.82);font-weight:300;margin-bottom:2.5rem;max-width:540px;line-height:1.75}
.btn-wa{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;text-decoration:none;padding:17px 30px;border-radius:8px;font-size:17px;font-weight:500;transition:all .2s;box-shadow:0 4px 24px rgba(200,16,46,.3)}
.btn-wa:hover{background:var(--red-dk);transform:translateY(-2px);box-shadow:0 8px 32px rgba(200,16,46,.45)}
.btn-wa svg{width:22px;height:22px;fill:#fff}
.btn-wa-sm{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;text-decoration:none;padding:13px 22px;border-radius:8px;font-size:15px;font-weight:500;transition:background .15s}
.btn-wa-sm:hover{background:var(--red-dk)}
.btn-wa-sm svg{width:18px;height:18px;fill:#fff}
.hero-trust{margin-top:1.75rem;display:flex;gap:1.75rem;flex-wrap:wrap}
.hero-trust-item{display:flex;align-items:center;gap:7px;font-size:13px;color:rgba(255,255,255,.7)}
.hero-trust-item::before{content:'✓';color:#4ade80;font-weight:700;font-size:14px}
.hero-stats{display:flex;gap:3rem;margin-top:4rem;padding-top:2.5rem;border-top:1px solid rgba(255,255,255,.18);flex-wrap:wrap}
.hero-stat strong{display:block;font-family:'Playfair Display',serif;font-size:38px;font-weight:900;color:#fff;line-height:1}
.hero-stat span{font-size:13px;color:rgba(255,255,255,.6);margin-top:5px;display:block}

/* SECTION COMMONS */
.section-label{display:inline-block;font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--red);margin-bottom:.75rem}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(28px,3vw,44px);font-weight:700;letter-spacing:-.5px;color:var(--navy);line-height:1.15}
.section-header{max-width:1100px;margin:0 auto 3rem}

/* ABOUT */
.about{padding:7rem 2rem;background:var(--white)}
.about-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:360px 1fr;gap:5rem;align-items:center}
.about-photo-wrap{position:relative}
.about-photo-wrap::before{content:'';position:absolute;top:-18px;left:-18px;right:18px;bottom:18px;background:var(--navy-lt);border-radius:16px;z-index:0}
.about-photo-wrap::after{content:'';position:absolute;bottom:-18px;right:-18px;width:90px;height:90px;background:var(--red);border-radius:14px;z-index:0}
.about-photo{width:100%;border-radius:12px;display:block;position:relative;z-index:1;object-fit:cover;aspect-ratio:3/4}
.about-badge{position:absolute;bottom:28px;left:-24px;background:#fff;border-radius:10px;padding:12px 16px;box-shadow:0 8px 32px rgba(0,0,0,.13);display:flex;align-items:center;gap:10px;z-index:2;white-space:nowrap}
.about-badge-icon{width:38px;height:38px;background:var(--navy);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.about-badge-icon svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.about-badge strong{display:block;font-size:13px;font-weight:600;color:var(--navy)}
.about-badge small{font-size:11px;color:var(--gray)}
.about-content .section-title{margin-bottom:1.5rem}
.about-content p{font-size:16px;color:var(--gray);line-height:1.85;margin-bottom:1rem}
.about-creds{display:flex;flex-direction:column;gap:10px;margin-top:2rem;margin-bottom:2.5rem}
.cred{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--gray-lt);border-radius:8px;border-left:3px solid var(--navy)}
.cred-icon{width:36px;height:36px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.cred-icon svg{width:22px;height:22px;stroke:var(--navy);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.cred strong{display:block;font-size:13px;font-weight:600;color:var(--navy)}
.cred small{font-size:11px;color:var(--gray)}

/* HOW */
.how{padding:7rem 2rem;background:var(--navy);position:relative;overflow:hidden}
.how::before{content:'';position:absolute;top:-120px;right:-120px;width:500px;height:500px;border-radius:50%;background:rgba(255,255,255,.03)}
.how-header{max-width:1100px;margin:0 auto 4rem;text-align:center}
.how-header .section-label{color:#FF7A5C}
.how-header .section-title{color:#fff}
.how-steps{max-width:860px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative}
.how-steps::before{content:'';position:absolute;top:36px;left:calc(16.666% + 36px);right:calc(16.666% + 36px);height:1px;background:rgba(255,255,255,.15)}
.how-step{text-align:center;position:relative}
.how-step-num{width:72px;height:72px;border-radius:50%;background:var(--red);color:#fff;font-family:'Playfair Display',serif;font-size:28px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;position:relative;z-index:1;box-shadow:0 4px 20px rgba(200,16,46,.4)}
.how-step h3{font-size:17px;font-weight:600;color:#fff;margin-bottom:.75rem}
.how-step p{font-size:14px;color:rgba(255,255,255,.6);line-height:1.65}
.how-cta-wrap{text-align:center;margin-top:3.5rem;position:relative;z-index:1}

/* SERVICES */
.services{padding:7rem 2rem;background:var(--gray-lt)}
.services-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem}
.service-card{background:#fff;border-radius:12px;padding:2rem;border:1px solid var(--border);transition:all .2s}
.service-card:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:0 12px 40px rgba(27,45,114,.1)}
.svc-icon{width:50px;height:50px;background:var(--navy-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.svc-icon svg{width:26px;height:26px;stroke:var(--navy);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.service-card h3{font-size:17px;font-weight:600;margin-bottom:.5rem;color:var(--navy)}
.service-card p{font-size:14px;color:var(--gray);line-height:1.65}
.service-link{display:inline-flex;align-items:center;gap:5px;margin-top:1rem;font-size:13px;font-weight:500;color:var(--red);text-decoration:none}
.service-link:hover{text-decoration:underline}

/* RESPALDO */
.respaldo{padding:5rem 2rem;background:var(--white)}
.respaldo-inner{max-width:800px;margin:0 auto;text-align:center}
.respaldo-inner p{font-size:16px;color:var(--gray);line-height:1.85;margin-top:1.5rem}

/* TESTIMONIALS */
.testimonials{padding:7rem 2rem;background:var(--gray-lt)}
.testimonials-header{max-width:1100px;margin:0 auto 3rem;text-align:center}
.testimonials-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.t-card{background:#fff;border-radius:12px;padding:2rem;border:1px solid var(--border)}
.stars{display:flex;gap:3px;margin-bottom:1rem}
.stars span{color:#F5A623;font-size:16px}
.t-card blockquote{font-size:15px;color:var(--black);line-height:1.75;font-style:italic;margin-bottom:1.5rem;quotes:none}
.t-author{display:flex;align-items:center;gap:12px}
.t-avatar{width:42px;height:42px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}
.t-author strong{display:block;font-size:14px;font-weight:600;color:var(--navy)}
.t-author small{font-size:12px;color:var(--gray)}
.google-note{text-align:center;margin-top:2.5rem;font-size:13px;color:var(--gray);display:flex;align-items:center;justify-content:center;gap:6px}

/* WHY */
.why{padding:7rem 2rem;background:var(--white)}
.why-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.why-list{list-style:none;display:flex;flex-direction:column;gap:1.75rem;margin-top:2rem}
.why-item{display:flex;gap:1rem;align-items:flex-start}
.why-num{width:34px;height:34px;background:var(--navy);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0;margin-top:1px}
.why-item strong{display:block;font-size:15px;font-weight:600;margin-bottom:3px;color:var(--navy)}
.why-item span{font-size:14px;color:var(--gray);line-height:1.65}
.why-visual{background:var(--navy);border-radius:16px;padding:2.75rem;color:#fff;position:relative;overflow:hidden}
.why-visual::before{content:'';position:absolute;top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.05)}
.why-visual h3{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;margin-bottom:1rem;position:relative;z-index:1}
.why-visual p{font-size:15px;opacity:.78;line-height:1.75;margin-bottom:2rem;position:relative;z-index:1}
.why-visual .btn-wa-sm{position:relative;z-index:1}

/* FAQ */
.faq{padding:7rem 2rem;background:var(--gray-lt)}
.faq-inner{max-width:780px;margin:0 auto}
.faq-header{margin-bottom:3rem}
.faq-item{background:#fff;border-radius:10px;border:1px solid var(--border);margin-bottom:.75rem;overflow:hidden}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:1.25rem 1.5rem;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .15s}
.faq-q:hover{background:var(--gray-lt)}
.faq-icon{width:26px;height:26px;border-radius:50%;background:var(--navy-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .25s,background .15s;font-size:17px;color:var(--navy);font-weight:700;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--navy);color:#fff}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-answer-inner{padding:0 1.5rem 1.25rem;font-size:14px;color:var(--gray);line-height:1.8}

/* CTA BAND */
.cta-band{padding:5.5rem 2rem;background:var(--red);text-align:center}
.cta-band h2{font-family:'Playfair Display',serif;font-size:clamp(26px,3vw,42px);color:#fff;font-weight:700;margin-bottom:.75rem}
.cta-band p{color:rgba(255,255,255,.78);font-size:17px;margin-bottom:2rem}
.cta-band-btn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--navy);text-decoration:none;padding:17px 34px;border-radius:8px;font-size:17px;font-weight:600;transition:all .2s;box-shadow:0 4px 20px rgba(0,0,0,.15)}
.cta-band-btn:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.2)}
.cta-band-btn svg{width:22px;height:22px;fill:#25D366}

/* FOOTER */
footer{background:var(--navy-dk);padding:3.5rem 2rem 2rem;color:rgba(255,255,255,.55)}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
.footer-logo img{height:52px;width:auto;margin-bottom:1rem;filter:brightness(0) invert(1);opacity:.8}
.footer-logo p{font-size:13px;line-height:1.7}
.footer-col h4{font-size:12px;font-weight:600;color:#fff;margin-bottom:1rem;letter-spacing:1px;text-transform:uppercase}
.footer-col p,.footer-col a{font-size:13px;color:rgba(255,255,255,.5);text-decoration:none;display:block;margin-bottom:.4rem;line-height:1.65}
.footer-col a:hover{color:#fff}
.footer-bottom{max-width:1100px;margin:0 auto;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);font-size:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}

/* FLOATING WA */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:200;background:var(--red);width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(200,16,46,.4);transition:transform .2s;animation:pulse 2.5s infinite}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:28px;height:28px;fill:#fff}
@keyframes pulse{0%,100%{box-shadow:0 4px 20px rgba(200,16,46,.4)}50%{box-shadow:0 4px 36px rgba(200,16,46,.7)}}

/* RESPONSIVE */
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .about-photo-wrap{max-width:320px;margin:0 auto}
  .why-grid{grid-template-columns:1fr;gap:3rem}
  .how-steps{grid-template-columns:1fr;gap:2.5rem}
  .how-steps::before{display:none}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:768px){
  nav{padding:0 1rem;height:70px}
  .nav-logo img{height:50px}
  .hero{padding-top:70px}
  .nav-cta span{display:none}
  .hero-bg-img{object-position:center top}
  .hero-stats{gap:2rem}
  .about,.how,.services,.respaldo,.testimonials,.why,.faq{padding:4.5rem 1.25rem}
  .about-badge{left:-10px}
  .footer-bottom{flex-direction:column;text-align:center}
}
.footer-legal{margin-top:1.25rem;font-size:11px;line-height:1.7;color:rgba(255,255,255,.35)}
.footer-legal-links{max-width:1100px;margin:.75rem auto 0;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.08);text-align:center;font-size:11px}
.footer-legal-links a{color:rgba(255,255,255,.4);text-decoration:none;transition:color .15s}
.footer-legal-links a:hover{color:rgba(255,255,255,.8)}
.footer-sep{margin:0 .5rem;color:rgba(255,255,255,.2)}

/* CONTACTO Y UBICACIÓN */
.contact-section{padding:5rem 2rem;background:var(--gray-lt)}
.contact-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start}
.contact-info .section-title{margin-bottom:2rem}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:1.25rem}
.contact-list li{display:flex;align-items:flex-start;gap:.9rem;font-size:15px;color:var(--black)}
.contact-list svg{flex-shrink:0;margin-top:2px;color:var(--navy)}
.contact-list a{color:var(--navy);text-decoration:none;font-weight:500}
.contact-list a:hover{text-decoration:underline}
.contact-map{display:flex;flex-direction:column;gap:.75rem}
.map-link{display:inline-flex;align-items:center;gap:.4rem;font-size:13px;color:var(--gray);text-decoration:none}
.map-link:hover{color:var(--navy)}
.map-link svg{flex-shrink:0}
@media(max-width:900px){
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
}
