
:root{
  --black:#030303;
  --black2:#080808;
  --card:#111;
  --card2:#151515;
  --line:rgba(255,255,255,.12);
  --text:#dce4e6;
  --muted:#aeb8bb;
  --white:#fff;
  --turq:#36aebf;
  --turq2:#237f8d;
  --silver:#d9e2e4;
}
*{box-sizing:border-box;margin:0;padding:0;scroll-behavior:smooth}
body{font-family:Inter,Arial,sans-serif;background:var(--black);color:var(--text);line-height:1.72}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:90%;max-width:1220px;margin:0 auto}
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:rgba(0,0,0,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-wrap{display:flex;justify-content:space-between;align-items:center;padding:13px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:54px;height:54px;object-fit:contain;border-radius:50%}
.brand span{font-family:"Cormorant Garamond",serif;font-weight:700;font-size:2rem;color:var(--white);letter-spacing:2px}
.nav-menu{display:flex;align-items:center;gap:22px;font-size:.92rem}
.nav-menu a{color:#edf4f5;opacity:.92;transition:.25s}
.nav-menu a:hover{color:var(--turq);opacity:1}
.menu-toggle{display:none;background:transparent;color:white;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:1.2rem}
.btn{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--turq),var(--turq2));color:white!important;padding:13px 24px;border-radius:10px;font-weight:700;box-shadow:0 14px 35px rgba(54,174,191,.22);transition:.25s;border:0;cursor:pointer}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 45px rgba(54,174,191,.32)}
.btn-small{padding:10px 17px;font-size:.88rem}
.btn-outline{background:transparent;border:1px solid rgba(255,255,255,.25);box-shadow:none}
.btn-outline:hover{border-color:var(--turq)}
.hero{min-height:100vh;display:flex;align-items:center;padding:128px 0 80px;background:radial-gradient(circle at 15% 20%,rgba(54,174,191,.18),transparent 30%),radial-gradient(circle at 85% 80%,rgba(255,255,255,.07),transparent 25%),linear-gradient(135deg,#020202,#0d0d0d)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center}
.hero h1,.page-hero h1,h2,h3{font-family:"Cormorant Garamond",serif;color:var(--white);line-height:1.06}
.hero h1{font-size:5rem;margin-bottom:25px}
.hero h1 span,.accent{color:var(--turq)}
.hero p{font-size:1.08rem;color:#d4dee0;max-width:720px;margin-bottom:32px}
.eyebrow{color:var(--turq);text-transform:uppercase;letter-spacing:3px;font-size:.78rem;font-weight:800;margin-bottom:15px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
.hero-panel{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:0 25px 60px rgba(0,0,0,.45)}
.hero-panel img{border-radius:22px}
.logo-panel img{width:310px;margin:0 auto 22px}
.logo-panel{text-align:center}
.logo-panel h3{font-size:2rem;margin-bottom:12px}
section{padding:94px 0}
.page-hero{padding:150px 0 80px;background:radial-gradient(circle at 15% 20%,rgba(54,174,191,.14),transparent 32%),#070707;border-bottom:1px solid var(--line)}
.page-hero h1{font-size:4.2rem;margin-bottom:18px}
.page-hero p{max-width:820px;color:#c9d3d5}
.section-head{text-align:center;margin-bottom:54px}
.section-head h2{font-size:3.45rem;margin-bottom:15px}
.section-head p{max-width:840px;margin:auto;color:#bfcbce}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:32px;transition:.28s;position:relative;overflow:hidden}
.card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--turq),transparent)}
.card:hover{transform:translateY(-6px);border-color:rgba(54,174,191,.45)}
.card h3{font-size:1.72rem;margin-bottom:15px}
.card p,.card li{color:#cbd4d6;font-size:.96rem}
.card ul{padding-left:18px;display:flex;flex-direction:column;gap:8px}
.dark-section{background:#080808}
.split{display:grid;grid-template-columns:.95fr 1.05fr;gap:48px;align-items:center}
.image-card{padding:0;overflow:hidden}
.image-card img{width:100%;height:100%;object-fit:cover}
.quote-box{border-left:4px solid var(--turq);padding-left:24px}
.quote-box h2{font-size:3.2rem;margin-bottom:18px}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stat{background:#0e0e0e;border:1px solid var(--line);border-radius:20px;padding:28px 18px}
.stat strong{display:block;color:var(--turq);font-size:2.2rem;margin-bottom:7px}
.service-number{font-size:.78rem;color:var(--turq);font-weight:800;letter-spacing:2px;margin-bottom:12px}
.team-card{padding:0;overflow:hidden}
.team-card img{width:100%;height:420px;object-fit:cover;object-position:center top}
.team-card .team-body{padding:30px}
.role{color:var(--turq);font-weight:700;margin-bottom:12px}
.badges{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}
.badge{border:1px solid rgba(54,174,191,.35);color:#dff6fa;border-radius:999px;padding:6px 10px;font-size:.78rem}
.blog-card a{color:var(--turq);font-weight:700;margin-top:14px;display:inline-block}
.cta{background:radial-gradient(circle at center,rgba(54,174,191,.16),transparent 38%),#070707;text-align:center}
.cta h2{font-size:3.4rem;margin-bottom:17px}
.cta p{max-width:760px;margin:0 auto 28px;color:#cbd3d5}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px}
form{display:grid;gap:14px}
input,textarea,select{width:100%;background:#151515;border:1px solid var(--line);border-radius:12px;padding:14px;color:white;font-family:Inter,sans-serif}
textarea{min-height:140px;resize:vertical}
.map-wrap{padding:0;overflow:hidden}
.map-wrap iframe{width:100%;height:430px;border:0;display:block}
.footer{background:#010101;border-top:1px solid var(--line);padding:54px 0 0;color:#b9c2c5}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.4fr 1fr;gap:28px}
.footer h4{color:white;margin-bottom:13px}
.footer a{display:block;color:#b9c2c5;margin-bottom:8px}
.footer a:hover{color:var(--turq)}
.footer-logo{width:120px;margin-bottom:14px}
.footer-bottom{text-align:center;border-top:1px solid var(--line);margin-top:34px;padding:18px;color:#8d9699;font-size:.9rem}
.whatsapp-float{position:fixed;right:22px;bottom:22px;z-index:1000;background:#25D366;color:white;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:29px;box-shadow:0 14px 35px rgba(0,0,0,.45)}
.notice{background:rgba(54,174,191,.08);border:1px solid rgba(54,174,191,.22);border-radius:18px;padding:22px;color:#dceff2}
@media(max-width:1000px){
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr}
  .grid-3,.grid-4,.stat-grid,.footer-grid{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:4rem}
  .nav-menu{position:absolute;top:82px;left:0;right:0;background:#050505;display:none;flex-direction:column;padding:20px;border-bottom:1px solid var(--line)}
  .nav-menu.active{display:flex}
  .menu-toggle{display:block}
}
@media(max-width:650px){
  .hero h1,.page-hero h1{font-size:3.05rem}
  .section-head h2,.cta h2{font-size:2.45rem}
  .grid-2,.grid-3,.grid-4,.stat-grid,.footer-grid{grid-template-columns:1fr}
  .brand span{font-size:1.5rem}
  .brand img{width:46px;height:46px}
  section{padding:72px 0}
}


/* =========================
   ANIMACIONES PREMIUM
   ========================= */

html {
  scroll-padding-top: 90px;
}

body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at var(--mx, 20%) var(--my, 20%), rgba(54,174,191,.10), transparent 28%),
    radial-gradient(circle at 80% 80%, rgba(255,255,255,.035), transparent 24%);
  transition: background .25s ease;
}

.preloader{
  position:fixed;
  inset:0;
  z-index:9999;
  background:#020202;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity .65s ease, visibility .65s ease;
}

.preloader.loaded{
  opacity:0;
  visibility:hidden;
}

.preloader-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:18px;
}

.preloader-inner img{
  width:130px;
  height:130px;
  object-fit:contain;
  animation: logoPulse 1.6s ease-in-out infinite;
}

.preloader-line{
  width:160px;
  height:2px;
  background:rgba(255,255,255,.12);
  overflow:hidden;
  border-radius:999px;
}

.preloader-line::after{
  content:"";
  display:block;
  width:45%;
  height:100%;
  background:linear-gradient(90deg, transparent, var(--turq), transparent);
  animation: lineMove 1.25s ease-in-out infinite;
}

@keyframes logoPulse{
  0%,100%{transform:scale(1);filter:drop-shadow(0 0 0 rgba(54,174,191,0));}
  50%{transform:scale(1.045);filter:drop-shadow(0 0 22px rgba(54,174,191,.42));}
}

@keyframes lineMove{
  from{transform:translateX(-120%);}
  to{transform:translateX(260%);}
}

.site-header{
  transition:background .3s ease, padding .3s ease, box-shadow .3s ease;
}

.site-header.scrolled{
  background:rgba(0,0,0,.95);
  box-shadow:0 18px 45px rgba(0,0,0,.35);
}

.brand img{
  transition:transform .35s ease, filter .35s ease;
}

.brand:hover img{
  transform:rotate(-4deg) scale(1.08);
  filter:drop-shadow(0 0 14px rgba(54,174,191,.35));
}

.nav-menu a{
  position:relative;
}

.nav-menu a:not(.btn)::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:0;
  height:2px;
  background:var(--turq);
  transition:width .28s ease;
}

.nav-menu a:not(.btn):hover::after,
.nav-menu a.active::after{
  width:100%;
}

.hero{
  position:relative;
  overflow:hidden;
}

.hero::before{
  content:"";
  position:absolute;
  inset:-30%;
  background:
    linear-gradient(115deg, transparent 20%, rgba(255,255,255,.05) 42%, transparent 62%);
  transform:translateX(-30%) rotate(8deg);
  animation: heroShine 8s ease-in-out infinite;
  pointer-events:none;
}

.hero::after{
  content:"";
  position:absolute;
  width:580px;
  height:580px;
  right:-260px;
  top:120px;
  border:1px solid rgba(54,174,191,.14);
  border-radius:50%;
  animation: orbitFloat 16s linear infinite;
  pointer-events:none;
}

@keyframes heroShine{
  0%,100%{transform:translateX(-45%) rotate(8deg);opacity:.25;}
  50%{transform:translateX(45%) rotate(8deg);opacity:.55;}
}

@keyframes orbitFloat{
  from{transform:rotate(0deg);}
  to{transform:rotate(360deg);}
}

.hero h1,
.page-hero h1{
  animation:titleEntrance .9s cubic-bezier(.2,.7,.2,1) both;
}

.hero p,
.page-hero p{
  animation:fadeUp .9s cubic-bezier(.2,.7,.2,1) .18s both;
}

.hero-actions{
  animation:fadeUp .9s cubic-bezier(.2,.7,.2,1) .34s both;
}

.hero-panel{
  animation:panelEntrance 1s cubic-bezier(.2,.7,.2,1) .22s both;
  transform-style:preserve-3d;
}

.hero-panel img,
.image-card img,
.team-card img{
  transition:transform .55s ease, filter .55s ease;
}

.hero-panel:hover img,
.image-card:hover img,
.team-card:hover img{
  transform:scale(1.045);
  filter:contrast(1.04) saturate(1.05);
}

@keyframes titleEntrance{
  from{opacity:0;transform:translateY(26px) scale(.985);}
  to{opacity:1;transform:translateY(0) scale(1);}
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(24px);}
  to{opacity:1;transform:translateY(0);}
}

@keyframes panelEntrance{
  from{opacity:0;transform:translateY(28px) rotateX(7deg) rotateY(-7deg);}
  to{opacity:1;transform:translateY(0) rotateX(0) rotateY(0);}
}

.reveal{
  opacity:0;
  transform:translateY(34px);
  transition:opacity .75s ease, transform .75s ease;
}

.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

.card{
  will-change:transform;
}

.card:hover{
  box-shadow:0 22px 55px rgba(0,0,0,.35), 0 0 0 1px rgba(54,174,191,.12) inset;
}

.card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(54,174,191,.08), transparent 36%);
  opacity:0;
  transition:opacity .35s ease;
  pointer-events:none;
}

.card:hover::after{
  opacity:1;
}

.btn{
  position:relative;
  overflow:hidden;
}

.btn::before{
  content:"";
  position:absolute;
  top:0;
  left:-80%;
  width:60%;
  height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.28), transparent);
  transform:skewX(-20deg);
  transition:left .65s ease;
}

.btn:hover::before{
  left:130%;
}

.service-number{
  transition:letter-spacing .3s ease, color .3s ease;
}

.card:hover .service-number{
  letter-spacing:4px;
  color:#66d6e4;
}

.badge{
  transition:transform .25s ease, background .25s ease, border-color .25s ease;
}

.badge:hover{
  transform:translateY(-2px);
  background:rgba(54,174,191,.12);
  border-color:rgba(54,174,191,.65);
}

.whatsapp-float{
  animation:whatsappPulse 2.6s ease-in-out infinite;
}

@keyframes whatsappPulse{
  0%,100%{transform:scale(1);box-shadow:0 14px 35px rgba(0,0,0,.45);}
  50%{transform:scale(1.08);box-shadow:0 18px 45px rgba(37,211,102,.34);}
}

.map-wrap iframe{
  filter:grayscale(.25) contrast(1.02);
  transition:filter .4s ease;
}

.map-wrap:hover iframe{
  filter:grayscale(0) contrast(1.06);
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation:none!important;
    transition:none!important;
    scroll-behavior:auto!important;
  }

  .reveal{
    opacity:1!important;
    transform:none!important;
  }

  .preloader{
    display:none!important;
  }
}


/* =========================
   BOTONES E ICONOS SOCIALES
   ========================= */

.icon{
  width:19px;
  height:19px;
  display:inline-block;
  flex:0 0 auto;
  vertical-align:middle;
}

.icon-btn,
.social-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.btn-whatsapp{
  background:linear-gradient(135deg,#25D366,#128C7E);
}

.btn-linkedin{
  background:linear-gradient(135deg,#0A66C2,#004182);
}

.btn-facebook{
  background:linear-gradient(135deg,#1877F2,#0b4ea2);
}

.social-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:18px;
}

.social-buttons .btn{
  padding:12px 18px;
}

.social-strip{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.social-strip a{
  width:44px;
  height:44px;
  border-radius:50%;
  background:#111;
  border:1px solid var(--line);
  color:white;
  transition:transform .25s ease, border-color .25s ease, background .25s ease;
}

.social-strip a:hover{
  transform:translateY(-3px);
  border-color:rgba(54,174,191,.55);
}

.social-strip a.linkedin:hover{
  background:#0A66C2;
}

.social-strip a.facebook:hover{
  background:#1877F2;
}

.social-strip a.whatsapp-icon:hover{
  background:#25D366;
}

.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
}

.footer-socials{
  display:flex;
  gap:10px;
  margin-top:12px;
}

.footer-socials a{
  width:40px;
  height:40px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#111;
  border:1px solid var(--line);
  margin-bottom:0;
  transition:transform .25s ease, background .25s ease, border-color .25s ease;
}

.footer-socials a:hover{
  transform:translateY(-3px);
  border-color:rgba(54,174,191,.55);
}

.footer-socials a.linkedin:hover{background:#0A66C2;color:white;}
.footer-socials a.facebook:hover{background:#1877F2;color:white;}
.footer-socials a.whatsapp-icon:hover{background:#25D366;color:white;}

.whatsapp-float{
  background:#25D366!important;
}

.whatsapp-float svg{
  width:30px;
  height:30px;
}

@media(max-width:650px){
  .social-buttons .btn,
  .contact-actions .btn{
    width:100%;
  }

  .social-strip{
    justify-content:flex-start;
  }
}


/* =========================================================
   SECCIÓN 01 PREMIUM: HEADER + HERO
   Optimización UX/UI, CLS, microinteracciones y responsive.
   ========================================================= */

.site-header{
  position:sticky;
  top:0;
  width:100%;
  z-index:1000;
  background:rgba(3,3,3,.82);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(255,255,255,.10);
  transition:background .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.site-header.scrolled{
  background:rgba(3,3,3,.94);
  box-shadow:0 18px 50px rgba(0,0,0,.34);
  border-bottom-color:rgba(54,174,191,.20);
}

.nav-shell{
  min-height:82px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
  transition:min-height .28s ease;
}

.site-header.scrolled .nav-shell{
  min-height:70px;
}

.brand{
  min-width:220px;
  display:flex;
  align-items:center;
  gap:12px;
}

.brand img{
  width:54px;
  height:54px;
  object-fit:contain;
  border-radius:50%;
}

.brand-copy{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}

.brand-copy strong{
  font-family:"Cormorant Garamond",serif;
  color:#fff;
  font-size:1.95rem;
  letter-spacing:2px;
}

.brand-copy small{
  color:#aeb8bb;
  font-size:.72rem;
  letter-spacing:.6px;
  margin-top:2px;
}

.nav-menu{
  justify-content:center;
}

.nav-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
}

.nav-social{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.13);
  color:#fff;
  background:rgba(255,255,255,.035);
  transition:transform .24s ease, background .24s ease, border-color .24s ease;
}

.nav-social .icon{
  width:20px;
  height:20px;
}

.nav-social:hover{
  transform:translateY(-3px);
  border-color:rgba(54,174,191,.55);
}

.nav-social.linkedin:hover{background:#0A66C2;}
.nav-social.facebook:hover{background:#1877F2;}

.menu-toggle{
  width:46px;
  height:46px;
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:12px;
  background:rgba(255,255,255,.04);
  cursor:pointer;
}

.menu-toggle span{
  width:20px;
  height:2px;
  background:#fff;
  border-radius:999px;
  transition:transform .24s ease, opacity .24s ease;
}

.menu-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle.is-open span:nth-child(2){opacity:0;}
.menu-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.hero-premium{
  min-height:calc(100vh - 0px);
  padding:116px 0 86px;
  display:flex;
  align-items:center;
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 22%, rgba(54,174,191,.18), transparent 32%),
    radial-gradient(circle at 78% 72%, rgba(217,226,228,.08), transparent 28%),
    linear-gradient(135deg,#020202 0%,#080b0c 52%,#0f1112 100%);
}

.hero-premium::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.026) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 82%);
}

.hero-premium::after{
  content:"";
  position:absolute;
  width:620px;
  height:620px;
  right:-280px;
  top:90px;
  z-index:-1;
  border:1px solid rgba(54,174,191,.16);
  border-radius:50%;
  box-shadow:0 0 120px rgba(54,174,191,.10) inset;
  animation:orbitFloat 18s linear infinite;
}

.hero-premium-grid{
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(420px,.98fr);
  align-items:center;
  gap:56px;
}

.hero-copy{
  max-width:760px;
}

.hero-premium h1{
  font-size:clamp(3.1rem,6.2vw,5.75rem);
  margin:0 0 24px;
  letter-spacing:-1.5px;
}

.hero-premium h1 span{
  color:var(--turq);
  text-shadow:0 0 30px rgba(54,174,191,.14);
}

.hero-lead{
  width:100%;
  max-width:720px;
  color:#d4dee0;
  font-size:1.08rem;
  margin-bottom:30px;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:30px;
}

.hero-trust{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  max-width:650px;
}

.trust-item{
  min-height:94px;
  padding:18px 16px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:18px;
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);
}

.trust-item strong{
  display:block;
  color:#fff;
  font-size:1.05rem;
  letter-spacing:.7px;
}

.trust-item span{
  display:block;
  color:#aeb8bb;
  font-size:.86rem;
  margin-top:5px;
}

.hero-visual{
  width:100%;
}

.hero-image-frame{
  position:relative;
  width:100%;
  aspect-ratio:4 / 5;
  max-height:690px;
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:#111;
  box-shadow:
    0 30px 80px rgba(0,0,0,.48),
    0 0 0 1px rgba(54,174,191,.10) inset;
}

.hero-image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
  transition:transform .7s ease, filter .7s ease;
}

.hero-image-frame:hover img{
  transform:scale(1.045);
  filter:contrast(1.03) saturate(1.04);
}

.hero-badge{
  position:absolute;
  left:22px;
  bottom:22px;
  min-height:64px;
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background:rgba(0,0,0,.62);
  backdrop-filter:blur(14px);
  box-shadow:0 18px 42px rgba(0,0,0,.34);
}

.hero-badge img{
  width:48px;
  height:48px;
  object-fit:contain;
  border-radius:50%;
  transform:none;
}

.hero-badge span{
  max-width:190px;
  color:#fff;
  font-weight:700;
  font-size:.92rem;
  line-height:1.25;
}

.reveal-hero{
  opacity:0;
  transform:translateY(22px);
  animation:heroReveal .82s cubic-bezier(.2,.7,.2,1) forwards;
}

.reveal-hero:nth-child(1){animation-delay:.05s;}
.reveal-hero:nth-child(2){animation-delay:.16s;}
.reveal-hero:nth-child(3){animation-delay:.26s;}
.reveal-hero:nth-child(4){animation-delay:.36s;}
.reveal-hero:nth-child(5){animation-delay:.46s;}

@keyframes heroReveal{
  to{
    opacity:1;
    transform:translateY(0);
  }
}

@media(max-width:1120px){
  .nav-shell{
    grid-template-columns:auto auto;
  }

  .menu-toggle{
    display:flex;
    justify-self:end;
  }

  .nav-menu{
    position:absolute;
    top:100%;
    left:5%;
    right:5%;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:12px;
    border:1px solid rgba(255,255,255,.12);
    border-radius:18px;
    background:rgba(5,5,5,.96);
    box-shadow:0 28px 60px rgba(0,0,0,.42);
  }

  .nav-menu.active{
    display:flex;
  }

  .nav-menu a{
    padding:13px 14px;
    border-radius:12px;
  }

  .nav-menu a:hover{
    background:rgba(54,174,191,.08);
  }

  .nav-actions{
    display:none;
  }

  .hero-premium-grid{
    grid-template-columns:1fr;
  }

  .hero-copy{
    max-width:860px;
  }

  .hero-image-frame{
    max-height:none;
    aspect-ratio:16 / 10;
  }
}

@media(max-width:680px){
  .hero-premium{
    padding:104px 0 64px;
  }

  .brand{
    min-width:unset;
  }

  .brand-copy small{
    display:none;
  }

  .brand-copy strong{
    font-size:1.55rem;
  }

  .brand img{
    width:46px;
    height:46px;
  }

  .hero-premium h1{
    letter-spacing:-.8px;
  }

  .hero-actions .btn{
    width:100%;
  }

  .hero-trust{
    grid-template-columns:1fr;
  }

  .hero-image-frame{
    aspect-ratio:1 / 1.08;
    border-radius:22px;
  }

  .hero-badge{
    left:14px;
    right:14px;
    bottom:14px;
  }
}


/* =========================================================
   SECCIÓN 02 PREMIUM: AUTORIDAD Y DIFERENCIAL
   Bloque de confianza posterior al Hero.
   ========================================================= */

.authority-section{
  position:relative;
  padding:108px 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(54,174,191,.10), transparent 30%),
    linear-gradient(180deg,#060606 0%,#0b0b0b 100%);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}

.authority-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255,255,255,.035) 48%, transparent 70%);
  opacity:.5;
}

.authority-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(360px,.88fr) minmax(0,1.12fr);
  gap:54px;
  align-items:center;
}

.authority-visual{
  min-width:0;
}

.authority-image-card{
  position:relative;
  width:100%;
  aspect-ratio:1 / 1.05;
  min-height:520px;
  margin:0;
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:#111;
  box-shadow:0 28px 78px rgba(0,0,0,.48);
}

.authority-image-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .75s ease, filter .75s ease;
}

.authority-image-card:hover img{
  transform:scale(1.045);
  filter:contrast(1.04) saturate(1.04);
}

.authority-image-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 52%, rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.authority-image-card figcaption{
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;
  z-index:2;
  min-height:82px;
  padding:18px 18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(14px);
}

.authority-image-card figcaption span{
  display:block;
  color:var(--turq);
  font-size:.76rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:2px;
  margin-bottom:5px;
}

.authority-image-card figcaption strong{
  display:block;
  color:#fff;
  font-size:1.05rem;
  line-height:1.3;
}

.authority-copy h2{
  max-width:820px;
  font-size:clamp(2.5rem,4vw,4.15rem);
  margin:0 0 22px;
  letter-spacing:-.7px;
}

.authority-lead{
  max-width:840px;
  color:#cbd4d6;
  font-size:1.03rem;
  margin-bottom:30px;
}

.authority-metrics{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}

.metric-card{
  min-height:190px;
  position:relative;
  padding:26px 24px;
  border:1px solid rgba(255,255,255,.11);
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.025));
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.metric-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,var(--turq),transparent);
}

