/* ═══════════════════════════════════════════════════════════
   KADLED — styles.css  v2
   Ajuste de legibilidad y jerarquía visual
   Paleta: 419C #2D2926 · 3308C #00352E · 369C #5CB825
   Navy: #011823 · #172831
═══════════════════════════════════════════════════════════ */
:root {
  --carbon:#2D2926; --carbon2:#1e1c1a; --navy:#011823; --navy2:#172831;
  --steel:#4A4845; --fog:#7a7775; --silver:#B8B5B2; --smoke:#E8E5E1;
  --cream:#F3F1ED; --white:#FFFFFF;
  --forest:#00352E; --forest2:#004d43;
  --green:#5CB825; --green2:#3e8318;
  --serif:'Bebas Neue',sans-serif;
  --cond:'Barlow Condensed',sans-serif;
  --body:'Barlow',sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--carbon);background:var(--white);overflow-x:hidden}
img{display:block;max-width:100%}
button{cursor:pointer}
ul{list-style:none}
a{text-decoration:none}
.sr{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.sr.up{opacity:1;transform:translateY(0)}
.sr.d1{transition-delay:.1s}.sr.d2{transition-delay:.2s}.sr.d3{transition-delay:.3s}.sr.d4{transition-delay:.4s}

/* ── NAVBAR ── */
#nav{
  position: fixed;
  inset: 0 0 auto;
  z-index: 1000;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5%;
  background: rgba(255,255,255,.90);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 1px 0 rgba(0,0,0,.08),
              0 8px 32px rgba(0,0,0,.06);
  transition: box-shadow .4s, height .3s;
}
#nav.solid{
  background:rgba(255,255,255,.97);
  box-shadow:0 1px 0 rgba(0,0,0,.08),0 8px 32px rgba(0,0,0,.06);
  height:70px
}
.nav-logo img{height:44px;width:auto}
.nav-menu{display:flex;align-items:center;gap:2.4rem}
.nav-menu a{
  font-family:var(--cond);
  font-weight:700;
  font-size:1.08rem;
  letter-spacing:.11em;
  text-transform:uppercase;
  color: var(--carbon);
  position:relative;
  transition:color .25s;
}
#nav.solid .nav-menu a{color:var(--carbon)}
.nav-menu a::after{
  content:'';
  position:absolute;
  bottom:-4px;
  left:0;
  width:0;
  height:2px;
  background:var(--green);
  transition:width .3s
}
.nav-menu a:hover{color:var(--green)}
#nav.solid .nav-menu a:hover{color:var(--green)}
.nav-menu a:hover::after{width:100%}
.nav-btn{
  background:var(--green)!important;
  color:var(--white)!important;
  padding:12px 26px;
  font-weight:700!important;
  font-size:1rem;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)
}
.nav-btn::after{display:none!important}
.nav-btn:hover{background:var(--green2)!important}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px}
.hamburger span{display:block;width:26px;height:2px;background:var(--white);transition:.3s}
#nav.solid .hamburger span{background:var(--carbon)}
.nav-menu.open{
  display:flex;
  flex-direction:column;
  position:absolute;
  top:70px;
  left:0;
  right:0;
  background:var(--white);
  padding:1.5rem 5%;
  gap:1rem;
  border-bottom:2px solid var(--green);
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  z-index:999
}
.nav-menu.open a{color:var(--carbon)!important}

/* ── HERO ── */
#hero{position:relative;height:100vh;min-height:640px;overflow:hidden}
.slide{position:absolute;inset:0;opacity:0;z-index:1;background-size:cover;background-position:center}
.slide.active{opacity:1;z-index:2;animation:kb 8s ease-out forwards}
.slide.leaving{animation:fade-out 1.2s ease forwards;z-index:2}
@keyframes kb{0%{transform:scale(1)}100%{transform:scale(1.08)}}
@keyframes fade-out{0%{opacity:1}100%{opacity:0}}
#s1{background-image:url('../img/hero-iluminacion.jpg')}
#s2{background-image:url('../img/hero-agua.jpg')}
#s3{background-image:url('../img/hero-tableros.jpg')}
.slide::after{content:'';position:absolute;inset:0;background:linear-gradient(110deg,rgba(1,24,35,.84) 0%,rgba(1,24,35,.52) 45%,rgba(0,53,46,.28) 100%)}
.hero-inner{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;justify-content:flex-end;padding:0 8% 5.5%}
.slide-tabs{display:flex;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}
.stab{
  font-family:var(--cond);
  font-weight:700;
  font-size:.9rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:9px 18px;
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.45);
  background:transparent;
  transition:all .3s;
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%)
}
.stab.on{background:var(--green);color:var(--white);border-color:var(--green)}
.stext{display:none}
.stext.on{display:block;animation:stxt-in .65s ease both}
@keyframes stxt-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.hero-tag{
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-family:var(--cond);
  font-weight:700;
  font-size:.88rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--green);
  background:rgba(92,184,37,.12);
  border:1px solid rgba(92,184,37,.32);
  padding:7px 15px;
  margin-bottom:1.1rem
}
.hero-tag .dot{
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--green);
  flex-shrink:0;
  animation:pdot 1.6s ease-in-out infinite
}
@keyframes pdot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.65)}}
.hero-h1{
  font-family:var(--serif);
  font-size:clamp(4rem,8.5vw,9.2rem);
  line-height:.9;
  text-transform:uppercase;
  color:var(--white);
  letter-spacing:.03em;
  margin-bottom:1.1rem
}
.hero-h1 em{font-style:normal;color:var(--green);display:block}
.hero-desc{
  font-size:1.28rem;
  line-height:1.65;
  color:rgba(255,255,255,.78);
  max-width:620px;
  margin-bottom:2.2rem
}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.6rem}
.hero-pills{display:flex;gap:.75rem;flex-wrap:wrap}
.hpill{
  display:flex;
  align-items:center;
  gap:.7rem;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);
  border-left:3px solid var(--green);
  padding:.9rem 1.2rem;
  transition:background .3s,transform .3s
}
.hpill:hover{background:rgba(92,184,37,.14);transform:translateY(-2px)}
.hpill svg{width:17px;height:17px;stroke:var(--green);flex-shrink:0}
.hpill strong{
  font-family:var(--cond);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--white);
  display:block;
  line-height:1.1
}
.hpill small{
  font-size:.85rem;
  color:rgba(255,255,255,.62)
}
.slide-prog{position:absolute;bottom:0;left:0;right:0;z-index:6;display:flex}
.pbar{flex:1;height:3px;background:rgba(255,255,255,.1);position:relative;overflow:hidden}
.pbar.on::after{content:'';position:absolute;inset:0 100% 0 0;background:var(--green);animation:pfill 7s linear forwards}
@keyframes pfill{from{right:100%}to{right:0%}}
.hero-scroll{position:absolute;right:5%;bottom:4.5rem;z-index:6;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero-scroll span{
  font-family:var(--cond);
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.38);
  writing-mode:vertical-lr
}
.sline{width:1px;height:72px;background:linear-gradient(to bottom,var(--green),transparent);animation:sl 2s ease-in-out infinite}
@keyframes sl{0%,100%{opacity:.4}50%{opacity:1}}

