:root{
  --nt-bg:#0b0f16;
  --nt-header:#11161d;
  --nt-white:#ffffff;
  --nt-black:#000000;
  --nt-muted:#9aa3ab;
  --nt-gold:#d7b56d;
  --nt-gold-dark:#b7924c;
  --nt-red:#c21d1d;
  --nt-red-dark:#971717;
  --nt-line:rgba(255,255,255,0.08);
  --nt-line-dark:rgba(17,17,17,0.08);
  --nt-text:#111111;
  --nt-text-soft:#4f5661;
  --nt-text-muted:#6f7782;
  --nt-beige:#f7f3ee;
  --nt-soft:#f5f2ec;
  --nt-soft-2:#fcfaf7;
  --nt-card:#ffffff;
  --nt-shadow-sm:0 10px 24px rgba(0,0,0,0.05);
  --nt-shadow-md:0 18px 40px rgba(0,0,0,0.08);
  --nt-shadow-lg:0 24px 60px rgba(0,0,0,0.16);
  --nt-radius-sm:12px;
  --nt-radius-md:20px;
  --nt-radius-lg:28px;
  --nt-transition:all .25s ease;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:'Inter',sans-serif;
  background:var(--nt-bg);
  color:var(--nt-white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{
  max-width:100%;
  display:block;
}

a{
  color:inherit;
  text-decoration:none;
  transition:var(--nt-transition);
}

a:hover{
  color:var(--nt-gold);
}

button,
.btn{
  transition:var(--nt-transition);
}

ul{
  margin:0;
  padding:0;
}

.section-light{
  background:#ffffff;
  color:var(--nt-text);
}

.section-soft{
  background:var(--nt-soft);
  color:var(--nt-text);
}

.section-dark{
  background:var(--nt-bg);
  color:var(--nt-white);
}

.nt-section{
  padding:6rem 0;
}

.section-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.2rem,4vw,3.2rem);
  font-weight:700;
  line-height:1.04;
  letter-spacing:-0.02em;
  color:var(--nt-text);
  margin-bottom:0;
}

.section-title.text-white{
  color:#fff !important;
}

.section-copy{
  color:var(--nt-text-soft);
  font-size:1.02rem;
  line-height:1.75;
  max-width:720px;
}

