/* =====================================================================
   masfollowers — network-page.css
   /servicios/{network}  (Instagram, TikTok, YouTube, etc.)
   Brand-new isolated stylesheet. ALL selectors prefixed `.nlp-` so
   nothing in this file can collide with the legacy mf-snet / catalog
   styles.

   Goals:
     · Each section truly full-bleed (forest hero, cream services band,
       white CTA strip…) regardless of any parent wrapper from the
       legacy Bootstrap layout.
     · Inner content capped at 1180px with editorial side padding.
     · Mobile-first, reduced motion respected, accessible.
   ===================================================================== */

/* Local design tokens (fall back to globals when present) */
.nlp-page{
  --nlp-accent:#0E5C3A;
  --nlp-accent-deep:#0A4A2E;
  --nlp-accent-soft:#E8F0EB;
  --nlp-accent-glow:rgba(14,92,58,.18);
  --nlp-gold:#E8C796;
  --nlp-mint:#7FE6B0;
  --nlp-ink:#1B1F1A;
  --nlp-ink-soft:#4A4F49;
  --nlp-ink-muted:#7A7F77;
  --nlp-surface:#FFFFFF;
  --nlp-surface-2:#F6F4EE;
  --nlp-line:rgba(27,31,26,.10);
  --nlp-line-soft:rgba(27,31,26,.06);
  --nlp-line-strong:rgba(27,31,26,.18);
  --nlp-font:'Inter', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --nlp-font-serif:'Instrument Serif', Georgia, 'Times New Roman', serif;
  --nlp-font-mono:'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
  --nlp-container:1180px;
  --nlp-r:18px;
  --nlp-r-pill:999px;

  font-family:var(--nlp-font);
  color:var(--nlp-ink);
  background:var(--nlp-surface);
  /* Required so the section breakouts never spawn horizontal scroll */
  overflow-x:hidden;
}
.nlp-page *,
.nlp-page *::before,
.nlp-page *::after{ box-sizing:border-box; }

/* =========================================================
   FULL-BLEED ESCAPE — works inside narrow Bootstrap wrappers.
   Pattern: position:relative + width:100vw + negative margin.
   The !important + `max-width:none` defeats any inherited cap.
   ========================================================= */
.nlp-bleed{
  position:relative !important;
  display:block !important;
  width:100vw !important;
  max-width:none !important;
  margin-left:calc(50% - 50vw) !important;
  margin-right:calc(50% - 50vw) !important;
}

/* Inner container — capped + padded */
.nlp-inner{
  position:relative;
  z-index:1;
  width:100%;
  max-width:var(--nlp-container);
  margin:0 auto;
  padding-left:max(20px, 5vw);
  padding-right:max(20px, 5vw);
}
@media (min-width:640px){
  .nlp-inner{
    padding-left:max(32px, 4vw);
    padding-right:max(32px, 4vw);
  }
}
@media (min-width:1100px){
  .nlp-inner{
    padding-left:48px;
    padding-right:48px;
  }
}

/* =========================================================
   1. HERO BAND — forest gradient + paper rail + glass card
   ========================================================= */
.nlp-hero{
  position:relative;
  isolation:isolate;
  color:#FFFFFF;
  padding:48px 0 56px;
  /* Layered green gradient (same DNA as the homepage) */
  background:
    radial-gradient(120% 80% at 85% 0%, rgba(232,199,150,.14), transparent 55%),
    radial-gradient(80% 60% at 0% 100%, rgba(255,255,255,.05), transparent 60%),
    linear-gradient(180deg, #0A4A2E 0%, #0E5C3A 55%, #0C5234 100%);
}
@media (min-width:640px){ .nlp-hero{ padding:64px 0 72px; } }
@media (min-width:900px){ .nlp-hero{ padding:96px 0 112px; } }

/* Vertical paper rail */
.nlp-hero::before{
  content:"";
  position:absolute; inset:0;
  background-image:linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size:88px 100%;
  background-position:24px 0;
  pointer-events:none;
  mask-image:linear-gradient(180deg, transparent 0, #000 14%, #000 86%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0, #000 14%, #000 86%, transparent 100%);
  z-index:0;
}
/* Paper grain overlay */
.nlp-hero::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    radial-gradient(rgba(0,0,0,.05) 1px, transparent 1px);
  background-size:3px 3px, 3px 3px;
  background-position:0 0, 1.5px 1.5px;
  opacity:.5;
  mix-blend-mode:overlay;
  pointer-events:none;
  z-index:0;
}

.nlp-hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:36px;
  align-items:center;
}
@media (min-width:900px){
  .nlp-hero-grid{
    grid-template-columns:minmax(0, 1.2fr) minmax(0, 1fr);
    gap:56px;
  }
}

/* === Hero text column === */
.nlp-hero-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  min-width:0;
}

