/* ═══════════════════════════════════════════
   GRUPO GESE – Estilos compartidos (páginas de servicio)
   ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --coal:    #0a0e17;
  --coal2:   #111827;
  --coal3:   #1c2535;
  --steel:   #243046;
  --blue:    #1d6fc7;
  --blue2:   #2484e8;
  --blue-lt: #4fa3f7;
  --blue-dim:rgba(29,111,199,0.15);
  --blue-brd:rgba(29,111,199,0.30);
  --yellow:  #ffffff;
  --yellow2: #d4e4ff;
  --yellow-dim:rgba(255,255,255,0.08);
  --yellow-brd:rgba(255,255,255,0.20);
  --bg:      #f2f5fa;
  --bg2:     #e6ecf5;
  --white:   #ffffff;
  --ink:     #0a0e17;
  --ink2:    #1c2d44;
  --mist:    #637796;
  --border:  rgba(29,111,199,0.13);
  --sh:      0 2px 20px rgba(10,14,23,0.08);
  --sh-md:   0 6px 40px rgba(10,14,23,0.13);
  --sh-bl:   0 8px 40px rgba(29,111,199,0.25);
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--coal2)}
::-webkit-scrollbar-thumb{background:var(--blue-brd);border-radius:2px}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 5vw;transition:background .35s,border-color .35s;border-bottom:1px solid transparent}
nav.scrolled{background:rgba(10,14,23,.97);border-color:rgba(255,255,255,.06);backdrop-filter:blur(16px)}
nav.breadcrumb,nav.footer-links{position:static!important;top:auto!important;left:auto!important;right:auto!important;width:auto!important;height:auto!important;background:transparent!important;border:none!important;z-index:auto!important;backdrop-filter:none!important;padding:0!important;transition:none!important}
.nav-logo img{height:36px;width:auto}
.nav-links{position:absolute;left:50%;transform:translateX(-50%);display:flex;gap:1.8rem}
.nav-links a{font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);transition:color .2s;white-space:nowrap;position:relative}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1.5px;background:var(--yellow);transition:width .25s}
.nav-links a:hover{color:#fff}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:#fff}
.btn-nav-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--yellow);color:var(--coal);padding:.5rem 1.4rem;font-family:'Oswald',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;transition:background .25s,color .25s,box-shadow .25s;box-shadow:none;border:2px solid var(--yellow)}
.btn-nav-cta:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 4px 20px rgba(29,111,199,.4)}
.ham{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:.5rem;z-index:600}
.ham span{display:block;width:24px;height:2px;background:#fff;transition:transform .3s,opacity .3s}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-overlay{position:fixed;inset:0;background:var(--coal);z-index:490;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .35s}
.nav-overlay.open{opacity:1;pointer-events:all}
.nav-overlay a{font-family:'Oswald',sans-serif;font-size:1.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6);transition:color .2s}
.nav-overlay a:hover{color:var(--yellow)}
.nav-overlay .btn-nav-cta{font-size:.9rem;padding:.7rem 2.4rem;margin-top:1rem}

/* ── HERO SERVICIO ── */
.srv-hero{background:var(--coal);padding:calc(68px + 6vh) 6vw 6vh;display:grid;grid-template-columns:60% 40%;align-items:center;gap:4vw;min-height:70vh;position:relative;overflow:hidden}
.srv-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:50px 50px;pointer-events:none}
.srv-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(29,111,199,.07),transparent 60%),radial-gradient(ellipse at 90% 80%,rgba(255,255,255,.04),transparent 50%);pointer-events:none}
.shp-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1);transition:transform 12s ease;will-change:transform}
.shp-bg.loaded{transform:scale(1.04)}
.shp-overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(10,14,23,.88) 35%,rgba(10,14,23,.55) 60%,rgba(10,14,23,.18) 100%)}
.srv-hero--photo .shv-icon{display:none}
.srv-hero--photo .shv-stats{margin-top:auto}
.srv-hero-content{position:relative;z-index:2}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-family:'Roboto Mono',monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1.8rem}
.breadcrumb a{color:rgba(255,255,255,.3);transition:color .2s}
.breadcrumb a:hover{color:var(--yellow)}
.breadcrumb span{color:rgba(255,255,255,.15)}
.sh-label{display:flex;align-items:center;gap:.6rem;margin-bottom:1.2rem}
.sh-bar{width:22px;height:1.5px;background:var(--yellow)}
.sh-tag{font-family:'Roboto Mono',monospace;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--yellow)}
.srv-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(2.2rem,4vw,4rem);font-weight:700;line-height:1;text-transform:uppercase;color:#fff;letter-spacing:-.01em}
.sh-hl{color:var(--yellow)}
.sh-sub{font-size:.9rem;font-weight:300;line-height:1.9;color:rgba(255,255,255,.5);max-width:520px;margin:1.4rem 0 2.2rem}
.sh-btns{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:.55rem;background:var(--blue);color:#fff;padding:.9rem 2.2rem;font-family:'Oswald',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:background .25s,color .25s,border-color .25s,transform .2s,box-shadow .25s;box-shadow:var(--sh-bl);border:2px solid var(--blue)}
.btn-primary:hover{background:transparent;color:var(--blue);border-color:var(--blue);transform:translateY(-2px);box-shadow:none}
.btn-ghost{display:inline-flex;align-items:center;gap:.45rem;color:rgba(255,255,255,.45);font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;transition:color .2s;border-bottom:1px solid rgba(255,255,255,.15);padding-bottom:.1rem}
.btn-ghost:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.srv-hero-visual{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:2rem}
.shv-icon{width:140px;height:140px;background:rgba(29,111,199,.1);border:1px solid var(--blue-brd);display:flex;align-items:center;justify-content:center}
.shv-stats{display:flex;flex-direction:column;gap:.8rem;width:100%}
.shv-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);padding:.9rem 1.2rem;display:flex;align-items:center;justify-content:space-between}
.shv-num{font-family:'Oswald',sans-serif;font-size:1.3rem;font-weight:700;color:var(--yellow);letter-spacing:-.01em}
.shv-label{font-family:'Roboto Mono',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35)}