.eyebrow{
  display:inline-block;
  margin-bottom:.9rem;
  color:var(--nt-gold);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.nt-divider{
  width:56px;
  height:1px;
  margin:1rem 0 1.5rem;
  background:linear-gradient(to right, transparent, var(--nt-red), transparent);
}

.text-gold{
  color:var(--nt-gold);
}

/* =========================
   NAVBAR
========================= */

.brand-logo{
  width:54px;
  height:54px;
  object-fit:contain;
  filter:drop-shadow(0 4px 16px rgba(0,0,0,.28));
}

.brand-mark{
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
  line-height:1;
  letter-spacing:.06em;
}

.brand-sub{
  color:rgba(255,255,255,.62);
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.nt-navbar .nav-link{
  color:rgba(255,255,255,.92);
  text-transform:uppercase;
  font-size:.88rem;
  font-weight:600;
  letter-spacing:.12em;
  padding:1rem .9rem !important;
}

.nt-navbar .nav-link:hover,
.nt-navbar .nav-link.active,
.nt-navbar .nav-link:focus{
  color:var(--nt-gold);
}

.btn-nav{
  min-height:46px;
  padding:.72rem 1.1rem;
  border:1px solid rgba(215,181,109,.7);
  color:#fff;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.82rem;
  font-weight:700;
  border-radius:999px;
}

.btn-nav:hover,
.btn-nav:focus{
  background:var(--nt-gold);
  border-color:var(--nt-gold);
  color:#111;
}
/* =========================
   NAVBAR
========================= */
/* =========================
   NAVBAR
========================= */

.navbar-toggler{
  border:none;
  padding:.35rem .5rem;
}

.navbar-toggler:focus{
  box-shadow:none;
}

@media (max-width:991.98px){
  .nt-navbar{
    margin-top:1rem;
    padding:1rem 1.25rem;
    background:rgba(10,14,22,.96);
    border:1px solid rgba(255,255,255,.08);
    border-radius:1rem;
  }

  .nt-navbar .nav-link{
    padding:.8rem 0 !important;
  }

  .navbar-brand{
    max-width:75%;
  }

  .brand-mark{
    font-size:1.1rem;
  }

  .brand-sub{
    font-size:.62rem;
    letter-spacing:.12em;
  }
}
.navbar-toggler{
  border:none;
}

.navbar-toggler:focus{
  box-shadow:none;
}

@media (max-width:991px){

  .nt-navbar{
    margin-top:1rem;
    background:rgba(10,14,22,.96

.brand-logo{
  width:54px;
  height:54px;
  object-fit:contain;
  filter:drop-shadow(0 4px 16px rgba(0,0,0,.28));
}

.brand-mark{
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
  line-height:1;
  letter-spacing:.06em;
}

.brand-sub{
  color:rgba(255,255,255,.62);
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.nt-navbar .nav-link{
  color:rgba(255,255,255,.92);
  text-transform:uppercase;
  font-size:.88rem;
  font-weight:600;
  letter-spacing:.12em;
  padding:1rem .9rem !important;
}

.nt-navbar .nav-link:hover,
.nt-navbar .nav-link.active,
.nt-navbar .nav-link:focus{
  color:var(--nt-gold);
}

.btn-nav{
  min-height:46px;
  padding:.72rem 1.1rem;
  border:1px solid rgba(215,181,109,.7);
  color:#fff;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.82rem;
  font-weight:700;
  border-radius:999px;
}

.btn-nav:hover,
.btn-nav:focus{
  background:var(--nt-gold);
  border-color:var(--nt-gold);
  color:#111;
}
/* =========================
   HERO
========================= */
.btn-hero-primary{
  background:var(--nt-gold);
  color:#0b0f16;
  border:none;
  padding:.9rem 1.4rem;
  border-radius:999px;
  font-weight:600;
  letter-spacing:.04em;
  transition:all .25s ease;
}

.btn-hero-primary:hover{
  background:#d4b06a;
  color:#0b0f16;
  transform:translateY(-1px);
}
.nt-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:
    linear-gradient(to right, rgba(5,10,18,.92) 10%, rgba(5,10,18,.68) 48%, rgba(5,10,18,.82) 100%),
    radial-gradient(circle at top right, rgba(215,181,109,.14), transparent 28%),
    radial-gradient(circle at bottom left, rgba(194,29,29,.10), transparent 30%),
    url('../img/hero/nt-hero.png') center center / cover no-repeat;
}

.about-visual{
  position:relative;
  min-height:480px;
  overflow:hidden;
  border-radius:1.6rem;
  background:
    linear-gradient(180deg, rgba(11,15,22,.24), rgba(11,15,22,.55)),
    url('../img/hero/nt-hero.png') center center / cover no-repeat;
  box-shadow:0 22px 50px rgba(0,0,0,.12);
}

.page-hero{
  position:relative;
  padding:12rem 0 6rem;
  background:
    linear-gradient(to right, rgba(5,10,18,.90), rgba(5,10,18,.72)),
    url('../img/hero/nt-hero.png') center center / cover no-repeat;
}
/* =========================
   SERVICE STRIP
========================= */
.service-strip{
  position:relative;
  z-index:5;
  margin-top:-92px;
}

.strip-shell{
  background:rgba(8,14,24,.88);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
  box-shadow:0 22px 60px rgba(0,0,0,.25);
}

.service-pill{
  height:100%;
  padding:1.7rem 1.4rem;
  border-right:1px solid rgba(255,255,255,.08);
  transition:var(--nt-transition);
}

.service-pill:last-child{
  border-right:none;
}

.service-pill:hover{
  background:rgba(255,255,255,.03);
}

.service-pill i{
  display:inline-block;
  margin-bottom:.9rem;
  color:var(--nt-gold);
  font-size:1.4rem;
}

.service-pill h3{
  margin-bottom:.6rem;
  color:#fff;
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
}

.service-pill p{
  margin:0;
  color:rgba(255,255,255,.72);
  font-size:.96rem;
  line-height:1.65;
}

/* =========================
   ABOUT
========================= */
.about-visual::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.25), transparent);
}
.about-visual{
  position:relative;
  min-height:480px;
  border-radius:1.6rem;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(11,15,22,.24), rgba(11,15,22,.55)),
    url('../img/backgrounds/about-visual.jpg') center center / cover no-repeat;
}
.about-visual{
  position:relative;
  min-height:520px;
  overflow:hidden;
  border-radius:1.6rem;
  background:
    linear-gradient(180deg, rgba(11,15,22,.20), rgba(11,15,22,.58)),
    url('../img/backgrounds/about-visual.jpg') center center / cover no-repeat;
  box-shadow:0 24px 54px rgba(0,0,0,.14);
}

.about-float{
  position:absolute;
  right:1.5rem;
  bottom:1.5rem;
  max-width:320px;
  padding:1.35rem 1.35rem 1.1rem;
  background:rgba(255,255,255,.94);
  color:var(--nt-text);
  border-radius:1.2rem;
  box-shadow:0 18px 42px rgba(0,0,0,.16);
}
.about-card{
  height:100%;
  padding:2rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  border-radius:1.25rem;
  box-shadow:var(--nt-shadow-sm);
}

.about-list{
  list-style:none;
}

.about-list li{
  display:flex;
  gap:.75rem;
  margin-bottom:1rem;
  color:var(--nt-text-soft);
  line-height:1.7;
}

.about-list i{
  color:var(--nt-gold);
  margin-top:.18rem;
}

.about-visual{
  position:relative;
  min-height:480px;
  overflow:hidden;
  border-radius:1.6rem;
  background:
    linear-gradient(180deg, rgba(11,15,22,.24), rgba(11,15,22,.55)),
    url('../img/backgrounds/about-visual.jpg') center center / cover no-repeat;
  box-shadow:0 22px 50px rgba(0,0,0,.12);
}

.about-float{
  position:absolute;
  right:1.25rem;
  bottom:1.25rem;
  max-width:310px;
  padding:1.2rem 1.2rem 1rem;
  background:rgba(255,255,255,.92);
  color:var(--nt-text);
  border-radius:1.2rem;
  box-shadow:0 16px 40px rgba(0,0,0,.15);
}

.about-float strong{
  display:block;
  margin-bottom:.45rem;
  color:var(--nt-red);
  font-size:.82rem;
  letter-spacing:.16em;
  text-transform:uppercase;
}

/* =========================
   SERVICES GRID
========================= */


.service-strip{
  margin-top:-80px;
  position:relative;
  z-index:5;
}

.strip-shell{
  background:#fff;
  box-shadow:0 25px 60px rgba(0,0,0,.12);
}

.service-pill{
  padding:2rem;
  height:100%;
  border-right:1px solid rgba(0,0,0,.06);
}

.service-pill:last-child{
  border-right:none;
}

.service-pill i{
  font-size:1.8rem;
  color:var(--nt-red);
  margin-bottom:.8rem;
  display:inline-block;
}

.service-pill h3{
  font-size:1.1rem;
  font-weight:700;
  margin-bottom:.5rem;
}

.service-pill p{
  font-size:.95rem;
  color:rgba(0,0,0,.65);
  line-height:1.6;
}
.service-card,
.about-card,
.process-step,
.content-card{
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  box-shadow:0 12px 30px rgba(0,0,0,.04);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.service-card:hover,
.about-card:hover,
.process-step:hover,
.content-card:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 44px rgba(0,0,0,.08);
  border-color:rgba(215,181,109,.18);
}
.service-card{
  height:100%;
  padding:2rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  border-radius:1.4rem;
  box-shadow:0 12px 30px rgba(0,0,0,.04);
  transition:transform .25s ease, box-shadow .25s ease;
}

.service-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--nt-shadow-md);
}