.nlp-hero-logo{
  width:64px; height:64px;
  display:grid; place-items:center;
  background:#FFFFFF;
  border:1px solid rgba(255,255,255,.18);
  border-radius:16px;
  margin-bottom:18px;
  box-shadow:0 14px 28px -12px rgba(0,0,0,.45);
  overflow:hidden;
}
.nlp-hero-logo img{ width:42px; height:42px; object-fit:contain; }
.nlp-hero-logo svg{ width:32px; height:32px; color:var(--nlp-accent); }

.nlp-hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font:600 11.5px/1 var(--nlp-font);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(232,199,150,.92);
  margin:0 0 16px;
}
.nlp-hero-eyebrow::before{
  content:"";
  width:24px; height:1px;
  background:rgba(232,199,150,.55);
}
.nlp-hero-eyebrow em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  font-size:1.12em;
  letter-spacing:0;
  color:#E8C796;
  text-transform:none;
}

.nlp-hero h1{
  font-size:clamp(34px, 6vw, 60px);
  line-height:1.02;
  letter-spacing:-.03em;
  font-weight:600;
  color:#FFFFFF;
  margin:0 0 16px;
  max-width:18ch;
}
.nlp-hero h1 em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  letter-spacing:-.02em;
  color:#E8C796;
}

.nlp-hero-lede{
  font-size:clamp(15px, 1.6vw, 17px);
  line-height:1.55;
  color:rgba(255,255,255,.82);
  margin:0 0 24px;
  max-width:48ch;
}

.nlp-hero-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px 14px;
  font-size:13px;
  color:rgba(255,255,255,.72);
  margin:0;
}
.nlp-hero-meta b{ color:#FFFFFF; font-weight:600; }
.nlp-hero-meta .star{ color:#E8C796; }
.nlp-hero-meta .sep{
  display:inline-block;
  width:3px; height:3px;
  border-radius:50%;
  background:rgba(255,255,255,.30);
}

/* === Hero glass card column === */
.nlp-hero-visual{
  position:relative;
  display:none;
  padding:14px;  /* room for the floating tags */
}
@media (min-width:900px){ .nlp-hero-visual{ display:block; } }

.nlp-hero-card{
  position:relative;
  z-index:1;
  width:100%;
  max-width:480px;
  margin:0 auto;
  padding:24px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:20px;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 28px 70px -24px rgba(0,0,0,.55);
  color:#FFFFFF;
}

.nlp-hero-card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,.12);
  margin-bottom:14px;
}
.nlp-hero-card__label{
  font:600 11px/1 var(--nlp-font);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(255,255,255,.65);
}
.nlp-hero-card__pulse{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font:500 12px/1 var(--nlp-font);
  color:rgba(255,255,255,.88);
}
.nlp-hero-card__pulse::before{
  content:"";
  width:7px; height:7px;
  border-radius:50%;
  background:var(--nlp-mint);
  box-shadow:0 0 0 4px rgba(127,230,176,.18);
  animation:nlpPulse 1.6s ease-in-out infinite;
}
@keyframes nlpPulse{
  0%,100%{ box-shadow:0 0 0 4px rgba(127,230,176,.18); }
  50%   { box-shadow:0 0 0 7px rgba(127,230,176,.06); }
}

.nlp-hero-card__rows{
  display:flex; flex-direction:column; gap:8px;
}
.nlp-hero-card__row{
  display:flex; align-items:center; gap:12px;
  padding:12px 14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;
}
.nlp-hero-card__row .ic{
  flex:none;
  width:36px; height:36px;
  display:grid; place-items:center;
  background:#FFFFFF;
  border:1px solid rgba(255,255,255,.40);
  border-radius:10px;
  color:var(--nlp-accent);
  box-shadow:0 6px 14px -6px rgba(0,0,0,.45);
}
.nlp-hero-card__row .ic svg{ width:16px; height:16px; }
.nlp-hero-card__row .ic img{ width:22px; height:22px; object-fit:contain; }
.nlp-hero-card__row > div:not(.ic){ flex:1; min-width:0; }
.nlp-hero-card__row .name{
  font:600 13.5px/1.2 var(--nlp-font);
  color:#FFFFFF;
}
.nlp-hero-card__row .sub{
  font-size:11.5px;
  color:rgba(255,255,255,.58);
  margin-top:2px;
}
.nlp-hero-card__row .num{
  margin-left:auto;
  flex:none;
  font-family:var(--nlp-font-mono);
  font-feature-settings:"tnum";
  font:600 13px/1 var(--nlp-font-mono);
  color:var(--nlp-gold);
  letter-spacing:-.01em;
}