/* ── CUERPO SERVICIO ── */
.srv-body{background:var(--bg);padding:8vh 6vw}
.srv-body-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:6vh}
.srv-article h2{font-family:'Oswald',sans-serif;font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:700;text-transform:uppercase;letter-spacing:-.01em;color:var(--ink);margin-bottom:1.2rem}
.srv-article p{font-size:.9rem;font-weight:300;line-height:1.95;color:var(--mist);margin-bottom:.9rem}
.srv-article p strong{color:var(--ink2);font-weight:500}

/* ── GRID DE SERVICIOS ── */
.srv-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.sd-card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--border);padding:2rem 1.8rem;display:flex;flex-direction:column;gap:.8rem;transition:border-top-color .3s,box-shadow .3s,transform .3s;box-shadow:var(--sh)}
.sd-card:hover{border-top-color:var(--blue);transform:translateY(-3px);box-shadow:var(--sh-md)}
.sd-card-highlight{border-top-color:var(--yellow)!important}
.sd-card-highlight:hover{box-shadow:0 8px 40px rgba(255,255,255,.08)}
.sd-icon{width:44px;height:44px;background:var(--blue-dim);border:1px solid var(--blue-brd);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue)}
.sd-card h3{font-family:'Oswald',sans-serif;font-size:1rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}
.sd-card p{font-size:.84rem;font-weight:300;line-height:1.85;color:var(--mist);flex:1}
.sd-list{list-style:none;display:flex;flex-direction:column;gap:.3rem;margin-top:.4rem}
.sd-list li{font-size:.78rem;color:var(--mist);display:flex;align-items:flex-start;gap:.5rem;line-height:1.5}
.sd-list li::before{content:'';width:5px;height:5px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:.38rem}

