/* ============================================
   KLIMARGI v2 — Sistema de diseño
   Gris pizarra + amarillo mostaza
   Tipografía: Archivo + Manrope
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800;900&family=Manrope:wght@300;400;500;600;700&display=swap');

:root{
  /* Paleta corporativa KLIMARGI - basada en el logo */
  --slate-950:#0F1F33;   /* navy muy oscuro */
  --slate-900:#1B3559;   /* navy corporativo (texto KLIMARGI, llave) */
  --slate-800:#2C4D75;
  --slate-700:#3D5F8F;
  --slate-500:#6A82A8;

  --white:#ffffff;
  --off:#f6f7f8;
  --line:#e5e7eb;
  --line-dark:#2C4D75;

  --yellow:#f5b800;
  --yellow-soft:#fdd770;
  --yellow-deep:#c89800;

  /* Cian corporativo (copo de nieve del logo) */
  --cyan:#3DA9E0;
  --cyan-soft:#6FC1E8;
  --cyan-deep:#2487BC;

  /* Compatibilidad con código antiguo */
  --blue:#3DA9E0;
  --blue-dark:#2487BC;

  --on-dark:#e5e7eb;
  --on-dark-mute:#9aa1ad;
  --on-light:#1d2127;
  --on-light-mute:#5a606b;

  --font-display:'Archivo', 'Helvetica Neue', sans-serif;
  --font-body:'Manrope', system-ui, sans-serif;

  --container:1240px;
  --gutter:clamp(20px, 4vw, 44px);
  --radius:4px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--white);
  color:var(--on-light);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.015em;
}
h1{font-size:clamp(2.6rem, 7vw, 5.6rem);font-weight:900}
h2{font-size:clamp(2rem, 4.5vw, 3.4rem)}
h3{font-size:clamp(1.2rem, 1.8vw, 1.5rem)}
.eyebrow{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--yellow);
  margin-bottom:14px;
}
.eyebrow::before{
  content:'';display:inline-block;
  width:24px;height:2px;background:var(--yellow);
  vertical-align:middle;margin-right:10px;
  transform:translateY(-2px);
}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

/* NAV */
.nav{
  position:sticky;top:0;z-index:100;
  background:var(--slate-900);
  border-bottom:1px solid var(--line-dark);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gutter);
  max-width:var(--container);margin:0 auto;
}
.brand{display:flex;align-items:center;gap:0;color:var(--white);text-decoration:none}
.brand img{height:50px;width:auto;object-fit:contain;display:block}
.brand-text{display:none}

.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{
  padding:10px 16px;
  font-size:.94rem;font-weight:500;
  color:var(--on-dark);
  transition:color .2s var(--ease);
}
.nav-links a:hover, .nav-links a.active{color:var(--yellow)}

.nav-cta{
  background:var(--yellow);color:var(--slate-950);
  padding:11px 20px;font-weight:700;font-size:.9rem;
  border-radius:var(--radius);
  display:inline-flex;align-items:center;gap:8px;
  transition:background .2s var(--ease), transform .2s var(--ease);
  margin-left:10px;
  font-family:var(--font-display);letter-spacing:.02em;
}
.nav-cta:hover{background:var(--white);transform:translateY(-1px);color:var(--slate-950) !important}

.burger{display:none;width:42px;height:42px;border:1px solid var(--line-dark);border-radius:var(--radius);color:var(--white)}
.burger span{display:block;width:18px;height:2px;background:currentColor;margin:3px auto;transition:.2s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

@media (max-width:900px){
  .nav-links{
    position:fixed;
    top:-100vh;
    left:0;right:0;
    background:var(--slate-900);
    flex-direction:column;align-items:stretch;
    padding:16px var(--gutter) 22px;
    border-bottom:1px solid var(--line-dark);
    transition:top .35s var(--ease);
    overflow-y:auto;
    max-height:calc(100vh - 69px);
    visibility:hidden;
  }
  .nav-links.open{top:69px;visibility:visible}
  .nav-links a{padding:14px 0;font-size:1.05rem;border-bottom:1px solid var(--line-dark)}
  .nav-cta{
    align-self:stretch;
    margin-top:14px;margin-left:0;
    text-align:center;justify-content:center;
  }
  .burger{display:block}
}

/* HERO */
.hero{
  position:relative;
  background:var(--slate-900);
  color:var(--on-dark);
  padding:clamp(70px,11vw,130px) 0 clamp(60px,9vw,110px);
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 85% 20%, rgba(245,184,0,.15) 0%, transparent 45%),
    radial-gradient(circle at 10% 90%, rgba(46,93,126,.18) 0%, transparent 50%);
}
.hero-grid{
  display:grid;grid-template-columns:1fr;gap:50px;
  position:relative;z-index:2;align-items:center;
}
@media(min-width:980px){.hero-grid{grid-template-columns:1.3fr 1fr;gap:60px}}

