.nslp, .nslp * { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; }
.nslp {
  --brand:#005C6F; --brand-dark:#013945; --ink:#333133; --muted:#687577;
  --soft:#E9F2F4; --soft2:#F6F8F8; --line:rgba(0,92,111,.16);
  --white:#fff; --shadow:0 24px 70px rgba(0,41,50,.13);
  --r-xl:34px; --r-lg:24px;
  margin:0; font-family:"Montserrat",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink); background:var(--soft2); letter-spacing:-.015em;
}
.nslp img { display:block; max-width:100%; }
.nslp a { color:inherit; }
.nslp-container { width:min(1180px,92%); margin:0 auto; }

.nslp-topbar { position:sticky; top:0; z-index:50; background:rgba(255,255,255,.9); backdrop-filter:blur(22px); border-bottom:1px solid var(--line); }
.nslp-nav { height:82px; display:flex; align-items:center; justify-content:space-between; gap:26px; }
.nslp-brand { text-decoration:none; min-width:205px; }
.nslp-brand img { width:188px; }
.nslp-navlinks { display:flex; gap:22px; align-items:center; color:var(--muted); font-weight:600; font-size:.86rem; }
.nslp-navlinks a { text-decoration:none; }
.nslp-navlinks a:hover { color:var(--brand); }