.metric-card::after{
  content:"";
  position:absolute;
  width:130px;
  height:130px;
  right:-60px;
  bottom:-70px;
  border-radius:50%;
  background:rgba(54,174,191,.10);
  transition:transform .35s ease, opacity .35s ease;
}

.metric-card:hover{
  transform:translateY(-5px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 22px 52px rgba(0,0,0,.34);
}

.metric-card:hover::after{
  transform:scale(1.35);
  opacity:.85;
}

.metric-icon{
  width:48px;
  height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:rgba(54,174,191,.10);
  border:1px solid rgba(54,174,191,.28);
  color:var(--turq);
  margin-bottom:18px;
}

.metric-icon .icon{
  width:23px;
  height:23px;
}

.metric-card strong{
  display:block;
  color:#fff;
  font-size:1.32rem;
  margin-bottom:9px;
  letter-spacing:.4px;
}

.metric-card p{
  color:#bfc9cc;
  font-size:.94rem;
  line-height:1.65;
}

@media(max-width:1050px){
  .authority-grid{
    grid-template-columns:1fr;
  }

  .authority-image-card{
    min-height:unset;
    aspect-ratio:16 / 9;
  }
}

@media(max-width:680px){
  .authority-section{
    padding:76px 0;
  }

  .authority-metrics{
    grid-template-columns:1fr;
  }

  .metric-card{
    min-height:auto;
  }

  .authority-image-card{
    aspect-ratio:1 / 1;
    border-radius:22px;
  }

  .authority-image-card figcaption{
    left:14px;
    right:14px;
    bottom:14px;
  }
}


/* =========================================================
   SECCIÓN 03 PREMIUM: SERVICIOS PRINCIPALES
   Cards clicables, iconografía consistente y CTA comercial.
   ========================================================= */

.services-preview-section{
  position:relative;
  padding:112px 0;
  background:
    radial-gradient(circle at 18% 12%, rgba(54,174,191,.10), transparent 30%),
    linear-gradient(180deg,#030303 0%,#080808 100%);
  overflow:hidden;
}

.services-preview-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.6), transparent 88%);
}

