
*{box-sizing:border-box}
:root{--cyan:#32dcff;--cyan2:#8ff2ff;--text:#f4fbff;--muted:#b7d8e7;--dark:#03070c;--panel:rgba(5,13,20,.74)}
html{scroll-behavior:smooth}
body{margin:0;background:#02060a;color:var(--text);font-family:Arial,Helvetica,sans-serif;overflow-x:hidden}
.background-dc{position:fixed;inset:0;background:url('datacenter.webp') center/cover no-repeat;z-index:-3;animation:zoomMove 24s ease-in-out infinite alternate}
.background-overlay{position:fixed;inset:0;background:linear-gradient(180deg,rgba(0,7,12,.68),rgba(0,9,16,.90));z-index:-2}
.scan{pointer-events:none;position:fixed;inset:0;background:repeating-linear-gradient(to bottom,rgba(255,255,255,.035) 0,rgba(255,255,255,.035) 1px,transparent 1px,transparent 5px);opacity:.10;z-index:20}
@keyframes zoomMove{0%{transform:scale(1) translateY(0)}100%{transform:scale(1.08) translateY(-18px)}}
.topbar{height:82px;display:flex;align-items:center;justify-content:space-between;padding:0 56px;background:rgba(3,8,13,.70);border-bottom:1px solid rgba(50,220,255,.28);backdrop-filter:blur(14px);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:flex-end;gap:16px;text-decoration:none;color:var(--text)}
.logo-img{height:70px;width:auto;display:block;filter:drop-shadow(0 0 15px rgba(50,220,255,.18))}
.brand-text b{display:block;font-size:18px}.brand-text span{display:block;color:var(--muted);font-size:12px;margin-top:2px}
nav{display:flex;gap:8px}nav a{color:var(--text);text-decoration:none;border:1px solid transparent;border-radius:999px;padding:10px 15px;font-size:14px}nav a:hover{background:rgba(50,220,255,.10);border-color:rgba(50,220,255,.42)}
.hero{min-height:calc(100vh - 82px);display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;padding:70px 7vw}
.eyebrow,.section-title span,.service-hero span{color:var(--cyan2);letter-spacing:2.4px;font-size:18px;font-weight:800}
h1{font-size:clamp(44px,6vw,82px);line-height:.96;margin:18px 0 22px;text-transform:uppercase;text-shadow:0 0 30px rgba(0,0,0,.8)}
.lead{color:#d7f5ff;font-size:19px;line-height:1.55;max-width:720px;text-shadow:0 0 18px #000}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 20px;border-radius:14px;text-decoration:none;font-weight:800;transition:.2s}
.btn.primary{color:#001015;background:linear-gradient(180deg,var(--cyan2),var(--cyan));box-shadow:0 10px 32px rgba(50,220,255,.22)}
.btn.ghost{color:var(--text);border:1px solid rgba(136,241,255,.38);background:rgba(3,10,16,.45)}
.btn:hover{transform:translateY(-2px)}
.hero-actions{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.hmi{background:linear-gradient(180deg,rgba(14,24,34,.84),rgba(5,9,14,.90));border:1px solid rgba(50,220,255,.32);border-radius:26px;padding:22px;box-shadow:0 26px 70px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(10px)}
.hmi-head{display:flex;justify-content:space-between;border-bottom:1px solid rgba(136,241,255,.16);padding-bottom:14px;color:var(--muted);font-size:13px;letter-spacing:1.5px}.hmi-head b{color:#70ff9c}
.rack{display:grid;gap:12px;margin:24px 0}.rack div{height:42px;border-radius:10px;border:1px solid rgba(136,241,255,.15);background:linear-gradient(90deg,rgba(255,255,255,.06),rgba(255,255,255,.02));position:relative;overflow:hidden}.rack div:before{content:"";position:absolute;left:15px;top:50%;width:10px;height:10px;margin-top:-5px;border-radius:50%;background:#70ff9c;box-shadow:0 0 16px #70ff9c}.rack div:nth-child(5):before{background:#ffbf3d;box-shadow:0 0 16px #ffbf3d}.rack div:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(50,220,255,.14),transparent);animation:sweep 2.8s infinite}@keyframes sweep{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.telemetry{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.telemetry a,.card,.detail-card,.mini,.contact-card{background:var(--panel);border:1px solid rgba(136,241,255,.22);border-radius:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 16px 40px rgba(0,0,0,.22);backdrop-filter:blur(10px)}
.telemetry a{padding:16px;text-decoration:none;color:var(--text);transition:.2s}.telemetry a:hover{transform:translateY(-2px);border-color:rgba(50,220,255,.75);box-shadow:0 16px 40px rgba(0,0,0,.30),0 0 24px rgba(50,220,255,.14)}.telemetry span{display:block;color:var(--muted);font-size:12px}.telemetry strong{display:block;color:var(--cyan2);font-size:22px;margin-top:6px}
.section{padding:82px 7vw}.section-title{text-align:center;max-width:780px;margin:0 auto 40px}.section-title h2{font-size:clamp(30px,4vw,52px);line-height:1.05;margin:14px 0}.section-title p{color:var(--muted);font-size:17px;line-height:1.5}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{padding:26px;min-height:220px;text-decoration:none;color:var(--text);transition:.2s}.card:hover{transform:translateY(-5px);border-color:rgba(50,220,255,.75);box-shadow:0 20px 42px rgba(0,0,0,.35),0 0 28px rgba(50,220,255,.12)}
.icon{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(145deg,var(--cyan2),var(--cyan));color:#001015;font-weight:900;margin-bottom:18px}.card h3{font-size:23px;margin:0 0 10px}.card p{color:var(--muted);line-height:1.55;margin:0}.card small{display:block;color:var(--cyan2);margin-top:18px;font-weight:800}
.service-hero{padding:76px 7vw 36px}.service-hero h1{max-width:900px}.service-layout{display:grid;grid-template-columns:1fr 380px;gap:24px;padding:20px 7vw 80px}.detail-card{padding:34px}.detail-card h2{font-size:34px;margin:0 0 16px}.detail-card p{color:#d7f5ff;font-size:18px;line-height:1.6}.service-list{display:grid;gap:12px;margin-top:26px;padding:0}.service-list li{list-style:none;padding:16px 18px;border:1px solid rgba(136,241,255,.16);border-radius:14px;background:rgba(255,255,255,.035);color:var(--muted)}.mini{padding:24px}.mini h3{margin-top:0}.mini p{color:var(--muted);line-height:1.5}.back{margin-top:18px;width:100%}
.contact{padding:70px 7vw;background:linear-gradient(90deg,rgba(50,220,255,.08),rgba(255,255,255,.02),rgba(50,220,255,.08));display:grid;grid-template-columns:1fr 420px;gap:36px;align-items:center}.contact h2{font-size:42px;margin:12px 0}.contact p{color:var(--muted)}.contact-card{padding:26px}.contact-card p{margin:0 0 12px;color:var(--text)}
footer{display:flex;justify-content:space-between;padding:22px 7vw;border-top:1px solid rgba(136,241,255,.15);color:var(--muted);background:rgba(0,0,0,.28)}
@media(max-width:980px){.hero,.service-layout,.contact{grid-template-columns:1fr}.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:660px){.topbar{padding:0 18px}.brand-text{display:none}nav{display:none}.hero,.section,.service-hero,.service-layout,.contact{padding-left:22px;padding-right:22px}.cards,.telemetry{grid-template-columns:1fr}footer{display:block}.logo-img{height:48px}}


.rack-row:hover{
background:rgba(50,220,255,.08);
border-color:rgba(50,220,255,.6);
}

/* === Nivel sala de control minera / industrial === */
body:before{
content:"";
position:fixed;
inset:0;
pointer-events:none;
z-index:-1;
background:
linear-gradient(90deg,rgba(255,176,35,.06) 0 1px,transparent 1px 100%),
linear-gradient(0deg,rgba(255,176,35,.045) 0 1px,transparent 1px 100%);
background-size:64px 64px;
mask-image:linear-gradient(to bottom,rgba(0,0,0,.45),transparent 78%);
}
.topbar:after{
content:"MINERÍA • INDUSTRIA • INFRAESTRUCTURA CRÍTICA • SOPORTE 24/7";
position:absolute;
left:50%;
bottom:-24px;
transform:translateX(-50%);
color:#ffbf3d;
font-size:11px;
letter-spacing:2.2px;
text-shadow:0 0 16px rgba(255,191,61,.55);
white-space:nowrap;
}
.industrial-badges{
display:flex;
gap:10px;
flex-wrap:wrap;
margin-top:22px;
}
.industrial-badges span{
border:1px solid rgba(255,191,61,.35);
background:rgba(255,191,61,.08);
color:#ffd994;
padding:9px 12px;
border-radius:999px;
font-size:12px;
font-weight:800;
letter-spacing:.7px;
box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 0 18px rgba(255,191,61,.10);
}
.hmi{
position:relative;
overflow:hidden;
}
.hmi:before{
content:"";
position:absolute;
inset:-2px;
background:linear-gradient(115deg,transparent 0%,rgba(255,191,61,.16) 18%,transparent 38%,rgba(50,220,255,.12) 58%,transparent 78%);
transform:translateX(-100%);
animation:controlSweep 5.5s infinite;
pointer-events:none;
}
@keyframes controlSweep{to{transform:translateX(100%)}}
.hmi-head span:before{
content:"● ";
color:#70ff9c;
text-shadow:0 0 14px #70ff9c;
}
.rack{
position:relative;
z-index:1;
}

.rack-row b{
font-size:14px;
color:#f4fbff;
}
.rack-row span{
font-size:11px;
color:#ffdb9b;
opacity:.92;
text-align:right;
}
.rack-row:before{
animation:ledPulse 2.4s infinite;
}
.rack-row.warning:before{
animation:warningPulse 1.2s infinite;
}
@keyframes ledPulse{
0%,100%{opacity:.8;filter:brightness(1)}
50%{opacity:1;filter:brightness(1.6)}
}
@keyframes warningPulse{
0%,100%{opacity:.75;filter:brightness(1)}
50%{opacity:1;filter:brightness(1.9)}
}
.rack-row:hover span{
color:#ffffff;
}
.telemetry a:nth-child(2) strong,
.industrial-badges span:nth-child(3){
color:#ffbf3d;
}
.cards .card{
position:relative;
overflow:hidden;
}
.cards .card:after{
content:"";
position:absolute;
left:0;
right:0;
bottom:0;
height:3px;
background:linear-gradient(90deg,var(--cyan),#ffbf3d,transparent);
opacity:.7;
}
.card:hover .icon{
box-shadow:0 0 24px rgba(50,220,255,.38),0 0 18px rgba(255,191,61,.18);
}
.service-hero:after{
content:"CONTROL ROOM / FAENA / PLANTA INDUSTRIAL";
display:block;
margin-top:18px;
color:#ffbf3d;
font-size:12px;
letter-spacing:2px;
font-weight:900;
}
.contact{
border-top:1px solid rgba(255,191,61,.18);
border-bottom:1px solid rgba(255,191,61,.16);
}
@media(max-width:660px){
.topbar:after{display:none}

.rack-row span{text-align:left}
}

/* FIX animacion rack manteniendo texto */
.rack-row{
    position:relative;
    display:flex !important;
    align-items:center;
    padding-left:44px !important;
    padding-right:18px;
    height:52px !important;
    overflow:hidden;
}

/* texto por encima */
.rack-row b, .rack-row span{
    position:relative;
    z-index:2;
}

/* capa animacion original */
.rack-row:after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(90deg,transparent,rgba(50,220,255,.18),transparent);
    animation:sweep 2.8s infinite;
    z-index:1;
}

/* LED activo */
.rack-row:before{
    content:"";
    position:absolute;
    left:16px;
    top:50%;
    width:10px;
    height:10px;
    margin-top:-5px;
    border-radius:50%;
    background:#70ff9c;
    box-shadow:0 0 16px #70ff9c;
    animation:ledPulse 2.4s infinite;
    z-index:2;
}

/* warning */
.rack-row.warning:before{
    background:#ffbf3d;
    box-shadow:0 0 16px #ffbf3d;
    animation:warningPulse 1.2s infinite;
}

/* === RACK FINAL LIMPIO: estilo primera captura, textos dentro de barra === */
.rack{
    display:grid !important;
    gap:12px !important;
    margin:24px 0 !important;
}

.rack-row{
    position:relative !important;
    height:42px !important;
    display:flex !important;
    align-items:center !important;
    padding-left:54px !important;
    padding-right:18px !important;
    border-radius:10px !important;
    border:1px solid rgba(136,241,255,.16) !important;
    background:linear-gradient(90deg,rgba(255,255,255,.06),rgba(255,255,255,.02)) !important;
    color:#dff8ff !important;
    text-decoration:none !important;
    overflow:hidden !important;
    font-weight:800 !important;
    letter-spacing:.2px !important;
    text-shadow:0 1px 2px rgba(0,0,0,.85) !important;
}

.rack-row span{
    position:relative !important;
    z-index:3 !important;
    color:#dff8ff !important;
    font-size:14px !important;
    text-align:left !important;
    opacity:1 !important;
}

.rack-row b{
    display:none !important;
}

.rack-row:before{
    content:"" !important;
    position:absolute !important;
    left:16px !important;
    top:50% !important;
    width:10px !important;
    height:10px !important;
    margin-top:-5px !important;
    border-radius:50% !important;
    background:#70ff9c !important;
    box-shadow:0 0 16px #70ff9c,0 0 34px rgba(112,255,156,.35) !important;
    animation:ledPulse 2.4s infinite !important;
    z-index:3 !important;
}

.rack-row.warning:before{
    background:#ffbf3d !important;
    box-shadow:0 0 16px #ffbf3d,0 0 34px rgba(255,191,61,.35) !important;
    animation:warningPulse 1.2s infinite !important;
}

.rack-row:after{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    background:linear-gradient(90deg,transparent,rgba(50,220,255,.18),transparent) !important;
    animation:sweep 2.8s infinite !important;
    z-index:1 !important;
}

.rack-row:hover{
    border-color:rgba(50,220,255,.65) !important;
    background:linear-gradient(90deg,rgba(50,220,255,.12),rgba(255,255,255,.03)) !important;
    transform:translateY(-1px) !important;
}

/* baja un poco la saturación amarilla anterior */
.rack-row.warning span{
    color:#f3fbff !important;
}

@media(max-width:660px){
    .rack-row{
        height:42px !important;
        display:flex !important;
        padding-left:54px !important;
    }
    .rack-row span{
        font-size:13px !important;
    }
}

/* === Versión comercial plus === */
.background-dc:after{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 20% 30%,rgba(0,215,255,.14),transparent 30%),
        radial-gradient(circle at 80% 70%,rgba(255,191,61,.10),transparent 34%);
    animation:bgPulse 8s ease-in-out infinite alternate;
}
@keyframes bgPulse{
    from{opacity:.45}
    to{opacity:.85}
}

.client-strip{
    margin-top:18px;
    display:inline-flex;
    flex-direction:column;
    gap:4px;
    padding:12px 16px;
    border:1px solid rgba(136,241,255,.22);
    background:rgba(5,13,20,.55);
    border-radius:16px;
    backdrop-filter:blur(10px);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.06),0 12px 26px rgba(0,0,0,.22);
}
.client-strip span{
    color:#ffdb9b;
    font-size:12px;
    letter-spacing:1.2px;
    text-transform:uppercase;
    font-weight:800;
}
.client-strip b{
    color:#dff8ff;
    font-size:13px;
}

.mailbtn{
    margin-top:10px;
}

.whatsapp-float{
    position:fixed;
    right:22px;
    bottom:22px;
    z-index:30;
    padding:14px 18px;
    border-radius:999px;
    color:#001015;
    text-decoration:none;
    font-weight:900;
    background:linear-gradient(180deg,#8ff2ff,#32dcff);
    box-shadow:0 0 28px rgba(50,220,255,.35),0 16px 34px rgba(0,0,0,.35);
    border:1px solid rgba(255,255,255,.45);
}
.whatsapp-float:hover{
    transform:translateY(-2px);
}

/* tarjetas más comerciales pero limpias */
.card h3{
    letter-spacing:-.2px;
}
.card small{
    text-transform:uppercase;
    letter-spacing:.8px;
    font-size:12px;
}

/* refuerzo modo demo */
.hmi-head:after{
    content:"DEMO READY";
    color:#ffbf3d;
    margin-left:14px;
    font-size:11px;
    letter-spacing:1.6px;
}

@media(max-width:660px){
    .whatsapp-float{
        right:14px;
        bottom:14px;
        padding:12px 15px;
        font-size:13px;
    }
    .client-strip{
        width:100%;
    }
}

/* === AJUSTE RESPONSIVE ANDROID / PANTALLAS PEQUEÑAS === */

/* tablets chicas y celulares grandes */
@media (max-width: 820px){
    body{
        overflow-x:hidden;
    }

    .topbar{
        height:auto !important;
        min-height:68px !important;
        padding:10px 16px !important;
        gap:10px !important;
    }

    .brand{
        min-width:0 !important;
    }

    .logo-img{
        height:44px !important;
        max-width:150px !important;
        object-fit:contain !important;
    }

    .brand-text b{
        font-size:15px !important;
    }

    .brand-text span{
        font-size:11px !important;
    }

    .hero{
        min-height:auto !important;
        display:block !important;
        padding:34px 16px 28px !important;
    }

    h1{
        font-size:clamp(30px, 9vw, 46px) !important;
        line-height:1.02 !important;
        margin:14px 0 16px !important;
    }

    .lead{
        font-size:15px !important;
        line-height:1.45 !important;
    }

    .hero-actions{
        gap:10px !important;
        margin-top:22px !important;
    }

    .btn{
        min-height:42px !important;
        padding:0 14px !important;
        font-size:13px !important;
        border-radius:12px !important;
    }

    .industrial-badges{
        gap:8px !important;
        margin-top:16px !important;
    }

    .industrial-badges span{
        font-size:11px !important;
        padding:8px 10px !important;
    }

    .hmi{
        margin-top:28px !important;
        padding:16px !important;
        border-radius:20px !important;
    }

    .hmi-head{
        font-size:11px !important;
        letter-spacing:1.1px !important;
        gap:8px !important;
    }

    .hmi-head:after{
        display:none !important;
    }

    .rack{
        gap:9px !important;
        margin:18px 0 !important;
    }

    .rack-row{
        height:40px !important;
        padding-left:48px !important;
        padding-right:10px !important;
        border-radius:9px !important;
    }

    .rack-row span{
        font-size:13px !important;
        white-space:nowrap !important;
        overflow:hidden !important;
        text-overflow:ellipsis !important;
    }

    .telemetry{
        grid-template-columns:1fr 1fr !important;
        gap:10px !important;
    }

    .telemetry a{
        padding:13px !important;
        min-height:76px !important;
    }

    .telemetry span{
        font-size:11px !important;
    }

    .telemetry strong{
        font-size:20px !important;
    }

    .section{
        padding:48px 16px !important;
    }

    .section-title{
        margin-bottom:24px !important;
    }

    .section-title h2{
        font-size:clamp(26px, 8vw, 38px) !important;
    }

    .section-title p{
        font-size:15px !important;
    }

    .cards{
        grid-template-columns:1fr !important;
        gap:14px !important;
    }

    .card{
        min-height:auto !important;
        padding:20px !important;
        border-radius:16px !important;
    }

    .icon{
        width:48px !important;
        height:48px !important;
        border-radius:13px !important;
        margin-bottom:14px !important;
    }

    .card h3{
        font-size:21px !important;
    }

    .card p{
        font-size:15px !important;
    }

    .contact{
        grid-template-columns:1fr !important;
        padding:48px 16px !important;
        gap:20px !important;
    }

    .contact h2{
        font-size:30px !important;
    }

    .contact-card{
        padding:20px !important;
    }

    .whatsapp-float{
        right:12px !important;
        bottom:12px !important;
        padding:11px 14px !important;
        font-size:12px !important;
    }

    footer{
        padding:18px 16px !important;
        font-size:12px !important;
    }
}

/* Android angosto: 360 / 375 / 390 px */
@media (max-width: 430px){
    .topbar{
        justify-content:center !important;
    }

    nav{
        display:none !important;
    }

    .brand-text{
        display:none !important;
    }

    .logo-img{
        height:42px !important;
        max-width:170px !important;
    }

    .hero{
        padding-top:28px !important;
    }

    .eyebrow,
    .section-title span,
    .service-hero span{
        font-size:10px !important;
        letter-spacing:1.5px !important;
    }

    h1{
        font-size:32px !important;
    }

    .hero-actions{
        display:grid !important;
        grid-template-columns:1fr !important;
    }

    .btn{
        width:100% !important;
    }

    .industrial-badges{
        display:grid !important;
        grid-template-columns:1fr 1fr !important;
    }

    .industrial-badges span{
        text-align:center !important;
    }

    .hmi{
        padding:14px !important;
    }

    .hmi-head{
        align-items:center !important;
    }

    .rack-row{
        height:38px !important;
        padding-left:44px !important;
    }

    .rack-row:before{
        left:14px !important;
    }

    .rack-row span{
        font-size:12px !important;
    }

    .telemetry{
        grid-template-columns:1fr !important;
    }

    .telemetry a{
        min-height:68px !important;
    }

    .section{
        padding-top:42px !important;
        padding-bottom:42px !important;
    }

    .card small{
        font-size:11px !important;
    }

    .contact h2{
        font-size:28px !important;
    }
}

/* Android muy pequeño: 320 px */
@media (max-width: 340px){
    h1{
        font-size:28px !important;
    }

    .lead{
        font-size:14px !important;
    }

    .industrial-badges{
        grid-template-columns:1fr !important;
    }

    .rack-row span{
        font-size:11px !important;
    }

    .telemetry strong{
        font-size:18px !important;
    }

    .card h3{
        font-size:19px !important;
    }

    .whatsapp-float{
        position:static !important;
        display:flex !important;
        width:calc(100% - 32px) !important;
        margin:0 16px 16px !important;
    }
}

/* páginas internas de servicios */
@media (max-width: 820px){
    .service-hero{
        padding:40px 16px 18px !important;
    }

    .service-layout{
        display:block !important;
        padding:18px 16px 54px !important;
    }

    .detail-card,
    .mini{
        padding:20px !important;
        border-radius:16px !important;
    }

    .mini{
        margin-top:16px !important;
    }

    .detail-card h2{
        font-size:26px !important;
    }

    .detail-card p{
        font-size:15px !important;
    }

    .service-list{
        gap:9px !important;
    }

    .service-list li{
        padding:13px 14px !important;
        font-size:14px !important;
    }
}

/* === FORMULARIO CONTACTO DESKTOP / RESPONSIVE === */
.contact-form{
    display:grid;
    gap:12px;
}

.contact-form label{
    display:grid;
    gap:6px;
    color:#b7d8e7;
    font-size:12px;
    font-weight:800;
    letter-spacing:.4px;
    text-transform:uppercase;
}

.contact-form input,
.contact-form select,
.contact-form textarea{
    width:100%;
    border:1px solid rgba(136,241,255,.24);
    background:rgba(2,8,13,.72);
    color:#f4fbff;
    border-radius:12px;
    padding:12px 13px;
    outline:none;
    font-family:Arial,Helvetica,sans-serif;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
    border-color:rgba(50,220,255,.70);
    box-shadow:0 0 0 3px rgba(50,220,255,.10), inset 0 1px 0 rgba(255,255,255,.05);
}

.contact-form textarea{
    resize:vertical;
    min-height:92px;
}

.contact-form button{
    border:0;
    cursor:pointer;
    width:100%;
    margin-top:4px;
}

.contact-direct{
    margin-top:16px;
    padding-top:14px;
    border-top:1px solid rgba(136,241,255,.15);
}

.contact-direct p{
    margin:0 0 8px;
}

.contact-direct .mailbtn{
    width:100%;
    margin-top:8px;
}

@media(max-width:820px){
    .contact-form input,
    .contact-form select,
    .contact-form textarea{
        padding:11px 12px !important;
        font-size:14px !important;
    }
}

/* === CONTACTO: desktop formulario + WhatsApp / mobile solo mailto + WhatsApp === */
.contact-desktop-actions{
    margin-top:16px;
    padding-top:14px;
    border-top:1px solid rgba(136,241,255,.15);
}

.contact-desktop-actions .mailbtn{
    width:100%;
}

.contact-mobile-actions{
    display:none;
}

/* Oculta bloque antiguo si existiera */
.contact-direct{
    display:none !important;
}

@media(max-width:820px){
    .contact-form{
        display:none !important;
    }

    .contact-desktop-actions{
        display:none !important;
    }

    .contact-mobile-actions{
        display:grid !important;
        gap:10px;
    }

    .contact-mobile-actions p{
        margin:0;
        color:#f4fbff;
    }

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

/* === CONTACTO EN HTML SEPARADO === */
.contact-page{
    padding-top:24px !important;
}

.contacto-hero{
    padding-bottom:10px !important;
}

.contacto-mobile-only{
    display:none;
}

@media(min-width:821px){
    .contacto-desktop-form{
        display:block !important;
    }
    .contacto-desktop-form .contact-form{
        display:grid !important;
    }
}

@media(max-width:820px){
    .contact-page{
        display:block !important;
    }

    .contacto-desktop-form{
        display:none !important;
    }

    .contacto-mobile-only{
        display:grid !important;
        margin-top:18px;
    }

    .contacto-mobile-only .btn{
        width:100%;
    }
}

/* === CONTACTO PHP FINAL === */
.compact-contact-hero{
    padding:42px 7vw 10px !important;
    text-align:center;
}

.compact-contact-hero h1{
    font-size:clamp(34px,4vw,56px) !important;
    margin:12px 0 10px !important;
}

.compact-contact-hero .lead{
    margin:0 auto !important;
    max-width:680px !important;
    font-size:16px !important;
}

.contact-centered{
    display:flex !important;
    justify-content:center !important;
    align-items:flex-start !important;
    padding:26px 7vw 70px !important;
}

.contact-centered .contact-card{
    width:min(100%,560px) !important;
}

.contact-centered .contact-mobile-actions{
    width:min(100%,520px);
}

@media(max-width:820px){
    .compact-contact-hero{
        padding:32px 16px 10px !important;
    }

    .compact-contact-hero h1{
        font-size:32px !important;
    }

    .contact-centered{
        display:block !important;
        padding:20px 16px 52px !important;
    }

    .contact-centered .contacto-desktop-form{
        display:none !important;
    }

    .contact-centered .contacto-mobile-only{
        display:grid !important;
    }
}


/* FIX header contacto overlap */
.compact-contact-hero{
    padding-top:70px !important;
}

.compact-contact-hero .service-hero:after{
    display:none !important;
}

.compact-contact-hero:after{
    content:none !important;
}

@media(max-width:820px){
    .compact-contact-hero{
        padding-top:52px !important;
    }
}


/* CONTACTO HERO CENTRADO Y COMPACTO */
.compact-contact-hero{
    min-height:auto !important;
    padding:38px 20px 18px !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    text-align:center !important;
}

.compact-contact-hero span{
    font-size:12px !important;
    letter-spacing:2px !important;
    margin-bottom:10px !important;
}

.compact-contact-hero h1{
    font-size:clamp(34px,4vw,64px) !important;
    line-height:1 !important;
    margin:0 0 14px !important;
    max-width:1000px !important;
    text-align:center !important;
}

.compact-contact-hero .lead{
    max-width:760px !important;
    margin:0 auto !important;
    font-size:15px !important;
    line-height:1.5 !important;
    text-align:center !important;
}

/* formulario más arriba y centrado */
.contact-centered{
    padding-top:20px !important;
}

/* mobile */
@media(max-width:820px){
    .compact-contact-hero{
        padding:28px 16px 12px !important;
    }

    .compact-contact-hero h1{
        font-size:34px !important;
    }

    .compact-contact-hero .lead{
        font-size:14px !important;
    }
}


/* AJUSTE FINAL HERO CONTACTO */
.compact-contact-hero h1{
    font-size:clamp(22px,2.4vw,40px) !important;
    line-height:1.05 !important;
    letter-spacing:-1px !important;
}

.compact-contact-hero{
    padding:26px 18px 10px !important;
}

.compact-contact-hero span{
    font-size:11px !important;
    margin-bottom:8px !important;
}

.compact-contact-hero .lead{
    font-size:14px !important;
    max-width:620px !important;
}

/* desktop: prioriza formulario */
.contact-centered{
    padding-top:10px !important;
}

/* móviles: ocultar hero/form desktop y usar contacto simple */
@media(max-width:820px){

    .compact-contact-hero{
        display:none !important;
    }

    .contact-centered{
        padding-top:34px !important;
    }

    .contacto-desktop-form{
        display:none !important;
    }

    .contacto-mobile-only{
        display:grid !important;
        max-width:100% !important;
    }
}

/* desktop grande: ancho más agradable */
@media(min-width:1200px){
    .contact-centered .contact-card{
        width:min(100%,520px) !important;
    }
}


/* AJUSTE TITULOS PAGINAS INTERNAS - 30% MAS PEQUEÑOS */
.service-hero h1{
    font-size:clamp(30px,4.1vw,58px) !important;
    line-height:1.02 !important;
    max-width:100% !important;
    white-space:nowrap !important;
    letter-spacing:-1px !important;
}

/* en pantallas medianas permite ajuste sin romper */
@media(max-width:1100px){
    .service-hero h1{
        font-size:clamp(26px,4.4vw,46px) !important;
        white-space:normal !important;
    }
}

/* mobile */
@media(max-width:820px){
    .service-hero h1{
        font-size:30px !important;
        white-space:normal !important;
        line-height:1.08 !important;
    }
}


/* FOOTER INDUSTRIAL */
footer{
    position:relative;
    z-index:5;
    display:grid !important;
    grid-template-columns:1.1fr 1fr .8fr;
    gap:48px;
    padding:46px 7vw 42px !important;
    background:rgba(0,0,0,.82);
    border-top:1px solid rgba(136,241,255,.16);
    backdrop-filter:blur(10px);
}

.footer-brand{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.footer-brand img{
    width:210px;
    max-width:100%;
    object-fit:contain;
}

.footer-brand p{
    color:#b8d7e7;
    line-height:1.6;
    font-size:14px;
    max-width:360px;
}

.footer-contact{
    display:grid;
    gap:22px;
}

.footer-contact h4,
.footer-menu h4{
    color:#ffffff;
    font-size:18px;
    margin:0 0 12px;
    letter-spacing:.8px;
}

.footer-contact p{
    margin:0 0 8px;
    color:#d9edf8;
    font-size:14px;
    line-height:1.55;
}

.footer-contact strong{
    color:#8ff2ff;
}

.footer-menu{
    display:flex;
    flex-direction:column;
}

.footer-menu a{
    color:#f3f8fb;
    text-decoration:none;
    margin-bottom:12px;
    transition:.2s;
    font-size:14px;
}

.footer-menu a:hover{
    color:#8ff2ff;
    transform:translateX(4px);
}

.footer-copy{
    grid-column:1/-1;
    margin-top:18px;
    padding-top:18px;
    border-top:1px solid rgba(136,241,255,.12);
    color:#9fb6c4;
    font-size:12px;
    display:flex;
    justify-content:space-between;
    gap:12px;
    flex-wrap:wrap;
}

@media(max-width:980px){
    footer{
        grid-template-columns:1fr;
        gap:34px;
        padding:38px 20px 34px !important;
    }

    .footer-brand img{
        width:180px;
    }

    .footer-copy{
        flex-direction:column;
    }
}
.service-item {
    list-style: none;
}

.service-toggle {
    width: 100%;
    background: transparent;
    border: none;
    color: inherit;
    text-align: left;
    font: inherit;
    cursor: pointer;
    padding: 0;
}

.service-description {
    display: none;
    margin-top: 14px;
    padding: 18px 20px;
    border: 1px solid rgba(80, 220, 255, 0.25);
    border-radius: 14px;
    background: rgba(0, 20, 30, 0.45);
    color: #d9f6ff;
    line-height: 1.6;
}

.service-item.active .service-description {
    display: block;
}
.service-list .service-item {
    list-style: none;
    padding: 0;
}

.service-list .service-toggle {
    width: 100%;
    display: block;
    background: transparent;
    border: none;
    color: #d9f6ff;
    text-align: left;
    font: inherit;
    font-weight: 600;
    cursor: pointer;
    padding: 0;
}

.service-list .service-description {
    display: none;
    margin-top: 14px;
    padding: 18px 20px;
    border: 1px solid rgba(80, 220, 255, 0.25);
    border-radius: 14px;
    background: rgba(0, 20, 30, 0.45);
    color: #d9f6ff;
    line-height: 1.6;
}

.service-list .service-item.active .service-description {
    display: block;
}
.service-list {
    margin-top: 28px;
    padding: 0;
}

.service-list li,
.service-list .service-item,
.service-list .service-toggle {
    width: 100%;
    display: block;
    font-size: 28px;
    font-weight: 600;
    color: #d9f6ff;
    padding: 22px 24px;
    margin-bottom: 16px;
    border: 1px solid rgba(80, 220, 255, 0.25);
    border-radius: 16px;
    background: rgba(0, 20, 30, 0.35);
    line-height: 1.3;
    box-sizing: border-box;
}

.service-list .service-toggle {
    background: transparent;
    border: none;
    text-align: left;
    cursor: pointer;
    font: inherit;
    color: inherit;
    padding: 22px 24px;
}

.service-list .service-description {
    display: none;
    margin-top: 14px;
    padding: 20px 24px;
    border: 1px solid rgba(80, 220, 255, 0.18);
    border-radius: 14px;
    background: rgba(0, 20, 30, 0.45);
    color: #d9f6ff;
    font-size: 20px;
    line-height: 1.6;
}

.service-list .service-item.active .service-description {
    display: block;
}
.service-list {
    margin-top: 20px;
    padding: 0;
}

.service-list li,
.service-list .service-item,
.service-list .service-toggle {
    width: 100%;
    display: block;
    font-size: 20px;
    font-weight: 600;
    color: #d9f6ff;
    padding: 14px 18px;
    margin-bottom: 10px;
    border: 1px solid rgba(80, 220, 255, 0.25);
    border-radius: 14px;
    background: rgba(0, 20, 30, 0.35);
    line-height: 1.3;
    box-sizing: border-box;
}

.service-list .service-toggle {
    background: transparent;
    border: none;
    text-align: left;
    cursor: pointer;
    font: inherit;
    color: inherit;
    padding: 14px 18px;
}

.service-list .service-description {
    display: none;
    margin-top: 10px;
    padding: 14px 18px;
    border: 1px solid rgba(80, 220, 255, 0.18);
    border-radius: 12px;
    background: rgba(0, 20, 30, 0.45);
    color: #d9f6ff;
    font-size: 16px;
    line-height: 1.5;
}

.service-list .service-item.active .service-description {
    display: block;
}
.service-card,
.service-card:link,
.service-card:visited,
.service-card:hover,
.service-card:active {
    color: inherit;
    text-decoration: none;
}
/* === EFECTO HOVER PARA ITEMS RACK / SERVICIOS === */
.rack-row {
    transition: transform 0.25s ease, 
                border-color 0.25s ease, 
                background 0.25s ease, 
                box-shadow 0.25s ease !important;
    transform-origin: center !important;
}

.rack-row:hover {
    transform: scale(1.025) translateY(-2px) !important;
    border-color: rgba(50,220,255,.85) !important;
    background: linear-gradient(
        90deg,
        rgba(50,220,255,.16),
        rgba(255,255,255,.05)
    ) !important;
    box-shadow: 
        0 0 22px rgba(50,220,255,.30),
        0 12px 28px rgba(0,0,0,.35) !important;
    color: #ffffff !important;
}

.rack-row:hover span {
    color: #ffffff !important;
}
/* === EFECTO HOVER ITEMS INTERNOS DE SERVICIOS === */
/* Aplica a UPS, Climatización, CCTV, Control de Acceso, etc. */

.service-list .service-item {
    transition: transform 0.25s ease,
                border-color 0.25s ease,
                background 0.25s ease,
                box-shadow 0.25s ease !important;
    transform-origin: center !important;
}

.service-list .service-item:hover {
    transform: scale(1.018) translateY(-2px) !important;
    border-color: rgba(50, 220, 255, 0.75) !important;
    background: rgba(0, 35, 50, 0.65) !important;
    box-shadow:
        0 0 22px rgba(50, 220, 255, 0.28),
        0 12px 28px rgba(0, 0, 0, 0.35) !important;
}

.service-list .service-item:hover .service-toggle {
    color: #ffffff !important;
}

.service-list .service-item:hover .service-description {
    border-color: rgba(50, 220, 255, 0.45) !important;
}
.service-list .service-toggle:hover {
    color: #8ff2ff !important;
}
/* === DETALLES INTERNOS MÁS COMPACTOS === */

.service-description .service-detail-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 5px;
}

.service-description .service-detail-list li {
    list-style: none;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 1.35 !important;
    padding: 6px 10px !important;
    margin-bottom: 0 !important;
    border-radius: 8px !important;
    border: 1px solid rgba(80, 220, 255, 0.16) !important;
    background: rgba(0, 20, 30, 0.22) !important;
    color: #d9f6ff !important;
}
/* === AJUSTE TAMAÑO DETALLES INTERNOS DE SERVICIO === */

.service-description .service-detail-list {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 7px;
}

.service-description .service-detail-list li {
    list-style: none;
    font-size: 15px !important;
    font-weight: 400 !important;
    line-height: 1.45 !important;
    padding: 8px 12px !important;
    margin-bottom: 0 !important;
    border-radius: 9px !important;
    border: 1px solid rgba(80, 220, 255, 0.18) !important;
    background: rgba(0, 20, 30, 0.28) !important;
    color: #d9f6ff !important;
}
.hero-strip {
    text-align: center;
    color: #f5b21b;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 4px;
    padding: 10px 20px;
    white-space: nowrap;
    transform: none !important;
    animation: none !important;
    transition: none !important;
}

.hero-strip span {
    display: inline-block;
    transform: none !important;
    animation: none !important;
    transition: none !important;
}

.hero:hover .hero-strip,
.hero:hover .hero-strip span {
    transform: none !important;
    animation: none !important;
    transition: none !important;
}