.hero h1{color:var(--white)}
.hero h1 .y{color:var(--yellow)}
.hero-eu{
  display:inline-block;
  background:rgba(245,184,0,.12);
  border:1px solid rgba(245,184,0,.35);
  color:var(--yellow);
  padding:6px 14px;border-radius:999px;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
  margin-bottom:22px;
}
.hero-lead{
  font-size:clamp(1.05rem, 1.25vw, 1.18rem);
  color:var(--on-dark-mute);
  max-width:48ch;
  margin:24px 0 32px;
  line-height:1.65;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:var(--radius);
  font-family:var(--font-display);
  font-weight:700;font-size:.92rem;
  letter-spacing:.02em;
  transition:all .2s var(--ease);
}
.btn-primary{background:var(--yellow);color:var(--slate-950)}
.btn-primary:hover{background:var(--white);transform:translateY(-2px)}
.btn-outline{border:1.5px solid var(--on-dark-mute);color:var(--white)}
.btn-outline:hover{border-color:var(--yellow);color:var(--yellow)}
.btn-arrow{transition:transform .2s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(3px)}

.hero-visual{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  aspect-ratio:4/5;
  border:1px solid var(--line-dark);
  box-shadow:0 30px 60px -30px rgba(0,0,0,.6);
}
.hero-visual img{width:100%;height:100%;object-fit:cover}
.hero-visual::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(29,33,39,.5), transparent 50%);
  pointer-events:none;
}
.hero-visual-tag{
  position:absolute;left:20px;bottom:20px;
  background:var(--yellow);color:var(--slate-950);
  font-family:var(--font-display);font-weight:700;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:8px 14px;border-radius:var(--radius);
  z-index:2;
}

.hero-card{
  background:var(--slate-800);
  border:1px solid var(--line-dark);
  border-radius:var(--radius);
  padding:32px;
  position:relative;
}
.hero-card-title{
  font-family:var(--font-display);
  font-weight:700;font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--yellow);
  margin-bottom:24px;
  display:flex;align-items:center;gap:10px;
}
.hero-card-title::before{
  content:'';display:inline-block;width:8px;height:8px;
  background:var(--yellow);border-radius:50%;
  box-shadow:0 0 0 4px rgba(245,184,0,.2);
  animation:pulse 2s var(--ease) infinite;
}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 4px rgba(245,184,0,.2)}
  50%{box-shadow:0 0 0 8px rgba(245,184,0,0)}
}
.hero-services{display:flex;flex-direction:column}
.hero-services-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 0;
  border-bottom:1px solid var(--line-dark);
  transition:padding .2s var(--ease);
}
.hero-services-item:last-child{border-bottom:none}
.hero-services-item:hover{padding-left:8px}
.hsi-name{display:flex;flex-direction:column;gap:2px}
.hsi-name b{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--white);letter-spacing:.01em}
.hsi-name span{font-size:.82rem;color:var(--on-dark-mute)}
.hsi-arrow{color:var(--on-dark-mute);transition:color .2s var(--ease), transform .2s var(--ease)}
.hero-services-item:hover .hsi-arrow{color:var(--yellow);transform:translate(3px,-3px)}

