:root{
  --nw-ink:#0f172a;
  --nw-muted:#64748b;
  --nw-soft:#f4f8f6;
  --nw-card:#ffffff;
  --nw-line:#dbe7e2;
  --nw-green:#00704A;
  --nw-green-2:#00a86b;
  --nw-dark:#063f31;
  --nw-radius:26px;
  --nw-shadow:0 22px 55px rgba(15,23,42,.10);
  --nw-shadow-soft:0 12px 30px rgba(15,23,42,.08);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;
  color:var(--nw-ink)!important;
  background:
    radial-gradient(circle at top left, rgba(0,168,107,.10), transparent 32rem),
    linear-gradient(180deg,#ffffff 0%,#f8fbfa 100%);
  overflow-x:hidden;
}
a{color:inherit;}
.container{max-width:1180px;}
/* Header global */
.nw-navbar.navbar{
  background:rgba(255,255,255,.88)!important;
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(219,231,226,.9);
  box-shadow:0 10px 35px rgba(15,23,42,.06)!important;
  padding:.85rem 0;
}
.nw-brand{display:flex;align-items:center;gap:.72rem;font-weight:800!important;color:var(--nw-dark)!important;letter-spacing:-.04em;font-size:1.35rem;}
.nw-brand-mark{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;color:#fff;background:linear-gradient(135deg,var(--nw-green),var(--nw-green-2));box-shadow:0 12px 28px rgba(0,112,74,.25);font-weight:900;letter-spacing:-.05em;}
.nw-navbar .nav-link{font-weight:700!important;font-size:.93rem;color:#334155;padding:.65rem .82rem!important;border-radius:999px;margin-left:.15rem!important;}
.nw-navbar .nav-link:hover,.nw-navbar .nav-link.active{color:var(--nw-green);background:rgba(0,168,107,.09);}
.nw-nav-cta{background:var(--nw-green)!important;color:#fff!important;box-shadow:0 12px 24px rgba(0,112,74,.18);padding:.65rem 1rem!important;}
.nw-nav-cta:hover{background:var(--nw-dark)!important;color:#fff!important;transform:translateY(-1px);}
.navbar-toggler{border:0!important;box-shadow:none!important;}
/* Hero */
body header:not(.nw-footer):not(.navbar){
  position:relative!important;
  isolation:isolate;
  overflow:hidden;
  min-height:480px;
  display:flex;
  align-items:center;
  color:#fff!important;
  text-align:left!important;
  padding:118px 20px!important;
  background-color:#062f27!important;
  background-size:cover!important;
  background-position:center!important;
  background-attachment:scroll!important;
}
body header:not(.nw-footer):not(.navbar)::before{
  content:"";
  position:absolute;inset:0;z-index:-2;
  background:linear-gradient(90deg,rgba(4,38,31,.92) 0%,rgba(4,38,31,.78) 44%,rgba(4,38,31,.42) 100%);
}
body header:not(.nw-footer):not(.navbar)::after{
  content:"";
  position:absolute;z-index:-1;right:-8rem;bottom:-12rem;width:34rem;height:34rem;border-radius:999px;
  background:radial-gradient(circle,rgba(0,168,107,.42),transparent 62%);
  filter:blur(4px);
}
body.page-home header.hero{min-height:560px;padding:130px 20px!important;text-align:left!important;}
body.page-home header.hero::before{background:linear-gradient(90deg,rgba(4,38,31,.90) 0%,rgba(4,38,31,.70) 52%,rgba(4,38,31,.35) 100%)!important;z-index:2!important;}
.hero-img{filter:saturate(1.02) contrast(1.03);}
body.page-diseno-web header{background-image:url('imgsitio/diseno-web.webp')!important;}
body.page-desarrollo-web header{background-image:url('imgsitio/desarrollo-web.webp')!important;}
body.page-tienda-online header{background-image:url('imgsitio/diseno-tienda-virtual.webp')!important;}
body.page-marketing-digital header,body.page-contacto header{background-image:url('imgsitio/marketing.webp')!important;}
header .container{max-width:1120px;position:relative;z-index:3;}
header h1{
  max-width:850px;
  font-size:clamp(2.45rem,5vw,4.75rem)!important;
  line-height:.98!important;
  letter-spacing:-.065em!important;
  font-weight:850!important;
  margin-bottom:1.15rem!important;
  text-wrap:balance;
}
header p, header .lead{
  max-width:720px;
  font-size:clamp(1.05rem,1.7vw,1.28rem)!important;
  line-height:1.7!important;
  color:rgba(255,255,255,.88)!important;
  margin-bottom:1.7rem!important;
}
.btn,.contact-form button{
  border-radius:999px!important;
  font-weight:800!important;
  letter-spacing:-.01em;
  transition:transform .22s ease, box-shadow .22s ease, background-color .22s ease!important;
}
.btn:hover,.contact-form button:hover{transform:translateY(-2px);}
.btn-light,.btn-success,.contact-form button{
  background:linear-gradient(135deg,var(--nw-green),var(--nw-green-2))!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 14px 30px rgba(0,112,74,.28)!important;
  padding:.85rem 1.4rem!important;
}
.btn-light:hover,.btn-success:hover,.contact-form button:hover{background:linear-gradient(135deg,var(--nw-dark),var(--nw-green))!important;color:#fff!important;}
/* Secciones */
main section, body > section{padding:88px 20px!important;}
section:nth-of-type(even){background:rgba(244,248,246,.72);}
section h2{
  color:var(--nw-dark)!important;
  font-weight:850!important;
  letter-spacing:-.045em!important;
  font-size:clamp(2rem,3.2vw,3rem)!important;
  line-height:1.05!important;
  margin-bottom:1.5rem!important;
  text-align:left!important;
  text-wrap:balance;
}
section h2.text-center,.text-center h2{ text-align:center!important;}
section h3{color:var(--nw-dark)!important;font-weight:800!important;letter-spacing:-.025em;font-size:1.18rem!important;}
section p,section li{font-size:1.03rem;line-height:1.76;color:#475569;}
#descripcion .container,#agencia-web .container,#orientacion .container{
  background:rgba(255,255,255,.76);
  border:1px solid var(--nw-line);
  border-radius:var(--nw-radius);
  box-shadow:var(--nw-shadow-soft);
  padding:clamp(1.5rem,4vw,3rem);
}
#descripcion img,.img-fluid.my-4{
  border-radius:24px;
  box-shadow:var(--nw-shadow);
  border:1px solid rgba(255,255,255,.65);
  width:100%;
  object-fit:cover;
  max-height:460px;
}
/* Cards */
.service-card,.plan-card,#proceso .row > div,#faq h3 + p{
  border:1px solid var(--nw-line)!important;
  background:rgba(255,255,255,.92)!important;
  border-radius:var(--nw-radius)!important;
  box-shadow:var(--nw-shadow-soft)!important;
}
.service-card,.plan-card{height:100%;padding:1.5rem!important;text-align:left!important;cursor:default!important;}
.service-card:hover,.plan-card:hover{transform:translateY(-8px)!important;box-shadow:var(--nw-shadow)!important;}
.service-card img,.plan-card img{border-radius:20px;margin-bottom:1rem!important;width:100%;height:160px;object-fit:cover;background:#eef6f2;}
.service-card h3,.plan-card h3,.plan-card h5{font-size:1.22rem!important;color:var(--nw-dark)!important;font-weight:850!important;padding-top:.25rem!important;}
.plan-card .price{font-size:2rem!important;letter-spacing:-.04em;color:var(--nw-green)!important;margin:.65rem 0!important;}
.plan-card ul li{padding:.35rem 0;border-bottom:1px dashed #e2ece8;}
.plan-card ul li:last-child{border-bottom:0;}
#proceso .row > div{padding:1.5rem;margin-bottom:0;position:relative;overflow:hidden;}
#proceso .row > div::before{content:"";display:block;width:44px;height:5px;border-radius:999px;background:linear-gradient(90deg,var(--nw-green),var(--nw-green-2));margin-bottom:1rem;}
/* Listas */
.feature-list{list-style:none!important;padding-left:0!important;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-top:1.5rem;}
.feature-list li{position:relative;padding:1rem 1rem 1rem 3rem;background:#fff;border:1px solid var(--nw-line);border-radius:18px;box-shadow:0 8px 18px rgba(15,23,42,.045);}
.feature-list li::before{content:"✓";position:absolute;left:1rem;top:1rem;width:28px;height:28px;border-radius:999px;display:flex;align-items:center;justify-content:center;background:rgba(0,168,107,.12);color:var(--nw-green);font-weight:900;}
#soluciones ul{list-style:none;padding-left:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin:1.4rem 0;}
#soluciones li{padding:.85rem 1rem;background:#fff;border:1px solid var(--nw-line);border-radius:16px;}
/* FAQ */
#faq .container{max-width:980px;}
#faq h2{text-align:center!important;margin-bottom:2rem!important;}
#faq h3{background:#fff;border:1px solid var(--nw-line);border-radius:20px 20px 0 0;padding:1.15rem 1.3rem;margin:1rem 0 0!important;box-shadow:0 10px 22px rgba(15,23,42,.05);}
#faq h3 + p{border-top:0!important;border-radius:0 0 20px 20px!important;margin:0 0 1rem!important;padding:1.15rem 1.3rem!important;box-shadow:0 10px 22px rgba(15,23,42,.05)!important;}
/* Form */
#contacto .container{max-width:900px;background:linear-gradient(180deg,#fff,rgba(244,248,246,.88));border:1px solid var(--nw-line);border-radius:var(--nw-radius);box-shadow:var(--nw-shadow);padding:clamp(1.5rem,4vw,3rem);}
#contacto h2{text-align:center!important;}
.contact-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-top:1.5rem;}
.contact-form textarea,.contact-form button{grid-column:1/-1;}
.contact-form input,.contact-form textarea{border:1px solid #d6e3de!important;border-radius:18px!important;padding:1rem 1.05rem!important;background:#fff!important;box-shadow:0 8px 18px rgba(15,23,42,.035);outline:none;transition:border-color .2s ease, box-shadow .2s ease!important;}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--nw-green-2)!important;box-shadow:0 0 0 4px rgba(0,168,107,.12)!important;}
.contact-form button{width:max-content;justify-self:center;min-width:220px;}
/* CTA */
#cta.cta-section{background:linear-gradient(135deg,var(--nw-dark),var(--nw-green))!important;color:#fff!important;text-align:center!important;}
#cta h3{font-size:clamp(2rem,3.2vw,3.2rem)!important;font-weight:850!important;letter-spacing:-.055em!important;color:#fff!important;}
#cta p{color:rgba(255,255,255,.82)!important;}
/* Footer */
.nw-footer{background:#052f25!important;color:#dceee8!important;padding:70px 0 28px!important;position:relative;overflow:hidden;}
.nw-footer::before{content:"";position:absolute;right:-8rem;top:-10rem;width:28rem;height:28rem;border-radius:999px;background:rgba(0,168,107,.18);filter:blur(2px);}
.nw-footer h4{color:#fff;font-weight:850;letter-spacing:-.035em;margin-bottom:1rem;}
.nw-footer p,.nw-footer li{color:#c8ded6!important;}
.nw-footer a{color:#eafff8!important;}
.nw-footer a:hover{color:#55e0a8!important;}
.nw-footer .small{font-size:.95rem;line-height:1.7;}
.nw-footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1.3rem;color:#b8d1c8;}
/* WhatsApp */
.whatsapp-float{width:60px!important;height:60px!important;right:22px!important;bottom:22px!important;padding:0!important;border-radius:999px!important;justify-content:center!important;background:#25d366!important;box-shadow:0 18px 35px rgba(37,211,102,.32)!important;}
.whatsapp-float img{width:26px!important;height:26px!important;}
/* Reveal */
[data-animate]{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease;}
[data-animate].active{opacity:1;transform:none;}
@media (max-width:991px){
  .nw-navbar .navbar-collapse{padding-top:1rem;}
  .nw-navbar .nav-link{margin:.15rem 0!important;}
  body header:not(.navbar){min-height:420px;text-align:center!important;padding:92px 20px!important;}
  header h1,header p,header .lead{margin-left:auto;margin-right:auto;}
  .feature-list,#soluciones ul,.contact-form{grid-template-columns:1fr;}
}
@media (max-width:575px){
  main section, body > section{padding:64px 16px!important;}
  .nw-brand{font-size:1.18rem;}
  .nw-brand-mark{width:36px;height:36px;border-radius:12px;}
  body header:not(.navbar){min-height:390px;}
  header h1{font-size:2.35rem!important;}
  section h2{font-size:2rem!important;}
  .service-card img{height:190px;}
  .whatsapp-float{width:56px!important;height:56px!important;right:16px!important;bottom:16px!important;}
}

/* ==== Fase 4 visual premium ==== */
.nw-kicker{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem .8rem;border-radius:999px;
  background:rgba(0,168,107,.10);color:var(--nw-green);
  font-size:.8rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
}
.nw-kicker::before{content:"";width:8px;height:8px;border-radius:999px;background:var(--nw-green-2);box-shadow:0 0 0 6px rgba(0,168,107,.10);}
.nw-section-heading{max-width:760px;margin:0 auto 2rem;}
.nw-section-heading h2{margin-top:1rem!important;}
.nw-section-intro{font-size:1.05rem;line-height:1.8;color:#5b6b66;}

.nw-trust-strip{padding:26px 20px 16px!important;background:linear-gradient(180deg,rgba(4,38,31,.06),rgba(4,38,31,0))!important;}
.nw-trust-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;}
.nw-mini-stat{background:#fff;border:1px solid var(--nw-line);border-radius:18px;padding:1rem 1.2rem;box-shadow:0 10px 24px rgba(15,23,42,.05);}
.nw-mini-stat strong{display:block;font-size:1.05rem;color:var(--nw-dark);font-weight:850;letter-spacing:-.03em;}
.nw-mini-stat span{display:block;margin-top:.3rem;color:#62726e;font-size:.96rem;line-height:1.55;}

.nw-icon-section{padding-top:20px!important;padding-bottom:22px!important;background:transparent!important;}
.nw-icon-card,.nw-contact-card,.nw-testimonial-card{
  height:100%;padding:1.5rem;border-radius:24px;background:rgba(255,255,255,.94);border:1px solid var(--nw-line);box-shadow:var(--nw-shadow-soft);
}
.nw-icon-wrap{
  width:58px;height:58px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,rgba(0,168,107,.16),rgba(0,112,74,.06));color:var(--nw-green);margin-bottom:1rem;
}
.nw-icon-wrap svg{width:28px;height:28px;display:block;}
.nw-icon-card h3,.nw-contact-card h3,.nw-testimonial-card strong{font-size:1.16rem!important;font-weight:850!important;letter-spacing:-.02em;}
.nw-icon-card p,.nw-contact-card p,.nw-testimonial-card p{margin-bottom:0;color:#5b6b66;line-height:1.72;}
.nw-contact-card a{color:var(--nw-dark);font-weight:700;}

.nw-showcase-section{background:linear-gradient(180deg,rgba(244,248,246,.75),rgba(255,255,255,.75))!important;}
.nw-portfolio-card{height:100%;overflow:hidden;background:#fff;border-radius:28px;border:1px solid var(--nw-line);box-shadow:var(--nw-shadow-soft);}
.nw-portfolio-card img{display:block;width:100%;height:230px;object-fit:cover;}
.nw-portfolio-body{padding:1.35rem 1.35rem 1.5rem;}
.nw-chip{display:inline-flex;padding:.35rem .75rem;border-radius:999px;background:rgba(15,23,42,.06);color:#334155;font-size:.82rem;font-weight:700;margin-bottom:.85rem;}
.nw-portfolio-body h3{font-size:1.24rem!important;line-height:1.18;color:var(--nw-dark)!important;font-weight:850!important;}

.nw-clients-section{padding-top:44px!important;}
.nw-logo-cloud{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:1.3rem;}
.nw-logo-cloud span{padding:.9rem 1.1rem;background:#fff;border:1px solid var(--nw-line);border-radius:18px;box-shadow:0 10px 22px rgba(15,23,42,.05);font-weight:800;color:#48625a;min-width:130px;text-align:center;}

.nw-testimonials-section{background:linear-gradient(180deg,rgba(255,255,255,.8),rgba(244,248,246,.9))!important;}
.nw-stars{display:flex;gap:.2rem;color:#f7b500;margin-bottom:.85rem;}
.nw-stars span{width:18px;height:18px;display:inline-flex;}
.nw-stars svg{width:18px;height:18px;display:block;}

.nw-media-section{padding-top:26px!important;}
.nw-media-card{display:grid;grid-template-columns:1.08fr .92fr;align-items:center;gap:1.6rem;background:linear-gradient(180deg,#fff,rgba(246,250,248,.88));border:1px solid var(--nw-line);border-radius:32px;box-shadow:var(--nw-shadow);padding:clamp(1.3rem,3.8vw,2.3rem);}
.nw-media-copy h2{text-align:left!important;margin-top:1rem!important;}
.nw-media-image img{width:100%;height:100%;min-height:320px;max-height:420px;object-fit:cover;border-radius:24px;box-shadow:0 16px 30px rgba(15,23,42,.12);}
.nw-check-list{list-style:none;padding-left:0;margin:1.25rem 0 0;display:grid;gap:.8rem;}
.nw-check-list li{position:relative;padding-left:2rem;color:#50615c;}
.nw-check-list li::before{content:"";position:absolute;left:0;top:.25rem;width:1.2rem;height:1.2rem;border-radius:999px;background:linear-gradient(135deg,var(--nw-green),var(--nw-green-2));box-shadow:0 0 0 6px rgba(0,168,107,.12);}
.nw-check-list li::after{content:"";position:absolute;left:.37rem;top:.57rem;width:.45rem;height:.22rem;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg);}

.nw-contact-cards{padding-top:30px!important;padding-bottom:20px!important;background:transparent!important;}

/* Header premium extras */
body.page-home .hero .lead{max-width:640px;}
body.page-home .hero .btn{margin-right:.75rem;}
body.page-home .hero .nw-hero-badges{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.5rem;}
body.page-home .hero .nw-hero-badges span{display:inline-flex;align-items:center;gap:.45rem;padding:.62rem .85rem;border-radius:999px;background:rgba(255,255,255,.11);color:#fff;font-weight:700;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(5px);}
body.page-home .hero .nw-hero-badges svg{width:16px;height:16px;}

/* Footer premium */
.nw-footer-grid-badges{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem;}
.nw-footer-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .78rem;border-radius:999px;background:rgba(255,255,255,.08);font-size:.86rem;color:#e8f6f1;}
.nw-footer-badge svg{width:15px;height:15px;}

@media (max-width:991px){
  .nw-trust-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .nw-media-card{grid-template-columns:1fr;}
  body.page-home .hero .container::after{display:none;}
}
@media (max-width:575px){
  .nw-trust-grid{grid-template-columns:1fr;}
  .nw-portfolio-card img{height:200px;}
  .nw-logo-cloud span{min-width:unset;flex:1 1 calc(50% - .5rem);}
  body.page-home .hero .nw-hero-badges{justify-content:center;}
}

/* ==== Fase 5 comercial premium ==== */
.nw-results-section{padding-top:10px!important;padding-bottom:18px!important;background:transparent!important;}
.nw-result-card,.nw-case-card,.nw-compare-card,.nw-example-card,.nw-step-card{
  height:100%;background:rgba(255,255,255,.95);border:1px solid var(--nw-line);border-radius:28px;box-shadow:var(--nw-shadow-soft);
}
.nw-result-card{padding:1.5rem;}
.nw-result-card h3{font-size:1.18rem!important;font-weight:850!important;color:var(--nw-dark)!important;}
.nw-result-card p{margin-bottom:0;color:#5b6b66;line-height:1.72;}

.nw-case-section{background:linear-gradient(180deg,rgba(244,248,246,.78),rgba(255,255,255,.88))!important;}
.nw-case-card,.nw-example-card{overflow:hidden;}
.nw-case-card img,.nw-example-card img{width:100%;height:220px;object-fit:cover;display:block;}
.nw-case-body,.nw-example-body{padding:1.35rem 1.35rem 1.5rem;}
.nw-case-body h3,.nw-example-body h3{font-size:1.2rem!important;line-height:1.2;color:var(--nw-dark)!important;font-weight:850!important;}
.nw-case-body ul{list-style:none;padding-left:0;margin:1rem 0 0;display:grid;gap:.7rem;}
.nw-case-body li{padding:.8rem .9rem;border-radius:16px;background:#f7faf8;color:#566763;line-height:1.65;}
.nw-case-body strong{color:var(--nw-dark);}

.nw-compare-section{background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(244,248,246,.88))!important;}
.nw-compare-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.2rem;max-width:980px;margin:0 auto;}
.nw-compare-card{padding:1.6rem;}
.nw-compare-card h3{font-size:1.28rem!important;color:var(--nw-dark)!important;font-weight:850!important;}
.nw-compare-card ul{list-style:none;padding-left:0;margin:1rem 0 0;display:grid;gap:.75rem;}
.nw-compare-card li{position:relative;padding-left:1.5rem;color:#5b6b66;line-height:1.65;}
.nw-compare-card li::before{content:"•";position:absolute;left:0;top:0;color:var(--nw-green);font-weight:900;}
.nw-compare-label{display:inline-flex;padding:.38rem .76rem;border-radius:999px;background:#eef6f2;color:#466157;font-size:.84rem;font-weight:800;margin-bottom:1rem;}
.nw-compare-card-featured{background:linear-gradient(180deg,#093f31,#0a5a44)!important;border-color:rgba(255,255,255,.08)!important;box-shadow:0 22px 40px rgba(0,0,0,.18)!important;}
.nw-compare-card-featured .nw-compare-label{background:rgba(255,255,255,.12);color:#fff;}
.nw-compare-card-featured h3,.nw-compare-card-featured li{color:#f4fffb!important;}
.nw-compare-card-featured li::before{color:#5bf2b6;}

.nw-final-cta-section{padding-top:24px!important;padding-bottom:24px!important;background:transparent!important;}
.nw-final-cta-card{display:grid;grid-template-columns:1.2fr auto;align-items:center;gap:1.4rem;padding:2rem;border-radius:32px;background:linear-gradient(135deg,#072f25,#0b5f47);box-shadow:0 26px 50px rgba(0,0,0,.18);}
.nw-final-cta-card h2{margin-top:1rem!important;margin-bottom:1rem!important;color:#fff!important;text-align:left!important;}
.nw-final-cta-card p{margin-bottom:0;color:rgba(255,255,255,.84)!important;max-width:760px;}
.nw-final-cta-actions{display:flex;flex-direction:column;gap:.8rem;min-width:250px;}
.nw-final-cta-actions .btn{width:100%;justify-content:center;}
.nw-final-cta-actions .btn-outline-success{border:1px solid rgba(255,255,255,.24)!important;color:#fff!important;background:rgba(255,255,255,.06)!important;}
.nw-final-cta-actions .btn-outline-success:hover{background:rgba(255,255,255,.12)!important;color:#fff!important;}

.nw-service-examples{padding-top:28px!important;}
.nw-example-body p{margin-bottom:0;color:#5b6b66;line-height:1.72;}

.nw-contact-steps{padding-top:20px!important;padding-bottom:16px!important;background:transparent!important;}
.nw-step-card{padding:1.45rem;position:relative;overflow:hidden;}
.nw-step-card strong{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:18px;background:linear-gradient(145deg,rgba(0,168,107,.14),rgba(0,112,74,.06));color:var(--nw-green);font-size:1.15rem;font-weight:900;margin-bottom:1rem;}
.nw-step-card h3{font-size:1.12rem!important;font-weight:850!important;color:var(--nw-dark)!important;}
.nw-step-card p{margin-bottom:0;color:#5b6b66;line-height:1.72;}

/* home service cards stronger */
body.page-home #servicios .service-card{padding:1.2rem 1.2rem 1.35rem!important;}
body.page-home #servicios .service-card p{min-height:84px;}
body.page-home #servicios .service-card::after{
  content:"Ver servicio";display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;padding:.55rem .9rem;border-radius:999px;
  background:#eef6f2;color:var(--nw-dark);font-weight:800;font-size:.9rem;
}

@media (max-width:991px){
  .nw-compare-grid{grid-template-columns:1fr;}
  .nw-final-cta-card{grid-template-columns:1fr;}
  .nw-final-cta-actions{min-width:unset;flex-direction:row;flex-wrap:wrap;}
  .nw-final-cta-actions .btn{width:auto;flex:1 1 220px;}
}
@media (max-width:575px){
  .nw-case-card img,.nw-example-card img{height:200px;}
  .nw-final-cta-card{padding:1.35rem;}
  .nw-final-cta-actions{flex-direction:column;}
  body.page-home #servicios .service-card p{min-height:unset;}
}

/* ==== Fase 6 UX, portafolio y conversión ==== */
body.page-portafolio header{background-image:url('imgsitio/diseno-webb.webp')!important;}
body.page-portafolio .nw-portfolio-intro{padding-bottom:18px!important;}
.nw-portfolio-grid-section{padding-top:28px!important;background:linear-gradient(180deg,rgba(244,248,246,.72),rgba(255,255,255,.9))!important;}
.nw-case-card-large img{height:255px;}
.nw-case-card-large .nw-case-body p{color:#5b6b66;line-height:1.72;margin-bottom:1rem;}
.nw-testimonial-card-rich{position:relative;overflow:hidden;}
.nw-testimonial-card-rich::after{content:"";position:absolute;right:-55px;bottom:-55px;width:140px;height:140px;border-radius:999px;background:rgba(0,168,107,.08);}
.nw-person{margin-top:1.1rem;padding-top:1rem;border-top:1px solid var(--nw-line);position:relative;z-index:1;}
.nw-person strong{display:block;color:var(--nw-dark)!important;font-size:1.02rem!important;}
.nw-person span{display:block;color:#64756f;font-size:.94rem;margin-top:.18rem;}
.contact-form select{
  border:1px solid #d6e3de!important;border-radius:18px!important;padding:1rem 1.05rem!important;background:#fff!important;
  box-shadow:0 8px 18px rgba(15,23,42,.035);outline:none;transition:border-color .2s ease, box-shadow .2s ease!important;width:100%;
}
.contact-form select:focus{border-color:var(--nw-green-2)!important;box-shadow:0 0 0 4px rgba(0,168,107,.12)!important;}
.nw-form-note{max-width:720px;margin:-.6rem auto 1.3rem;text-align:center;color:#60726b;}
.nw-nav-cta{white-space:nowrap;}
@media (max-width:575px){.nw-case-card-large img{height:210px;}}

/* ==== Fase 7 producción ==== */
.nw-hp-field{
  position:absolute!important;
  left:-9999px!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.contact-form select{
  margin-bottom:15px;
  border-radius:18px!important;
  border:1px solid #d6e3de!important;
  padding:1rem 1.05rem!important;
  width:100%;
  background:#fff!important;
  color:#475569;
  box-shadow:0 8px 18px rgba(15,23,42,.035);
  outline:none;
}
.contact-form select:focus{
  border-color:var(--nw-green-2)!important;
  box-shadow:0 0 0 4px rgba(0,168,107,.12)!important;
}
.nw-form-helper{
  grid-column:1/-1;
  text-align:center;
  margin:.2rem 0 .4rem!important;
  font-size:.95rem!important;
  color:#5b6b66!important;
}
.nw-state-page{background:linear-gradient(180deg,#f5faf7,#fff);}
.nw-state-hero{padding:110px 20px!important;min-height:560px;display:flex;align-items:center;background:radial-gradient(circle at top right,rgba(0,168,107,.16),transparent 34%),linear-gradient(180deg,#f5faf7,#fff)!important;}
.nw-state-card{max-width:840px;margin:0 auto;text-align:center;background:#fff;border:1px solid var(--nw-line);border-radius:34px;box-shadow:var(--nw-shadow);padding:clamp(1.6rem,5vw,3.2rem);}
.nw-state-card .nw-icon-wrap{margin-bottom:1.3rem;}
.nw-state-card h1{font-size:clamp(2rem,4vw,3.7rem);font-weight:900;letter-spacing:-.06em;line-height:1.02;color:var(--nw-dark);margin-bottom:1rem;}
.nw-state-card p{max-width:680px;margin:0 auto 1.6rem;color:#5b6b66;font-size:1.08rem;line-height:1.75;}
.nw-state-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;}
.nw-state-actions .btn-outline-success{border:1px solid rgba(0,112,74,.25)!important;color:var(--nw-dark)!important;background:#fff!important;box-shadow:none!important;}
.nw-state-actions .btn-outline-success:hover{background:#eef6f2!important;color:var(--nw-dark)!important;}
@media (max-width:575px){
  .nw-state-actions{flex-direction:column;}
  .nw-state-actions .btn{width:100%;}
}

/* ==== Fase 8 UX/UI polish final ==== */
:root{
  --nw-section-gap:clamp(4rem,7vw,6.5rem);
  --nw-card-radius:28px;
  --nw-focus:0 0 0 4px rgba(0,168,107,.16);
}
body{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;height:auto;}
.nw-navbar.navbar{padding:.72rem 0!important;z-index:1040;}
.nw-navbar .container{gap:1rem;}
.nw-navbar .navbar-nav{gap:.08rem;}
.nw-navbar .nav-link{font-size:.88rem!important;padding:.58rem .68rem!important;line-height:1.2;}
.nw-brand{font-size:1.25rem!important;flex-shrink:0;}
.nw-nav-cta{padding:.66rem .9rem!important;}
@media (min-width:992px) and (max-width:1199px){
  .nw-navbar .container{max-width:100%;padding-left:1.1rem;padding-right:1.1rem;}
  .nw-navbar .nav-link{font-size:.82rem!important;padding:.54rem .52rem!important;}
  .nw-brand{font-size:1.14rem!important;}
  .nw-brand-mark{width:36px;height:36px;border-radius:12px;}
}
body header:not(.nw-footer):not(.navbar){min-height:clamp(420px,56vw,620px);padding:clamp(5.4rem,9vw,8.4rem) 20px!important;}
body header:not(.nw-footer):not(.navbar)::before{background:linear-gradient(90deg,rgba(3,35,28,.93) 0%,rgba(3,35,28,.78) 48%,rgba(3,35,28,.35) 100%);}
header h1{max-width:900px;letter-spacing:-.055em!important;}
header p,header .lead{max-width:700px;}
body.page-home .hero .container{padding-top:.5rem;padding-bottom:.5rem;}
.btn-outline-light{border:1px solid rgba(255,255,255,.34)!important;background:rgba(255,255,255,.08)!important;color:#fff!important;backdrop-filter:blur(8px);box-shadow:none!important;}
.btn-outline-light:hover{background:rgba(255,255,255,.16)!important;color:#fff!important;}
main section, body > section{padding-top:var(--nw-section-gap)!important;padding-bottom:var(--nw-section-gap)!important;}
.nw-trust-strip,.nw-results-section,.nw-icon-section,.nw-contact-cards,.nw-contact-steps{padding-top:clamp(1.2rem,3vw,2rem)!important;padding-bottom:clamp(1.2rem,3vw,2rem)!important;}
.nw-section-heading{margin-bottom:clamp(2rem,4vw,3rem)!important;}
.nw-section-heading h2,section h2{max-width:920px;}
.text-center h2,section h2.text-center{margin-left:auto!important;margin-right:auto!important;}
.nw-section-intro{max-width:760px;margin-left:auto;margin-right:auto;}
.service-card,.plan-card,.nw-icon-card,.nw-result-card,.nw-case-card,.nw-example-card,.nw-portfolio-card,.nw-testimonial-card,.nw-contact-card,.nw-step-card,.nw-compare-card{
  transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease!important;
}
.service-card:hover,.plan-card:hover,.nw-icon-card:hover,.nw-result-card:hover,.nw-case-card:hover,.nw-example-card:hover,.nw-portfolio-card:hover,.nw-contact-card:hover,.nw-step-card:hover{
  transform:translateY(-6px)!important;box-shadow:0 24px 50px rgba(15,23,42,.12)!important;border-color:rgba(0,168,107,.22)!important;
}
body.page-home #servicios .service-card::after{display:none!important;content:none!important;}
.nw-card-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:auto;padding:.6rem .95rem;border-radius:999px;background:#eef7f2;color:var(--nw-dark)!important;font-weight:850;font-size:.92rem;text-decoration:none!important;}
.nw-card-link::after{content:"→";transition:transform .18s ease;}
.nw-card-link:hover{background:rgba(0,168,107,.14);color:var(--nw-green)!important;}
.nw-card-link:hover::after{transform:translateX(3px);}
body.page-home #servicios .service-card{display:flex;flex-direction:column;}
body.page-home #servicios .service-card p{min-height:unset!important;}
.service-card img,.plan-card img,.nw-case-card img,.nw-example-card img,.nw-portfolio-card img{filter:saturate(1.03) contrast(1.02);}
#descripcion .container,#agencia-web .container,#orientacion .container,#contacto .container{border-radius:34px!important;}
#descripcion .container,#agencia-web .container,#orientacion .container{max-width:1080px;}
.feature-list{align-items:stretch;}
.feature-list li{min-height:86px;display:flex;align-items:flex-start;}
#faq h3{font-size:1.08rem!important;line-height:1.35;}
#faq h3 + p{line-height:1.75!important;}
#contacto .container{max-width:960px!important;position:relative;overflow:hidden;}
#contacto .container::before{content:"";position:absolute;right:-5rem;top:-5rem;width:15rem;height:15rem;border-radius:999px;background:rgba(0,168,107,.08);pointer-events:none;}
#contacto h2,#contacto p,#contacto form{position:relative;z-index:1;}
.contact-form{gap:1rem 1.1rem!important;}
.contact-form input,.contact-form select,.contact-form textarea{font-size:1rem!important;min-height:56px;}
.contact-form textarea{min-height:150px;resize:vertical;}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#7b8e88;}
.contact-form button{min-width:min(100%,320px)!important;justify-self:center!important;}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{box-shadow:var(--nw-focus)!important;}
.nw-form-note{font-size:1rem!important;line-height:1.7;margin-top:-.2rem!important;}
.nw-form-helper{max-width:680px;justify-self:center;line-height:1.6;}
.nw-footer{padding-top:clamp(3rem,5vw,4.5rem)!important;}
.nw-footer .btn{margin-bottom:.4rem;}
.nw-footer-bottom{align-items:center;}
.whatsapp-float{z-index:1050!important;}
body.page-portafolio .nw-case-card-large img{height:260px;}
body.page-portafolio .nw-case-card-large .nw-case-body{padding:1.45rem;}
body.page-portafolio .nw-case-card-large h3{font-size:1.28rem!important;}
.nw-state-card{border-radius:34px!important;}
@media (max-width:991px){
  .nw-navbar .navbar-collapse{background:#fff;border:1px solid var(--nw-line);border-radius:22px;box-shadow:var(--nw-shadow-soft);padding:1rem;margin-top:.85rem;}
  .nw-navbar .nav-link{font-size:.96rem!important;padding:.78rem .9rem!important;border-radius:14px;}
  .nw-navbar .nav-item{width:100%;}
  .nw-nav-cta{text-align:center;margin-top:.35rem;}
  body header:not(.nw-footer):not(.navbar){text-align:center!important;}
  header h1,header p,header .lead{margin-left:auto;margin-right:auto;}
  .feature-list{grid-template-columns:1fr!important;}
  .contact-form{grid-template-columns:1fr!important;}
}
@media (max-width:575px){
  .container{padding-left:1rem!important;padding-right:1rem!important;}
  main section,body > section{padding-top:3.6rem!important;padding-bottom:3.6rem!important;}
  header h1{font-size:clamp(2.25rem,12vw,3.05rem)!important;line-height:1.04!important;}
  header p,header .lead{font-size:1rem!important;line-height:1.65!important;}
  .btn{width:100%;justify-content:center;margin-right:0!important;}
  body.page-home .hero .nw-hero-badges span{width:100%;justify-content:center;}
  .nw-trust-grid,.row.g-4{row-gap:1rem!important;}
  .service-card,.plan-card,.nw-icon-card,.nw-result-card,.nw-case-card,.nw-example-card,.nw-portfolio-card,.nw-testimonial-card,.nw-contact-card,.nw-step-card,.nw-compare-card{border-radius:22px!important;}
  #descripcion .container,#agencia-web .container,#orientacion .container,#contacto .container{border-radius:24px!important;}
  .contact-form button{width:100%;}
  .nw-footer{text-align:left;}
}


/* ==== Fase 9 publicación y privacidad ==== */
.nw-privacy-check{grid-column:1/-1;display:flex;align-items:flex-start;gap:.65rem;margin:.2rem 0 .4rem;padding:1rem;border:1px solid var(--nw-line);border-radius:18px;background:#fff;color:#53645f;font-size:.95rem;line-height:1.55;box-shadow:0 8px 18px rgba(15,23,42,.035);}
.nw-privacy-check input{width:18px!important;height:18px!important;margin-top:.2rem;flex:0 0 auto;accent-color:var(--nw-green);}
.nw-privacy-check a{color:var(--nw-green);font-weight:800;text-decoration:underline;text-underline-offset:3px;}
.nw-legal-section{background:linear-gradient(180deg,rgba(244,248,246,.72),rgba(255,255,255,.9))!important;}
.nw-legal-card{max-width:980px;margin:0 auto;background:#fff;border:1px solid var(--nw-line);border-radius:28px;box-shadow:var(--nw-shadow-soft);padding:clamp(1.4rem,4vw,3rem);}
.nw-legal-card h2{font-size:clamp(1.25rem,2vw,1.65rem)!important;text-align:left!important;margin:2rem 0 .75rem!important;color:var(--nw-dark)!important;}
.nw-legal-card p{color:#53645f;line-height:1.8;}
.nw-legal-card a{color:var(--nw-green);font-weight:800;}
.nw-legal-note{margin-top:2rem;padding:1rem 1.15rem;border-radius:18px;background:#f4f8f6;border:1px solid var(--nw-line);font-size:.95rem;}
@media (max-width:575px){.nw-privacy-check{font-size:.9rem;padding:.85rem}.nw-legal-card{border-radius:22px}}

/* ==== Corrección global alineación menú ==== */
@media (min-width: 992px) {
  .nw-navbar.navbar {
    min-height: 72px;
  }
  .nw-navbar > .container {
    display: flex;
    align-items: center;
  }
  .nw-navbar .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
    flex-direction: row-reverse;
    align-items: center;
  }
  .nw-navbar .navbar-nav {
    align-items: center !important;
  }
}

/* ==== Ajuste global solicitado: containers a 1180px ==== */
.container,
header .container,
body header .container,
.nw-navbar .container,
.nw-footer .container,
#descripcion .container,
#agencia-web .container,
#orientacion .container,
#faq .container,
#contacto .container,
.nw-trust-strip .container,
.nw-icon-section .container,
.nw-showcase-section .container,
.nw-clients-section .container,
.nw-testimonials-section .container,
.nw-media-section .container,
.nw-contact-cards .container,
.nw-results-section .container,
.nw-case-section .container,
.nw-compare-section .container,
.nw-final-cta-section .container,
.nw-service-examples .container,
.nw-contact-steps .container {
  max-width: 1180px !important;
}

@media (max-width: 991px) {
  .container,
  header .container,
  body header .container,
  .nw-navbar .container,
  .nw-footer .container,
  #descripcion .container,
  #agencia-web .container,
  #orientacion .container,
  #faq .container,
  #contacto .container {
    max-width: 100% !important;
  }
}