.services-preview-head{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(340px,.7fr);
  gap:42px;
  align-items:end;
  margin-bottom:48px;
}

.services-preview-head h2{
  max-width:820px;
  font-size:clamp(2.55rem,4.2vw,4.2rem);
  letter-spacing:-.8px;
}

.services-preview-intro{
  color:#c7d0d2;
  font-size:1rem;
  max-width:520px;
  margin-left:auto;
}

.services-premium-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}

.service-premium-card{
  position:relative;
  min-height:330px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.11);
  background:
    linear-gradient(180deg,rgba(255,255,255,.048),rgba(255,255,255,.025));
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.service-premium-card a{
  width:100%;
  height:100%;
  min-height:330px;
  display:flex;
  flex-direction:column;
  padding:28px;
  color:inherit;
  outline:none;
}

.service-premium-card a:focus-visible{
  outline:2px solid var(--turq);
  outline-offset:-6px;
  border-radius:24px;
}

.service-premium-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 22% 20%, rgba(54,174,191,.13), transparent 34%),
    linear-gradient(135deg, rgba(54,174,191,.08), transparent 42%);
  opacity:.75;
  transition:opacity .28s ease;
}

.service-premium-card::after{
  content:"";
  position:absolute;
  right:-80px;
  bottom:-90px;
  width:190px;
  height:190px;
  border-radius:50%;
  border:1px solid rgba(54,174,191,.16);
  background:rgba(54,174,191,.055);
  transition:transform .35s ease, opacity .35s ease;
}

.service-premium-card:hover{
  transform:translateY(-7px);
  border-color:rgba(54,174,191,.52);
  box-shadow:0 24px 62px rgba(0,0,0,.38);
}

.service-premium-card:hover::before{
  opacity:1;
}

.service-premium-card:hover::after{
  transform:scale(1.26);
  opacity:.9;
}

.featured-service{
  background:
    linear-gradient(135deg,rgba(54,174,191,.16),rgba(255,255,255,.035)),
    #111;
  border-color:rgba(54,174,191,.35);
}

.service-premium-icon{
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  margin-bottom:22px;
  position:relative;
  z-index:1;
  transition:transform .28s ease, background .28s ease, border-color .28s ease;
}

.service-premium-icon .icon{
  width:27px;
  height:27px;
}

.service-premium-card:hover .service-premium-icon{
  transform:translateY(-3px) scale(1.04);
  background:rgba(54,174,191,.18);
  border-color:rgba(54,174,191,.56);
}

.service-kicker{
  position:relative;
  z-index:1;
  color:var(--turq);
  font-size:.76rem;
  font-weight:800;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-bottom:12px;
}

.service-premium-card h3{
  position:relative;
  z-index:1;
  font-size:1.62rem;
  line-height:1.12;
  margin-bottom:14px;
}

.service-premium-card p{
  position:relative;
  z-index:1;
  color:#c5d0d2;
  font-size:.94rem;
  line-height:1.68;
  margin-bottom:24px;
}

.service-link{
  position:relative;
  z-index:1;
  margin-top:auto;
  color:#fff;
  font-weight:800;
  font-size:.92rem;
  display:inline-flex;
  align-items:center;
  transition:transform .24s ease, color .24s ease;
}

.service-premium-card:hover .service-link{
  transform:translateX(4px);
  color:var(--turq);
}

.services-preview-cta{
  position:relative;
  z-index:1;
  min-height:92px;
  margin-top:28px;
  padding:22px 24px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.services-preview-cta p{
  color:#dce4e6;
  font-weight:600;
  margin:0;
}

@media(max-width:1080px){
  .services-preview-head{
    grid-template-columns:1fr;
    gap:18px;
  }

  .services-preview-intro{
    margin-left:0;
    max-width:780px;
  }

  .services-premium-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:720px){
  .services-preview-section{
    padding:78px 0;
  }

  .services-premium-grid{
    grid-template-columns:1fr;
  }

  .service-premium-card,
  .service-premium-card a{
    min-height:unset;
  }

  .services-preview-cta{
    flex-direction:column;
    align-items:stretch;
  }

  .services-preview-cta .btn{
    width:100%;
  }
}


/* =========================================================
   SECCIÓN 04 PREMIUM: NOSOTROS / FIRMA BOUTIQUE
   Narrativa institucional con pilares y visual corporativo.
   ========================================================= */

.boutique-section{
  position:relative;
  padding:112px 0;
  background:
    radial-gradient(circle at 80% 18%, rgba(54,174,191,.11), transparent 32%),
    linear-gradient(180deg,#080808 0%,#050505 100%);
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.boutique-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(135deg, transparent 0%, rgba(255,255,255,.035) 48%, transparent 74%);
  opacity:.55;
}

.boutique-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(390px,.92fr);
  gap:58px;
  align-items:center;
}

.boutique-copy h2{
  max-width:850px;
  font-size:clamp(2.55rem,4.2vw,4.15rem);
  letter-spacing:-.8px;
  margin-bottom:22px;
}

.boutique-lead{
  max-width:780px;
  color:#c8d2d4;
  font-size:1.03rem;
  margin-bottom:30px;
}

.boutique-pillars{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
  margin:32px 0 30px;
}

.boutique-pillar{
  min-height:190px;
  padding:24px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.boutique-pillar::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 20% 16%, rgba(54,174,191,.13), transparent 38%);
  opacity:.72;
  pointer-events:none;
}

.boutique-pillar:hover{
  transform:translateY(-5px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 22px 52px rgba(0,0,0,.34);
}

.boutique-pillar span{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  font-size:.82rem;
  font-weight:900;
  margin-bottom:18px;
}

.boutique-pillar h3{
  position:relative;
  z-index:1;
  font-size:1.38rem;
  margin-bottom:10px;
}

.boutique-pillar p{
  position:relative;
  z-index:1;
  color:#c5d0d2;
  font-size:.92rem;
  line-height:1.65;
}

.boutique-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}

.boutique-visual{
  min-width:0;
}

.boutique-stack{
  position:relative;
  width:100%;
  min-height:620px;
}

.boutique-main-image{
  position:absolute;
  inset:28px 0 28px 48px;
  margin:0;
  border-radius:32px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:#111;
  box-shadow:0 30px 78px rgba(0,0,0,.48);
}