/* STRIP */
.strip{
  background:var(--yellow);
  color:var(--slate-950);
  padding:18px 0;
  border-top:1px solid var(--slate-950);
}
.strip-inner{
  display:flex;align-items:center;gap:30px;justify-content:center;
  flex-wrap:wrap;
  font-family:var(--font-display);
  font-weight:700;font-size:.85rem;
  letter-spacing:.14em;text-transform:uppercase;
}
.strip-inner span{display:inline-flex;align-items:center;gap:30px}
.strip-inner span::after{content:'●';font-size:.5em;opacity:.6}
.strip-inner span:last-child::after{display:none}

/* SECCIONES */
section{padding:clamp(70px,9vw,120px) 0}
.section-head{margin-bottom:60px;max-width:760px}
.section-head h2{margin-bottom:16px}
.section-head h2 .y{color:var(--yellow-deep)}
.section-head p{color:var(--on-light-mute);font-size:1.05rem;max-width:60ch}

.dark{background:var(--slate-900);color:var(--on-dark)}
.dark .section-head h2{color:var(--white)}
.dark .section-head h2 .y{color:var(--yellow)}
.dark .section-head p{color:var(--on-dark-mute)}

/* SERVICIOS 6 cards */
.services-4{display:grid;gap:20px;grid-template-columns:1fr}
@media(min-width:680px){.services-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1080px){.services-4{grid-template-columns:repeat(3,1fr)}}
.s4-card{
  background:var(--off);
  border:1px solid var(--line);
  border-radius:var(--radius);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:all .3s var(--ease);
}
.s4-card::after{
  content:'';position:absolute;left:0;top:0;height:3px;width:0;
  background:var(--yellow);transition:width .35s var(--ease);z-index:3;
}
.s4-card:hover{transform:translateY(-4px);border-color:var(--slate-700);box-shadow:0 18px 40px -20px rgba(29,33,39,.25)}
.s4-card:hover::after{width:100%}
.s4-img{
  position:relative;
  aspect-ratio:4/3;
  background:var(--slate-900);
  overflow:hidden;
}
.s4-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s var(--ease);
}
.s4-card:hover .s4-img img{transform:scale(1.04)}
.s4-body{
  padding:26px 24px 28px;
  display:flex;flex-direction:column;gap:14px;flex:1;
}
.s4-tag{
  font-family:var(--font-display);font-weight:800;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--yellow-deep);
}
.s4-card h3{font-size:1.35rem}
.s4-card p{color:var(--on-light-mute);font-size:.95rem}
.s4-link{
  margin-top:auto;
  font-family:var(--font-display);font-weight:700;font-size:.88rem;
  color:var(--slate-900);
  display:inline-flex;align-items:center;gap:8px;
  padding-top:6px;
}
.s4-link svg{transition:transform .2s var(--ease)}
.s4-card:hover .s4-link svg{transform:translateX(4px)}

/* SPLIT */
.split{display:grid;gap:50px;grid-template-columns:1fr;align-items:center}
@media(min-width:980px){.split{grid-template-columns:1fr 1fr;gap:80px}}
.split-visual{
  position:relative;
  border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/5;
  background:var(--slate-900);
}
.split-visual img{
  width:100%;height:100%;
  object-fit:cover;
}
.split-meta{
  position:absolute;left:20px;bottom:20px;
  background:var(--yellow);color:var(--slate-950);
  font-family:var(--font-display);font-weight:700;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;
  padding:8px 14px;border-radius:var(--radius);
}
.split h2{margin-bottom:20px}
.split-body p{color:var(--on-light-mute);font-size:1.02rem;margin-bottom:16px}
.dark .split-body p{color:var(--on-dark-mute)}

.feature-list{list-style:none;margin-top:28px;display:grid;gap:16px}
.feature-list li{display:flex;align-items:flex-start;gap:14px;font-size:.98rem}
.feature-list li svg{flex-shrink:0;margin-top:3px;color:var(--yellow-deep)}
.dark .feature-list li svg{color:var(--yellow)}