/* ── TICKER ── */
.ticker{background:var(--navy);padding:13px 0;overflow:hidden;z-index:5;position:relative}
.ttrack{display:flex;white-space:nowrap;animation:tscroll 26s linear infinite}
@keyframes tscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.titem{
  display:inline-flex;
  align-items:center;
  gap:1.4rem;
  padding:0 2.4rem;
  font-family:var(--cond);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.58)
}
.titem .tdot{width:5px;height:5px;border-radius:50%;background:var(--green);flex-shrink:0}

/* ── BUTTONS ── */
.btn-g,
.btn-ow,
.btn-w,
.btn-bo{
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-family:var(--cond);
  font-weight:700;
  font-size:1.05rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  clip-path:polygon(10px 0%,100% 0%,calc(100% - 10px) 100%,0% 100%);
}

.btn-g{
  background:var(--green);
  color:var(--white);
  border:none;
  padding:16px 34px;
  transition:background .25s,transform .2s
}
.btn-g:hover{background:var(--green2);transform:translateY(-2px)}
.btn-g svg{transition:transform .25s}
.btn-g:hover svg{transform:translateX(4px)}

.btn-ow{
  background:transparent;
  color:var(--white);
  padding:15px 32px;
  border:2px solid rgba(255,255,255,.38);
  transition:border-color .25s,color .25s,background .25s
}
.btn-ow:hover{border-color:var(--green);color:var(--green);background:rgba(92,184,37,.07)}

.btn-w{
  background:var(--white);
  color:var(--forest);
  border:none;
  padding:16px 34px;
  transition:background .25s
}
.btn-w:hover{background:var(--smoke)}

.btn-bo{
  background:transparent;
  color:var(--white);
  padding:15px 32px;
  border:2px solid rgba(255,255,255,.35);
  transition:background .25s,border-color .25s
}
.btn-bo:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.7)}

/* ── CHIPS / TITLES ── */
.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--cond);
  font-weight:700;
  font-size:.88rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:.9rem
}
.chip::before{content:'';display:block;width:22px;height:2px;background:currentColor;flex-shrink:0}
.chip.g{color:var(--green)}.chip.w{color:rgba(255,255,255,.5)}.chip.s{color:var(--silver)}.chip.n{color:var(--navy2)}
.dtitle{font-family:var(--serif);font-size:clamp(2.8rem,5.2vw,5.5rem);line-height:.95;letter-spacing:.02em;text-transform:uppercase}
.dtitle.lght{color:var(--white)}.dtitle.drk{color:var(--carbon)}.dtitle em{font-style:normal;color:var(--green)}
.stitle{font-family:var(--cond);font-weight:900;font-size:clamp(1.9rem,3vw,2.9rem);line-height:1.05;letter-spacing:-.01em}
.stitle em{font-style:normal;color:var(--green)}

/* ── NOSOTROS ── */
#nosotros{background:var(--white)}
.nos-grid{display:grid;grid-template-columns:1fr 1fr;min-height:600px}
.nos-photo{position:relative;overflow:hidden;background:url('../img/nosotros-equipo.jpg') center/cover no-repeat}
.nos-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,transparent 55%,rgba(255,255,255,.06))}
.nos-stat{position:absolute;bottom:2.5rem;right:-1.5rem;background:var(--green);color:var(--white);padding:1.4rem 1.8rem;z-index:2;box-shadow:0 14px 44px rgba(92,184,37,.35)}
.nos-stat .nnum{font-family:var(--serif);font-size:3.2rem;line-height:.9;display:block}
.nos-stat .nlbl{font-family:var(--cond);font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;opacity:.9;margin-top:.4rem}
.nos-badge{position:absolute;top:2rem;left:2rem;background:var(--navy);color:var(--white);padding:.8rem 1.25rem;z-index:2}
.nos-badge p{font-family:var(--cond);font-weight:700;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--silver)}
.nos-badge strong{font-family:var(--cond);font-weight:700;font-size:1rem;letter-spacing:.07em;text-transform:uppercase;color:var(--green)}
.nos-copy{padding:5rem 6% 5rem 7%;display:flex;flex-direction:column;justify-content:center}
.nos-copy p{font-size:1.18rem;line-height:1.8;color:var(--steel);margin:1rem 0}