.boutique-main-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .75s ease, filter .75s ease;
}

.boutique-main-image:hover img{
  transform:scale(1.045);
  filter:contrast(1.04) saturate(1.04);
}

.boutique-main-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(0,0,0,.62) 100%);
  pointer-events:none;
}

.boutique-floating-card{
  position:absolute;
  z-index:2;
  width:min(270px,78%);
  min-height:96px;
  padding:18px 18px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.64);
  backdrop-filter:blur(16px);
  box-shadow:0 22px 52px rgba(0,0,0,.38);
}

.boutique-floating-card span{
  display:block;
  color:var(--turq);
  font-size:.76rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:2px;
  margin-bottom:6px;
}

.boutique-floating-card strong{
  display:block;
  color:#fff;
  font-size:1.02rem;
  line-height:1.35;
}

.boutique-card-top{
  top:0;
  left:0;
}

.boutique-card-bottom{
  right:0;
  bottom:0;
}

@media(max-width:1100px){
  .boutique-grid{
    grid-template-columns:1fr;
  }

  .boutique-stack{
    min-height:560px;
  }

  .boutique-main-image{
    inset:30px 0;
  }
}

@media(max-width:780px){
  .boutique-section{
    padding:78px 0;
  }

  .boutique-pillars{
    grid-template-columns:1fr;
  }

  .boutique-actions .btn{
    width:100%;
  }

  .boutique-stack{
    min-height:500px;
  }

  .boutique-main-image{
    inset:42px 0 44px 0;
    border-radius:24px;
  }

  .boutique-floating-card{
    width:min(250px,86%);
  }

  .boutique-card-top{
    left:12px;
  }

  .boutique-card-bottom{
    right:12px;
  }
}


/* =========================================================
   SECCIÓN 05 PREMIUM: EQUIPO DIRECTIVO CON AVATARES
   Sin fotografías reales. Avatares ejecutivos minimalistas.
   ========================================================= */

.leadership-section{
  position:relative;
  padding:112px 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(54,174,191,.12), transparent 32%),
    linear-gradient(180deg,#030303 0%,#090909 100%);
  overflow:hidden;
}

.leadership-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:74px 74px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 88%);
}

.leadership-page{
  border-top:1px solid rgba(255,255,255,.08);
}

.leadership-head{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(340px,.72fr);
  gap:42px;
  align-items:end;
  margin-bottom:46px;
}

.leadership-head h2{
  max-width:870px;
  font-size:clamp(2.55rem,4.2vw,4.18rem);
  letter-spacing:-.8px;
}

.leadership-intro{
  color:#c8d2d4;
  font-size:1rem;
  max-width:540px;
  margin-left:auto;
}

.leadership-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px;
}

.leader-card{
  min-height:510px;
  display:grid;
  grid-template-columns:170px 1fr;
  gap:26px;
  padding:30px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 18% 18%, rgba(54,174,191,.11), transparent 36%),
    linear-gradient(180deg,rgba(255,255,255,.047),rgba(255,255,255,.024));
  overflow:hidden;
  position:relative;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.leader-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,var(--turq),transparent 70%);
}

.leader-card::after{
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  right:-110px;
  bottom:-120px;
  border-radius:50%;
  background:rgba(54,174,191,.07);
  border:1px solid rgba(54,174,191,.14);
  transition:transform .35s ease, opacity .35s ease;
}

.leader-card:hover{
  transform:translateY(-7px);
  border-color:rgba(54,174,191,.50);
  box-shadow:0 26px 66px rgba(0,0,0,.40);
}

.leader-card:hover::after{
  transform:scale(1.24);
  opacity:.9;
}

.leader-avatar{
  width:170px;
  height:170px;
  border-radius:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.16), transparent 30%),
    linear-gradient(135deg,rgba(54,174,191,.30),rgba(8,8,8,.95));
  border:1px solid rgba(54,174,191,.38);
  box-shadow:
    0 22px 55px rgba(0,0,0,.35),
    inset 0 0 28px rgba(54,174,191,.10);
  position:relative;
  overflow:hidden;
}

.leader-avatar::before{
  content:"";
  position:absolute;
  inset:14px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.12);
}

.leader-avatar::after{
  content:"";
  position:absolute;
  width:84px;
  height:84px;
  right:-28px;
  bottom:-28px;
  border-radius:50%;
  background:rgba(255,255,255,.08);
}

.leader-avatar span{
  position:relative;
  z-index:1;
  font-family:"Cormorant Garamond",serif;
  font-size:2.8rem;
  font-weight:700;
  letter-spacing:2px;
  color:#fff;
  text-shadow:0 0 28px rgba(54,174,191,.28);
}

.leader-content{
  min-width:0;
  position:relative;
  z-index:1;
}

.leader-kicker{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(54,174,191,.10);
  border:1px solid rgba(54,174,191,.26);
  color:var(--turq);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
  margin-bottom:16px;
}

.leader-card h3{
  font-size:2rem;
  line-height:1.08;
  margin-bottom:8px;
}

.leader-role{
  color:#dce4e6;
  font-weight:700;
  margin-bottom:14px;
}

.leader-content p:not(.leader-role){
  color:#c5d0d2;
  font-size:.95rem;
  line-height:1.72;
}

.leader-badges{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
  margin-top:20px;
}

.leader-badges span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(54,174,191,.30);
  background:rgba(255,255,255,.035);
  color:#dff6fa;
  font-size:.78rem;
  font-weight:700;
  transition:transform .24s ease, background .24s ease, border-color .24s ease;
}

.leader-badges span:hover{
  transform:translateY(-2px);
  background:rgba(54,174,191,.12);
  border-color:rgba(54,174,191,.60);
}

.leadership-note{
  position:relative;
  z-index:1;
  margin-top:26px;
  min-height:94px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  padding:22px 24px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
}

.leadership-note strong{
  display:block;
  color:#fff;
  margin-bottom:5px;
}

.leadership-note p{
  color:#bfc9cc;
  margin:0;
}

@media(max-width:1120px){
  .leadership-head{
    grid-template-columns:1fr;
    gap:18px;
  }

  .leadership-intro{
    margin-left:0;
    max-width:820px;
  }

  .leadership-grid{
    grid-template-columns:1fr;
  }

  .leader-card{
    min-height:auto;
  }
}

@media(max-width:720px){
  .leadership-section{
    padding:78px 0;
  }

  .leader-card{
    grid-template-columns:1fr;
    padding:24px;
  }

  .leader-avatar{
    width:138px;
    height:138px;
    border-radius:28px;
  }

  .leader-avatar span{
    font-size:2.35rem;
  }

  .leadership-note{
    flex-direction:column;
    align-items:flex-start;
  }

  .leadership-note .btn{
    width:100%;
  }
}


/* =========================================================
   SECCIÓN 06 PREMIUM: SECTORES ATENDIDOS
   Experiencia sectorial sin revelar clientes.
   ========================================================= */

.sectors-section{
  position:relative;
  padding:112px 0;
  background:
    radial-gradient(circle at 78% 16%, rgba(54,174,191,.12), transparent 30%),
    linear-gradient(180deg,#090909 0%,#040404 100%);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}

.sectors-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(120deg, transparent 0%, rgba(255,255,255,.032) 45%, transparent 75%);
  opacity:.58;
}

.sectors-head{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(340px,.72fr);
  gap:42px;
  align-items:end;
  margin-bottom:46px;
}

.sectors-head h2{
  max-width:850px;
  font-size:clamp(2.55rem,4.2vw,4.15rem);
  letter-spacing:-.8px;
}

.sectors-intro{
  color:#c8d2d4;
  font-size:1rem;
  max-width:540px;
  margin-left:auto;
}

.sectors-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}

.sector-card{
  min-height:245px;
  padding:25px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:
    linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.sector-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 18% 14%, rgba(54,174,191,.13), transparent 34%);
  opacity:.72;
  pointer-events:none;
}

.sector-card::after{
  content:"";
  position:absolute;
  width:120px;
  height:120px;
  right:-58px;
  bottom:-62px;
  border-radius:50%;
  background:rgba(54,174,191,.08);
  border:1px solid rgba(54,174,191,.12);
  transition:transform .34s ease, opacity .34s ease;
}

.sector-card:hover{
  transform:translateY(-6px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 22px 52px rgba(0,0,0,.34);
}

.sector-card:hover::after{
  transform:scale(1.35);
  opacity:.9;
}

.sector-icon{
  position:relative;
  z-index:1;
  width:52px;
  height:52px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:rgba(54,174,191,.11);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  margin-bottom:18px;
  transition:transform .28s ease, background .28s ease, border-color .28s ease;
}

.sector-icon .icon{
  width:25px;
  height:25px;
}

.sector-card:hover .sector-icon{
  transform:translateY(-3px) scale(1.04);
  background:rgba(54,174,191,.18);
  border-color:rgba(54,174,191,.55);
}

.sector-card h3{
  position:relative;
  z-index:1;
  font-size:1.45rem;
  margin-bottom:10px;
}

.sector-card p{
  position:relative;
  z-index:1;
  color:#c5d0d2;
  font-size:.92rem;
  line-height:1.65;
}

.sectors-footer{
  position:relative;
  z-index:1;
  min-height:94px;
  margin-top:26px;
  padding:22px 24px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}

.sectors-footer p{
  color:#cbd4d6;
  max-width:790px;
  margin:0;
}

@media(max-width:1120px){
  .sectors-head{
    grid-template-columns:1fr;
    gap:18px;
  }

  .sectors-intro{
    margin-left:0;
    max-width:820px;
  }

  .sectors-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:720px){
  .sectors-section{
    padding:78px 0;
  }

  .sectors-grid{
    grid-template-columns:1fr;
  }

  .sector-card{
    min-height:auto;
  }

  .sectors-footer{
    flex-direction:column;
    align-items:flex-start;
  }

  .sectors-footer .btn{
    width:100%;
  }
}


/* =========================================================
   SECCIÓN 07 PREMIUM: BLOG / ACTUALIDAD TRIBUTARIA
   Autoridad técnica, SEO y conversión consultiva.
   ========================================================= */

.insights-section{
  position:relative;
  padding:112px 0;
  background:
    radial-gradient(circle at 15% 18%, rgba(54,174,191,.12), transparent 31%),
    linear-gradient(180deg,#040404 0%,#090909 100%);
  overflow:hidden;
}

.insights-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.017) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.52), transparent 88%);
}

.insights-head{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(340px,.72fr);
  gap:42px;
  align-items:end;
  margin-bottom:46px;
}

.insights-head h2{
  max-width:850px;
  font-size:clamp(2.55rem,4.2vw,4.15rem);
  letter-spacing:-.8px;
}

.insights-intro{
  color:#c8d2d4;
  font-size:1rem;
  max-width:540px;
  margin-left:auto;
}

.insights-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.14fr .93fr .93fr;
  gap:20px;
}

.insight-card{
  min-height:390px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.11);
  background:
    linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.insight-card a{
  width:100%;
  height:100%;
  min-height:390px;
  display:flex;
  flex-direction:column;
  padding:30px;
  color:inherit;
  outline:none;
}