/* ZONA */
.zone-grid{
  display:grid;gap:0;grid-template-columns:1fr;
  border:1px solid var(--line-dark);
  border-radius:var(--radius);overflow:hidden;
}
@media(min-width:780px){.zone-grid{grid-template-columns:repeat(3,1fr)}}
.zone-item{
  padding:36px 30px;
  border-right:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
  transition:background .25s var(--ease);
}
.zone-item:hover{background:var(--slate-800)}
@media(min-width:780px){
  .zone-item{border-bottom:none}
  .zone-item:last-child{border-right:none}
}
.zone-num{font-family:var(--font-display);font-weight:800;font-size:.8rem;letter-spacing:.14em;color:var(--yellow);margin-bottom:14px}
.zone-item h3{color:var(--white);font-size:1.35rem;margin-bottom:8px}
.zone-item p{color:var(--on-dark-mute);font-size:.92rem}

/* CTA */
.cta-banner{
  background:var(--yellow);
  color:var(--slate-950);
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;right:-60px;top:-60px;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.25), transparent 70%);
}
.cta-banner-inner{
  display:flex;align-items:center;justify-content:space-between;gap:32px;
  padding:clamp(22px,3vw,32px) 0;
  position:relative;z-index:2;
  flex-wrap:wrap;
}
.cta-banner-text{flex:1;min-width:260px;display:flex;flex-direction:column;gap:4px}
.cta-banner h2{font-size:clamp(1.15rem,1.7vw,1.45rem);color:var(--slate-950);line-height:1.25;margin:0;letter-spacing:-.005em}
.cta-banner p{margin:0;font-size:.92rem;max-width:54ch;color:var(--slate-950);opacity:.78}
.cta-banner p strong{font-weight:700;opacity:1}

/* PHONE BUTTON — botón con forma de móvil, pantalla encendida en oscuro */
.phone-btn{
  display:inline-block;text-decoration:none;
  transition:transform .35s var(--ease);
  flex-shrink:0;
}
.phone-btn:hover{transform:translateY(-4px) rotate(-3deg)}
.phone-btn:active{transform:translateY(-2px) scale(.98)}
.phone{
  width:96px;height:170px;
  background:var(--slate-950);
  border-radius:16px;
  padding:9px 7px;
  position:relative;
  box-shadow:0 14px 30px rgba(0,0,0,.35), inset 0 0 0 1px var(--slate-700);
  display:flex;flex-direction:column;
}
.phone-notch{
  width:32px;height:4px;background:var(--slate-700);border-radius:2px;
  margin:0 auto 6px;
}
.phone-screen{
  background:linear-gradient(160deg, #1d2127, #0d1015);
  border-radius:7px;flex:1;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  gap:6px;padding:6px 4px;
  position:relative;overflow:hidden;
}
.phone-screen::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 20%, rgba(245,184,0,.15), transparent 60%);
  pointer-events:none;
}
.phone-call-dot{
  width:6px;height:6px;border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 8px #22c55e;
  margin-bottom:2px;
  animation:phone-pulse 1.6s var(--ease) infinite;
}
@keyframes phone-pulse{
  0%,100%{opacity:1}
  50%{opacity:.4}
}
.phone-text{
  font-family:var(--font-display);font-weight:800;
  font-size:.7rem;color:var(--yellow);letter-spacing:.06em;
  position:relative;z-index:1;
  white-space:nowrap;
}
.phone-sub{
  font-family:var(--font-body);font-weight:600;
  font-size:.62rem;color:#fff;opacity:.9;
  letter-spacing:.02em;position:relative;z-index:1;
  white-space:nowrap;
}
.phone-home{
  width:38px;height:3px;background:var(--slate-700);border-radius:2px;
  margin:6px auto 0;
}

/* FOOTER */
.footer{background:var(--slate-950);color:var(--on-dark);padding:70px 0 28px}
.footer-grid{display:grid;gap:36px;grid-template-columns:1fr;margin-bottom:50px}
@media(min-width:780px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1.2fr}}
.footer-brand p{color:var(--on-dark-mute);max-width:34ch;margin-top:14px;font-size:.94rem}
.footer h4{font-family:var(--font-display);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--yellow);margin-bottom:18px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul a, .footer ul li{color:var(--on-dark-mute);font-size:.94rem;transition:color .2s var(--ease)}
.footer ul a:hover{color:var(--white)}
.footer-bottom{
  border-top:1px solid var(--line-dark);padding-top:22px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
  font-size:.84rem;color:var(--on-dark-mute);
}