.nos-divisiones{display:flex;flex-direction:column;gap:.6rem;margin-top:1.8rem}
.nd-item{display:flex;align-items:center;gap:1rem;padding:.95rem 1.15rem;border-left:3px solid var(--green);background:var(--cream);transition:background .3s}
.nd-item:hover{background:var(--smoke)}
.nd-num{font-family:var(--serif);font-size:2.2rem;line-height:1;color:var(--green);min-width:2.5rem;flex-shrink:0}
.nd-item strong{
  font-family:var(--cond);
  font-weight:800;
  font-size:1.02rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--carbon);
  display:block;
  line-height:1.2;
  margin-bottom:.3rem
}
.nd-item p{font-size:.95rem;color:var(--fog);margin:0 0 .5rem;line-height:1.6}
.nd-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}
.nd-tags span{
  font-family:var(--cond);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:4px 10px;
  background:rgba(92,184,37,.1);
  color:var(--green);
  border:1px solid rgba(92,184,37,.25)
}

/* Filosofía */
.nos-filosofia{
  background: var(--cream);
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:0;
  border-top:1px solid rgba(0,0,0,.05);
}
.nf-left{
  padding:5rem 6% 5rem 8%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.nf-title{
  font-family:var(--cond);
  font-weight:900;
  font-size:clamp(1.7rem,2.6vw,2.5rem);
  line-height:1.1;
  color:var(--carbon);
  margin-top:.5rem;
}
.nf-title em{font-style:normal;color:var(--green)}
.nf-right{
  padding:5rem 7% 5rem 5%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.nf-right p{
  font-size:1.1rem;
  line-height:1.8;
  color:var(--steel);
  margin-bottom:.75rem;
}

/* ── CALIDAD ── */
#calidad{
  position:relative;
  overflow:hidden;
  background: var(--white);
  padding:0;
}
#calidad::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:url('../img/nosotros-equipo.jpg') center/cover no-repeat;
  opacity:.08;
}
#calidad::after{
  content:'CALIDAD';
  position:absolute; right:-2%; bottom:-8%;
  font-family:var(--serif); font-size:22vw; line-height:1;
  color:transparent; -webkit-text-stroke:1px rgba(255,255,255,.04);
  pointer-events:none; user-select:none; z-index:0;
}
.cal-inner{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  min-height:420px;
}
.cal-left{
  background:var(--green);
  padding:5rem 6%;
  display:flex; flex-direction:column; justify-content:center;
  position:relative; overflow:hidden;
}
.cal-left::before{
  content:'';
  position:absolute; inset:0;
  background:repeating-linear-gradient(
    -45deg, transparent, transparent 18px,
    rgba(0,0,0,.06) 18px, rgba(0,0,0,.06) 19px
  );
}
.cal-left .chip{position:relative;z-index:1;color:rgba(0,0,0,.45)}
.cal-left .chip::before{background:rgba(0,0,0,.35)}
.cal-left .stitle{
  position:relative;z-index:1;
  color:var(--white);font-size:clamp(2.2rem,3.5vw,3.4rem);
  text-shadow:0 2px 12px rgba(0,0,0,.2);
}
.cal-left .stitle em{color:var(--carbon2)}
.cal-right{
  padding:5rem 7%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.cal-quote{
  font-size:1.28rem;
  line-height:1.65;
  font-style:italic;
  color: var(--carbon);
  border-left:4px solid var(--green);
  padding-left:1.4rem;
  margin-bottom:1.6rem;
}
.cal-quote strong{font-style:normal;color:var(--green)}
.cal-right>p{
  color: var(--steel);
  font-size:1.08rem;
  line-height:1.8;
}
.cal-badges{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.cal-badge{
  background: var(--white);
  border:1px solid rgba(0,0,0,.08);
}
.cal-badge:hover{background:rgba(255,255,255,.1)}
.cal-badge span{color: var(--carbon)}
.cal-badge small{
  font-size:.8rem;
  color: var(--fog);
}

/* ── SOLUCIONES ── */
#soluciones{background:var(--navy);position:relative;overflow:hidden}
#soluciones::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 0% 60%,rgba(92,184,37,.05) 0%,transparent 50%)}
.sol-hd{padding:6rem 8% 4rem;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem}
.sol-hd-desc{max-width:400px;font-size:1.12rem;line-height:1.75;color:var(--silver)}
.sol-cards{display:grid;grid-template-columns:repeat(3,1fr)}
.sc{position:relative;height:520px;overflow:hidden;cursor:pointer}
.sc-photo{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .65s ease}
.sc:hover .sc-photo{transform:scale(1.06)}
.sc-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 55%,transparent 100%)}
#sc-ilum .sc-photo{background-image:url('../img/sol-iluminacion.jpg')}
#sc-tableros .sc-photo{background-image:url('../img/sol-tableros.jpg')}
#sc-ptar .sc-photo{background-image:url('../img/sol-agua.jpg')}
#sc-ensambles .sc-photo{background-image:url('../img/sol-ensambles.jpg')}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;z-index:3}
#sc-ilum::before{background:var(--green)}
#sc-tableros::before{background:var(--navy2)}
#sc-ptar::before{background:var(--forest2)}
#sc-ensambles::before{background:var(--steel)}
.sc-body{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:2rem}
.sc-num{font-family:var(--serif);font-size:5.5rem;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.1);margin-bottom:auto}
.sc-icon{width:50px;height:50px;flex-shrink:0;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;transition:background .3s,border-color .3s}
.sc:hover .sc-icon{background:var(--green);border-color:var(--green)}
.sc-icon svg{width:22px;height:22px;stroke:#fff}
.sc-tag{
  font-family:var(--cond);
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:.4rem
}
.sc-title{
  font-family:var(--cond);
  font-weight:900;
  font-size:1.9rem;
  text-transform:uppercase;
  letter-spacing:.02em;
  line-height:1.1;
  color:var(--white);
  margin-bottom:.85rem
}
.sc-list{display:flex;flex-direction:column;gap:.3rem}
.sc-list li{
  font-size:.98rem;
  color:rgba(255,255,255,.68);
  display:flex;
  align-items:center;
  gap:.55rem;
  transition:color .25s
}
.sc:hover .sc-list li{color:rgba(255,255,255,.82)}
.sc-list li::before{content:'';display:block;width:5px;height:5px;border-radius:50%;background:var(--green);flex-shrink:0}
.sc-cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--cond);
  font-weight:700;
  font-size:.92rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--green);
  margin-top:1.2rem;
  padding-top:1.1rem;
  border-top:1px solid rgba(255,255,255,.1);
  transition:gap .25s;
  cursor:pointer
}
.sc:hover .sc-cta{gap:11px}