.insight-card a:focus-visible{
  outline:2px solid var(--turq);
  outline-offset:-6px;
  border-radius:24px;
}

.insight-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 16%, rgba(54,174,191,.13), transparent 36%),
    linear-gradient(135deg, rgba(54,174,191,.08), transparent 42%);
  opacity:.78;
  pointer-events:none;
}

.insight-card::after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  right:-88px;
  bottom:-96px;
  border-radius:50%;
  background:rgba(54,174,191,.07);
  border:1px solid rgba(54,174,191,.14);
  transition:transform .35s ease, opacity .35s ease;
}

.insight-card:hover{
  transform:translateY(-7px);
  border-color:rgba(54,174,191,.50);
  box-shadow:0 24px 62px rgba(0,0,0,.38);
}

.insight-card:hover::after{
  transform:scale(1.28);
  opacity:.9;
}

.insight-featured{
  background:
    linear-gradient(135deg,rgba(54,174,191,.16),rgba(255,255,255,.035)),
    #111;
  border-color:rgba(54,174,191,.34);
}

.insight-top{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:24px;
}

.insight-icon{
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  transition:transform .28s ease, background .28s ease, border-color .28s ease;
}

.insight-icon .icon{
  width:27px;
  height:27px;
}

.insight-card:hover .insight-icon{
  transform:translateY(-3px) scale(1.04);
  background:rgba(54,174,191,.18);
  border-color:rgba(54,174,191,.56);
}

.insight-tag{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid rgba(54,174,191,.28);
  background:rgba(54,174,191,.09);
  color:var(--turq);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:1.5px;
  text-transform:uppercase;
}

.insight-card h3{
  position:relative;
  z-index:1;
  font-size:1.72rem;
  line-height:1.1;
  margin-bottom:16px;
}

.insight-featured h3{
  font-size:2.05rem;
}

.insight-card p{
  position:relative;
  z-index:1;
  color:#c5d0d2;
  font-size:.95rem;
  line-height:1.7;
  margin-bottom:26px;
}

.insight-link{
  position:relative;
  z-index:1;
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  font-weight:850;
  font-size:.93rem;
  transition:transform .24s ease, color .24s ease;
}

.insight-link .icon{
  width:18px;
  height:18px;
  transition:transform .24s ease;
}

.insight-card:hover .insight-link{
  color:var(--turq);
  transform:translateX(4px);
}

.insight-card:hover .insight-link .icon{
  transform:translateX(2px);
}

.insights-newsletter{
  position:relative;
  z-index:1;
  margin-top:28px;
  min-height:98px;
  padding:23px 24px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}

.insights-newsletter strong{
  display:block;
  color:#fff;
  margin-bottom:5px;
}

.insights-newsletter p{
  max-width:790px;
  color:#cbd4d6;
  margin:0;
}

@media(max-width:1080px){
  .insights-head{
    grid-template-columns:1fr;
    gap:18px;
  }

  .insights-intro{
    margin-left:0;
    max-width:820px;
  }

  .insights-grid{
    grid-template-columns:1fr;
  }

  .insight-card,
  .insight-card a{
    min-height:unset;
  }
}

@media(max-width:720px){
  .insights-section{
    padding:78px 0;
  }

  .insights-newsletter{
    flex-direction:column;
    align-items:flex-start;
  }

  .insights-newsletter .btn{
    width:100%;
  }

  .insight-featured h3{
    font-size:1.72rem;
  }
}


/* =========================================================
   SECCIÓN 08 PREMIUM: CTA FINAL + CONTACTO RÁPIDO
   Conversión comercial, redes sociales y datos de contacto.
   ========================================================= */

.final-contact-section{
  position:relative;
  padding:116px 0;
  background:
    radial-gradient(circle at 22% 18%, rgba(54,174,191,.16), transparent 34%),
    radial-gradient(circle at 84% 76%, rgba(255,255,255,.07), transparent 28%),
    linear-gradient(135deg,#020202 0%,#090b0c 100%);
  overflow:hidden;
  border-top:1px solid rgba(255,255,255,.08);
}

.final-contact-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.60), transparent 88%);
}

.final-contact-section::after{
  content:"";
  position:absolute;
  width:620px;
  height:620px;
  right:-300px;
  top:80px;
  border-radius:50%;
  border:1px solid rgba(54,174,191,.14);
  box-shadow:0 0 120px rgba(54,174,191,.10) inset;
  pointer-events:none;
  animation:orbitFloat 20s linear infinite;
}

.final-contact-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(360px,.78fr);
  gap:54px;
  align-items:center;
}

.final-contact-copy h2{
  max-width:880px;
  font-size:clamp(2.75rem,5vw,4.75rem);
  letter-spacing:-1px;
  margin-bottom:22px;
}

.final-contact-lead{
  max-width:780px;
  color:#cbd4d6;
  font-size:1.04rem;
  margin-bottom:30px;
}

.final-contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:28px;
}

.final-socials{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.final-socials a{
  width:48px;
  height:48px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.04);
  color:#fff;
  transition:transform .24s ease, background .24s ease, border-color .24s ease;
}

.final-socials a .icon{
  width:22px;
  height:22px;
}

.final-socials a:hover{
  transform:translateY(-3px);
  border-color:rgba(54,174,191,.55);
}

.final-socials .whatsapp-icon:hover{background:#25D366;}
.final-socials .linkedin:hover{background:#0A66C2;}
.final-socials .facebook:hover{background:#1877F2;}
.final-socials .maps:hover{background:var(--turq);}

.final-contact-panel{
  min-height:520px;
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.13);
  background:
    radial-gradient(circle at 18% 15%, rgba(54,174,191,.13), transparent 38%),
    rgba(255,255,255,.045);
  backdrop-filter:blur(16px);
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  position:relative;
  overflow:hidden;
}

.final-contact-panel::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,var(--turq),transparent 70%);
}

.final-contact-panel::after{
  content:"";
  position:absolute;
  width:220px;
  height:220px;
  right:-110px;
  bottom:-120px;
  border-radius:50%;
  background:rgba(54,174,191,.08);
  border:1px solid rgba(54,174,191,.14);
}

.final-panel-logo{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:16px;
  padding-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.10);
  margin-bottom:24px;
}

.final-panel-logo img{
  width:74px;
  height:74px;
  object-fit:contain;
  border-radius:50%;
  box-shadow:0 14px 34px rgba(0,0,0,.35);
}

.final-panel-logo strong{
  display:block;
  font-family:"Cormorant Garamond",serif;
  color:#fff;
  font-size:2rem;
  line-height:1;
  letter-spacing:1.4px;
}

.final-panel-logo span{
  display:block;
  color:#aeb8bb;
  font-size:.82rem;
  margin-top:4px;
}

.final-contact-list{
  position:relative;
  z-index:1;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:16px;
  padding:0;
  margin:0 0 24px;
}

.final-contact-list li{
  display:grid;
  grid-template-columns:46px 1fr;
  gap:13px;
  align-items:center;
}

.final-contact-list li > span{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:rgba(54,174,191,.11);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
}

.final-contact-list .icon{
  width:22px;
  height:22px;
}

.final-contact-list a{
  color:#dce4e6;
  font-weight:650;
  transition:color .24s ease;
}

.final-contact-list a:hover{
  color:var(--turq);
}

.final-contact-note{
  position:relative;
  z-index:1;
  padding:20px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(0,0,0,.28);
}

.final-contact-note strong{
  display:block;
  color:#fff;
  margin-bottom:5px;
}

.final-contact-note p{
  color:#cbd4d6;
  margin:0;
}

@media(max-width:1080px){
  .final-contact-grid{
    grid-template-columns:1fr;
  }

  .final-contact-panel{
    min-height:auto;
  }
}

@media(max-width:720px){
  .final-contact-section{
    padding:82px 0;
  }

  .final-contact-actions .btn{
    width:100%;
  }

  .final-contact-panel{
    padding:26px;
    border-radius:24px;
  }

  .final-panel-logo{
    align-items:flex-start;
  }

  .final-panel-logo img{
    width:62px;
    height:62px;
  }

  .final-contact-list li{
    grid-template-columns:42px 1fr;
  }

  .final-contact-list li > span{
    width:42px;
    height:42px;
  }
}


/* =========================================================
   PÁGINA INTERNA PREMIUM: CONTACTO
   Formulario accesible con estados focus, success y error.
   ========================================================= */

.contact-page-hero{
  background:
    radial-gradient(circle at 18% 20%, rgba(54,174,191,.15), transparent 32%),
    linear-gradient(135deg,#030303 0%,#0a0d0e 100%);
}

.contact-premium-section{
  position:relative;
  padding:104px 0;
  background:
    radial-gradient(circle at 85% 18%, rgba(54,174,191,.11), transparent 31%),
    linear-gradient(180deg,#060606 0%,#090909 100%);
  overflow:hidden;
}

.contact-premium-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.016) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 88%);
}

.contact-premium-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(340px,.82fr) minmax(0,1.18fr);
  gap:30px;
  align-items:start;
}

.contact-info-premium,
.contact-form-premium{
  border-radius:30px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 18% 14%, rgba(54,174,191,.12), transparent 36%),
    rgba(255,255,255,.042);
  backdrop-filter:blur(16px);
  box-shadow:0 28px 78px rgba(0,0,0,.42);
  overflow:hidden;
  position:relative;
}

.contact-info-premium{
  min-height:620px;
  padding:32px;
}

.contact-form-premium{
  min-height:620px;
  padding:34px;
}

.contact-info-premium::before,
.contact-form-premium::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg,var(--turq),transparent 70%);
}

.contact-brand-block{
  display:flex;
  align-items:center;
  gap:16px;
  padding-bottom:24px;
  margin-bottom:24px;
  border-bottom:1px solid rgba(255,255,255,.10);
}

.contact-brand-block img{
  width:78px;
  height:78px;
  object-fit:contain;
  border-radius:50%;
  box-shadow:0 14px 34px rgba(0,0,0,.35);
}

.contact-brand-block strong{
  display:block;
  font-family:"Cormorant Garamond",serif;
  color:#fff;
  font-size:2.1rem;
  line-height:1;
  letter-spacing:1.4px;
}

.contact-brand-block span{
  display:block;
  color:#aeb8bb;
  font-size:.82rem;
  margin-top:4px;
}

.contact-channel-list{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.contact-channel{
  min-height:82px;
  display:grid;
  grid-template-columns:50px 1fr;
  gap:14px;
  align-items:center;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
  transition:transform .24s ease, border-color .24s ease, background .24s ease;
}

.contact-channel:hover{
  transform:translateY(-3px);
  border-color:rgba(54,174,191,.44);
  background:rgba(54,174,191,.07);
}

.contact-channel > span{
  width:50px;
  height:50px;
  border-radius:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(54,174,191,.11);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
}

.contact-channel .icon{
  width:23px;
  height:23px;
}

.contact-channel strong{
  display:block;
  color:#fff;
  margin-bottom:3px;
}

.contact-channel small{
  display:block;
  color:#c5d0d2;
  line-height:1.35;
}

.contact-social-panel{
  margin-top:22px;
  padding:18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.22);
}