.service-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:58px;
  height:58px;
  margin-bottom:1rem;
  border-radius:50%;
  background:rgba(215,181,109,.12);
  color:var(--nt-gold);
  font-size:1.35rem;
}

.service-card h3{
  margin-bottom:.85rem;
  color:var(--nt-text);
  font-family:'Playfair Display',serif;
  font-size:1.7rem;
  line-height:1.08;
}

.service-card p{
  margin-bottom:1rem;
  color:var(--nt-text-soft);
  line-height:1.75;
}

.service-card ul{
  list-style:none;
}

.service-card li{
  display:flex;
  gap:.65rem;
  margin-bottom:.7rem;
  color:var(--nt-text-soft);
}

.service-card li i{
  color:var(--nt-gold);
  margin-top:.16rem;
}

/* =========================
   ADVANTAGES
========================= */


.advantage-card{
  ...
}

/* WHY SECTION ENHANCEMENT */
.nt-why-section{
  position:relative;
  overflow:hidden;
}

.nt-why-section::before{
  content:"";
  position:absolute;
  top:-120px;
  right:-120px;
  width:320px;
  height:320px;
  background:radial-gradient(circle, rgba(215,181,109,.10), transparent 70%);
  pointer-events:none;
}

.nt-why-section::after{
  content:"";
  position:absolute;
  bottom:-140px;
  left:-140px;
  width:340px;
  height:340px;
  background:radial-gradient(circle, rgba(194,29,29,.08), transparent 70%);
  pointer-events:none;
}
/* =========================
   PROCESS
========================= */