/* ── MODALES ── */
.modal-overlay{position:fixed;inset:0;z-index:2000;background:rgba(1,24,35,.85);display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .35s}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal-box{background:var(--white);max-width:780px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:mod-in .35s ease both;padding-bottom:1rem}
@keyframes mod-in{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.modal-close{position:absolute;top:1.2rem;right:1.2rem;background:rgba(0,0,0,.1);border:none;width:36px;height:36px;font-size:1.4rem;line-height:1;color:var(--steel);transition:background .2s;z-index:2}
.modal-close:hover{background:rgba(0,0,0,.2);color:var(--carbon)}
.modal-header{display:flex;align-items:flex-start;gap:1.4rem;padding:2.5rem 2.5rem 2rem;border-bottom:2px solid var(--smoke)}
.modal-header.ilum{border-top:5px solid var(--green)}
.modal-header.tab{border-top:5px solid var(--navy2)}
.modal-header.ptar{border-top:5px solid var(--forest2)}
.modal-header.ens{border-top:5px solid var(--steel)}
.modal-icon{width:56px;height:56px;flex-shrink:0;background:var(--green);display:flex;align-items:center;justify-content:center}
.modal-header.tab .modal-icon{background:var(--navy2)}
.modal-header.ptar .modal-icon{background:var(--forest2)}
.modal-header.ens .modal-icon{background:var(--steel)}
.modal-icon svg{width:26px;height:26px;stroke:#fff}
.modal-tag{
  font-family:var(--cond);
  font-weight:700;
  font-size:.85rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green);
  margin-bottom:.4rem
}
.modal-header.tab .modal-tag{color:var(--navy2)}
.modal-header.ptar .modal-tag{color:var(--forest2)}
.modal-header.ens .modal-tag{color:var(--steel)}
.modal-title{font-family:var(--cond);font-weight:900;font-size:1.95rem;text-transform:uppercase;line-height:1.15;color:var(--carbon)}
.modal-body{padding:2rem 2.5rem 2.5rem}
.modal-body>p{font-size:1.08rem;line-height:1.8;color:var(--steel);margin-bottom:1.6rem}
.modal-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.6rem}
.modal-col h4{
  font-family:var(--cond);
  font-weight:800;
  font-size:.95rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--carbon);
  margin-bottom:.7rem;
  padding-bottom:.4rem;
  border-bottom:2px solid var(--green)
}
.modal-col ul{
  display:flex;
  flex-direction:column;
  gap:.4rem;
}

/* ══ FIX: listas del modal — flujo inline para que <strong> no rompa línea ══ */
.modal-col li{
  font-size:1rem;
  color:var(--steel);
  line-height:1.6;
  padding-left:1rem;
  position:relative;
}
.modal-col li::before{
  content:'';
  position:absolute;
  left:0;
  top:.55em;
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--green);
}
.modal-col li strong{
  font-weight:800;
}
/* ══ FIN FIX ══ */

.modal-result{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.8rem}
.modal-result span{
  font-family:var(--cond);
  font-weight:700;
  font-size:.86rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--white);
  background:var(--green);
  padding:6px 12px
}
.modal-norms{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.8rem}
.modal-norms span{
  font-family:var(--cond);
  font-weight:700;
  font-size:.86rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:6px 12px;
  border:1.5px solid var(--smoke);
  color:var(--steel)
}
.modal-btn{width:100%;justify-content:center;font-size:1rem}
.modal-section-title{
  font-family:var(--cond);
  font-weight:800;
  font-size:.84rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--green);
  border-bottom:1px solid var(--smoke);
  padding-bottom:.5rem;
  margin:1.8rem 0 1rem
}
.modal-steps{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.modal-step{display:flex;gap:1rem;align-items:flex-start;padding:.95rem 1rem;background:var(--cream);border-left:3px solid var(--green)}
.mstep-num{font-family:var(--serif);font-size:2rem;line-height:1;color:var(--green);flex-shrink:0;min-width:2rem}
.modal-step strong{
  font-family:var(--cond);
  font-weight:800;
  font-size:.98rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--carbon);
  display:block;
  margin-bottom:.25rem
}
.modal-step p{font-size:.95rem;color:var(--steel);margin:0;line-height:1.6}
.modal-diferenciador{background:var(--navy);border-left:4px solid var(--green);padding:1.1rem 1.3rem;margin-bottom:1.6rem}
.modal-diferenciador p{font-size:1rem;line-height:1.7;color:var(--silver);margin:0}
.modal-diferenciador strong{color:var(--white)}

