/* IRP V49 - pulido final */
*{box-sizing:border-box}
:root{
  --blue:#062b56;
  --deep:#031f3f;
  --yellow:#f6a313;
  --text:#071f3d;
  --muted:#50627a;
  --line:#e5edf5;
}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:#f3f7fc;color:var(--text)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1240px,calc(100% - 40px));margin:0 auto}

.topbar{background:#062b56;color:#fff;font-size:14px;font-weight:700}
.topbar__inner{height:62px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.topbar__left,.topbar__right,a{display:flex;align-items:center;gap:10px}
.topbar__right{gap:22px}
.pipe{width:1px;height:24px;background:rgba(255,255,255,.35)}
.top-icon,.btn-icon{width:20px;height:20px;display:inline-block;background-position:center;background-repeat:no-repeat;background-size:contain}
.phone{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2A19.8 19.8 0 0 1 3.1 5.18 2 2 0 0 1 5.11 3h3a2 2 0 0 1 2 1.72c.12.9.33 1.77.62 2.61a2 2 0 0 1-.45 2.11L9 10.7a16 16 0 0 0 4.3 4.3l1.26-1.26a2 2 0 0 1 2.11-.45c.84.29 1.71.5 2.61.62A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E")}
.whats{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 11.5a8 8 0 0 1-11.9 7L4 20l1.6-3.9A8 8 0 1 1 20 11.5z'/%3E%3Cpath d='M9 8.5c.5 2.4 2.1 4 4.5 4.5l1-1.2 2 1.1c.2.1.3.4.2.6-.4 1-1.1 1.6-2.2 1.5-3.1-.2-6.1-3.2-6.3-6.3 0-1.1.5-1.8 1.5-2.2.2-.1.5 0 .6.2l1.1 2-1.4 1z'/%3E%3C/svg%3E")}

.header{background:#fff;box-shadow:0 1px 0 rgba(8,35,67,.08);position:relative;z-index:20}
.header__inner{height:126px;display:flex;align-items:center;justify-content:space-between;gap:30px}
.logo img{width:200px;height:auto}
.nav{display:flex;align-items:center;gap:34px;font-size:15px;font-weight:900;text-transform:uppercase;color:#071f3d}
.nav a{position:relative;white-space:nowrap}
.nav a.active,.nav a:hover{color:var(--yellow)}
.nav a:not(.nav-btn)::after{content:"";position:absolute;left:0;bottom:-12px;width:0;height:4px;border-radius:999px;background:var(--yellow);transition:.2s}
.nav a.active::after,.nav a:hover::after{width:100%}
.nav-btn{background:var(--yellow);color:#fff!important;padding:20px 30px;border-radius:12px;box-shadow:0 12px 26px rgba(246,163,19,.25);gap:14px}
.nav-btn span{font-size:28px;line-height:0}
.menu-toggle{display:none}

/* HERO PHP REAL */
.hero{background:#f3f7fc;padding:0 0 36px}
.hero__shell{position:relative;display:grid;grid-template-columns:44% 56%;min-height:620px;background:#062b56;overflow:hidden}
.hero__copy{position:relative;z-index:5;overflow:hidden;clip-path:polygon(0 0,100% 0,89% 100%,0 100%);margin-right:-62px}
.hero__copy-bg{position:absolute;inset:0;background:url("assets/hero-bg-industrial.jpg") center/cover no-repeat;filter:brightness(.62) saturate(.75)}
.hero__copy-shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,21,42,.97),rgba(6,43,86,.92) 62%,rgba(6,43,86,.38))}
.hero__content{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;padding:64px 82px 142px 66px;color:#fff}
.hero__content h1{margin:0 0 24px;text-transform:uppercase;font-size:clamp(46px,4.2vw,70px);line-height:.98;letter-spacing:-.05em;font-weight:900;color:#fff;text-shadow:0 8px 20px rgba(0,0,0,.16)}
.hero__content h1 span{color:var(--yellow)}
.hero__content p{max-width:610px;margin:0;color:#fff;font-size:24px;line-height:1.45;font-weight:500}
.hero__actions{display:flex;gap:20px;flex-wrap:wrap;margin-top:34px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:20px 28px;border-radius:12px;font-weight:900;font-size:18px}
.btn-primary{background:var(--yellow);color:#fff;box-shadow:0 16px 30px rgba(246,163,19,.27)}
.btn-secondary{background:rgba(255,255,255,.03);color:#fff;border:2px solid rgba(255,255,255,.65)}
.btn-secondary span{font-size:28px;line-height:0}

.hero__collage{position:relative;z-index:1;overflow:hidden;background:#062b56}
.hero__collage::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,43,86,0),rgba(6,43,86,.18) 72%,rgba(6,43,86,.28));pointer-events:none}
.slice{position:absolute;top:0;bottom:0;overflow:hidden;clip-path:polygon(25% 0,100% 0,75% 100%,0 100%);box-shadow:inset 2px 0 0 rgba(255,255,255,.75),inset -2px 0 0 rgba(255,255,255,.75)}
.slice img{width:100%;height:100%;object-fit:cover;filter:saturate(1.06) contrast(1.04) brightness(.99);transform:scale(1.08);transition:.25s}
.slice--solar{left:0;width:29%;z-index:1}.slice--solar img{object-position:48% center}
.slice--data{left:24%;width:29%;z-index:2}.slice--data img{object-position:50% center}
.slice--access{left:49%;width:28%;z-index:3}.slice--access img{object-position:56% center}
.slice--air{left:73%;width:29%;z-index:4}.slice--air img{object-position:62% center}

.hero__servicebar{position:absolute;z-index:10;right:7%;bottom:84px;width:52%;display:grid;grid-template-columns:repeat(4,1fr);border-radius:14px;overflow:hidden;background:rgba(6,43,86,.88);backdrop-filter:blur(10px);box-shadow:0 18px 34px rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.12)}
.hero-service{min-height:142px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#fff;text-align:center;border-right:1px solid rgba(255,255,255,.15)}
.hero-service:last-child{border-right:0}
.hero-service strong{text-transform:uppercase;font-size:17px;line-height:1.15;font-weight:900}
.service-icon{width:54px;height:54px;background-repeat:no-repeat;background-size:contain;background-position:center;display:block}
.service-icon.solar{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M25 10h14M32 5v7M15 32h34M19 32l4 17h18l4-17M20 39h24M29 32v17M37 32v17M32 49v9M24 58h16'/%3E%3C/g%3E%3Cpath d='M20 23a12 12 0 0 1 24 0' stroke='%23f6a313' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E")}
.service-icon.data{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='27' y='9' width='10' height='10' rx='2'/%3E%3Crect x='9' y='45' width='10' height='10' rx='2'/%3E%3Crect x='27' y='45' width='10' height='10' rx='2'/%3E%3Crect x='45' y='45' width='10' height='10' rx='2'/%3E%3Cpath d='M32 19v14M14 33h36M14 33v12M32 33v12M50 33v12'/%3E%3C/g%3E%3C/svg%3E")}
.service-icon.access{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='18' y='28' width='28' height='23' rx='4'/%3E%3Cpath d='M24 28v-6a8 8 0 0 1 16 0v6M32 37v6'/%3E%3Ccircle cx='32' cy='37' r='2' fill='%23fff' stroke='none'/%3E%3C/g%3E%3C/svg%3E")}
.service-icon.air{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M32 8v48M32 13l-6 6M32 13l6 6M32 51l-6-6M32 51l6-6M11 21l42 22M11 43l42-22'/%3E%3C/g%3E%3C/svg%3E")}

.hero__metrics{width:min(1520px,calc(100% - 128px));margin:-50px auto 0;position:relative;z-index:12;background:#fff;border-radius:18px;display:grid;grid-template-columns:repeat(5,1fr);box-shadow:0 18px 34px rgba(8,35,67,.10);border:1px solid var(--line);overflow:hidden}
.hero__metrics article{min-height:132px;display:flex;align-items:center;gap:22px;padding:26px 34px;border-right:1px solid var(--line)}
.hero__metrics article:last-child{border-right:0}
.metric-icon{width:58px;height:58px;flex:0 0 58px;background-repeat:no-repeat;background-size:contain;background-position:center}
.metric-icon.shield{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cpath d='M32 9l17 6v12c0 13-8 22-17 27-9-5-17-14-17-27V15l17-6z' stroke='%23062b56' stroke-width='3'/%3E%3Cpath d='M24 32l5 5 11-13' stroke='%23062b56' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.metric-icon.team{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23062b56' stroke-width='3' stroke-linecap='round'%3E%3Ccircle cx='25' cy='24' r='7'/%3E%3Ccircle cx='42' cy='27' r='5'/%3E%3Cpath d='M12 50c2-8 8-12 14-12s12 4 14 12M39 50c1.5-5 5-8 10-8 3 0 6 2 8 5'/%3E%3C/g%3E%3C/svg%3E")}
.metric-icon.badge{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23062b56' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='32' cy='24' r='12'/%3E%3Cpath d='M25 36l-4 18 11-6 11 6-4-18'/%3E%3C/g%3E%3C/svg%3E")}
.metric-icon.headset{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23062b56' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M16 34a16 16 0 0 1 32 0'/%3E%3Crect x='12' y='34' width='8' height='14' rx='4'/%3E%3Crect x='44' y='34' width='8' height='14' rx='4'/%3E%3Cpath d='M50 48c0 5-4 8-9 8h-5'/%3E%3C/g%3E%3C/svg%3E")}
.metric-icon.pin{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cg stroke='%23062b56' stroke-width='3'%3E%3Cpath d='M32 54s15-15 15-28a15 15 0 1 0-30 0c0 13 15 28 15 28z'/%3E%3Ccircle cx='32' cy='26' r='5'/%3E%3C/g%3E%3C/svg%3E")}
.hero__metrics strong{display:block;font-size:23px;color:var(--blue);line-height:1.05}
.hero__metrics span{display:block;margin-top:6px;color:#41536b;font-size:15px;line-height:1.35}

.section{padding:86px 0;background:#f3f7fc}.section--dark{background:#062b56;color:#fff}.section--contact{background:#fff}
.section-head{max-width:760px;margin-bottom:34px}.section-head.center{text-align:center;margin-left:auto;margin-right:auto}.section-head.light h2,.section-head.light p{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--yellow);text-transform:uppercase;font-size:13px;font-weight:900;letter-spacing:.18em;margin-bottom:10px}.eyebrow::before{content:"";width:8px;height:8px;border-radius:99px;background:var(--yellow)}
h2{font-size:clamp(32px,4vw,48px);line-height:1.05;margin:0 0 14px;color:var(--blue);letter-spacing:-.04em}p{font-size:17px;line-height:1.7;color:var(--muted);margin:0}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.service-card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 14px 30px rgba(8,35,67,.08)}.service-card img{width:100%;height:170px;object-fit:cover}.service-card__body{padding:20px}.service-card h3{margin:0 0 8px;color:var(--blue);font-size:20px}.service-card p{font-size:15px;line-height:1.55}
.project-band{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.project-band article{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:28px;border-radius:16px}.project-band strong{display:block;font-size:44px;color:var(--yellow);line-height:1}.project-band span{display:block;margin-top:8px;color:#eaf2ff;font-weight:700}
.process-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:40px}.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.steps article{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 12px 28px rgba(8,35,67,.06)}.steps span{color:var(--yellow);font-weight:900}.steps h3{margin:12px 0 8px;color:var(--blue);font-size:22px}
.contact-box{display:flex;align-items:center;justify-content:space-between;gap:24px;background:var(--blue);color:#fff;border-radius:24px;padding:42px;box-shadow:0 18px 42px rgba(8,35,67,.16)}.contact-box h2,.contact-box p{color:#fff}.btn-main{display:inline-flex;align-items:center;justify-content:center;background:var(--yellow);color:#fff;font-weight:900;border-radius:14px;padding:18px 24px;box-shadow:0 14px 28px rgba(246,163,19,.25);white-space:nowrap}
.whatsapp-float{position:fixed;right:24px;bottom:24px;z-index:40;width:56px;height:56px;border-radius:99px;background:#25d366;color:#fff;display:grid;place-items:center;font-size:24px;font-weight:900;box-shadow:0 12px 28px rgba(37,211,102,.34)}

@media(max-width:1250px){.nav{gap:18px}.hero__content h1{font-size:54px}.hero__content p{font-size:20px}.hero__metrics{width:min(100% - 40px,1520px)}}
@media(max-width:1050px){.topbar__left{display:none}.menu-toggle{display:grid;gap:5px;background:transparent;border:0}.menu-toggle span{width:28px;height:3px;background:var(--blue)}.nav{position:absolute;left:20px;right:20px;top:110px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px;display:none;flex-direction:column;align-items:flex-start}.nav.open{display:flex}.hero__shell{grid-template-columns:1fr}.hero__copy{clip-path:none;margin-right:0}.hero__collage{height:380px}.slice{position:relative!important;left:auto!important;width:auto!important;clip-path:none}.hero__collage{display:grid;grid-template-columns:repeat(4,1fr)}.hero__servicebar{position:relative;right:auto;bottom:auto;width:auto;margin:0 20px 20px;grid-template-columns:repeat(2,1fr)}.hero__metrics{grid-template-columns:repeat(2,1fr);margin-top:20px}.services-grid{grid-template-columns:repeat(2,1fr)}.process-grid{grid-template-columns:1fr}.project-band{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.header__inner{height:92px}.logo img{width:160px}.hero__content{padding:40px 22px 34px}.hero__content h1{font-size:39px}.hero__content p{font-size:16px}.hero__actions,.btn{width:100%}.hero__collage{grid-template-columns:repeat(2,1fr);height:280px}.hero__servicebar{grid-template-columns:repeat(2,1fr)}.hero-service{min-height:105px}.hero-service strong{font-size:13px}.service-icon{width:40px;height:40px}.hero__metrics,.services-grid,.project-band,.steps{grid-template-columns:1fr}.hero__metrics article{border-right:0;border-bottom:1px solid var(--line)}.contact-box{display:block;padding:28px}.btn-main{margin-top:24px;width:100%}.container{width:min(100% - 24px,1240px)}}






/* V49 - pulido final: menos franja azul, barra más tipo mockup */
.hero__copy{
  clip-path: polygon(0 0, 100% 0, 91% 100%, 0 100%) !important;
  margin-right: -48px !important;
}
.hero__copy-shade{
  background: linear-gradient(90deg,rgba(3,21,42,.98),rgba(6,43,86,.94) 60%,rgba(6,43,86,.30)) !important;
}

.slice{
  clip-path: polygon(15% 0, 100% 0, 85% 100%, 0 100%) !important;
  box-shadow:
    inset 1px 0 0 rgba(255,255,255,.82),
    inset -1px 0 0 rgba(255,255,255,.82) !important;
}

/* Collage más lleno, con menos hueco azul entre paneles */
.slice--solar{left:-2.8% !important;width:35% !important;z-index:1}
.slice--data{left:23% !important;width:35% !important;z-index:2}
.slice--access{left:49.2% !important;width:32% !important;z-index:3}
.slice--air{left:72.5% !important;width:35.5% !important;z-index:4}

.slice--solar img{object-position:50% center !important}
.slice--data img{object-position:50% center !important}
.slice--access img{object-position:59% center !important}
.slice--air img{object-position:65% center !important}

/* Barra de iconos un poquito más premium y centrada visualmente */
.hero__servicebar{
  bottom:92px !important;
  width:56% !important;
  right:5.8% !important;
  border-radius:14px !important;
  background: rgba(6,43,86,.90) !important;
}
.hero-service{
  min-height:136px !important;
  gap:10px !important;
}
.service-icon{
  width:50px !important;
  height:50px !important;
}
.hero-service strong{
  font-size:15px !important;
}

/* Métricas integradas al hero como en mockup */
.hero__metrics{
  margin-top:-58px !important;
}

/* Texto un poquito más equilibrado */
.hero__content h1{
  letter-spacing:-.055em !important;
}
.hero__content p{
  max-width:590px !important;
}


/* V50 - diagonales uniformes y marco blanco real */

.hero__copy{
  clip-path: polygon(0 0, 100% 0, 65% 100%, 0 100%) !important;
  margin-right: -42px !important;
}
.hero__copy-shade{
  background: linear-gradient(90deg, rgba(3,21,42,.98), rgba(6,43,86,.94) 60%, rgba(6,43,86,.28)) !important;
}

.hero__collage{
  background:#062b56 !important;
}

/* Todas las diagonales con el mismo ángulo */
.slice{
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
  background:#ffffff !important;
  box-shadow:none !important;
}

/* Marco blanco en el cuadro, no dentro de la imagen fuente */
.slice img{
  position:absolute !important;
  inset:3px !important;
  width:calc(100% - 6px) !important;
  height:calc(100% - 6px) !important;
  object-fit:cover !important;
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
  transform:scale(1.06) !important;
}

/* Paneles totalmente uniformes y paralelos */
.slice--solar,
.slice--data,
.slice--access,
.slice--air{
  width:34% !important;
}

.slice--solar{left:-4% !important; z-index:1;}
.slice--data{left:20.5% !important; z-index:2;}
.slice--access{left:45% !important; z-index:3;}
.slice--air{left:69.5% !important; z-index:4;}

.slice--solar img{object-position:50% center !important;}
.slice--data img{object-position:50% center !important;}
.slice--access img{object-position:58% center !important;}
.slice--air img{object-position:64% center !important;}

.hero__servicebar{
  width:56% !important;
  right:5.8% !important;
  bottom:92px !important;
}

.hero__metrics{
  margin-top:-58px !important;
}


/* V52 - marco blanco delgado sin separar demasiado las imágenes */
.hero__collage{
  background:#062b56 !important;
}

/* Diagonales uniformes y paralelas */
.slice{
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
  background:#ffffff !important;
  box-shadow:none !important;
}

/* Marco blanco delgado generado por el contenedor */
.slice img{
  position:absolute !important;
  inset:2px !important;
  width:calc(100% - 4px) !important;
  height:calc(100% - 4px) !important;
  object-fit:cover !important;
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
  transform:scale(1.06) !important;
}

/* Mantener imágenes juntas: sin huecos blancos exagerados */
.slice--solar,
.slice--data,
.slice--access,
.slice--air{
  width:34% !important;
}

.slice--solar{left:-4% !important; z-index:1 !important;}
.slice--data{left:20.5% !important; z-index:2 !important;}
.slice--access{left:45% !important; z-index:3 !important;}
.slice--air{left:69.5% !important; z-index:4 !important;}

.slice--solar img{object-position:50% center !important;}
.slice--data img{object-position:50% center !important;}
.slice--access img{object-position:58% center !important;}
.slice--air img{object-position:64% center !important;}

/* Barra de iconos conservada, sin tapar demasiado */
.hero__servicebar{
  width:56% !important;
  right:5.8% !important;
  bottom:92px !important;
}


/* V53 - diagonal del bloque de texto paralela a las imágenes */
.hero__copy{
  clip-path: polygon(0 0, 100% 0, 65% 100%, 0 100%) !important;
  margin-right: -42px !important;
}

/* La capa de sombra sigue la misma diagonal para que no se vea descuadrada */
.hero__copy-shade{
  background:
    linear-gradient(90deg,
      rgba(3,21,42,.98) 0%,
      rgba(6,43,86,.95) 58%,
      rgba(6,43,86,.34) 100%) !important;
}

/* Mantener todas las piezas del collage paralelas al bloque izquierdo */
.slice{
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
}
.slice img{
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
}


/* V54 - corrección real: la diagonal del bloque de texto sí queda paralela a las demás */
:root{
  --diag-slice-top:35%;
  --diag-slice-bottom:65%;
  --diag-copy-bottom:85%;
}

/* Mantener todas las diagonales del collage exactamente iguales */
.slice,
.slice img{
  clip-path: polygon(var(--diag-slice-top) 0, 100% 0, var(--diag-slice-bottom) 100%, 0 100%) !important;
}

/* Ajuste real del bloque izquierdo: misma inclinación visual que los paneles */
.hero__copy{
  clip-path: polygon(0 0, 100% 0, var(--diag-copy-bottom) 100%, 0 100%) !important;
  margin-right: -18px !important;
}

/* La sombra acompaña el nuevo corte para que no se vea rara */
.hero__copy-shade{
  background: linear-gradient(90deg,
    rgba(3,21,42,.985) 0%,
    rgba(6,43,86,.95) 58%,
    rgba(6,43,86,.42) 82%,
    rgba(6,43,86,.12) 100%) !important;
}

/* En tablet y móvil quitamos el corte para que no rompa el layout */
@media(max-width:1050px){
  .hero__copy{
    clip-path:none !important;
    margin-right:0 !important;
  }
}


/* =========================================================
   V55 - CORRECCION FUERTE
   El bloque azul izquierdo quedó con una diagonal más cerrada
   para verse paralela a los cortes de las imágenes.
   Se carga como styles-v55.css para evitar cache del navegador.
   ========================================================= */

body .hero .hero__shell > .hero__copy{
  /*
    Antes se veía muy abierta.
    Con 86% el punto inferior derecho se acerca y la diagonal queda
    visualmente paralela a los paneles del collage.
  */
  clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%) !important;
  -webkit-clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%) !important;
  margin-right: -18px !important;
}

/* La sombra también se ajusta para que no parezca otra diagonal */
body .hero .hero__shell > .hero__copy .hero__copy-shade{
  background:
    linear-gradient(90deg,
      rgba(3,21,42,.985) 0%,
      rgba(6,43,86,.955) 58%,
      rgba(6,43,86,.44) 84%,
      rgba(6,43,86,.10) 100%) !important;
}

/* Mantener las imágenes del collage uniformes y paralelas */
body .hero .hero__collage .slice,
body .hero .hero__collage .slice img{
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
  -webkit-clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
}

/* Marco blanco delgado generado por contenedor, no por la imagen */
body .hero .hero__collage .slice{
  background:#ffffff !important;
}
body .hero .hero__collage .slice img{
  inset:2px !important;
  width:calc(100% - 4px) !important;
  height:calc(100% - 4px) !important;
}

/* Evitar que en móvil se rompa */
@media(max-width:1050px){
  body .hero .hero__shell > .hero__copy{
    clip-path:none !important;
    -webkit-clip-path:none !important;
    margin-right:0 !important;
  }
}


/* =========================================================
   V57 - BASE V55 + JUNTAR DIAGONALES
   Mantiene la diagonal de V55, pero acerca el primer panel
   para que no se vea tanta separación entre la diagonal del
   bloque azul y la diagonal de la primera imagen.
   ========================================================= */

body .hero .hero__shell > .hero__copy{
  clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%) !important;
  -webkit-clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%) !important;
  margin-right: -18px !important;
}

body .hero .hero__collage .slice,
body .hero .hero__collage .slice img{
  clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
  -webkit-clip-path: polygon(35% 0, 100% 0, 65% 100%, 0 100%) !important;
}

body .hero .hero__collage .slice{
  background:#ffffff !important;
  box-shadow:none !important;
}

body .hero .hero__collage .slice img{
  inset:2px !important;
  width:calc(100% - 4px) !important;
  height:calc(100% - 4px) !important;
  object-fit:cover !important;
  transform:scale(1.06) !important;
}

/* Acercar primera imagen a la diagonal del bloque azul */
body .hero .hero__collage .slice--solar{
  left:-7.5% !important;
  width:36% !important;
}
body .hero .hero__collage .slice--data{
  left:18.8% !important;
  width:36% !important;
}
body .hero .hero__collage .slice--access{
  left:45% !important;
  width:34% !important;
}
body .hero .hero__collage .slice--air{
  left:70.8% !important;
  width:36% !important;
}

body .hero .hero__servicebar{
  width:56% !important;
  right:5.8% !important;
  bottom:92px !important;
}

@media(max-width:1050px){
  body .hero .hero__shell > .hero__copy{
    clip-path:none !important;
    -webkit-clip-path:none !important;
    margin-right:0 !important;
  }
  body .hero .hero__collage .slice--solar,
  body .hero .hero__collage .slice--data,
  body .hero .hero__collage .slice--access,
  body .hero .hero__collage .slice--air{
    left:auto !important;
    width:auto !important;
  }
}


/* V65 - solar abierta y barra más baja */
body .hero .hero__shell > .hero__copy{
  clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%) !important;
  -webkit-clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%) !important;
  margin-right: -18px !important;
}
body .hero .hero__collage .slice{
  clip-path: polygon(35% 0,100% 0,65% 100%,0 100%) !important;
  -webkit-clip-path: polygon(35% 0,100% 0,65% 100%,0 100%) !important;
  background:#fff !important;
  box-shadow:none !important;
  overflow:hidden !important;
}
body .hero .hero__collage .slice img{
  position:absolute !important;
  inset:2px !important;
  width:calc(100% - 4px) !important;
  height:calc(100% - 4px) !important;
  object-fit:cover !important;
  clip-path:polygon(35% 0,100% 0,65% 100%,0 100%) !important;
  -webkit-clip-path:polygon(35% 0,100% 0,65% 100%,0 100%) !important;
  transform:scale(1.04) !important;
}
body .hero .hero__collage .slice--solar{left:-13.5% !important;width:43.5% !important;z-index:1 !important;}
body .hero .hero__collage .slice--solar img{object-position:48% 64% !important;transform:scale(1.02) !important;}
body .hero .hero__collage .slice--data{left:19.0% !important;width:36% !important;z-index:2 !important;}
body .hero .hero__collage .slice--data img{object-position:50% center !important;}
body .hero .hero__collage .slice--access{left:45.2% !important;width:34% !important;z-index:3 !important;}
body .hero .hero__collage .slice--access img{object-position:56% center !important;}
body .hero .hero__collage .slice--air{left:71.0% !important;width:36% !important;z-index:4 !important;}
body .hero .hero__collage .slice--air img{object-position:62% center !important;}
body .hero .hero__servicebar{width:56% !important;right:5.8% !important;bottom:76px !important;border-radius:14px !important;}
body .hero .hero-service{min-height:118px !important;gap:8px !important;}
body .hero .service-icon{width:45px !important;height:45px !important;}
body .hero .hero-service strong{font-size:14px !important;}


/* V66 - más panel solar visible */
body .hero .hero__shell > .hero__copy{clip-path:polygon(0 0,100% 0,86% 100%,0 100%) !important;-webkit-clip-path:polygon(0 0,100% 0,86% 100%,0 100%) !important;margin-right:-18px !important;}
body .hero .hero__collage .slice{clip-path:polygon(35% 0,100% 0,65% 100%,0 100%) !important;-webkit-clip-path:polygon(35% 0,100% 0,65% 100%,0 100%) !important;background:#fff !important;box-shadow:none !important;overflow:hidden !important;}
body .hero .hero__collage .slice img{position:absolute !important;inset:2px !important;width:calc(100% - 4px) !important;height:calc(100% - 4px) !important;object-fit:cover !important;clip-path:polygon(35% 0,100% 0,65% 100%,0 100%) !important;-webkit-clip-path:polygon(35% 0,100% 0,65% 100%,0 100%) !important;transform:scale(1.03) !important;}
body .hero .hero__collage .slice--solar{left:-13.5% !important;width:43.5% !important;z-index:1 !important;}
body .hero .hero__collage .slice--solar img{object-position:48% 88% !important;transform:scale(1.00) !important;}
body .hero .hero__collage .slice--data{left:19.0% !important;width:36% !important;z-index:2 !important;}
body .hero .hero__collage .slice--data img{object-position:50% center !important;}
body .hero .hero__collage .slice--access{left:45.2% !important;width:34% !important;z-index:3 !important;}
body .hero .hero__collage .slice--access img{object-position:56% center !important;}
body .hero .hero__collage .slice--air{left:71.0% !important;width:36% !important;z-index:4 !important;}
body .hero .hero__collage .slice--air img{object-position:62% center !important;}
body .hero .hero__servicebar{width:56% !important;right:5.8% !important;bottom:58px !important;border-radius:14px !important;}
body .hero .hero-service{min-height:104px !important;gap:6px !important;}
body .hero .service-icon{width:40px !important;height:40px !important;}
body .hero .hero-service strong{font-size:13px !important;line-height:1.05 !important;}