.process-step{
  position:relative;
  height:100%;
  padding:2rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  border-radius:1.25rem;
  box-shadow:0 10px 26px rgba(0,0,0,.04);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.process-step:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 42px rgba(0,0,0,.08);
  border-color:rgba(215,181,109,.18);
}

.process-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  margin-bottom:1rem;
  border-radius:50%;
  background:var(--nt-text);
  color:#fff;
  font-weight:800;
  box-shadow:0 10px 24px rgba(17,17,17,.12);
}
.process-step{
  position:relative;
  height:100%;
  padding:1.8rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  border-radius:1.25rem;
  box-shadow:0 8px 24px rgba(0,0,0,.03);
}

.process-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  margin-bottom:1rem;
  border-radius:50%;
  background:var(--nt-text);
  color:#fff;
  font-weight:800;
}

.process-step h3{
  margin-bottom:.65rem;
  color:var(--nt-text);
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
}

.process-step p{
  margin-bottom:0;
  color:var(--nt-text-soft);
  line-height:1.75;
}

/* =========================
   CTA
========================= */
.cta-box{
  padding:3rem;
  border-radius:1.6rem;
  background:
    linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 20px 50px rgba(0,0,0,.18);
}

.cta-box p{
  color:rgba(255,255,255,.7);
  max-width:520px;
}
.cta-box{
  padding:3rem;
  background:
    linear-gradient(135deg, rgba(215,181,109,.12), rgba(255,255,255,.03)),
    #101720;
  border:1px solid rgba(255,255,255,.08);
  border-radius:1.8rem;
  box-shadow:0 22px 50px rgba(0,0,0,.18);
}

.cta-box p{
  max-width:740px;
  color:rgba(255,255,255,.74);
  line-height:1.75;
}

/* =========================
   FOOTER
========================= */
.nm-foot-divider
.nm-foot-title
.nm-divider
.nm-foot-text
.nt-why-section{
  position:relative;
  overflow:hidden;
}

.nt-why-section::before{
  content:"";
  position:absolute;
  top:-120px;
  right:-120px;
  width:320px;
  height:320px;
  background:radial-gradient(circle, rgba(215,181,109,.10), transparent 70%);
  pointer-events:none;
}

.nt-why-section::after{
  content:"";
  position:absolute;
  bottom:-140px;
  left:-140px;
  width:340px;
  height:340px;
  background:radial-gradient(circle, rgba(194,29,29,.08), transparent 70%);
  pointer-events:none;
}