/* ── CTA BAND ── */
.cta-band{background:linear-gradient(115deg,var(--forest) 0%,var(--forest2) 55%,#1a6b20 100%);padding:5.5rem 8%;display:flex;align-items:center;justify-content:space-between;gap:3rem;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(255,255,255,.04) 59px,rgba(255,255,255,.04) 60px),repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(255,255,255,.04) 59px,rgba(255,255,255,.04) 60px)}
.cta-txt{position:relative;z-index:1}
.cta-txt h2{font-family:var(--serif);font-size:clamp(2.4rem,4.2vw,4rem);text-transform:uppercase;color:var(--white);line-height:.92;letter-spacing:.03em;margin-bottom:.75rem}
.cta-txt h2 em{font-style:normal;color:rgba(255,255,255,.45)}
.cta-txt p{font-size:1.12rem;color:rgba(255,255,255,.74);max-width:460px;line-height:1.75}
.cta-acts{position:relative;z-index:1;display:flex;gap:1rem;flex-wrap:wrap}

/* ── PORTAFOLIO ── */
#portafolio{background:var(--cream);padding:7rem 8%}
.port-hd{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1.5rem;margin-bottom:3.5rem}
.port-filter{display:flex;gap:.5rem;flex-wrap:wrap}
.pf{
  font-family:var(--cond);
  font-weight:700;
  font-size:.88rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:9px 22px;
  background:transparent;
  color:var(--steel);
  border:1.5px solid var(--smoke);
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
  transition:all .2s
}
.pf:hover,.pf.on{background:var(--navy);color:var(--white);border-color:var(--navy)}
.pgrid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:280px 280px;gap:.75rem}
.pi{position:relative;overflow:hidden;cursor:pointer}
.pi:nth-child(1){grid-column:span 2}
.pphoto{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .55s ease}
.pi:hover .pphoto{transform:scale(1.06)}
.pphoto::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.76) 0%,rgba(0,0,0,.1) 55%,transparent 100%)}
#pp-reforma{background-image:url('../img/port-reforma-cdmx.jpg')}
#pp-mty{background-image:url('../img/port-planta-mty.jpg')}
#pp-qro{background-image:url('../img/port-ptar-qro.jpg')}
#pp-gdl{background-image:url('../img/port-industrial-gdl.jpg')}
#pp-edomex{background-image:url('../img/port-cc-edomex.jpg')}
.pinfo{position:absolute;bottom:0;left:0;right:0;padding:1.3rem;z-index:2}
.ptag{
  font-family:var(--cond);
  font-weight:700;
  font-size:.8rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--green);
  display:block;
  margin-bottom:.3rem
}
.pname{font-family:var(--cond);font-weight:700;font-size:1.2rem;color:var(--white);line-height:1.25}
.phover{position:absolute;inset:0;z-index:3;background:rgba(1,24,35,.88);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .35s}
.pi:hover .phover{opacity:1}
.phover-c{text-align:center;transform:translateY(10px);transition:transform .35s}
.pi:hover .phover-c{transform:translateY(0)}
.phover-c h3{font-family:var(--cond);font-weight:900;font-size:1.35rem;text-transform:uppercase;color:var(--white);margin-bottom:.4rem}
.phover-c span{font-size:.95rem;color:var(--green)}

/* ── STATS ── */
.stats-band{background:var(--navy2);display:grid;grid-template-columns:repeat(4,1fr)}
.scell{padding:3.5rem 1.5rem;text-align:center;border-right:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden;transition:background .3s}
.scell:last-child{border-right:none}
.scell:hover{background:rgba(92,184,37,.05)}
.scell::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:2px;background:var(--green);transition:width .4s}
.scell:hover::after{width:60%}
.snum{font-family:var(--serif);font-size:4.2rem;line-height:.9;color:var(--green);display:block}
.slbl{
  font-family:var(--cond);
  font-weight:600;
  font-size:.88rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.34);
  margin-top:.6rem;
  display:block
}

/* ── CONTACTO ── */
#contacto{background:var(--white)}
.con-grid{display:grid;grid-template-columns:1fr 1fr;min-height:660px}
.con-photo{position:relative;overflow:hidden;background:url('../img/contacto-oficina.jpg') center/cover no-repeat}
.con-photo::after{content:'';position:absolute;inset:0;background:rgba(1,24,35,.86)}
.con-photo-in{position:relative;z-index:2;padding:5rem 4.5rem;display:flex;flex-direction:column;justify-content:space-between;height:100%;gap:2rem}
.con-photo-in p{font-size:1.12rem;line-height:1.8;color:rgba(255,255,255,.68);margin:1.3rem 0 0}
.con-ttl{font-size:clamp(2.4rem,3.8vw,3.7rem)!important}
.cilist{display:flex;flex-direction:column;gap:.75rem}
.ci{display:flex;align-items:flex-start;gap:.9rem}
.ci-ico{width:37px;height:37px;flex-shrink:0;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;background:rgba(92,184,37,.14);margin-top:2px}
.ci-ico svg,.ci-ico .wa-icon{width:15px;height:15px;stroke:var(--green)}
.ci-ico .wa-icon{fill:var(--green);stroke:none}
.ci-txt span{
  font-family:var(--cond);
  font-weight:700;
  font-size:.8rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--green);
  display:block
}
.ci-txt p{font-size:1rem;color:var(--white);margin:0;line-height:1.6}

.con-social{margin-top:auto;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08)}
.con-social-lbl{
  font-family:var(--cond);
  font-weight:700;
  font-size:.8rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.34);
  display:block;
  margin-bottom:.75rem
}
.social-row{display:flex;gap:.6rem}
.soc-link{width:38px;height:38px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:background .25s,color .25s,border-color .25s}
.soc-link:hover{background:var(--green);border-color:var(--green);color:var(--white)}