.nlp-hero-card__foot{
  margin-top:14px;
  display:flex; align-items:center; gap:8px;
  font-size:11.5px;
  color:rgba(255,255,255,.62);
}
.nlp-hero-card__foot .dot{
  width:6px; height:6px;
  border-radius:50%;
  background:var(--nlp-mint);
  animation:nlpDot 1.6s ease-in-out infinite;
}
@keyframes nlpDot{
  0%,100%{ opacity:1; } 50%{ opacity:.4; }
}

/* Floating tags pinned to corners */
.nlp-hero-tag{
  position:absolute;
  z-index:3;
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:9px 14px;
  background:#FFFFFF;
  border-radius:12px;
  color:#0A4A2E;
  font:600 12.5px/1 var(--nlp-font);
  box-shadow:0 18px 36px -12px rgba(0,0,0,.55);
  white-space:nowrap;
}
.nlp-hero-tag em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  color:var(--nlp-accent);
}
.nlp-hero-tag.tl{
  top:-8px; left:8px;
  transform:rotate(-3deg);
}
.nlp-hero-tag.br{
  bottom:-8px; right:8px;
  transform:rotate(2deg);
}

/* =========================================================
   2. SERVICES BAND — cream gradient with paper rail
   ========================================================= */
.nlp-services{
  position:relative;
  padding:56px 0 72px;
  background:linear-gradient(180deg, var(--nlp-surface) 0%, var(--nlp-surface-2) 100%);
  border-top:1px solid var(--nlp-line-soft);
}
@media (min-width:900px){ .nlp-services{ padding:80px 0 112px; } }

.nlp-services::before{
  content:"";
  position:absolute; inset:0;
  background-image:linear-gradient(90deg, rgba(27,31,26,.04) 1px, transparent 1px);
  background-size:88px 100%;
  background-position:24px 0;
  pointer-events:none;
  mask-image:linear-gradient(180deg, transparent 0, #000 14%, #000 86%, transparent 100%);
  -webkit-mask-image:linear-gradient(180deg, transparent 0, #000 14%, #000 86%, transparent 100%);
}

.nlp-services-head{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-bottom:32px;
  text-align:center;
}
@media (min-width:900px){
  .nlp-services-head{
    flex-direction:row;
    align-items:flex-end;
    justify-content:space-between;
    gap:24px;
    text-align:left;
    margin-bottom:40px;
  }
}
.nlp-services-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  align-self:center;
  font:600 11.5px/1 var(--nlp-font);
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--nlp-accent-deep);
  margin:0;
}
@media (min-width:900px){ .nlp-services-eyebrow{ align-self:flex-start; } }
.nlp-services-eyebrow::before{
  content:""; width:24px; height:1px; background:var(--nlp-accent);
}
.nlp-services-title{
  flex:1 1 auto;
  min-width:0;
  font:600 clamp(26px, 4vw, 40px)/1.1 var(--nlp-font);
  letter-spacing:-.025em;
  color:var(--nlp-ink);
  margin:0;
  max-width:22ch;
  margin-inline:auto;
}
@media (min-width:900px){ .nlp-services-title{ margin-inline:0; } }
.nlp-services-title em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  color:var(--nlp-accent);
}
.nlp-services-count{
  display:inline-flex;
  align-items:center;
  align-self:center;
  font:600 12.5px/1 var(--nlp-font);
  letter-spacing:.04em;
  color:var(--nlp-ink-muted);
  background:var(--nlp-surface);
  border:1px solid var(--nlp-line);
  border-radius:999px;
  padding:8px 14px;
  white-space:nowrap;
}
.nlp-services-count b{
  color:var(--nlp-accent-deep);
  font-weight:700;
  margin-right:4px;
}

/* Grid */
.nlp-services-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media (min-width:520px){ .nlp-services-grid{ grid-template-columns:repeat(2, 1fr); gap:16px; } }
@media (min-width:1100px){ .nlp-services-grid{ grid-template-columns:repeat(3, 1fr); gap:18px; } }