.contact-social-panel p{
  color:#dce4e6;
  font-weight:700;
  margin-bottom:12px;
}

.contact-social-panel div{
  display:flex;
  gap:10px;
}

.contact-social-panel a{
  width:46px;
  height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.04);
  color:#fff;
  transition:transform .24s ease, background .24s ease, border-color .24s ease;
}

.contact-social-panel a:hover{
  transform:translateY(-3px);
  border-color:rgba(54,174,191,.55);
}

.contact-social-panel a .icon{
  width:22px;
  height:22px;
}

.contact-social-panel .linkedin:hover{background:#0A66C2;}
.contact-social-panel .facebook:hover{background:#1877F2;}
.contact-social-panel .whatsapp-icon:hover{background:#25D366;}

.form-head{
  margin-bottom:22px;
}

.form-head h2{
  font-size:clamp(2.1rem,3vw,3.15rem);
  margin-bottom:12px;
}

.form-head p{
  color:#c5d0d2;
}

.form-alert{
  min-height:54px;
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 16px;
  border-radius:16px;
  margin-bottom:18px;
  font-weight:700;
}

.form-alert .icon{
  width:22px;
  height:22px;
  flex:0 0 auto;
}

.form-success{
  color:#dfffea;
  border:1px solid rgba(37,211,102,.34);
  background:rgba(37,211,102,.12);
}

.form-error{
  color:#ffe7e7;
  border:1px solid rgba(255,91,91,.35);
  background:rgba(255,91,91,.11);
}

.premium-form{
  display:grid;
  gap:16px;
}

.form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}

.premium-form label{
  display:grid;
  gap:8px;
}

.premium-form label > span{
  color:#eef6f8;
  font-size:.9rem;
  font-weight:750;
}

.premium-form em{
  color:var(--turq);
  font-style:normal;
}

.premium-form input,
.premium-form select,
.premium-form textarea{
  width:100%;
  min-height:52px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(0,0,0,.28);
  color:#fff;
  padding:14px 15px;
  font-family:Inter,sans-serif;
  font-size:.95rem;
  transition:border-color .24s ease, box-shadow .24s ease, background .24s ease;
}

.premium-form textarea{
  min-height:142px;
  resize:vertical;
}

.premium-form input:focus,
.premium-form select:focus,
.premium-form textarea:focus{
  outline:none;
  border-color:rgba(54,174,191,.72);
  box-shadow:0 0 0 4px rgba(54,174,191,.13);
  background:rgba(0,0,0,.36);
}

.premium-form input:invalid:not(:placeholder-shown),
.premium-form textarea:invalid:not(:placeholder-shown){
  border-color:rgba(255,91,91,.64);
}

.form-consent{
  padding:14px 16px;
  border-radius:16px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.10);
}

.form-consent label{
  display:flex;
  align-items:flex-start;
  gap:10px;
}

.form-consent input{
  width:18px;
  height:18px;
  min-height:18px;
  margin-top:2px;
  accent-color:var(--turq);
}

.form-consent span{
  color:#cbd4d6!important;
  font-weight:600!important;
  line-height:1.45;
}

.form-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:4px;
}

.contact-map-section{
  padding:96px 0;
  background:#050505;
  border-top:1px solid rgba(255,255,255,.08);
}

.contact-map-section .map-wrap iframe{
  width:100%;
  height:430px;
  display:block;
}

@media(max-width:1080px){
  .contact-premium-grid{
    grid-template-columns:1fr;
  }

  .contact-info-premium,
  .contact-form-premium{
    min-height:auto;
  }
}

@media(max-width:720px){
  .contact-premium-section{
    padding:78px 0;
  }

  .contact-info-premium,
  .contact-form-premium{
    padding:24px;
    border-radius:24px;
  }

  .form-grid{
    grid-template-columns:1fr;
  }

  .form-actions .btn{
    width:100%;
  }

  .contact-brand-block{
    align-items:flex-start;
  }

  .contact-brand-block img{
    width:64px;
    height:64px;
  }

  .contact-channel{
    grid-template-columns:44px 1fr;
  }

  .contact-channel > span{
    width:44px;
    height:44px;
  }
}


/* =========================================================
   PÁGINA INTERNA PREMIUM: SERVICIOS
   Desarrollo comercial, técnico y SEO por línea de servicio.
   ========================================================= */

.services-page-hero{
  background:
    radial-gradient(circle at 16% 18%, rgba(54,174,191,.15), transparent 32%),
    linear-gradient(135deg,#030303 0%,#0a0d0e 100%);
}

.services-method-section{
  position:relative;
  padding:96px 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(54,174,191,.11), transparent 31%),
    linear-gradient(180deg,#060606 0%,#090909 100%);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}

.services-method-section::before,
.services-detail-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.016) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 88%);
}

.services-method-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,.88fr) minmax(0,1.12fr);
  gap:38px;
  align-items:center;
}

.services-method-copy h2{
  font-size:clamp(2.4rem,4vw,4rem);
  margin-bottom:18px;
}

.services-method-copy p{
  color:#cbd4d6;
}

.method-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.method-step{
  min-height:220px;
  padding:25px 22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.method-step::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 18% 14%, rgba(54,174,191,.13), transparent 34%);
  opacity:.72;
}

.method-step:hover{
  transform:translateY(-5px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 22px 52px rgba(0,0,0,.34);
}

.method-step span{
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:14px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  font-size:.82rem;
  font-weight:900;
  margin-bottom:18px;
}

.method-step h3,
.method-step p{
  position:relative;
  z-index:1;
}

.method-step h3{
  font-size:1.4rem;
  margin-bottom:10px;
}

.method-step p{
  color:#c5d0d2;
  font-size:.93rem;
}

.services-detail-section{
  position:relative;
  padding:104px 0;
  background:#040404;
  overflow:hidden;
}

.service-detail-list{
  position:relative;
  z-index:1;
  display:grid;
  gap:22px;
}

.service-detail-card{
  display:grid;
  grid-template-columns:86px 1fr;
  gap:26px;
  padding:30px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.11);
  background:
    radial-gradient(circle at 10% 16%, rgba(54,174,191,.11), transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.service-detail-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  height:3px;
  width:100%;
  background:linear-gradient(90deg,var(--turq),transparent 70%);
}

.service-detail-card:hover{
  transform:translateY(-5px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 24px 62px rgba(0,0,0,.36);
}

.service-detail-icon{
  width:76px;
  height:76px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:22px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
}

.service-detail-icon .icon{
  width:34px;
  height:34px;
}

.service-detail-body{
  min-width:0;
}

.service-detail-kicker{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid rgba(54,174,191,.28);
  background:rgba(54,174,191,.09);
  color:var(--turq);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:1.5px;
  text-transform:uppercase;
  margin-bottom:14px;
}

.service-detail-body h3{
  font-size:clamp(1.8rem,2.4vw,2.45rem);
  margin-bottom:12px;
}

.service-detail-body > p{
  color:#cbd4d6;
  max-width:920px;
  margin-bottom:22px;
}

.service-detail-columns{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin-bottom:22px;
}

.service-detail-columns div{
  padding:20px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.09);
  background:rgba(0,0,0,.22);
}

.service-detail-columns h4{
  color:#fff;
  font-size:1rem;
  margin-bottom:12px;
}

.service-detail-columns ul{
  list-style:none;
  padding:0;
  display:grid;
  gap:9px;
}

.service-detail-columns li{
  position:relative;
  color:#c5d0d2;
  padding-left:24px;
  font-size:.93rem;
}

.service-detail-columns li::before{
  content:"";
  position:absolute;
  left:0;
  top:.5em;
  width:9px;
  height:9px;
  border-radius:50%;
  background:var(--turq);
  box-shadow:0 0 0 4px rgba(54,174,191,.12);
}

.service-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  font-weight:850;
  transition:color .24s ease, transform .24s ease;
}

.service-cta .icon{
  width:18px;
  height:18px;
}

.service-cta:hover{
  color:var(--turq);
  transform:translateX(4px);
}

.services-final-cta{
  padding:96px 0;
  background:
    radial-gradient(circle at 22% 18%, rgba(54,174,191,.16), transparent 34%),
    linear-gradient(135deg,#020202 0%,#090b0c 100%);
  border-top:1px solid rgba(255,255,255,.08);
}

.services-final-card{
  min-height:250px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.045);
  backdrop-filter:blur(16px);
  box-shadow:0 28px 78px rgba(0,0,0,.42);
}

.services-final-card h2{
  font-size:clamp(2.1rem,3.4vw,3.4rem);
  margin-bottom:12px;
}

.services-final-card p{
  color:#cbd4d6;
}

.services-final-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
}

@media(max-width:1080px){
  .services-method-grid,
  .method-steps{
    grid-template-columns:1fr;
  }

  .service-detail-card{
    grid-template-columns:1fr;
  }

  .services-final-card{
    flex-direction:column;
    align-items:flex-start;
  }

  .services-final-actions{
    justify-content:flex-start;
  }
}

@media(max-width:720px){
  .services-method-section,
  .services-detail-section,
  .services-final-cta{
    padding:78px 0;
  }

  .service-detail-card{
    padding:24px;
    border-radius:24px;
  }

  .service-detail-columns{
    grid-template-columns:1fr;
  }

  .services-final-card{
    padding:26px;
    border-radius:24px;
  }

  .services-final-actions,
  .services-final-actions .btn{
    width:100%;
  }
}


/* =========================================================
   PÁGINA INTERNA PREMIUM: NOSOTROS
   Identidad institucional, propósito, metodología y valores.
   ========================================================= */

.about-page-hero{
  background:
    radial-gradient(circle at 16% 18%, rgba(54,174,191,.15), transparent 32%),
    linear-gradient(135deg,#030303 0%,#0a0d0e 100%);
}

.about-identity-section,
.about-method-section{
  position:relative;
  padding:104px 0;
  background:
    radial-gradient(circle at 84% 18%, rgba(54,174,191,.11), transparent 31%),
    linear-gradient(180deg,#060606 0%,#090909 100%);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}

.about-identity-section::before,
.about-purpose-section::before,
.about-method-section::before,
.about-values-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.016) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 88%);
}

.about-identity-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,.88fr);
  gap:56px;
  align-items:center;
}

.about-identity-copy h2,
.about-method-copy h2{
  font-size:clamp(2.55rem,4.2vw,4.15rem);
  letter-spacing:-.8px;
  margin-bottom:20px;
}

.about-identity-copy p,
.about-method-copy p{
  color:#cbd4d6;
  margin-bottom:16px;
}

.about-identity-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:26px;
}

.about-identity-visual{
  position:relative;
  width:100%;
  aspect-ratio:1 / 1.04;
  margin:0;
  border-radius:30px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:#111;
  box-shadow:0 28px 78px rgba(0,0,0,.45);
}

.about-identity-visual img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .75s ease, filter .75s ease;
}