/* ── WhatsApp contact panel ── */
.con-wa{background:var(--cream);display:flex;align-items:center;justify-content:center;padding:3rem}
.con-wa-inner{max-width:400px;width:100%;text-align:center}
.wa-big-icon{width:90px;height:90px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;box-shadow:0 12px 36px rgba(37,211,102,.35)}
.wa-big-icon svg{fill:var(--white)}
.wa-title{font-family:var(--cond);font-weight:900;font-size:1.95rem;text-transform:uppercase;letter-spacing:.02em;color:var(--carbon);margin-bottom:.7rem}
.wa-desc{font-size:1.05rem;line-height:1.7;color:var(--fog);margin-bottom:2rem}
.wa-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.8rem}
.wa-opt{display:flex;align-items:center;gap:.85rem;padding:.95rem 1.15rem;background:var(--white);border:1.5px solid var(--smoke);text-align:left;color:var(--carbon);transition:border-color .25s,background .25s,transform .2s}
.wa-opt:hover{border-color:var(--green);background:#f7fff3;transform:translateX(4px)}
.wa-opt svg{flex-shrink:0;stroke:var(--green)}
.wa-opt span{
  font-family:var(--cond);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  flex:1
}
.wa-opt .arr{margin-left:auto;flex-shrink:0;stroke:var(--green);opacity:0;transition:opacity .2s}
.wa-opt:hover .arr{opacity:1}
.btn-wa-main{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.75rem;
  width:100%;
  padding:16px;
  background:#25D366;
  color:var(--white);
  font-family:var(--cond);
  font-weight:800;
  font-size:1.05rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  border:none;
  transition:background .25s,transform .2s
}
.btn-wa-main:hover{background:#1da851;transform:translateY(-2px)}
.btn-wa-main svg{fill:var(--white)}
.wa-note{font-size:.9rem;color:var(--fog);margin-top:1rem;line-height:1.6}
.wa-note a{color:var(--green);text-decoration:underline}

/* ── WhatsApp floating button ── */
.wa-float{position:fixed;bottom:2rem;right:2rem;z-index:900;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(37,211,102,.5);transition:transform .25s,box-shadow .25s}
.wa-float:hover{transform:scale(1.1);box-shadow:0 10px 32px rgba(37,211,102,.65)}
.wa-float svg{fill:var(--white)}

/* ── FOOTER ── */
footer{background:var(--navy);padding:5rem 8% 2rem}
.ftop{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.05)}
.fbrand img{height:38px;margin-bottom:1.3rem}
.fbrand p{font-size:.95rem;line-height:1.75;color:var(--fog);max-width:265px;margin-bottom:1.2rem}
.f-social{display:flex;gap:.5rem}
.fsoc{width:34px;height:34px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3);transition:background .25s,color .25s,border-color .25s}
.fsoc:hover{background:var(--green);border-color:var(--green);color:var(--white)}
.fsoc svg{fill:currentColor}
.fcol h5{
  font-family:var(--cond);
  font-weight:700;
  font-size:.84rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--silver);
  margin-bottom:1.1rem;
  padding-bottom:.65rem;
  border-bottom:1px solid rgba(255,255,255,.05)
}
.fcol ul{display:flex;flex-direction:column;gap:.5rem}
.fcol ul li a{font-size:.95rem;color:var(--fog);transition:color .2s}
.fcol ul li a:hover{color:var(--green)}
.fbot{padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.fbot p{font-size:.88rem;color:rgba(255,255,255,.22)}
.fbot span{color:var(--green)}

/* ── RESPONSIVE ── */
@media(max-width:1200px){
  .sol-cards{grid-template-columns:1fr 1fr}
  .sc{height:480px}
}
@media(max-width:1100px){
  .nos-filosofia{grid-template-columns:1fr}
  .nf-left,.nf-right{padding:3rem 6%}
  .nos-grid,.con-grid{grid-template-columns:1fr}
  .nos-photo,.con-photo{min-height:360px}
  .cal-inner{grid-template-columns:1fr}
  .cal-left{padding:4rem 6%}
  .cal-right{padding:4rem 6%}
  .stats-band{grid-template-columns:1fr 1fr}
  .ftop{grid-template-columns:1fr 1fr}
  .modal-cols{grid-template-columns:1fr}
}
@media(max-width:768px){
  .hamburger{display:flex}
  .nav-menu{display:none}
  .sol-cards{grid-template-columns:1fr}
  .sc{height:400px}
  .pgrid{grid-template-columns:1fr;grid-template-rows:auto}
  .pi{height:240px}
  .pi:nth-child(1){grid-column:span 1}
  .stats-band{grid-template-columns:1fr 1fr}
  .ftop{grid-template-columns:1fr;gap:2rem}
  .sol-hd,.cta-band{flex-direction:column;align-items:flex-start}
  .hero-h1{font-size:clamp(3.5rem,14vw,5.5rem)}
  .hero-desc{font-size:1.08rem;line-height:1.6}
  .hero-pills{flex-direction:column}
  .hero-scroll{display:none}
  .con-wa{padding:2.5rem 1.5rem}
  .modal-box{max-height:95vh}
  .modal-header{padding:1.8rem 2rem 1.5rem;flex-direction:column;gap:1rem}
  .modal-body{padding:1.8rem 2rem 2.2rem}
  .btn-g,.btn-ow,.btn-w,.btn-bo{font-size:.96rem;padding:14px 24px}
  .nav-menu.open a{font-size:1rem}
}
@media(max-width:480px){
  .stats-band{grid-template-columns:1fr}
  .scell{border-right:none;border-bottom:1px solid rgba(255,255,255,.04)}
  .nos-divisiones .nd-item{flex-direction:column;align-items:flex-start;gap:.4rem}
  .cal-badges{flex-direction:column}
  .hero-tag,.chip,.stab{letter-spacing:.08em}
  .hero-desc,.nos-copy p,.nf-right p,.sol-hd-desc,.cta-txt p,.wa-desc{font-size:1rem}
}

/* ═══════════════════════════════════════════════════════════
   CLIENTES — LOGOS CARRUSEL (FRANJA)
═══════════════════════════════════════════════════════════ */
.clients-band{
  background: var(--white);
  padding: 4.5rem 8% 3.8rem;
  overflow: hidden;
}
.clients-hd{
  display: flex;
  flex-direction: column;
  gap: .7rem;
  margin-bottom: 1.6rem;
}
.clients-title{
  font-family: var(--cond);
  font-weight: 900;
  font-size: clamp(1.9rem, 3vw, 2.7rem);
  line-height: 1.05;
  letter-spacing: -.01em;
  color: var(--carbon);
  text-transform: uppercase;
  margin: 0;
}
.clients-title em{
  font-style: normal;
  color: var(--green);
}
.clients-marquee{
  position: relative;
  border-top: 1px solid rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(0,0,0,.08);
  background: linear-gradient(
    90deg,
    rgba(243,241,237,.85) 0%,
    rgba(255,255,255,.98) 25%,
    rgba(255,255,255,.98) 75%,
    rgba(243,241,237,.85) 100%
  );
  padding: 1.25rem 0;
  margin-left: calc(-8vw);
  margin-right: calc(-8vw);
  padding-left: calc(8vw);
  padding-right: calc(8vw);
}
.clients-marquee::before,
.clients-marquee::after{
  content:'';
  position:absolute;
  top:0; bottom:0;
  width: 70px;
  pointer-events:none;
  z-index:2;
}
.clients-marquee::before{
  left:0;
  background: linear-gradient(90deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
}
.clients-marquee::after{
  right:0;
  background: linear-gradient(270deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 100%);
}
.clients-track{
  display: flex;
  align-items: center;
  gap: 2.6rem;
  width: max-content;
  animation: cscroll 28s linear infinite;
  padding-left: 1rem;
}
@keyframes cscroll{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}
.clogo{
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: .45rem .8rem;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 26px rgba(0,0,0,.05);
  border-radius: 10px;
}
.clogo img{
  height: 48px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  filter: grayscale(1) contrast(1.05);
  opacity: .86;
  transition: opacity .25s ease, filter .25s ease, transform .25s ease;
}
.clogo:hover img{
  filter: none;
  opacity: 1;
  transform: translateY(-1px);
}
.clients-marquee:hover .clients-track{
  animation-play-state: paused;
}
@media (max-width: 768px){
  .clients-band{ padding: 3.5rem 6% 3rem; }
  .clients-track{ gap: 2rem; animation-duration: 22s; }
  .clogo{ height: 46px; border-radius: 9px; }
  .clogo img{ height: 30px; max-width: 140px; }
}

/* ── MODAL PROCESS GRID ── */
.modal-process-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-top:.8rem;
}
.modal-process-card{
  background:rgba(255,255,255,.7);
  border:1px solid rgba(0,0,0,.08);
  padding:1rem;
}
.modal-process-card strong{
  display:block;
  font-family:var(--cond);
  font-weight:800;
  font-size:.94rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--carbon);
  margin-bottom:.45rem;
}
.modal-process-card p{
  margin:0;
  font-size:.95rem;
  line-height:1.6;
  color:var(--steel);
}
@media (max-width: 980px){
  .modal-process-grid{
    grid-template-columns:repeat(2,1fr);
  }
}
@media (max-width: 640px){
  .modal-process-grid{
    grid-template-columns:1fr;
  }
}