.nlp-card{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:6px;
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:18px;
  padding:22px 22px 20px;
  text-decoration:none;
  color:var(--nlp-ink);
  overflow:hidden;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.nlp-card::after{
  content:"";
  position:absolute; left:0; right:0; bottom:0;
  height:3px;
  background:linear-gradient(90deg, var(--nlp-accent) 0%, var(--nlp-gold) 100%);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform .25s ease;
}
.nlp-card:hover{
  transform:translateY(-3px);
  border-color:var(--nlp-accent);
  box-shadow:0 22px 40px -20px rgba(14,92,58,.30);
  color:var(--nlp-ink);
  text-decoration:none;
}
.nlp-card:hover::after{ transform:scaleX(1); }

.nlp-card-name{
  font:600 16px/1.3 var(--nlp-font);
  letter-spacing:-.005em;
  color:var(--nlp-ink);
  margin:0 0 4px;
}
.nlp-card-meta{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  margin-top:auto;
  padding-top:16px;
  border-top:1px dashed var(--nlp-line-soft);
}
.nlp-card-price{
  font-family:var(--nlp-font-mono);
  font-feature-settings:"tnum";
  font-size:15px;
  font-weight:600;
  color:var(--nlp-accent);
  letter-spacing:-.01em;
}
.nlp-card-price-prefix{
  font-family:var(--nlp-font);
  font-size:11px;
  font-weight:500;
  color:var(--nlp-ink-muted);
  text-transform:uppercase;
  letter-spacing:.10em;
  margin-right:4px;
}
.nlp-card-cta{
  display:inline-flex;
  align-items:center;
  gap:4px;
  color:var(--nlp-accent-deep);
  font:600 12.5px/1 var(--nlp-font);
  transition:transform .18s ease;
}
.nlp-card:hover .nlp-card-cta{ transform:translateX(3px); }
.nlp-card-cta svg{ flex:none; }

.nlp-card-badge{
  position:absolute;
  top:14px; right:14px;
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 9px;
  background:linear-gradient(180deg, #F2D9A8 0%, var(--nlp-gold) 100%);
  color:#5A4416;
  font:700 10px/1 var(--nlp-font);
  letter-spacing:.10em;
  text-transform:uppercase;
  border-radius:999px;
  z-index:1;
  border:1px solid rgba(90,68,22,.18);
}

/* Empty state */
.nlp-services-empty{
  grid-column:1 / -1;
  text-align:center;
  padding:56px 24px;
  color:var(--nlp-ink-soft);
  font-size:15px;
  background:#FFFFFF;
  border:1px dashed var(--nlp-line);
  border-radius:18px;
}

/* =========================================================
   3. LONG-FORM CONTENT BAND
   ========================================================= */
.nlp-content{
  position:relative;
  padding:56px 0;
  background:var(--nlp-surface);
}
@media (min-width:900px){ .nlp-content{ padding:80px 0; } }
.nlp-content-body{
  max-width:820px;
  margin:0 auto;
  font-size:16px;
  line-height:1.7;
  color:var(--nlp-ink);
}
.nlp-content-body h2{
  font:600 clamp(24px, 3.4vw, 32px)/1.15 var(--nlp-font);
  letter-spacing:-.02em;
  margin:36px 0 14px;
  color:var(--nlp-ink);
}
.nlp-content-body h2 em{
  font-family:'Instrument Serif', Georgia, serif;
  font-style:italic;font-weight:400;
  color:var(--nlp-accent);
}
.nlp-content-body h3{
  font:600 19px/1.3 var(--nlp-font);
  letter-spacing:-.01em;
  margin:24px 0 10px;
  color:var(--nlp-ink);
}
.nlp-content-body h3 em{
  font-family:'Instrument Serif', Georgia, serif;
  font-style:italic;font-weight:400;
  color:var(--nlp-accent);
}
.nlp-content-body p{ margin:0 0 16px; }
.nlp-content-body ul, .nlp-content-body ol{
  padding-left:22px; margin:0 0 16px;
}
.nlp-content-body li{ margin:0 0 6px; }
.nlp-content-body a{
  color:var(--nlp-accent-deep);
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:3px;
}
.nlp-content-body a:hover{ color:var(--nlp-accent); }
.nlp-content-body strong{ color:var(--nlp-ink); font-weight:600; }

/* ----- Eyebrow + lede ----- */
.nlp-content-body .nlp-eyebrow{
  display:inline-flex;align-items:center;
  font:600 11px/1 var(--nlp-font-mono, 'JetBrains Mono', ui-monospace, monospace);
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#5A4416;
  background:#F8E9CC;
  border:1px solid rgba(232,199,150,.6);
  padding:6px 11px;border-radius:999px;
  margin:0 0 14px;
}
.nlp-content-body .nlp-lede{
  font-size:18px;line-height:1.55;
  color:var(--nlp-ink);
  margin:0 0 24px;
  letter-spacing:-.005em;
}
.nlp-content-body .nlp-updated{
  display:inline-flex;align-items:center;gap:6px;
  font:500 12px/1 var(--nlp-font);
  color:var(--nlp-ink-muted);
  margin:0 0 28px;
}
.nlp-content-body .nlp-updated::before{
  content:"";width:6px;height:6px;border-radius:50%;background:#3DD68C;
}

/* ----- Tables ----- */
.nlp-content-body table{
  width:100%;border-collapse:collapse;
  margin:18px 0 22px;
  font-size:14.5px;
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:12px;
  overflow:hidden;
}
.nlp-content-body table thead{
  background:var(--nlp-surface-2, #F6F4EE);
}
.nlp-content-body table th{
  text-align:left;
  font:600 12px/1.3 var(--nlp-font);
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--nlp-ink-soft);
  padding:12px 14px;
  border-bottom:1px solid var(--nlp-line);
  vertical-align:top;
}
.nlp-content-body table td{
  padding:12px 14px;
  border-bottom:1px solid var(--nlp-line-soft);
  vertical-align:top;
  color:var(--nlp-ink);
}
.nlp-content-body table tbody tr:last-child td{ border-bottom:0; }
.nlp-content-body table tbody tr:hover{ background:var(--nlp-surface-2, #F8F7F4); }
.nlp-content-body table .num{
  font-family:var(--nlp-font-mono, 'JetBrains Mono', ui-monospace, monospace);
  font-feature-settings:"tnum";
  font-variant-numeric:tabular-nums;
  font-weight:600;
  white-space:nowrap;
}
.nlp-content-body table .ok{ color:var(--nlp-accent); font-weight:600; }
.nlp-content-body table .ko{ color:#B91C1C; font-weight:600; }

/* Wrap tables on small screens */
.nlp-content-body .nlp-table-wrap{
  overflow-x:auto;
  margin:18px -16px 22px;
  padding:0 16px;
}
@media (max-width:640px){
  .nlp-content-body table{ font-size:13.5px; min-width:560px; }
  .nlp-content-body table th, .nlp-content-body table td{ padding:10px 12px; }
}

/* ----- Callouts ----- */
.nlp-content-body .nlp-callout{
  display:flex;gap:12px;
  margin:22px 0;
  padding:16px 18px;
  background:var(--nlp-accent-soft, #E8F0EB);
  border:1px solid rgba(14,92,58,.15);
  border-left:3px solid var(--nlp-accent);
  border-radius:10px;
}
.nlp-content-body .nlp-callout > svg,
.nlp-content-body .nlp-callout > .nlp-callout-icon{
  flex:none;color:var(--nlp-accent);
}
.nlp-content-body .nlp-callout p{ margin:0 0 6px; }
.nlp-content-body .nlp-callout p:last-child{ margin:0; }
.nlp-content-body .nlp-callout strong{ color:var(--nlp-accent-deep); }

.nlp-content-body .nlp-callout--warn{
  background:#FFF8EC;
  border-color:#E8C796;
  border-left-color:#B98A2C;
}
.nlp-content-body .nlp-callout--warn strong{ color:#7A5A12; }

.nlp-content-body .nlp-callout--note{
  background:#F6F4EE;
  border-color:rgba(27,31,26,.10);
  border-left-color:var(--nlp-ink);
}
.nlp-content-body .nlp-callout--note strong{ color:var(--nlp-ink); }

/* ----- Stat strip ----- */
.nlp-content-body .nlp-stats{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:12px;
  margin:20px 0 24px;
}
@media (min-width:640px){
  .nlp-content-body .nlp-stats{ grid-template-columns:repeat(4, 1fr); }
}
.nlp-content-body .nlp-stat{
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:12px;
  padding:14px 16px;
}
.nlp-content-body .nlp-stat-num{
  font-family:var(--nlp-font-mono, 'JetBrains Mono', ui-monospace, monospace);
  font-feature-settings:"tnum";
  font-size:24px;font-weight:700;color:var(--nlp-accent);
  letter-spacing:-.02em;
  display:block;
  line-height:1.1;margin-bottom:4px;
}
.nlp-content-body .nlp-stat-label{
  font-size:12px;color:var(--nlp-ink-muted);
  line-height:1.35;
}

/* ----- Definition list (glosario) ----- */
.nlp-content-body dl{
  margin:18px 0 22px;
  display:grid;
  gap:10px;
}
.nlp-content-body dt{
  font-weight:600;color:var(--nlp-ink);
  font-size:15px;
  margin-top:4px;
}
.nlp-content-body dd{
  margin:0 0 6px;
  color:var(--nlp-ink-soft);
  font-size:15px;
  padding-left:14px;
  border-left:2px solid var(--nlp-line);
}

/* ----- Pros / Cons grid ----- */
.nlp-content-body .nlp-proscons{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin:20px 0;
}
@media (min-width:640px){
  .nlp-content-body .nlp-proscons{ grid-template-columns:1fr 1fr; }
}
.nlp-content-body .nlp-pros, .nlp-content-body .nlp-cons{
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:12px;
  padding:16px 18px;
}
.nlp-content-body .nlp-pros{ border-top:3px solid var(--nlp-accent); }
.nlp-content-body .nlp-cons{ border-top:3px solid #B98A2C; }
.nlp-content-body .nlp-pros h4,
.nlp-content-body .nlp-cons h4{
  margin:0 0 10px;
  font:600 14px/1 var(--nlp-font);
  letter-spacing:-.005em;
  display:flex;align-items:center;gap:6px;
}
.nlp-content-body .nlp-pros h4{ color:var(--nlp-accent-deep); }
.nlp-content-body .nlp-cons h4{ color:#7A5A12; }
.nlp-content-body .nlp-pros ul,
.nlp-content-body .nlp-cons ul{
  list-style:none;padding:0;margin:0;
  font-size:14px;
}
.nlp-content-body .nlp-pros li,
.nlp-content-body .nlp-cons li{
  position:relative;padding-left:20px;
  margin:0 0 7px;
  line-height:1.55;
}
.nlp-content-body .nlp-pros li::before{
  content:"✓";position:absolute;left:0;top:0;
  color:var(--nlp-accent);font-weight:700;
}
.nlp-content-body .nlp-cons li::before{
  content:"!";position:absolute;left:0;top:0;
  color:#B98A2C;font-weight:700;
}

/* ----- Roadmap / steps ----- */
.nlp-content-body .nlp-steps{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin:20px 0 24px;
}
@media (min-width:780px){
  .nlp-content-body .nlp-steps{ grid-template-columns:repeat(3, 1fr); }
}
.nlp-content-body .nlp-step{
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:12px;
  padding:18px;
  position:relative;
}
.nlp-content-body .nlp-step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:28px;border-radius:50%;
  background:var(--nlp-accent);color:#fff;
  font:700 13px/1 var(--nlp-font-mono, monospace);
  margin-bottom:10px;
}
.nlp-content-body .nlp-step h4{
  margin:0 0 6px;
  font:600 15px/1.3 var(--nlp-font);
  color:var(--nlp-ink);
}
.nlp-content-body .nlp-step p{
  margin:0;font-size:14px;line-height:1.55;
  color:var(--nlp-ink-soft);
}

/* ----- Blockquote ----- */
.nlp-content-body blockquote{
  margin:22px 0;
  padding:14px 0 14px 18px;
  border-left:3px solid var(--nlp-gold, #E8C796);
  font-family:'Instrument Serif', Georgia, serif;
  font-style:italic;font-weight:400;
  font-size:18px;line-height:1.55;
  color:var(--nlp-ink);
  letter-spacing:-.005em;
}
.nlp-content-body blockquote cite{
  display:block;
  margin-top:8px;
  font-family:var(--nlp-font);
  font-style:normal;font-size:13px;
  color:var(--nlp-ink-muted);
  letter-spacing:0;
}
.nlp-content-body blockquote cite::before{ content:"— "; }

/* ----- Details / FAQ collapsible ----- */
.nlp-content-body details{
  margin:0 0 10px;
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:10px;
  padding:12px 16px;
}
.nlp-content-body details[open]{
  border-color:rgba(14,92,58,.30);
}
.nlp-content-body details summary{
  cursor:pointer;
  font:600 15px/1.3 var(--nlp-font);
  color:var(--nlp-ink);
  list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.nlp-content-body details summary::-webkit-details-marker{display:none;}
.nlp-content-body details summary::after{
  content:"+";
  flex:none;
  font-family:var(--nlp-font-mono, monospace);
  font-weight:600;font-size:18px;
  color:var(--nlp-accent);
  transition:transform .2s ease;
}
.nlp-content-body details[open] summary::after{ content:"−"; }
.nlp-content-body details > p,
.nlp-content-body details > ul,
.nlp-content-body details > ol{
  margin-top:10px;
  font-size:14.5px;
  color:var(--nlp-ink-soft);
}

/* ----- Comparison cards (3-up) ----- */
.nlp-content-body .nlp-compare{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  margin:22px 0;
}
@media (min-width:780px){
  .nlp-content-body .nlp-compare{ grid-template-columns:repeat(3, 1fr); }
}
.nlp-content-body .nlp-compare-card{
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:12px;
  padding:18px;
  display:flex;flex-direction:column;
}
.nlp-content-body .nlp-compare-card.is-best{
  border-color:var(--nlp-accent);
  box-shadow:0 12px 24px -14px rgba(14,92,58,.30);
}
.nlp-content-body .nlp-compare-card .badge{
  display:inline-flex;align-self:flex-start;
  font:700 10px/1 var(--nlp-font-mono, monospace);
  letter-spacing:.10em;text-transform:uppercase;
  background:var(--nlp-accent);color:#fff;
  padding:4px 8px;border-radius:999px;
  margin-bottom:10px;
}
.nlp-content-body .nlp-compare-card h4{
  margin:0 0 8px;font:600 16px/1.3 var(--nlp-font);
}
.nlp-content-body .nlp-compare-card .price{
  font-family:var(--nlp-font-mono, monospace);
  font-size:22px;font-weight:700;color:var(--nlp-accent);
  margin:6px 0 12px;
}

/* ----- Inline highlight ----- */
.nlp-content-body mark{
  background:linear-gradient(180deg, transparent 60%, rgba(232,199,150,.55) 60%);
  padding:0 2px;color:var(--nlp-ink);
}

/* =========================================================
   4. RELATED BUNDLES
   ========================================================= */
.nlp-bundles{
  position:relative;
  padding:56px 0 72px;
  background:linear-gradient(180deg, var(--nlp-surface-2) 0%, var(--nlp-surface) 100%);
  border-top:1px solid var(--nlp-line-soft);
}
@media (min-width:900px){ .nlp-bundles{ padding:80px 0 96px; } }

.nlp-bundles-head{
  text-align:center;
  margin-bottom:32px;
}
.nlp-bundles-head .nlp-services-eyebrow{
  justify-content:center;
}
.nlp-bundles-head h2{
  font:600 clamp(26px, 4vw, 38px)/1.1 var(--nlp-font);
  letter-spacing:-.025em;
  color:var(--nlp-ink);
  margin:14px 0 10px;
}
.nlp-bundles-head h2 em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  color:var(--nlp-accent);
}
.nlp-bundles-head p{
  font-size:15px;
  color:var(--nlp-ink-soft);
  margin:0;
  max-width:60ch;
  margin-inline:auto;
}

.nlp-bundles-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
@media (min-width:640px){ .nlp-bundles-grid{ grid-template-columns:repeat(2, 1fr); } }
@media (min-width:1100px){ .nlp-bundles-grid{ grid-template-columns:repeat(3, 1fr); } }

.nlp-bundle{
  position:relative;
  display:flex;
  flex-direction:column;
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:20px;
  overflow:hidden;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.nlp-bundle:hover{
  transform:translateY(-3px);
  border-color:var(--nlp-accent);
  box-shadow:0 22px 40px -20px rgba(14,92,58,.30);
}
.nlp-bundle-img{
  position:relative;
  display:block;
  aspect-ratio:16/10;
  background:var(--nlp-surface-2);
  overflow:hidden;
}
.nlp-bundle-img img{
  width:100%; height:100%;
  object-fit:cover;
}
.nlp-bundle-img svg{
  width:100%; height:100%;
  padding:32px;
  color:var(--nlp-accent);
  opacity:.6;
}
.nlp-bundle-discount{
  position:absolute;
  top:14px; left:14px;
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  background:var(--nlp-accent);
  color:#FFFFFF;
  font:700 11px/1 var(--nlp-font);
  letter-spacing:.08em;
  text-transform:uppercase;
  border-radius:999px;
  box-shadow:0 8px 16px -6px rgba(14,92,58,.45);
}
.nlp-bundle-body{
  padding:18px 20px 16px;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.nlp-bundle-name{
  font:600 17px/1.25 var(--nlp-font);
  letter-spacing:-.005em;
  color:var(--nlp-ink);
  margin:0;
}
.nlp-bundle-name a{
  color:inherit;
  text-decoration:none;
}
.nlp-bundle-items{
  list-style:none;
  padding:0; margin:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.nlp-bundle-items li{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:var(--nlp-ink-soft);
}
.nlp-bundle-items li b{
  color:var(--nlp-ink);
  font-weight:600;
  margin-right:4px;
}
.nlp-bundle-items .check{
  flex:none;
  width:14px; height:14px;
  color:var(--nlp-accent);
}
.nlp-bundle-items-extra{
  color:var(--nlp-ink-muted);
  font-size:12px;
}
.nlp-bundle-foot{
  padding:14px 20px;
  border-top:1px solid var(--nlp-line-soft);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:var(--nlp-surface-2);
}
.nlp-bundle-price-old{
  font-family:var(--nlp-font-mono);
  font-size:13px;
  color:var(--nlp-ink-muted);
  text-decoration:line-through;
  margin-right:8px;
}
.nlp-bundle-price-new{
  font-family:var(--nlp-font-mono);
  font-feature-settings:"tnum";
  font-size:18px;
  font-weight:600;
  color:var(--nlp-accent-deep);
  letter-spacing:-.01em;
}
.nlp-bundle-cta{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 16px;
  background:var(--nlp-accent);
  color:#FFFFFF;
  font:600 13px/1 var(--nlp-font);
  border-radius:999px;
  text-decoration:none;
  transition:background .18s ease, transform .18s ease;
}
.nlp-bundle-cta:hover{
  background:var(--nlp-accent-deep);
  color:#FFFFFF;
  transform:translateY(-1px);
}

.nlp-bundles-foot{
  text-align:center;
  margin-top:32px;
}
.nlp-bundles-foot a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:12px 22px;
  border:1px solid var(--nlp-line-strong);
  border-radius:999px;
  color:var(--nlp-ink);
  text-decoration:none;
  font:600 13.5px/1 var(--nlp-font);
  transition:background .15s ease, border-color .15s ease;
}
.nlp-bundles-foot a:hover{
  background:var(--nlp-surface-2);
  border-color:var(--nlp-accent-deep);
  color:var(--nlp-accent-deep);
}

/* =========================================================
   5. FAQ
   ========================================================= */
.nlp-faq{
  position:relative;
  padding:56px 0 72px;
  background:var(--nlp-surface);
}
@media (min-width:900px){ .nlp-faq{ padding:80px 0 96px; } }

.nlp-faq-head{
  text-align:center;
  margin-bottom:32px;
}
.nlp-faq-head h2{
  font:600 clamp(26px, 4vw, 38px)/1.1 var(--nlp-font);
  letter-spacing:-.025em;
  color:var(--nlp-ink);
  margin:14px 0 10px;
}
.nlp-faq-head h2 em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  color:var(--nlp-accent);
}
.nlp-faq-head p{
  font-size:15px;
  color:var(--nlp-ink-soft);
  margin:0;
  max-width:60ch;
  margin-inline:auto;
}

.nlp-faq-list{
  max-width:760px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.nlp-faq-item{
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:14px;
  overflow:hidden;
  transition:border-color .15s ease;
}
.nlp-faq-item[open]{
  border-color:var(--nlp-accent);
  box-shadow:0 0 0 3px var(--nlp-accent-glow);
}
.nlp-faq-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:18px 20px;
  font:600 15px/1.4 var(--nlp-font);
  color:var(--nlp-ink);
  cursor:pointer;
  list-style:none;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.nlp-faq-summary::-webkit-details-marker{ display:none; }
.nlp-faq-summary::after{
  content:"";
  flex:none;
  width:20px; height:20px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230A4A2E' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  transition:transform .2s ease;
}
.nlp-faq-item[open] .nlp-faq-summary::after{ transform:rotate(180deg); }

.nlp-faq-content{
  padding:0 20px 18px;
  font-size:14.5px;
  line-height:1.6;
  color:var(--nlp-ink-soft);
}
.nlp-faq-content p{ margin:0 0 10px; }
.nlp-faq-content p:last-child{ margin:0; }

.nlp-faq-foot{
  text-align:center;
  margin-top:28px;
}
.nlp-faq-foot a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--nlp-accent-deep);
  font:600 13.5px/1 var(--nlp-font);
  text-decoration:none;
  border-bottom:1px solid transparent;
  padding-bottom:3px;
  transition:border-color .15s ease, color .15s ease;
}
.nlp-faq-foot a:hover{
  color:var(--nlp-accent);
  border-bottom-color:var(--nlp-accent);
}

/* =========================================================
   6. STEPS — "Cómo comprar"
   ========================================================= */
.nlp-steps{
  position:relative;
  padding:56px 0 72px;
  background:linear-gradient(180deg, var(--nlp-surface) 0%, var(--nlp-surface-2) 100%);
  border-top:1px solid var(--nlp-line-soft);
}
@media (min-width:900px){ .nlp-steps{ padding:80px 0 112px; } }

.nlp-steps-head{
  text-align:center;
  margin-bottom:36px;
}
.nlp-steps-head h2{
  font:600 clamp(26px, 4vw, 38px)/1.1 var(--nlp-font);
  letter-spacing:-.025em;
  color:var(--nlp-ink);
  margin:14px 0 10px;
}
.nlp-steps-head h2 em{
  font-family:var(--nlp-font-serif);
  font-style:italic;
  font-weight:400;
  color:var(--nlp-accent);
}
.nlp-steps-head p{
  font-size:15px;
  color:var(--nlp-ink-soft);
  margin:0;
  max-width:60ch;
  margin-inline:auto;
}

.nlp-steps-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
}
@media (min-width:640px){ .nlp-steps-grid{ grid-template-columns:repeat(3, 1fr); gap:18px; } }

.nlp-step{
  background:#FFFFFF;
  border:1px solid var(--nlp-line);
  border-radius:18px;
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.nlp-step-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px; height:36px;
  border-radius:50%;
  background:var(--nlp-accent);
  color:#FFFFFF;
  font:700 14px/1 var(--nlp-font-mono);
}
.nlp-step h3{
  font:600 17px/1.25 var(--nlp-font);
  letter-spacing:-.005em;
  color:var(--nlp-ink);
  margin:0;
}
.nlp-step p{
  font-size:14px;
  line-height:1.55;
  color:var(--nlp-ink-soft);
  margin:0;
}

/* =========================================================
   Reduced motion
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  .nlp-card,
  .nlp-card::after,
  .nlp-card-cta,
  .nlp-bundle,
  .nlp-bundle-cta,
  .nlp-faq-summary::after,
  .nlp-hero-card__pulse::before,
  .nlp-hero-card__foot .dot{
    transition:none !important;
    animation:none !important;
  }
}