.about-identity-visual:hover img{
  transform:scale(1.045);
  filter:contrast(1.04) saturate(1.04);
}

.about-identity-visual::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 52%, rgba(0,0,0,.78) 100%);
  pointer-events:none;
}

.about-identity-visual figcaption{
  position:absolute;
  z-index:2;
  left:22px;
  right:22px;
  bottom:22px;
  padding:18px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(14px);
}

.about-identity-visual figcaption span{
  display:block;
  color:var(--turq);
  font-size:.76rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:2px;
  margin-bottom:6px;
}

.about-identity-visual figcaption strong{
  display:block;
  color:#fff;
  font-size:1.05rem;
}

.about-purpose-section,
.about-values-section{
  position:relative;
  padding:104px 0;
  background:#040404;
  overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.about-purpose-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}

.about-purpose-card,
.about-value-card{
  min-height:300px;
  padding:28px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.11);
  background:
    radial-gradient(circle at 18% 14%, rgba(54,174,191,.12), transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.about-purpose-card:hover,
.about-value-card:hover{
  transform:translateY(-6px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 22px 52px rgba(0,0,0,.34);
}

.about-purpose-icon{
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  margin-bottom:22px;
}

.about-purpose-icon .icon{
  width:27px;
  height:27px;
}

.about-purpose-card h3,
.about-value-card h3{
  font-size:1.72rem;
  margin-bottom:14px;
}

.about-purpose-card p,
.about-value-card p{
  color:#c5d0d2;
}

.about-method-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(360px,.82fr) minmax(0,1.18fr);
  gap:58px;
  align-items:center;
}

.about-method-visual{
  display:flex;
  justify-content:center;
}

.method-orbit{
  width:430px;
  height:430px;
  position:relative;
  border-radius:50%;
  border:1px solid rgba(54,174,191,.22);
  background:radial-gradient(circle at center,rgba(54,174,191,.10),transparent 54%);
  box-shadow:inset 0 0 80px rgba(54,174,191,.08);
}

.method-center{
  position:absolute;
  width:170px;
  height:170px;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  border-radius:34px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:1px solid rgba(54,174,191,.35);
  background:rgba(0,0,0,.58);
  backdrop-filter:blur(14px);
}

.method-center img{
  width:86px;
  height:86px;
  object-fit:contain;
  border-radius:50%;
}

.method-center strong{
  color:#fff;
  font-family:"Cormorant Garamond",serif;
  font-size:1.6rem;
}

.orbit-item{
  position:absolute;
  min-width:118px;
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(54,174,191,.28);
  background:rgba(255,255,255,.05);
  backdrop-filter:blur(12px);
  color:#dff6fa;
  font-weight:800;
  font-size:.86rem;
}

.orbit-1{top:18px;left:50%;transform:translateX(-50%);}
.orbit-2{right:-16px;top:50%;transform:translateY(-50%);}
.orbit-3{bottom:18px;left:50%;transform:translateX(-50%);}
.orbit-4{left:-16px;top:50%;transform:translateY(-50%);}

.about-method-list{
  display:grid;
  gap:14px;
  margin-top:24px;
}

.about-method-list div{
  display:grid;
  grid-template-columns:48px 130px 1fr;
  gap:14px;
  align-items:center;
  padding:16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.24);
}

.about-method-list span{
  width:42px;
  height:42px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--turq);
  background:rgba(54,174,191,.11);
  border:1px solid rgba(54,174,191,.30);
  font-weight:900;
}

.about-method-list strong{
  color:#fff;
}

.about-method-list p{
  margin:0;
  color:#c5d0d2;
}

.about-values-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}

.about-value-card{
  min-height:240px;
}

.about-value-card span{
  display:inline-flex;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:rgba(54,174,191,.11);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  font-weight:900;
  margin-bottom:18px;
}

.about-final-cta{
  padding:96px 0;
  background:
    radial-gradient(circle at 22% 18%, rgba(54,174,191,.16), transparent 34%),
    linear-gradient(135deg,#020202 0%,#090b0c 100%);
}

.about-final-card{
  min-height:250px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.045);
  backdrop-filter:blur(16px);
  box-shadow:0 28px 78px rgba(0,0,0,.42);
}

.about-final-card h2{
  font-size:clamp(2.1rem,3.4vw,3.4rem);
  margin-bottom:12px;
}

.about-final-card p{
  color:#cbd4d6;
}

.about-final-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
}

@media(max-width:1080px){
  .about-identity-grid,
  .about-method-grid{
    grid-template-columns:1fr;
  }

  .about-purpose-grid,
  .about-values-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .about-final-card{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media(max-width:720px){
  .about-identity-section,
  .about-purpose-section,
  .about-method-section,
  .about-values-section,
  .about-final-cta{
    padding:78px 0;
  }

  .about-identity-actions .btn,
  .about-final-actions .btn{
    width:100%;
  }

  .about-purpose-grid,
  .about-values-grid{
    grid-template-columns:1fr;
  }

  .method-orbit{
    width:320px;
    height:320px;
  }

  .method-center{
    width:132px;
    height:132px;
    border-radius:26px;
  }

  .method-center img{
    width:62px;
    height:62px;
  }

  .orbit-item{
    min-width:100px;
    font-size:.76rem;
  }

  .orbit-2{right:-8px;}
  .orbit-4{left:-8px;}

  .about-method-list div{
    grid-template-columns:1fr;
    gap:8px;
  }

  .about-final-card{
    padding:26px;
    border-radius:24px;
  }

  .about-final-actions{
    width:100%;
  }
}


/* =========================================================
   PÁGINA INTERNA PREMIUM: ESPECIALIDADES
   Autoridad técnica, prevención y defensa especializada.
   ========================================================= */

.expertise-page-hero{
  background:
    radial-gradient(circle at 16% 18%, rgba(54,174,191,.15), transparent 32%),
    linear-gradient(135deg,#030303 0%,#0a0d0e 100%);
}

.expertise-overview-section,
.expertise-process-section{
  position:relative;
  padding:98px 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(54,174,191,.11), transparent 31%),
    linear-gradient(180deg,#060606 0%,#090909 100%);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}

.expertise-overview-section::before,
.expertise-detail-section::before,
.expertise-process-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.016) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 88%);
}

.expertise-overview-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(340px,.78fr);
  gap:42px;
  align-items:center;
}

.expertise-overview-copy h2,
.expertise-process-copy h2{
  font-size:clamp(2.45rem,4vw,4rem);
  letter-spacing:-.8px;
  margin-bottom:18px;
}

.expertise-overview-copy p,
.expertise-process-copy p{
  color:#cbd4d6;
}

.expertise-overview-panel{
  min-height:330px;
  padding:28px;
  border-radius:26px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 18% 14%, rgba(54,174,191,.12), transparent 36%),
    rgba(255,255,255,.045);
  box-shadow:0 28px 78px rgba(0,0,0,.42);
}

.expertise-overview-panel strong{
  display:block;
  color:#fff;
  font-size:1.4rem;
  margin-bottom:18px;
}

.expertise-overview-panel ul{
  list-style:none;
  display:grid;
  gap:14px;
  padding:0;
  margin:0;
}

.expertise-overview-panel li{
  display:flex;
  gap:10px;
  color:#cbd4d6;
  align-items:flex-start;
}

.expertise-overview-panel li .icon{
  width:20px;
  height:20px;
  color:var(--turq);
  flex:0 0 auto;
  margin-top:3px;
}

.expertise-detail-section{
  position:relative;
  padding:104px 0;
  background:#040404;
  overflow:hidden;
}

.expertise-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}

.expertise-card{
  min-height:390px;
  padding:26px 24px;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.11);
  background:
    radial-gradient(circle at 18% 14%, rgba(54,174,191,.12), transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  position:relative;
  overflow:hidden;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.expertise-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  height:3px;
  width:100%;
  background:linear-gradient(90deg,var(--turq),transparent 70%);
}

.expertise-card:hover{
  transform:translateY(-6px);
  border-color:rgba(54,174,191,.48);
  box-shadow:0 22px 52px rgba(0,0,0,.34);
}

.expertise-icon{
  width:56px;
  height:56px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  margin-bottom:18px;
}

.expertise-icon .icon{
  width:26px;
  height:26px;
}

.expertise-card span{
  display:inline-flex;
  min-height:30px;
  align-items:center;
  padding:6px 10px;
  border-radius:999px;
  color:var(--turq);
  background:rgba(54,174,191,.09);
  border:1px solid rgba(54,174,191,.26);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:1.4px;
  text-transform:uppercase;
  margin-bottom:14px;
}

.expertise-card h3{
  font-size:1.52rem;
  line-height:1.12;
  margin-bottom:12px;
}

.expertise-card p{
  color:#c5d0d2;
  font-size:.93rem;
  margin-bottom:16px;
}

.expertise-card ul{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:8px;
}

.expertise-card li{
  position:relative;
  color:#bfc9cc;
  font-size:.88rem;
  padding-left:20px;
}

.expertise-card li::before{
  content:"";
  position:absolute;
  left:0;
  top:.55em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--turq);
  box-shadow:0 0 0 4px rgba(54,174,191,.12);
}

.expertise-process-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:42px;
  align-items:center;
}

.expertise-process-list{
  display:grid;
  gap:16px;
}

.expertise-process-list article{
  min-height:132px;
  padding:22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
  display:grid;
  grid-template-columns:56px 170px 1fr;
  gap:16px;
  align-items:center;
}

.expertise-process-list span{
  width:46px;
  height:46px;
  border-radius:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--turq);
  background:rgba(54,174,191,.11);
  border:1px solid rgba(54,174,191,.30);
  font-weight:900;
}

.expertise-process-list strong{
  color:#fff;
}

.expertise-process-list p{
  color:#c5d0d2;
  margin:0;
}

.expertise-final-cta{
  padding:96px 0;
  background:
    radial-gradient(circle at 22% 18%, rgba(54,174,191,.16), transparent 34%),
    linear-gradient(135deg,#020202 0%,#090b0c 100%);
}

.expertise-final-card{
  min-height:250px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:34px;
  border-radius:30px;
  border:1px solid rgba(255,255,255,.13);
  background:rgba(255,255,255,.045);
  backdrop-filter:blur(16px);
  box-shadow:0 28px 78px rgba(0,0,0,.42);
}

.expertise-final-card h2{
  font-size:clamp(2.1rem,3.4vw,3.4rem);
  margin-bottom:12px;
}

.expertise-final-card p{
  color:#cbd4d6;
}

.expertise-final-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  justify-content:flex-end;
}

@media(max-width:1180px){
  .expertise-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:1080px){
  .expertise-overview-grid,
  .expertise-process-grid{
    grid-template-columns:1fr;
  }

  .expertise-final-card{
    flex-direction:column;
    align-items:flex-start;
  }

  .expertise-process-list article{
    grid-template-columns:56px 1fr;
  }

  .expertise-process-list p{
    grid-column:2;
  }
}