/* ── Fila de acciones bajo cada tarjeta de solución ── */
.sc-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 1rem;
  flex-wrap: wrap;
}

/* ── Botón descarga PDF en tarjeta ── */
.sc-pdf {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: .88rem;
  font-weight: 700;
  color: rgba(255,255,255,.55);
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.22);
  padding: 6px 12px;
  border-radius: 20px;
  transition: color .2s, border-color .2s;
}
.sc-pdf:hover {
  color: #fff;
  border-color: rgba(255,255,255,.55);
}
.sc-pdf svg {
  flex-shrink: 0;
}

.modal-step--highlight {
  border: 2px solid rgba(92, 184, 37, 0.45);
  border-radius: 12px;
  padding: 1.2rem 1.5rem;
  position: relative;
  background: rgba(92, 184, 37, 0.06);
  box-shadow: 0 0 20px rgba(92, 184, 37, 0.1);
  transform: scale(1.02);
}

.modal-step--highlight::before {
  content: "★ DESTACADO";
  position: absolute;
  top: -10px;
  right: 16px;
  background: var(--green);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}

.dboom-breakdown {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.dboom-breakdown span {
  background: rgba(92, 184, 37, 0.1);
  border: 1px solid rgba(92, 184, 37, 0.3);
  border-radius: 6px;
  padding: 0.4rem 0.8rem;
  font-size: 0.85rem;
  white-space: nowrap;
}

.dboom-breakdown span b {
  color: var(--green);
  font-size: 1.05em;
}

/* ══════════════════════════════════════════════════════════
   PARCHE DE CORRECCIONES — agregar al final de styles.css
══════════════════════════════════════════════════════════ */

/* FIX #1: Bajar contenido del hero para que no lo tape el navbar */
.slide-tabs {
  margin-top: 90px;  /* espacio para librar el navbar fijo de 80px */
}

/* FIX #2: Intercambiar imágenes de slides (ahora: s2=tableros, s3=agua) */
#s2 { background-image: url('../img/hero-tableros.jpg') !important; }
#s3 { background-image: url('../img/hero-agua.jpg') !important; }

/* FIX #3: Tags de sección en tarjetas de soluciones — fondo verde, texto blanco */
.sc-tag {
  background: var(--green);
  color: var(--white) !important;
  padding: 6px 14px;
  font-size: .88rem !important;
  display: inline-block;
  clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}


/* ══════════════════════════════════════════════════════════
   PARCHE DE CORRECCIONES — agregar al final de styles.css
══════════════════════════════════════════════════════════ */

/* FIX #1: Bajar contenido del hero para que no lo tape el navbar */
.slide-tabs {
  margin-top: 90px;
}

/* FIX #2: Intercambiar imágenes de slides (ahora: s2=tableros, s3=agua) */
#s2 { background-image: url('../img/hero-tableros.jpg') !important; }
#s3 { background-image: url('../img/hero-agua.jpg') !important; }

/* FIX #3: Tags de sección en tarjetas de soluciones — fondo verde, texto blanco */
.sc-tag {
  background: var(--green);
  color: var(--white) !important;
  padding: 6px 14px;
  font-size: .88rem !important;
  display: inline-block;
  clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}


/* ══════════════════════════════════════════════════════════
   GALERÍA SIMPLIFICADA — solo foto + etiqueta de categoría
══════════════════════════════════════════════════════════ */

/* Anular estilos anteriores de hover/overlay del portafolio */
.pinfo,
.phover,
.phover-c { display: none !important; }

/* Las fotos ahora usan inline style en el HTML */
.pi .pphoto {
  background-size: cover;
  background-position: center;
}

/* Etiqueta de categoría — esquina inferior izquierda */
.pi-label {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  z-index: 4;
  font-family: var(--cond);
  font-weight: 700;
  font-size: .88rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--white);
  background: rgba(0, 0, 0, .45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 6px 14px;
  transition: background .3s;
}
.pi:hover .pi-label {
  background: var(--green);
}

/* Hover: solo zoom suave en la foto, sin overlay */
.pi .pphoto {
  transition: transform .5s ease;
}
.pi:hover .pphoto {
  transform: scale(1.05);
}

/* Quitar cursor pointer si no hay acción */
.pi {
  cursor: default;
}

/* ══════════════════════════════════════════════════════════
   PARCHE DE CORRECCIONES — agregar al final de styles.css
══════════════════════════════════════════════════════════ */

/* FIX #1: Bajar contenido del hero para que no lo tape el navbar */
.slide-tabs {
  margin-top: 90px;
}

/* FIX #2: Intercambiar imágenes de slides (ahora: s2=tableros, s3=agua) */
#s2 { background-image: url('../img/hero-tableros.jpg') !important; }
#s3 { background-image: url('../img/hero-agua.jpg') !important; }

/* FIX #3: Tags de sección en tarjetas de soluciones — fondo verde, texto blanco */
.sc-tag {
  background: var(--green);
  color: var(--white) !important;
  padding: 6px 14px;
  font-size: .88rem !important;
  display: inline-block;
  clip-path: polygon(6px 0%, 100% 0%, calc(100% - 6px) 100%, 0% 100%);
}


/* ══════════════════════════════════════════════════════════
   GALERÍA REDISEÑADA — grid adaptable con todas las fotos
══════════════════════════════════════════════════════════ */

/* Anular estilos legacy del portafolio */
.pinfo,
.phover,
.phover-c { display: none !important; }

/* ── Grid principal ── */
.pgrid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  grid-template-rows: auto !important;
  grid-auto-rows: 260px !important;
  gap: .5rem !important;
}