.nslp-btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:48px; padding:13px 21px; border-radius:999px; border:1px solid transparent; text-decoration:none; font-weight:800; font-size:.9rem; transition:.18s ease; white-space:nowrap; color:var(--brand); }
.nslp-btn:hover { transform:translateY(-2px); }
.nslp-btn:focus-visible { outline:3px solid rgba(0,92,111,.28); outline-offset:3px; }
.nslp-btn-primary { background:#fff; color:var(--brand); border-color:rgba(0,92,111,.34); box-shadow:0 15px 34px rgba(0,92,111,.18); }
.nslp-btn-primary:hover { background:var(--soft); color:var(--brand); border-color:var(--brand); }
.nslp-btn-light { background:#fff; color:var(--brand); border-color:rgba(255,255,255,.78); box-shadow:0 15px 34px rgba(0,41,50,.12); }
.nslp-btn-light:hover { background:var(--soft); color:var(--brand); border-color:rgba(255,255,255,.9); }
.nslp-btn-outline { background:rgba(255,255,255,.92); color:var(--brand); border-color:rgba(255,255,255,.68); }
.nslp-btn-outline:hover { background:#fff; color:var(--brand); border-color:#fff; }

.nslp-hero { position:relative; overflow:hidden; color:#fff; padding:94px 0 82px; background:radial-gradient(circle at 82% 18%,rgba(255,255,255,.18),transparent 28%),linear-gradient(135deg,#021F26 0%,#005C6F 58%,#01313B 100%); }
.nslp-hero:before { content:""; position:absolute; inset:0; opacity:.12; background-image:linear-gradient(rgba(255,255,255,.35) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.35) 1px,transparent 1px); background-size:54px 54px; mask-image:linear-gradient(to bottom,black,transparent 78%); }
.nslp-hero:after { content:""; position:absolute; width:560px; height:560px; right:-145px; bottom:-190px; background:var(--nslp-favicon) center/contain no-repeat; opacity:.085; filter:grayscale(1) brightness(2.7); }
.nslp-hero-grid { position:relative; z-index:2; display:grid; grid-template-columns:1.02fr .98fr; gap:54px; align-items:center; }
.nslp-hero-logo { width:min(360px,70vw); margin-bottom:32px; }
.nslp-eyebrow { display:inline-flex; align-items:center; gap:10px; padding:9px 13px; border:1px solid rgba(255,255,255,.24); border-radius:999px; background:rgba(255,255,255,.09); color:rgba(255,255,255,.88); font-size:.77rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.nslp-dot { width:9px; height:9px; border-radius:50%; background:#fff; box-shadow:0 0 0 7px rgba(255,255,255,.12); }
.nslp h1 { margin:22px 0 20px; font-size:clamp(2.55rem,5.65vw,5.2rem); line-height:.96; letter-spacing:-.075em; font-weight:800; max-width:880px; color:#fff; }
.nslp-hero p { max-width:735px; color:rgba(255,255,255,.80); font-size:1.12rem; line-height:1.72; margin:0; }
.nslp-actions { display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.nslp-hero-points { display:flex; gap:14px; flex-wrap:wrap; margin-top:34px; }
.nslp-hero-point { display:inline-flex; align-items:center; gap:9px; color:rgba(255,255,255,.78); font-size:.88rem; font-weight:600; }
.nslp-tick { width:22px; height:22px; display:inline-grid; place-items:center; border-radius:50%; background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.22); color:#fff; font-size:.76rem; font-weight:900; }

.nslp-field-card { background:rgba(255,255,255,.94); border:1px solid rgba(255,255,255,.6); border-radius:34px; box-shadow:0 35px 100px rgba(0,0,0,.25); overflow:hidden; color:var(--ink); }
.nslp-photo { height:330px; position:relative; overflow:hidden; }
.nslp-photo img { width:100%; height:100%; object-fit:cover; }
.nslp-photo-badge { position:absolute; left:18px; bottom:18px; background:rgba(0,92,111,.92); color:#fff; padding:10px 13px; border-radius:999px; font-size:.78rem; font-weight:800; letter-spacing:.04em; text-transform:uppercase; }
.nslp-field-body { padding:22px; }
.nslp-field-body h2 { margin:0 0 8px; color:var(--brand-dark); font-size:1.18rem; letter-spacing:-.04em; }
.nslp-field-body p { color:var(--muted); font-size:.92rem; line-height:1.62; margin:0; }
.nslp-mini-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:18px; }
.nslp-mini { border:1px solid var(--line); border-radius:18px; padding:13px; background:#fff; }
.nslp-mini small { display:block; color:var(--muted); font-size:.68rem; font-weight:700; margin-bottom:5px; }
.nslp-mini strong { color:var(--brand); font-size:1.05rem; }

.nslp-section { padding:86px 0; }
.nslp-section.nslp-white { background:#fff; }
.nslp-section-head { max-width:820px; margin-bottom:38px; }
.nslp-kicker { color:var(--brand); font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; font-weight:900; margin-bottom:13px; }
.nslp-section h2 { margin:0 0 16px; font-size:clamp(2rem,4vw,3.48rem); line-height:1.03; letter-spacing:-.065em; font-weight:800; color:var(--ink); }
.nslp-lead { margin:0; color:var(--muted); font-size:1.08rem; line-height:1.72; }

.nslp-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:22px; }
.nslp-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.nslp-grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.nslp-card { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:28px; box-shadow:0 16px 44px rgba(0,41,50,.06); }
.nslp-card h3 { margin:0 0 10px; color:var(--brand-dark); font-size:1.18rem; line-height:1.18; letter-spacing:-.04em; }
.nslp-card p { margin:0; color:var(--muted); line-height:1.65; font-size:.95rem; }
.nslp-icon { width:50px; height:50px; display:grid; place-items:center; border-radius:18px; background:var(--soft); color:var(--brand); font-size:1.3rem; margin-bottom:20px; }
.nslp-number { width:36px; height:36px; display:grid; place-items:center; border-radius:50%; background:var(--brand); color:#fff; font-weight:900; margin-bottom:18px; }

.nslp-why { background:#fff; }
.nslp-why-wrap { display:grid; grid-template-columns:.9fr 1.1fr; gap:28px; align-items:stretch; }
.nslp-brand-panel { position:relative; overflow:hidden; border-radius:var(--r-xl); padding:34px; color:#fff; background:linear-gradient(145deg,#01313B,#005C6F); box-shadow:var(--shadow); }
.nslp-brand-panel:after { content:""; position:absolute; width:300px; height:300px; right:-98px; bottom:-112px; background:var(--nslp-favicon) center/contain no-repeat; opacity:.13; filter:grayscale(1) brightness(2.5); }
.nslp-brand-panel img { width:min(310px,82%); margin-bottom:30px; position:relative; z-index:1; }
.nslp-brand-panel h3 { position:relative; z-index:1; margin:0 0 14px; font-size:2rem; line-height:1.05; letter-spacing:-.06em; color:#fff; }
.nslp-brand-panel p { position:relative; z-index:1; margin:0; color:rgba(255,255,255,.78); line-height:1.72; }
.nslp-why-list { display:grid; gap:14px; }
.nslp-why-item { display:grid; grid-template-columns:44px 1fr; gap:14px; align-items:start; background:#fff; border:1px solid var(--line); border-radius:22px; padding:22px; box-shadow:0 12px 34px rgba(0,41,50,.05); }
.nslp-why-tag { width:44px; height:44px; display:grid; place-items:center; border-radius:15px; background:var(--soft); color:var(--brand); font-weight:900; }
.nslp-why-item h3 { margin:0 0 6px; color:var(--brand-dark); font-size:1.05rem; }
.nslp-why-item p { margin:0; color:var(--muted); line-height:1.6; font-size:.94rem; }

.nslp-pilot { background:linear-gradient(180deg,#fff 0%,#F6FAFA 100%); }
.nslp-pilot-grid { display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:stretch; }
.nslp-pilot-text { background:#fff; border:1px solid var(--line); border-radius:var(--r-xl); padding:34px; box-shadow:0 16px 44px rgba(0,41,50,.06); }
.nslp-pilot-badge { display:inline-flex; width:fit-content; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background:var(--soft); color:var(--brand); font-size:.78rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; margin-bottom:18px; }
.nslp-pilot-text h3 { margin:0 0 14px; color:var(--brand-dark); font-size:1.9rem; line-height:1.05; letter-spacing:-.055em; }
.nslp-pilot-text p { margin:0 0 18px; color:var(--muted); line-height:1.72; }
.nslp-pilot-points { display:grid; gap:12px; margin-top:10px; }
.nslp-pilot-point { display:grid; grid-template-columns:28px 1fr; gap:10px; color:var(--muted); line-height:1.58; font-size:.94rem; }
.nslp-num { width:28px; height:28px; display:grid; place-items:center; border-radius:50%; background:var(--brand); color:#fff; font-weight:900; font-size:.82rem; }
.nslp-gallery { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.nslp-shot { background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:0 16px 44px rgba(0,41,50,.06); }
.nslp-shot-big { grid-column:1 / -1; }
.nslp-shot img { width:100%; height:270px; object-fit:cover; }
.nslp-shot-big img { height:350px; }
.nslp-caption { padding:15px 17px 17px; border-top:1px solid var(--line); }
.nslp-caption strong { display:block; color:var(--brand-dark); font-size:.98rem; margin-bottom:5px; }
.nslp-caption span { color:var(--muted); font-size:.86rem; line-height:1.5; }

.nslp-value-chain { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; align-items:stretch; }
.nslp-chain-step { position:relative; background:#fff; border:1px solid var(--line); border-radius:20px; padding:22px; box-shadow:0 12px 34px rgba(0,41,50,.05); }
.nslp-chain-step:after { content:""; position:absolute; right:-12px; top:50%; width:22px; height:2px; background:var(--line); }
.nslp-chain-step:last-child:after { display:none; }
.nslp-chain-step strong { display:block; color:var(--brand-dark); margin-bottom:8px; }
.nslp-chain-step span { color:var(--muted); font-size:.88rem; line-height:1.5; }

.nslp-final { position:relative; overflow:hidden; color:#fff; padding:92px 0; text-align:center; background:linear-gradient(135deg,#01313B 0%,#005C6F 70%,#021F26 100%); }
.nslp-final:after { content:""; position:absolute; width:480px; height:480px; left:-142px; bottom:-180px; background:var(--nslp-favicon) center/contain no-repeat; opacity:.09; filter:grayscale(1) brightness(2.5); }
.nslp-final .nslp-container { position:relative; z-index:1; }
.nslp-final-logo { width:min(330px,72vw); margin:0 auto 30px; }
.nslp-final h2 { max-width:880px; margin:0 auto 18px; color:#fff; font-size:clamp(2rem,4vw,3.48rem); line-height:1.03; letter-spacing:-.065em; }
.nslp-final p { max-width:760px; margin:0 auto 30px; color:rgba(255,255,255,.78); line-height:1.72; }
.nslp-final-actions { display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap; }
.nslp-footer { background:var(--ink); color:rgba(255,255,255,.66); padding:34px 0; font-size:.86rem; }
.nslp-footer-inner { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.nslp-footer img { width:155px; }

@media(max-width:1000px) {
  .nslp-hero-grid,.nslp-why-wrap,.nslp-pilot-grid,.nslp-grid-2 { grid-template-columns:1fr; }
  .nslp-grid-4,.nslp-grid-3,.nslp-value-chain { grid-template-columns:repeat(2,1fr); }
  .nslp-chain-step:after { display:none; }
  .nslp-navlinks { display:none; }
  .nslp-brand img { width:172px; }
}
@media(max-width:650px) {
  .nslp-nav { height:74px; } .nslp-nav .nslp-btn { display:none; } .nslp-brand img { width:158px; }
  .nslp-hero { padding:64px 0; } .nslp h1 { font-size:clamp(2.25rem,12vw,3.6rem); } .nslp-hero p,.nslp-lead { font-size:1rem; }
  .nslp-grid-4,.nslp-grid-3,.nslp-gallery,.nslp-value-chain,.nslp-mini-metrics { grid-template-columns:1fr; }
  .nslp-section { padding:64px 0; } .nslp-photo,.nslp-shot img,.nslp-shot-big img { height:auto; }
  .nslp-footer-inner { flex-direction:column; align-items:flex-start; }
}

/* =========================================================
   Corrección final botones CTA
   Fuerza el texto visible en verde corporativo Nergysens.
   Evita que el color blanco del hero o una caché/estilo anterior
   deje los botones blancos sin texto visible.
   ========================================================= */
.nslp .nslp-btn,
.nslp a.nslp-btn,
.nslp a.nslp-btn:link,
.nslp a.nslp-btn:visited {
  color: var(--brand) !important;
  -webkit-text-fill-color: var(--brand) !important;
  opacity: 1 !important;
}

.nslp .nslp-btn-primary,
.nslp a.nslp-btn-primary,
.nslp .nslp-btn-light,
.nslp a.nslp-btn-light,
.nslp .nslp-btn-outline,
.nslp a.nslp-btn-outline {
  background: #fff !important;
  color: var(--brand) !important;
  -webkit-text-fill-color: var(--brand) !important;
  border-color: rgba(0,92,111,.34) !important;
}

.nslp .nslp-btn-primary:hover,
.nslp a.nslp-btn-primary:hover,
.nslp .nslp-btn-light:hover,
.nslp a.nslp-btn-light:hover,
.nslp .nslp-btn-outline:hover,
.nslp a.nslp-btn-outline:hover {
  background: var(--soft) !important;
  color: var(--brand) !important;
  -webkit-text-fill-color: var(--brand) !important;
  border-color: var(--brand) !important;
}
