﻿:root{--p:#04275f;--a:#ffdd83;--a2:#f4b930;--t:#263142;--m:#627286;--bg:#f6f9fd;--b:#d8e1ee;--w:#fff;--r:14px;--h:82px;--c:1220px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Segoe UI,Roboto,Arial,sans-serif;color:var(--t);background:var(--bg);line-height:1.5}a{text-decoration:none;color:inherit}img{max-width:100%;display:block}ul{margin:0;padding:0;list-style:none}p{margin-top:0}
.container{width:min(var(--c),calc(100% - 2rem));margin-inline:auto}.skip-link{position:absolute;top:-40px;left:10px;padding:.5rem .8rem;border-radius:8px;background:#111;color:#fff;z-index:999}.skip-link:focus{top:10px}
.site-header{position:sticky;top:0;z-index:90;height:var(--h);background:rgba(4,39,95,.94);color:#fff;border-bottom:1px solid rgba(255,255,255,.16)}.site-header__inner{height:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.8rem}.brand__logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-weight:900;color:var(--p);background:linear-gradient(135deg,var(--a),var(--a2))}.brand__title{font-weight:800;font-size:1.04rem}.brand__tag{display:block;font-size:.75rem;opacity:.8}
.nav-toggle{display:none;width:42px;height:42px;border-radius:12px;border:1px solid rgba(255,255,255,.35);background:transparent;color:#fff}.nav{display:flex;gap:.4rem}.nav__link{padding:.56rem .9rem;border-radius:999px;font-size:.9rem;opacity:.9}.nav__link:hover,.nav__link:focus-visible{background:rgba(255,255,255,.15)}.nav__link.is-active{opacity:1;color:var(--p);font-weight:700;background:linear-gradient(135deg,var(--a),var(--a2))}
.page-hero{padding:clamp(2.4rem,5vw,4.2rem) 0;background:radial-gradient(circle at 8% 20%,rgba(255,221,131,.55),transparent 35%),linear-gradient(180deg,#f1f6ff,#edf3fb);border-bottom:1px solid var(--b)}.page-hero--dark{color:#fff;background:linear-gradient(145deg,rgba(3,26,63,.92),rgba(7,52,119,.85)),url('../images/wp-content/uploads/2021/01/Parallax.jpg') center/cover no-repeat}
.page-hero__eyebrow{display:inline-flex;padding:.34rem .7rem;border-radius:999px;font-size:.76rem;font-weight:700;text-transform:uppercase;background:rgba(4,39,95,.1);color:var(--p)}.page-hero--dark .page-hero__eyebrow{background:rgba(255,255,255,.16);color:#fff}.page-hero h1{margin:.6rem 0 0;font-size:clamp(1.9rem,4vw,3.2rem);line-height:1.08}.page-hero p{margin:1rem 0 0;max-width:74ch}
.page-main{padding:clamp(1.8rem,4vw,3.4rem) 0}.section{margin-bottom:clamp(1.8rem,4vw,3.4rem)}.section:last-child{margin-bottom:0}.section__title{margin:0;color:var(--p);font-size:clamp(1.35rem,2.6vw,2rem)}.section__lead{margin:.8rem 0 0;color:var(--m)}
.card-grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{background:var(--w);border:1px solid var(--b);border-radius:var(--r);padding:1rem;box-shadow:0 7px 20px rgba(9,30,66,.08)}.card h3,.card h4{margin:0 0 .5rem;color:var(--p)}.card p{margin:0;color:var(--m)}
.btn-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem}.btn{border:0;border-radius:12px;padding:.72rem .98rem;font-weight:700;cursor:pointer}.btn--primary{color:var(--p);background:linear-gradient(135deg,var(--a),var(--a2))}.btn--secondary{background:var(--p);color:#fff}.btn--ghost{border:1px solid rgba(4,39,95,.35);background:#fff;color:var(--p)}
.pill{display:inline-flex;padding:.25rem .6rem;border-radius:999px;font-size:.74rem;font-weight:700;border:1px solid rgba(4,39,95,.2);background:rgba(4,39,95,.05);color:var(--p)}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.9rem}.kpi{background:#fff;border:1px solid var(--b);border-radius:var(--r);padding:1rem;text-align:center}.kpi strong{display:block;font-size:1.45rem;color:var(--p)}.kpi span{font-size:.9rem;color:var(--m)}
.slider{margin-top:1.1rem;border:1px solid rgba(255,255,255,.24);border-radius:20px;overflow:hidden}.slide{display:none;padding:1rem;background:rgba(0,0,0,.17)}.slide.active{display:block}.slider-controls{display:flex;justify-content:space-between;padding:.65rem;border-top:1px solid rgba(255,255,255,.24)}.icon-btn{width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.34);background:transparent;color:#fff}
.process{display:grid;gap:.85rem}.step{display:grid;grid-template-columns:58px 1fr;gap:.9rem;background:#fff;border:1px solid var(--b);border-radius:var(--r);padding:.9rem}.step-no{width:52px;height:52px;border-radius:12px;display:grid;place-items:center;font-weight:800;color:var(--p);background:linear-gradient(135deg,var(--a),var(--a2))}
.input,.select,.textarea{width:100%;padding:.72rem .9rem;border-radius:12px;border:1px solid var(--b);background:#fff;color:var(--t);font:inherit}.textarea{min-height:130px;resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.full{grid-column:1/-1}
.project-controls{display:grid;grid-template-columns:1fr 220px 220px;gap:.8rem;margin-bottom:1rem}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.project-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--b);border-radius:18px;overflow:hidden}.project-media{position:relative;aspect-ratio:16/9;background:linear-gradient(135deg,#dce8f8,#c8d9ef)}.project-media img{width:100%;height:100%;object-fit:cover;object-position:center}.img-token{position:absolute;left:8px;bottom:8px;font-size:.7rem;color:#fff;background:rgba(4,39,95,.82);padding:.2rem .4rem;border-radius:6px}.project-body{padding:1rem;display:flex;flex-direction:column;gap:.65rem}.project-body h3{margin:0;color:var(--p);font-size:1.05rem}.project-body p{margin:0;color:var(--m);font-size:.92rem}.project-meta{display:flex;flex-wrap:wrap;gap:.4rem}
.video-grid,.media-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.video-card,.media-card{background:#fff;border:1px solid var(--b);border-radius:var(--r);padding:1rem}.video-thumb{aspect-ratio:16/9;border-radius:12px;overflow:hidden;background:#d9e4f4;margin-bottom:.6rem}.video-thumb img{width:100%;height:100%;object-fit:cover}
.notice{border-radius:12px;padding:.75rem;border:1px solid rgba(15,157,88,.35);background:rgba(15,157,88,.08);color:#086339;font-size:.93rem}.is-hidden{display:none!important}
.site-footer{margin-top:2.8rem;background:#061d46;color:#d5dff2;border-top:1px solid rgba(255,255,255,.15)}.site-footer__inner{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:1.1rem;padding:1.8rem 0}.site-footer h4{margin:0 0 .55rem;color:#fff}.site-footer a:hover{color:#fff;text-decoration:underline}.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding:.75rem 0;font-size:.84rem}
.cookie-banner{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:120;background:#fff;border:1px solid var(--b);border-radius:14px;box-shadow:0 10px 30px rgba(4,39,95,.14);padding:.85rem;display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}.cookie-banner p{margin:0;flex:1 1 320px;color:var(--m)}
.modal{position:fixed;inset:0;z-index:130;background:rgba(1,9,24,.72);display:grid;place-items:center;padding:1rem}.modal-dialog{width:min(760px,100%);max-height:88vh;overflow:auto;background:#fff;border:1px solid var(--b);border-radius:14px;padding:1rem}.modal-head{display:flex;justify-content:space-between;gap:.8rem;align-items:start;margin-bottom:.8rem}.modal-close{width:36px;height:36px;border-radius:10px;border:0;background:#edf3fb;cursor:pointer}
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.js .reveal.visible{opacity:1;transform:none}
@media (max-width:1100px){.project-grid,.video-grid,.media-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.site-footer__inner{grid-template-columns:1fr 1fr}}
@media (max-width:900px){.nav-toggle{display:inline-grid;place-items:center}.nav{position:absolute;top:var(--h);left:0;right:0;display:none;flex-direction:column;align-items:stretch;padding:.6rem;background:#05255b;border-bottom:1px solid rgba(255,255,255,.15)}.nav.open{display:flex}.nav__link{border-radius:10px}.project-controls{grid-template-columns:1fr}}
@media (max-width:768px){:root{--h:74px}.container{width:min(var(--c),calc(100% - 1.2rem))}.card-grid,.grid-2,.grid-3,.grid-4,.project-grid,.video-grid,.media-grid,.form-grid,.site-footer__inner{grid-template-columns:1fr}.kpis{grid-template-columns:1fr 1fr}.project-media{aspect-ratio:4/3}.cookie-banner{left:.6rem;right:.6rem;bottom:.6rem}}

/* Home replica (Inicio) */
.home-main{padding-top:0}
.home-hero{position:relative;min-height:72vh;display:flex;align-items:flex-end;color:#fff;padding:7.5rem 0 4.2rem;background:url('../images/wp-content/uploads/2021/01/Parallax.jpg') center/cover no-repeat}
.home-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(2,24,58,.78),rgba(6,37,91,.55))}
.home-hero__inner{position:relative;z-index:1;max-width:760px}
.home-hero__kicker{margin:0 0 .65rem;font-size:clamp(1.05rem,2.2vw,1.75rem);font-weight:500}
.home-hero h1{margin:0;font-size:clamp(1.8rem,3.7vw,3.2rem);line-height:1.1;text-wrap:balance}
.home-hero p{margin:1rem 0 0;color:#e7edf8}
.home-slider-wrap{margin-top:-2.2rem}
.home-sector-slider{margin:0;border:0;border-radius:22px;overflow:hidden;box-shadow:0 16px 40px rgba(5,31,74,.24)}
.home-sector-slider .slide{position:relative;min-height:600px;padding:0;background:#0a2e6a}
.home-sector-slider .slide.active{display:block}
.home-slide__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.home-slide__overlay{position:absolute;inset:0;background:linear-gradient(112deg,rgba(255,255,255,.82) 20%,rgba(255,255,255,.38) 66%,rgba(255,255,255,.1) 100%)}
.home-slide__content{position:relative;z-index:1;max-width:760px;padding:5.2rem 4rem;color:#003366}
.home-slide__content h2{margin:0 0 1rem;font-size:clamp(1.45rem,3vw,2.45rem);line-height:1.2}
.home-slide__content p{margin:0;max-width:64ch;font-size:1rem;line-height:1.6;font-weight:500}
.home-sector-slider .slider-controls{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:.85rem 1rem;border-top:1px solid rgba(255,255,255,.35);background:linear-gradient(180deg,transparent,rgba(0,0,0,.22));display:flex;justify-content:space-between}
.home-sector-slider .icon-btn{width:40px;height:40px;color:#fff;border-color:rgba(255,255,255,.7);background:rgba(6,36,88,.35)}
.home-two-col{display:grid;grid-template-columns:1fr 1.1fr;gap:1.3rem;align-items:center}
.home-autoconsumo__media img{width:100%;height:100%;max-height:460px;object-fit:cover;border-radius:18px;box-shadow:0 10px 26px rgba(7,32,73,.18)}
.home-autoconsumo__text p{color:var(--m);margin:.8rem 0 0}
.home-definition p{color:var(--m);margin:.9rem 0 0}
.home-place-grid{margin-top:1.1rem}
.home-place-card{background:#fff;border:1px solid var(--b);border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(8,29,66,.08)}
.home-place-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.home-place-card h3{margin:0;padding:.9rem 1rem 1rem;color:#003366;font-size:1.02rem}
.home-projects__intro{display:flex;align-items:center;gap:1rem;margin-bottom:.8rem}
.home-projects__intro img{width:56px;height:56px;object-fit:contain}
.home-testimonials .section__lead{margin-bottom:1.2rem}
.home-quote-card{background:#fff;border:1px solid var(--b);border-radius:18px;padding:1.1rem;box-shadow:0 8px 24px rgba(8,29,66,.08)}
.home-quote-avatar{width:78px;height:78px;border-radius:50%;object-fit:cover;margin-bottom:.7rem;border:3px solid #d8e4f6}
.home-quote-card h3{margin:0 0 .5rem;color:#003366}
.home-quote-card p{margin:0;color:var(--m);font-size:.95rem;line-height:1.6}
.home-quote-sign{margin-top:1rem;height:42px;width:auto;object-fit:contain}
.home-parallax-claim{position:relative;background:url('../images/wp-content/uploads/2021/01/Parallax.jpg') center/cover fixed no-repeat;color:#003366;border-top:1px solid var(--b);border-bottom:1px solid var(--b)}
.home-parallax-claim::before{content:"";position:absolute;inset:0;background:rgba(255,255,255,.72)}
.home-parallax-claim .container{position:relative;z-index:1;padding:6rem 0}
.home-parallax-claim p{margin:0;font-size:clamp(1.4rem,3.4vw,2.8rem);line-height:1.25;font-weight:500;max-width:20ch;text-wrap:balance}
.home-footer-image{background:#002f68;padding:3.4rem 0}
.home-footer-image img{width:min(980px,100%);margin:0 auto;display:block}
@media (max-width:1200px){.home-slide__content{padding:4.2rem 2.3rem;max-width:680px}.home-sector-slider .slide{min-height:540px}}
@media (max-width:900px){.home-hero{min-height:64vh;padding:6.4rem 0 3.2rem}.home-two-col{grid-template-columns:1fr}.home-autoconsumo__media img{max-height:340px}.home-slider-wrap{margin-top:0}.home-slide__overlay{background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.56) 58%,rgba(255,255,255,.34))}.home-slide__content{padding:2.2rem 1.15rem 3.8rem}.home-slide__content h2{font-size:1.45rem}.home-slide__content p{font-size:.95rem}.home-sector-slider .slide{min-height:500px}}
@media (max-width:768px){.home-hero__kicker{font-size:1.05rem}.home-hero h1{font-size:1.86rem}.home-sector-slider .slide{min-height:560px}.home-slide__content{padding:1.2rem 1rem 3.6rem}.home-slide__content h2{font-size:1.22rem;line-height:1.25}.home-slide__content p{font-size:.9rem;line-height:1.45}.home-projects__intro img{width:44px;height:44px}.home-parallax-claim .container{padding:4.1rem 0}.home-footer-image{padding:2.1rem 0}.home-parallax-claim{background-attachment:scroll}}
@media (max-width:480px){.home-sector-slider .slide{min-height:620px}.home-slide__content{padding:.95rem .85rem 3.2rem}.home-slide__content h2{font-size:1.1rem}.home-slide__content p{font-size:.86rem}}

/* Mobile fix for home sector slider: avoid text overlap/cropping */
@media (max-width:768px){
  .home-sector-slider .slide{min-height:auto}
  .home-sector-slider .slide.active{display:flex;flex-direction:column}
  .home-slide__bg{position:relative;inset:auto;height:220px;object-position:center}
  .home-slide__overlay{position:relative;inset:auto;height:0;background:none}
  .home-slide__content{max-width:none;padding:1rem .95rem 1.2rem;background:#fff;color:#003366}
  .home-slide__content h2{font-size:1.08rem;line-height:1.28}
  .home-slide__content p{font-size:.9rem;line-height:1.48;max-width:none}
  .home-sector-slider .slider-controls{position:static;padding:.6rem .85rem;border-top:1px solid #d8e1ee;background:#edf3fb}
  .home-sector-slider .icon-btn{color:#003366;border-color:rgba(4,39,95,.28);background:#fff}
}

/* Autoconsumo + Servicios */
.auto-hero{background:linear-gradient(145deg,rgba(3,26,63,.88),rgba(7,52,119,.72)),url('../images/wp-content/uploads/2019/01/Header_Autoconsumo.jpg') center/cover no-repeat}
.auto-highlight{text-align:center;padding:1.3rem 1.2rem}
.auto-highlight h2{margin:0 0 .6rem;color:var(--p);font-size:clamp(1.25rem,2.5vw,1.9rem)}
.auto-highlight p{margin:0;color:var(--m)}
.auto-split{display:grid;grid-template-columns:1.2fr .8fr;gap:1rem;align-items:stretch}
.auto-side-image{padding:0;overflow:hidden}
.auto-side-image img{width:100%;height:100%;object-fit:cover;min-height:280px}
.auto-benefits-grid{display:grid;gap:1rem}
.auto-benefit{display:grid;grid-template-columns:260px 1fr;gap:1rem;align-items:stretch;padding:0;overflow:hidden}
.auto-benefit:nth-child(even){grid-template-columns:1fr 260px}
.auto-benefit:nth-child(even) img{order:2}
.auto-benefit img{width:100%;height:100%;object-fit:cover;min-height:220px}
.auto-benefit h3{margin:0 0 .5rem;color:var(--p);font-size:1.15rem}
.auto-benefit p{margin:0;color:var(--m)}
.auto-benefit>div{padding:1rem}
.auto-final p{margin:.8rem 0 0;color:var(--m)}
.auto-legal-cta{margin-top:1.1rem}
.auto-legal-cta__inner{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:end;border:1px solid rgba(255,255,255,.22);border-radius:18px;padding:1.2rem;background:linear-gradient(120deg,#083273,#164b9f);color:#fff}
.auto-legal-cta__inner h2{margin:.35rem 0 .55rem;font-size:clamp(1.2rem,2.4vw,1.75rem);line-height:1.2}
.auto-legal-cta__inner p{margin:0;color:#dbe6fb;max-width:64ch}
.auto-legal-cta__eyebrow{margin:0;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#ffd97a}
.services-hero{background:linear-gradient(145deg,rgba(2,24,58,.82),rgba(5,38,92,.68)),url('../images/wp-content/uploads/2019/01/Instalaciones_detalle_0000_IMG-20180306-WA0008.jpg') center/cover no-repeat}
.services-intro .card h2{margin:0 0 .7rem;color:var(--p)}
.services-intro .card p{margin:.65rem 0 0;color:var(--m)}
.service-steps{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.service-step{position:relative;padding:1rem 1rem 1rem 4.2rem}
.service-step__no{position:absolute;left:1rem;top:1rem;width:2.35rem;height:2.35rem;border-radius:12px;display:grid;place-items:center;font-weight:800;color:var(--p);background:linear-gradient(135deg,var(--a),var(--a2))}
.service-step h3{margin:0 0 .45rem;color:var(--p);font-size:1.08rem}
.service-step p{margin:0;color:var(--m)}
.services-panels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.services-panel{padding:0;overflow:hidden}
.services-panel img{width:100%;aspect-ratio:16/9;object-fit:cover}
.services-panel h3{margin:1rem 1rem .25rem;color:var(--p)}
.services-panel__lead{margin:0 1rem .5rem;color:#f4b930;font-weight:700}
.services-panel p{margin:0 1rem 1rem;color:var(--m)}
.services-cta__inner{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:end;border-radius:18px;padding:1.2rem;border:1px solid var(--b);background:linear-gradient(135deg,#fff,#eef4ff)}
.services-cta__inner h2{margin:0 0 .45rem;color:var(--p);font-size:clamp(1.2rem,2.4vw,1.7rem)}
.services-cta__inner p{margin:0;color:var(--m)}
@media (max-width:1100px){
  .auto-benefit,.auto-benefit:nth-child(even){grid-template-columns:220px 1fr}
  .auto-benefit:nth-child(even) img{order:0}
}
@media (max-width:900px){
  .auto-split,.auto-legal-cta__inner,.services-cta__inner{grid-template-columns:1fr}
  .service-steps,.services-panels{grid-template-columns:1fr}
}
@media (max-width:768px){
  .auto-hero,.services-hero{background-position:center}
  .auto-benefit,.auto-benefit:nth-child(even){grid-template-columns:1fr}
  .auto-benefit img{min-height:190px}
  .auto-benefit>div{padding:.95rem}
  .service-step{padding:.95rem .95rem .95rem 3.7rem}
}