@media(max-width:720px){
  .expertise-overview-section,
  .expertise-detail-section,
  .expertise-process-section,
  .expertise-final-cta{
    padding:78px 0;
  }

  .expertise-grid{
    grid-template-columns:1fr;
  }

  .expertise-card{
    min-height:auto;
  }

  .expertise-process-list article{
    grid-template-columns:1fr;
  }

  .expertise-process-list p{
    grid-column:auto;
  }

  .expertise-final-card{
    padding:26px;
    border-radius:24px;
  }

  .expertise-final-actions,
  .expertise-final-actions .btn{
    width:100%;
  }
}


/* =========================================================
   PÁGINA INTERNA PREMIUM: BLOG
   Autoridad técnica, categorías, artículos y SEO.
   ========================================================= */

.blog-page-hero{
  background:
    radial-gradient(circle at 16% 18%, rgba(54,174,191,.15), transparent 32%),
    linear-gradient(135deg,#030303 0%,#0a0d0e 100%);
}

.blog-featured-section,
.blog-categories-section,
.blog-list-section,
.blog-seo-section{
  position:relative;
  overflow:hidden;
}

.blog-featured-section{
  padding:98px 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(54,174,191,.11), transparent 31%),
    linear-gradient(180deg,#060606 0%,#090909 100%);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.blog-featured-section::before,
.blog-categories-section::before,
.blog-list-section::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.024) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,.016) 1px, transparent 1px);
  background-size:76px 76px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.55), transparent 88%);
}

.blog-featured-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);
  gap:24px;
}

.blog-featured-card,
.blog-authority-panel,
.blog-post-card,
.blog-seo-card{
  border-radius:28px;
  border:1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 18% 14%, rgba(54,174,191,.12), transparent 36%),
    linear-gradient(180deg,rgba(255,255,255,.046),rgba(255,255,255,.022));
  box-shadow:0 24px 62px rgba(0,0,0,.34);
  overflow:hidden;
  position:relative;
}

.blog-featured-card a{
  min-height:440px;
  display:flex;
  flex-direction:column;
  padding:34px;
  color:inherit;
  outline:none;
}

.blog-featured-card a:focus-visible,
.blog-post-card a:focus-visible{
  outline:2px solid var(--turq);
  outline-offset:-6px;
  border-radius:28px;
}

.blog-card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:24px;
}

.blog-card-meta span{
  min-height:32px;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:7px 11px;
  border-radius:999px;
  color:var(--turq);
  background:rgba(54,174,191,.09);
  border:1px solid rgba(54,174,191,.26);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:1.2px;
  text-transform:uppercase;
}

.blog-card-meta .icon{
  width:16px;
  height:16px;
}

.blog-featured-card h2{
  font-size:clamp(2.25rem,4vw,4rem);
  letter-spacing:-.8px;
  margin-bottom:16px;
}

.blog-featured-card p{
  color:#cbd4d6;
  max-width:820px;
}

.blog-read-link{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#fff;
  font-weight:850;
  transition:color .24s ease, transform .24s ease;
}

.blog-read-link .icon{
  width:18px;
  height:18px;
}

.blog-featured-card:hover .blog-read-link,
.blog-post-card:hover .blog-read-link{
  color:var(--turq);
  transform:translateX(4px);
}

.blog-authority-panel{
  min-height:440px;
  padding:32px;
}

.blog-panel-icon{
  width:62px;
  height:62px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:20px;
  background:rgba(54,174,191,.12);
  border:1px solid rgba(54,174,191,.30);
  color:var(--turq);
  margin-bottom:22px;
}

.blog-panel-icon .icon{
  width:30px;
  height:30px;
}

.blog-authority-panel h3{
  font-size:2rem;
  margin-bottom:14px;
}

.blog-authority-panel p,
.blog-authority-panel li{
  color:#c5d0d2;
}

.blog-authority-panel ul{
  list-style:none;
  padding:0;
  display:grid;
  gap:12px;
  margin-top:20px;
}

.blog-authority-panel li{
  display:flex;
  gap:10px;
  align-items:flex-start;
}

.blog-authority-panel li .icon{
  width:19px;
  height:19px;
  color:var(--turq);
  flex:0 0 auto;
  margin-top:3px;
}

.blog-categories-section{
  padding:96px 0;
  background:#040404;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.blog-category-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}

.blog-category{
  min-height:104px;
  display:flex;
  align-items:center;
  gap:16px;
  padding:22px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.04);
  transition:transform .24s ease, border-color .24s ease, background .24s ease;
}

.blog-category:hover{
  transform:translateY(-4px);
  border-color:rgba(54,174,191,.48);
  background:rgba(54,174,191,.07);
}

.blog-category .icon{
  width:26px;
  height:26px;
  color:var(--turq);
  flex:0 0 auto;
}

.blog-category span{
  color:#fff;
  font-weight:800;
}

.blog-list-section{
  padding:104px 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(54,174,191,.10), transparent 31%),
    linear-gradient(180deg,#060606 0%,#090909 100%);
}

.blog-post-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}

.blog-post-card{
  min-height:330px;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.blog-post-card:hover{
  transform:translateY(-6px);
  border-color:rgba(54,174,191,.48);
}

.blog-post-card a{
  min-height:330px;
  height:100%;
  display:flex;
  flex-direction:column;
  padding:28px;
  color:inherit;
}

.blog-post-card h3{
  font-size:1.62rem;
  line-height:1.12;
  margin-bottom:14px;
}

.blog-post-card p{
  color:#c5d0d2;
  font-size:.94rem;
  line-height:1.68;
  margin-bottom:22px;
}

.blog-seo-section{
  padding:96px 0;
  background:
    radial-gradient(circle at 22% 18%, rgba(54,174,191,.16), transparent 34%),
    linear-gradient(135deg,#020202 0%,#090b0c 100%);
}

.blog-seo-card{
  min-height:240px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:34px;
}

.blog-seo-card h2{
  font-size:clamp(2.1rem,3.4vw,3.4rem);
  margin-bottom:12px;
}

.blog-seo-card p{
  color:#cbd4d6;
  max-width:800px;
}

@media(max-width:1080px){
  .blog-featured-grid,
  .blog-post-grid{
    grid-template-columns:1fr;
  }

  .blog-category-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

  .blog-featured-card a,
  .blog-authority-panel,
  .blog-post-card,
  .blog-post-card a{
    min-height:auto;
  }

  .blog-seo-card{
    flex-direction:column;
    align-items:flex-start;
  }
}

@media(max-width:720px){
  .blog-featured-section,
  .blog-categories-section,
  .blog-list-section,
  .blog-seo-section{
    padding:78px 0;
  }

  .blog-category-grid{
    grid-template-columns:1fr;
  }

  .blog-featured-card a,
  .blog-authority-panel,
  .blog-post-card a,
  .blog-seo-card{
    padding:24px;
    border-radius:24px;
  }

  .blog-seo-card .btn{
    width:100%;
  }
}


/* =========================================================
   AJUSTES FINALES PRODUCCIÓN
   Accesibilidad, formulario, consistencia y rendimiento visual.
   ========================================================= */

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--turq);
  outline-offset: 3px;
}

.field-invalid input,
.field-invalid select,
.field-invalid textarea,
.form-consent .field-invalid input {
  border-color: rgba(255,91,91,.72) !important;
  box-shadow: 0 0 0 4px rgba(255,91,91,.12) !important;
}

img {
  max-width: 100%;
  height: auto;
}

.site-header {
  will-change: background, box-shadow;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 1120px) {
  .nav-actions {
    display: none !important;
  }
}

@media print {
  .site-header,
  .whatsapp-float,
  .preloader,
  .nav-actions,
  .menu-toggle {
    display: none !important;
  }

  body {
    background: white !important;
    color: #111 !important;
  }
}


/* =========================================================
   CORRECCIÓN FINAL DE DIMENSIONES
   Control estricto de íconos, logos e imágenes para evitar distorsión.
   ========================================================= */

svg.icon{
  width:20px!important;
  height:20px!important;
  max-width:24px!important;
  max-height:24px!important;
  min-width:20px;
  min-height:20px;
  display:inline-block!important;
  vertical-align:middle;
  flex:0 0 auto;
}

.btn svg.icon,
.icon-btn svg.icon{
  width:18px!important;
  height:18px!important;
  min-width:18px;
  min-height:18px;
}

.nav-social,
.footer-socials a,
.final-socials a,
.social-strip a,
.contact-social-panel a{
  width:44px!important;
  height:44px!important;
  min-width:44px;
  min-height:44px;
  padding:0!important;
}

.nav-social svg.icon,
.footer-socials svg.icon,
.final-socials svg.icon,
.social-strip svg.icon,
.contact-social-panel svg.icon{
  width:20px!important;
  height:20px!important;
}

.whatsapp-float{
  width:56px!important;
  height:56px!important;
  min-width:56px;
  min-height:56px;
  padding:0!important;
}

.whatsapp-float svg.icon{
  width:30px!important;
  height:30px!important;
  min-width:30px;
  min-height:30px;
}

.brand img{
  width:54px!important;
  height:54px!important;
  max-width:54px!important;
  max-height:54px!important;
  object-fit:contain!important;
  flex:0 0 54px;
}

.footer-logo{
  width:120px!important;
  height:auto!important;
  max-width:120px!important;
}

.final-panel-logo img,
.contact-brand-block img{
  width:74px!important;
  height:74px!important;
  max-width:74px!important;
  max-height:74px!important;
  object-fit:contain!important;
}

.hero-badge img{
  width:48px!important;
  height:48px!important;
  max-width:48px!important;
  max-height:48px!important;
  object-fit:contain!important;
}

.preloader-inner img{
  width:130px!important;
  height:130px!important;
  max-width:130px!important;
  max-height:130px!important;
  object-fit:contain!important;
}

.hero-image-frame,
.authority-image-card,
.boutique-main-image,
.about-identity-visual{
  overflow:hidden!important;
}

.hero-image-frame img,
.authority-image-card img,
.boutique-main-image img,
.about-identity-visual img,
.image-card img,
.team-card img{
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  object-fit:cover!important;
}

.hero-image-frame{
  max-height:640px!important;
}

.authority-image-card{
  max-height:620px!important;
}

.boutique-stack{
  min-height:560px;
}

.boutique-main-image{
  max-height:560px!important;
}

.service-premium-icon svg.icon,
.metric-icon svg.icon,
.sector-icon svg.icon,
.insight-icon svg.icon,
.expertise-icon svg.icon,
.blog-panel-icon svg.icon,
.about-purpose-icon svg.icon,
.service-detail-icon svg.icon{
  width:26px!important;
  height:26px!important;
}

.service-detail-icon svg.icon{
  width:32px!important;
  height:32px!important;
}

@media(max-width:680px){
  .brand img{
    width:46px!important;
    height:46px!important;
    max-width:46px!important;
    max-height:46px!important;
    flex-basis:46px;
  }

  .hero-image-frame,
  .authority-image-card,
  .boutique-main-image,
  .about-identity-visual{
    max-height:520px!important;
  }

  .final-panel-logo img,
  .contact-brand-block img{
    width:62px!important;
    height:62px!important;
    max-width:62px!important;
    max-height:62px!important;
  }
}