.advantage-card{
  height:100%;
  padding:1.8rem;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:1.35rem;
  box-shadow:0 12px 30px rgba(0,0,0,.08);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.advantage-card:hover{
  transform:translateY(-4px);
  border-color:rgba(215,181,109,.18);
  box-shadow:0 22px 44px rgba(0,0,0,.16);
}

.nm-footer{
  background:#0b0f16;
  border-top:1px solid rgba(
.nm-foot-copy,
.nm-foot-legal{
  color:rgba(255,255,255,.58);
  font-size:.84rem;
  line-height:1.7;
}

.nm-foot-signature{
  color:rgba(255,255,255,.72);
  font-size:.9rem;
  letter-spacing:.05em;
}

.nm-accent{
  color:var(--nt-gold);
}
.nm-footer{
  background:#0b0f16;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:4.5rem;
}

.nm-foot-brand{
  color:#fff;
  font-family:'Playfair Display', serif;
  font-size:1.6rem;
  letter-spacing:.08em;
}

.nm-foot-sub{
  margin-top:.3rem;
  color:rgba(255,255,255,.6);
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.nm-foot-note{
  color:rgba(255,255,255,.5);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.nm-foot-links{
  list-style:none;
  padding-left:0;
}

.nm-foot-links li{
  margin-bottom:.65rem;
}

.nm-foot-links a,
.nm-foot-links span{
  color:rgba(255,255,255,.75);
  font-size:.95rem;
  line-height:1.7;
}

.nm-foot-links a:hover{
  color:var(--nt-gold);
}

.nm-foot-bottom{
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.08);
}
/* =========================
   FOOTER ENHANCEMENTS
========================= */

/* Divider entre bloques */
.nm-foot-divider{
  border-top:1px solid rgba(255,255,255,.08);
}

/* Títulos de columnas */
.nm-foot-title{
  color:#fff;
  font-size:.95rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:.4rem;
}

/* Línea decorativa debajo de títulos */
.nm-divider{
  width:32px;
  height:1px;
  background:var(--nt-red);
  margin:.6rem 0 1rem;
  opacity:.7;
}

/* Texto narrativo del ecosystem */
.nm-foot-text{
  color:rgba(255,255,255,.7);
  font-size:.95rem;
  line-height:1.75;
}

/* Ajuste visual del bloque superior */
.nm-footer .nm-foot-note{
  align-self:center;
}

/* CTA dentro del footer */
.nm-footer .btn{
  min-height:52px;
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  border-radius:999px;
}
/* =========================
   PAGE HELPERS
========================= */
.nt-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:
    linear-gradient(to right, rgba(5,10,18,.92) 10%, rgba(5,10,18,.68) 48%, rgba(5,10,18,.82) 100%),
    radial-gradient(circle at top right, rgba(215,181,109,.14), transparent 28%),
    radial-gradient(circle at bottom left, rgba(194,29,29,.10), transparent 30%),
    url('../img/hero/hero-main.jpg') center center / cover no-repeat;
}
.page-hero{
  position:relative;
  padding:12rem 0 6rem;
  background:
    linear-gradient(to right, rgba(5,10,18,.90), rgba(5,10,18,.72)),
    url('../img/backgrounds/page-hero.jpg') center center / cover no-repeat;
}

.page-hero .section-title{
  color:#fff;
}

.page-hero .section-copy{
  color:rgba(255,255,255,.75);
}

.content-card{
  padding:2rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  border-radius:1.2rem;
  box-shadow:var(--nt-shadow-sm);
}

/* =========================
   FORMS
========================= */
.form-control,
.form-select{
  min-height:54px;
  border:1px solid rgba(17,17,17,.10);
  border-radius:14px;
  padding:.85rem 1rem;
  color:var(--nt-text);
  background:#fff;
  box-shadow:none;
}

.form-control:focus,
.form-select:focus{
  border-color:rgba(215,181,109,.7);
  box-shadow:0 0 0 .2rem rgba(215,181,109,.15);
}

textarea.form-control{
  min-height:150px;
  resize:vertical;
}

/* =========================
   RESPONSIVE
========================= */
@media (max-width: 991.98px){
  .nt-navbar{
    margin-top:.75rem;
    padding:.5rem 1rem;
    background:rgba(10,14,22,.92);
    border-radius:1rem;
  }

  .hero-content{
    padding:8.6rem 0 6rem;
    text-align:center;
  }

  .hero-subtitle{
    margin-left:auto;
    margin-right:auto;
  }

  .hero-actions{
    justify-content:center;
  }

  .hero-metrics{
    justify-content:center;
  }

  .metric-item{
    padding-left:0;
    border-left:none;
  }

  .service-strip{
    margin-top:-64px;
  }

  .service-pill{
    border-right:none;
    border-bottom:1px solid rgba(255,255,255,.08);
  }

  .service-pill:last-child{
    border-bottom:none;
  }

  .about-visual{
    min-height:360px;
  }

  .about-float{
    position:static;
    max-width:none;
    margin:1rem;
  }
}

@media (max-width: 767.98px){
  .brand-mark{
    font-size:1.15rem;
  }

  .brand-sub{
    font-size:.68rem;
  }

  .hero-title{
    font-size:clamp(2.6rem,12vw,4.2rem);
  }

  .hero-actions .btn{
    width:100%;
  }

  .service-strip{
    margin-top:-32px;
  }

  .nt-section{
    padding:4.5rem 0;
  }

  .cta-box{
    padding:2rem;
  }

  .nm-foot-bottom,
  .nm-foot-note{
    text-align:center;
  }
}

@media (max-width: 575.98px){
  .brand-logo{
    width:46px;
    height:46px;
  }

  .section-title{
    font-size:2rem;
  }

  .service-card,
  .about-card,
  .process-step,
  .advantage-card{
    padding:1.5rem;
  }
}
/* =========================
   PROCESS SECTION ENHANCEMENT
========================= */

.nt-process-section{
  position:relative;
}

.process-step{
  height:100%;
  padding:1.8rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  border-radius:1.3rem;
  box-shadow:0 12px 30px rgba(0,0,0,.04);
  transition:all .25s ease;
}

.process-step:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 44px rgba(0,0,0,.08);
  border-color:rgba(215,181,109,.18);
}

/* Highlight del paso clave */
.process-step-highlight{
  background:linear-gradient(180deg, rgba(215,181,109,.08), rgba(215,181,109,.02));
  border-left:2px solid var(--nt-gold);
}

/* Número */
.process-number{
  display:inline-block;
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.12em;
  color:var(--nt-gold);
  margin-bottom:.6rem;
}
/* =========================
   CTA SECTION ENHANCEMENT
========================= */
.cta-box{
  position:relative;
  overflow:hidden;
}

.cta-box::before{
  content:"";
  position:absolute;
  top:-100px;
  right:-100px;
  width:260px;
  height:260px;
  background:radial-gradient(circle, rgba(215,181,109,.12), transparent 70%);
  pointer-events:none;
}

.cta-box::after{
  content:"";
  position:absolute;
  bottom:-120px;
  left:-120px;
  width:280px;
  height:280px;
  background:radial-gradient(circle, rgba(194,29,29,.08), transparent 70%);
  pointer-events:none;
}

.cta-box > *{
  position:relative;
  z-index:2;
}
/* =========================
   CONTACT PAGE ENHANCEMENT
========================= */

.content-card{
  padding:2.5rem;
  border-radius:1.5rem;
  background:#fff;
  border:1px solid rgba(17,17,17,.06);
  box-shadow:0 18px 50px rgba(0,0,0,.06);
}

.form-control,
.form-select{
  border-radius:.9rem;
  border:1px solid rgba(17,17,17,.08);
  padding:.75rem .9rem;
}

.form-control:focus,
.form-select:focus{
  border-color:var(--nt-gold);
  box-shadow:0 0 0 2px rgba(215,181,109,.15);
}