/* Items base */
.pi {
  position: relative;
  overflow: hidden;
  cursor: default;
  height: 260px;
}
/* Primera foto destacada (más grande) */
.pi:first-child {
  grid-column: span 2;
  grid-row: span 2;
  height: auto;
}

.pi .pphoto {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform .5s ease;
}
.pi .pphoto::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 50%);
  pointer-events: none;
}
.pi:hover .pphoto {
  transform: scale(1.05);
}

/* Etiqueta de categoría */
.pi-label {
  position: absolute;
  bottom: .8rem;
  left: .8rem;
  z-index: 4;
  font-family: var(--cond);
  font-weight: 700;
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--white);
  background: rgba(0, 0, 0, .4);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 5px 12px;
  transition: background .3s;
}
.pi:hover .pi-label {
  background: var(--green);
}

/* ── Vista "Todos": muestra solo 8 iniciales ── */
.pgrid:not(.pgrid--filtered):not(.pgrid--expanded) .pi:nth-child(n+9) {
  display: none;
}

/* ── Vista filtrada: muestra todos de la categoría ── */
.pgrid--filtered .pi {
  display: none;
}
.pgrid--filtered .pi.pi--visible {
  display: block;
}

/* ── Vista expandida (botón "ver más"): muestra todos ── */
.pgrid--expanded .pi {
  display: block !important;
}

/* ── Botón "Ver más" ── */
.port-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 1.5rem auto 0;
  font-family: var(--cond);
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--steel);
  background: var(--white);
  border: 1.5px solid var(--smoke);
  padding: 12px 32px;
  cursor: pointer;
  transition: all .25s;
  clip-path: polygon(8px 0%, 100% 0%, calc(100% - 8px) 100%, 0% 100%);
}
.port-toggle:hover {
  background: var(--navy);
  color: var(--white);
  border-color: var(--navy);
}
.port-toggle svg {
  transition: transform .3s;
}
.port-toggle.collapsed svg {
  transform: rotate(180deg);
}

/* ── Counter en filtros ── */
.pf-count {
  font-size: .72rem;
  opacity: .5;
  margin-left: 2px;
}

/* ── Responsive ── */
@media (max-width: 1100px) {
  .pgrid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .pgrid {
    grid-template-columns: repeat(2, 1fr) !important;
    grid-auto-rows: 200px !important;
  }
  .pi {
    height: 200px;
  }
  .pi:first-child {
    grid-column: span 2;
    grid-row: span 1;
    height: 200px;
  }
}
@media (max-width: 480px) {
  .pgrid {
    grid-template-columns: 1fr !important;
    grid-auto-rows: 220px !important;
  }
  .pi, .pi:first-child {
    grid-column: span 1;
    height: 220px;
  }
}