/* PAGE HEAD */
.page-head{
  background:var(--slate-900);color:var(--white);
  padding:clamp(60px,8vw,100px) 0 clamp(50px,6vw,80px);
  position:relative;overflow:hidden;border-bottom:1px solid var(--line-dark);
}
.page-head::before{
  content:'';position:absolute;inset:0;opacity:.7;pointer-events:none;
  background:radial-gradient(circle at 85% 50%, rgba(245,184,0,.10) 0%, transparent 50%);
}
.page-head-inner{position:relative;z-index:2;max-width:760px}
.breadcrumb{font-size:.82rem;color:var(--on-dark-mute);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.breadcrumb a{color:var(--on-dark-mute);transition:color .2s var(--ease)}
.breadcrumb a:hover{color:var(--yellow)}
.breadcrumb .sep{color:var(--yellow)}
.page-head h1{font-size:clamp(2.4rem,5.5vw,4.2rem)}
.page-head h1 .y{color:var(--yellow)}
.page-head-lead{max-width:54ch;margin-top:20px;color:var(--on-dark-mute);font-size:1.05rem}

/* SERVICIO detalle */
.sd-img{
  border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/3;
  background:var(--slate-900);
  margin-bottom:24px;
}
.sd-img img{width:100%;height:100%;object-fit:cover}

.service-detail{
  display:grid;gap:36px;
  grid-template-columns:1fr;
  padding:50px 0;border-bottom:1px solid var(--line);
}
.service-detail:last-child{border-bottom:none}
@media(min-width:880px){.service-detail{grid-template-columns:.8fr 1.4fr;gap:60px}}
.sd-left .eyebrow{color:var(--yellow-deep)}
.sd-left h2{font-size:clamp(1.8rem,3vw,2.4rem);margin-bottom:14px}
.sd-left h2 small{
  display:block;font-family:var(--font-body);font-weight:500;
  font-size:1rem;color:var(--on-light-mute);
  margin-top:6px;letter-spacing:0;text-transform:none;
}
.sd-left p{color:var(--on-light-mute);font-size:1rem}

.sd-right ul{list-style:none;display:grid;gap:12px}
.sd-right li{
  background:var(--off);
  border:1px solid var(--line);
  border-left:3px solid var(--yellow);
  border-radius:var(--radius);
  padding:18px 22px;
  font-family:var(--font-display);font-weight:600;
  transition:background .25s var(--ease), transform .25s var(--ease);
}
.sd-right li:hover{background:var(--white);transform:translateX(4px)}
.sd-right li small{
  display:block;font-family:var(--font-body);font-weight:400;
  font-size:.84rem;color:var(--on-light-mute);
  margin-top:3px;letter-spacing:0;text-transform:none;
}
.sd-right li b{font-weight:700;color:var(--slate-900)}

/* STATS */
.stats-row{
  display:grid;gap:0;grid-template-columns:1fr;
  border:1px solid var(--line-dark);
  border-radius:var(--radius);overflow:hidden;
}
@media(min-width:780px){.stats-row{grid-template-columns:repeat(3,1fr)}}
.stat{
  padding:38px 30px;
  border-right:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
}
@media(min-width:780px){
  .stat{border-bottom:none}
  .stat:last-child{border-right:none}
}
.stat .v{font-family:var(--font-display);font-weight:900;font-size:clamp(2.6rem,4.5vw,3.6rem);color:var(--white);line-height:1}
.stat .v sup{font-size:.45em;color:var(--yellow);margin-left:4px;vertical-align:top}
.stat .k{font-size:.88rem;color:var(--on-dark-mute);margin-top:10px;letter-spacing:.04em}

/* VALORES */
.values{
  display:grid;gap:0;grid-template-columns:1fr;
  border:1px solid var(--line-dark);
  border-radius:var(--radius);overflow:hidden;
}
@media(min-width:780px){.values{grid-template-columns:repeat(3,1fr)}}
.value{
  padding:34px 30px;
  border-right:1px solid var(--line-dark);
  border-bottom:1px solid var(--line-dark);
  transition:background .25s var(--ease);
}
@media(min-width:780px){
  .value{border-bottom:none}
  .value:last-child{border-right:none}
}
.value:hover{background:var(--slate-800)}
.value .v-icon{width:44px;height:44px;border-radius:var(--radius);background:var(--yellow);color:var(--slate-950);display:grid;place-items:center;margin-bottom:18px}
.value h3{color:var(--white);font-size:1.2rem;margin-bottom:8px}
.value p{color:var(--on-dark-mute);font-size:.94rem}

/* CONTACTO */
.contact-grid{display:grid;gap:50px;grid-template-columns:1fr}
@media(min-width:980px){.contact-grid{grid-template-columns:1fr 1fr;gap:70px}}
.contact-info{display:flex;flex-direction:column;gap:18px}
.info-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 26px;
  display:flex;gap:18px;align-items:flex-start;
  transition:border-color .25s var(--ease), background .25s var(--ease);
}
.info-card:hover{border-color:var(--yellow);background:var(--off)}
.ic-icon{width:46px;height:46px;border-radius:var(--radius);background:var(--slate-900);color:var(--yellow);display:grid;place-items:center;flex-shrink:0}
.info-card h4{font-family:var(--font-display);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--on-light-mute);margin-bottom:6px;font-weight:700}
.info-card p, .info-card a{font-size:1.02rem;color:var(--slate-900);font-weight:500}
.info-card a:hover{color:var(--yellow-deep)}