/* ── FAQ SERVICIO ── */
.srv-faq{background:var(--bg2);padding:4vh 3vw;border:1px solid var(--border)}
.srv-faq h2{font-family:'Oswald',sans-serif;font-size:clamp(1.4rem,2.2vw,1.9rem);font-weight:700;text-transform:uppercase;color:var(--ink);margin-bottom:2.5vh}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:1.3rem 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;font-family:'Inter',sans-serif;font-size:.93rem;font-weight:500;color:var(--ink2);cursor:pointer;transition:color .2s}
.faq-q:hover{color:var(--blue)}
.faq-chevron{font-size:1.1rem;color:var(--blue);flex-shrink:0;transition:transform .3s;display:inline-block}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-ans{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s}
.faq-ans p{font-size:.86rem;font-weight:300;line-height:1.95;color:var(--mist);padding-bottom:1.2rem}
.faq-item.open .faq-ans{max-height:300px}

/* ── CTA FINAL ── */
.srv-cta{background:var(--coal);padding:4vh 4vw;position:relative;overflow:hidden}
.srv-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(29,111,199,.1),transparent);pointer-events:none}
.srv-cta-inner{position:relative;z-index:1;text-align:center;max-width:700px;margin:0 auto}
.srv-cta h2{font-family:'Oswald',sans-serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:700;text-transform:uppercase;color:#fff;margin-bottom:.8rem}
.srv-cta p{font-size:.9rem;font-weight:300;color:rgba(255,255,255,.45);line-height:1.8;margin-bottom:2rem}
.srv-cta-btns{display:flex;align-items:center;justify-content:center;gap:1.2rem;flex-wrap:wrap}
.btn-ghost-lt{display:inline-flex;align-items:center;gap:.45rem;color:rgba(255,255,255,.5);font-family:'Oswald',sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;transition:color .2s;border:1px solid rgba(255,255,255,.15);padding:.85rem 1.6rem}
.btn-ghost-lt:hover{color:#fff;border-color:rgba(255,255,255,.35)}

/* ── FOOTER ── */
footer{background:var(--coal2);border-top:1px solid rgba(255,255,255,.04);padding:2rem 6vw;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem}
.footer-logo img{height:28px;filter:brightness(0) invert(1);opacity:.4}
.footer-copy{text-align:center;font-size:.68rem;color:rgba(255,255,255,.2);letter-spacing:.08em}
.footer-links{display:flex;justify-content:flex-end;gap:2rem}
.footer-links a{font-family:'Roboto Mono',monospace;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.25);transition:color .2s}
.footer-links a:hover{color:rgba(255,255,255,.6)}

/* ── REVEAL ── */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
.rv-l{opacity:0;transform:translateX(-22px);transition:opacity .7s ease,transform .7s ease}
.rv-l.in{opacity:1;transform:none}
.rv-r{opacity:0;transform:translateX(22px);transition:opacity .7s ease,transform .7s ease}
.rv-r.in{opacity:1;transform:none}
.rv-d1{transition-delay:.1s}.rv-d2{transition-delay:.2s}.rv-d3{transition-delay:.3s}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.srv-detail-grid{grid-template-columns:1fr 1fr}}
@media(max-width:1024px){
  .srv-hero{grid-template-columns:1fr}
  .srv-hero-visual{display:none}
  .nav-links,.btn-nav-cta{display:none}
  .ham{display:flex}
  footer{grid-template-columns:1fr;text-align:center}
  .footer-links{justify-content:center}
}
@media(max-width:768px){
  .srv-detail-grid{grid-template-columns:1fr}
  .srv-body{padding:6vh 5vw}
}
@media(max-width:480px){
  .srv-hero{padding:calc(68px + 3vh) 5vw 5vh;min-height:60vh}
  .srv-hero h1{font-size:1.8rem}
  .sh-sub{font-size:.83rem}
  .srv-cta h2{font-size:1.4rem}
  footer{padding:1.5rem 5vw}
  .nav-overlay a{font-size:1.4rem}
}

/* ── PERFORMANCE ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rv,.rv-l,.rv-r{opacity:1!important;transform:none!important}
}