.form{border:1px solid var(--line);border-radius:var(--radius);background:var(--white);padding:36px}
.form h3{font-size:1.5rem;margin-bottom:6px}
.form-lead{color:var(--on-light-mute);font-size:.95rem;margin-bottom:24px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-family:var(--font-display);font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--on-light-mute)}
.field input, .field textarea, .field select{
  font:inherit;color:inherit;
  background:var(--off);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px 16px;font-size:1rem;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus{outline:none;border-color:var(--yellow);background:var(--white)}
.field textarea{resize:vertical;min-height:120px;font-family:inherit}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form button[type=submit]{
  background:var(--slate-900);color:var(--white);
  padding:15px 28px;border-radius:var(--radius);
  font-family:var(--font-display);font-weight:700;font-size:.92rem;
  letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:10px;
  margin-top:8px;
  transition:background .2s var(--ease), transform .2s var(--ease);
}
.form button[type=submit]:hover{background:var(--yellow);color:var(--slate-950);transform:translateY(-1px)}
.form-msg{margin-top:16px;padding:14px 18px;background:rgba(245,184,0,.12);border:1px solid var(--yellow);border-radius:var(--radius);font-size:.94rem;display:none}
.form-msg.show{display:block}

.map-wrap{aspect-ratio:16/9;background:var(--line);overflow:hidden;border-radius:var(--radius);border:1px solid var(--line)}
.map-wrap iframe{width:100%;height:100%;border:none;filter:grayscale(.2)}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.fade-up.in{opacity:1;transform:none}

/* WHATSAPP FLOATING BUTTON */
.wa-fab{
  position:fixed;
  bottom:22px;right:22px;
  width:58px;height:58px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:grid;place-items:center;
  box-shadow:0 8px 26px rgba(37,211,102,.4), 0 2px 6px rgba(0,0,0,.15);
  z-index:99;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.wa-fab::before{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(37,211,102,.4);
  animation:wa-ring 2.4s var(--ease) infinite;
}
@keyframes wa-ring{
  0%{transform:scale(.9);opacity:1}
  100%{transform:scale(1.5);opacity:0}
}
.wa-fab:hover{transform:scale(1.08);box-shadow:0 12px 34px rgba(37,211,102,.55), 0 4px 10px rgba(0,0,0,.2)}
.wa-fab svg{width:30px;height:30px}
.wa-fab-label{
  position:absolute;right:68px;
  background:var(--slate-950);color:#fff;
  font-size:.86rem;font-weight:600;
  padding:8px 14px;border-radius:6px;
  white-space:nowrap;
  opacity:0;pointer-events:none;
  transform:translateX(8px);
  transition:opacity .25s var(--ease), transform .25s var(--ease);
}
.wa-fab-label::after{
  content:'';position:absolute;right:-5px;top:50%;
  transform:translateY(-50%);
  border:5px solid transparent;
  border-left-color:var(--slate-950);
}
.wa-fab:hover .wa-fab-label{opacity:1;transform:translateX(0)}
@media(max-width:600px){
  .wa-fab{width:54px;height:54px;bottom:18px;right:18px}
  .wa-fab-label{display:none}
}

::selection{background:var(--yellow);color:var(--slate-950)}

@media(min-width:880px){
  html::-webkit-scrollbar{width:10px;background:var(--slate-900)}
  html::-webkit-scrollbar-thumb{background:var(--slate-700);border-radius:5px}
  html::-webkit-scrollbar-thumb:hover{background:var(--yellow-deep)}
}

/* ============================================
   MEJORAS MÓVIL — añadidas v3
   ============================================ */
@media (max-width: 680px){
  body{font-size:15px}
  h1{font-size:clamp(2rem, 9vw, 2.8rem)}
  h2{font-size:clamp(1.6rem, 6vw, 2.2rem)}
  h3{font-size:1.15rem}

  .nav-inner{padding:12px var(--gutter)}
  .brand img{height:40px;width:auto}

  .hero{padding:50px 0 40px}
  .hero-grid{gap:30px}
  .hero-eu{font-size:.72rem;margin-bottom:14px}
  .hero h1{line-height:1.05}
  .hero-lead{font-size:.98rem;margin:18px 0 24px}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{justify-content:center;width:100%}
  .hero-visual{aspect-ratio:16/11;border-radius:8px}
  .hero-visual-tag{font-size:.66rem;padding:6px 10px;left:14px;bottom:14px}

  .strip{padding:14px 0}
  .strip-inner{font-size:.7rem;gap:16px}
  .strip-inner span{gap:16px}
  .strip-inner span::after{font-size:.4em}

  section{padding:55px 0}
  .section-head{margin-bottom:36px}
  .section-head h2{font-size:clamp(1.7rem, 7vw, 2.4rem)}
  .section-head p{font-size:.96rem}
  .eyebrow{font-size:.7rem;margin-bottom:10px}

  .services-4{gap:14px}
  .s4-card h3{font-size:1.2rem}
  .s4-body{padding:22px 20px 24px;gap:12px}

  .split{gap:32px}
  .split-visual{aspect-ratio:4/3}

  .zone-item{padding:28px 22px}
  .zone-item h3{font-size:1.2rem}

  .cta-banner-inner{flex-direction:column;text-align:center;gap:18px;padding:24px 0}
  .cta-banner-text{align-items:center}
  .cta-banner h2{font-size:1.15rem}
  .cta-banner p{font-size:.88rem}

  .page-head{padding:50px 0 36px}
  .page-head h1{font-size:clamp(1.9rem, 8vw, 2.8rem)}
  .page-head-lead{font-size:.96rem;margin-top:14px}
  .breadcrumb{font-size:.74rem;margin-bottom:14px}

  .service-detail{padding:32px 0;gap:22px}
  .sd-left h2{font-size:1.5rem}
  .sd-right li{padding:14px 16px}

  .stats-row{gap:0}
  .stat{padding:28px 22px}
  .stat .v{font-size:2.4rem}

  .values .value{padding:24px 22px}

  .info-card{padding:18px 20px;gap:14px}
  .info-card p, .info-card a{font-size:.95rem}
  .ic-icon{width:40px;height:40px}

  .form{padding:24px 20px}
  .form h3{font-size:1.3rem}

  .footer{padding:50px 0 22px}
  .footer-grid{gap:28px;margin-bottom:32px}
  .footer-brand p{font-size:.9rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px;font-size:.78rem}

  .wa-fab{width:52px;height:52px;bottom:16px;right:16px}
  .wa-fab svg{width:26px;height:26px}
}

@media (max-width: 380px){
  :root{--gutter: 16px}
  .nav-cta{padding:9px 14px;font-size:.82rem}
  .strip-inner{font-size:.64rem;gap:12px}
  .strip-inner span{gap:12px}
}

/* ============================================
   COOKIE BANNER
   ============================================ */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;
  max-width:560px;margin:0 auto;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:10px;
  box-shadow:0 18px 50px rgba(15,31,51,.25);
  padding:20px 22px;
  z-index:200;
  display:none;
  font-size:.92rem;line-height:1.5;
}
.cookie-banner.show{display:block;animation:cookie-in .4s var(--ease)}
@keyframes cookie-in{
  from{transform:translateY(20px);opacity:0}
  to{transform:none;opacity:1}
}
.cookie-banner h4{
  font-family:var(--font-display);font-weight:800;
  font-size:1rem;margin-bottom:6px;color:var(--slate-900);
}
.cookie-banner p{color:var(--on-light-mute);margin-bottom:14px;font-size:.88rem}
.cookie-banner p a{color:var(--slate-900);text-decoration:underline}
.cookie-banner-buttons{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner-buttons button{
  font-family:var(--font-display);font-weight:700;font-size:.85rem;
  padding:10px 18px;border-radius:var(--radius);
  cursor:pointer;transition:transform .2s var(--ease), background .2s var(--ease);
}
.cookie-banner-buttons .accept{background:var(--yellow);color:var(--slate-950);border:none}
.cookie-banner-buttons .accept:hover{background:var(--yellow-soft)}
.cookie-banner-buttons .reject{background:transparent;color:var(--slate-900);border:1.5px solid var(--line)}
.cookie-banner-buttons .reject:hover{border-color:var(--slate-900)}

/* ============================================
   PÁGINAS LEGALES — typography
   ============================================ */
.legal-content{
  max-width:780px;margin:0 auto;padding:50px 0;
}
.legal-content h2{
  font-size:clamp(1.4rem, 2.5vw, 1.8rem);
  margin:36px 0 14px;color:var(--slate-900);
}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{
  font-size:1.1rem;margin:22px 0 8px;color:var(--slate-900);
  font-weight:700;
}
.legal-content p, .legal-content li{
  color:var(--on-light);font-size:.98rem;line-height:1.7;
  margin-bottom:12px;
}
.legal-content ul, .legal-content ol{margin:0 0 18px 22px}
.legal-content li{margin-bottom:6px}
.legal-content a{color:var(--yellow-deep);text-decoration:underline}
.legal-content a:hover{color:var(--slate-900)}
.legal-content strong{color:var(--slate-900);font-weight:700}
.legal-content .updated{
  font-size:.84rem;color:var(--on-light-mute);
  padding:10px 14px;background:var(--off);
  border-left:3px solid var(--yellow);
  margin-bottom:30px;border-radius:var(--radius);
}
.legal-content table{
  width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:.92rem;
}
.legal-content th, .legal-content td{
  padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);
}
.legal-content th{background:var(--off);font-family:var(--font-display);font-weight:700}

/* Enlace legal en footer-bottom */
.footer-legal{
  display:flex;gap:18px;flex-wrap:wrap;font-size:.78rem;
}
.footer-legal a{color:var(--on-dark-mute);transition:color .2s var(--ease)}
.footer-legal a:hover{color:var(--yellow)}
@media (max-width:780px){
  .footer-legal{gap:14px}
}

/* ============================================
   SELECTOR DE IDIOMA (ES / EU)
   ============================================ */
.lang-switch{
  display:inline-flex;
  align-items:center;
  gap:0;
  border:1px solid var(--line-dark);
  border-radius:var(--radius);
  overflow:hidden;
  margin-right:10px;
  font-family:var(--font-display);
}
.lang-switch button{
  background:transparent;color:var(--on-dark-mute);
  padding:7px 12px;font-size:.78rem;font-weight:700;letter-spacing:.06em;
  cursor:pointer;border:none;
  transition:background .2s var(--ease), color .2s var(--ease);
}
.lang-switch button:hover{color:var(--white)}
.lang-switch button.active{background:var(--yellow);color:var(--slate-950)}
.lang-switch button + button{border-left:1px solid var(--line-dark)}

@media (max-width:900px){
  .lang-switch{
    order:-1;
    margin:0 0 14px 0;
    align-self:flex-start;
  }
}

/* Mensajes de formulario */
.form-msg.error{
  color:#c00;
  background:#fff3f3;
  border-color:#fbb;
}
