/*
Theme Name: NL Solutions Child
Template: astra
Version: 3.0
Description: NL Soluciones Ambientales — Monterrey
*/

/* ══ FONTS ══ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Outfit:wght@300;400;500;600;700;800;900&display=swap');

/* ══ VARIABLES ══ */
:root{
  --orange:#E85D04;
  --orange2:#F48C06;
  --dark:#1A1A1A;
  --darker:#111111;
  --gray:#5A5A5A;
  --light-gray:#F4F4F4;
  --white:#FFFFFF;
  --radius:14px;
}

/* ══ BASE ══ */
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Outfit',sans-serif;color:var(--dark);overflow-x:hidden;background:#fff;}
img{max-width:100%;display:block;}
a{text-decoration:none;}
h1,h2,h3{font-family:'Bebas Neue',sans-serif;letter-spacing:0.03em;line-height:1.05;}

/* Astra overrides */
.site-header,.ast-header-wrap,.header-main-layout-1{display:none!important;}
.ast-container{padding:0!important;}
.site-content,.entry-content{padding:0!important;margin:0!important;}
.entry-header{display:none!important;}
.hfb-header{display:none!important;}

/* ══ CUSTOM HEADER ══ */
.nl-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(12px);
  border-bottom:2px solid transparent;
  transition:border-color 0.3s,box-shadow 0.3s;
  padding:0 40px;
}
.nl-header.scrolled{
  border-bottom-color:var(--orange);
  box-shadow:0 4px 30px rgba(0,0,0,0.12);
}
.nl-header-inner{
  max-width:1280px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:96px;gap:24px;
}
.nl-logo-link{display:flex;align-items:center;gap:12px;text-decoration:none;}
.nl-logo-img{width:80px;height:80px;object-fit:contain;border-radius:50%;}
.nl-logo-text{display:flex;flex-direction:column;line-height:1.2;}
.nl-logo-main{font-family:'Bebas Neue',sans-serif;font-size:1.55rem;color:var(--dark);letter-spacing:0.05em;}
.nl-logo-sub{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--orange);}
.nl-nav{display:flex;align-items:center;gap:28px;}
.nl-nav a{font-size:0.82rem;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;color:var(--dark);transition:color 0.2s;}
.nl-nav a:hover{color:var(--orange);}
.nl-header-cta{
  background:var(--orange);color:#fff;
  padding:10px 22px;border-radius:8px;
  font-size:0.82rem;font-weight:800;
  text-transform:uppercase;letter-spacing:0.06em;
  transition:all 0.25s;white-space:nowrap;
}
.nl-header-cta:hover{background:var(--orange2);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,93,4,0.35);}
.nl-hamburger{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--dark);}

/* ══ ANIMATIONS ══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(32px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeRight{from{opacity:0;transform:translateX(50px);}to{opacity:1;transform:translateX(0);}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(232,93,4,0.55);}70%{box-shadow:0 0 0 16px rgba(232,93,4,0);}100%{box-shadow:0 0 0 0 rgba(232,93,4,0);}}

.nl-fade-up{opacity:0;animation:fadeUp 0.75s ease forwards;animation-delay:var(--d,0s);}
.nl-fade-right{opacity:0;animation:fadeRight 0.9s ease forwards;animation-delay:var(--d,0s);}
.nl-pulse{animation:pulse 2s infinite;}

.nl-scroll-reveal{opacity:0;transform:translateY(36px);transition:opacity 0.7s ease,transform 0.7s ease;}
.nl-scroll-reveal.nl-in{opacity:1;transform:translateY(0);}

/* ══ BUTTONS ══ */
.nl-btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--orange);color:#fff;
  padding:16px 32px;border-radius:10px;
  font-family:'Outfit',sans-serif;font-weight:800;font-size:1rem;
  text-transform:uppercase;letter-spacing:0.06em;
  transition:all 0.3s;border:none;cursor:pointer;
}
.nl-btn-primary:hover{background:var(--orange2);transform:translateY(-3px);box-shadow:0 12px 32px rgba(232,93,4,0.38);color:#fff;}
.nl-btn-phone{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--dark);
  border:2px solid #ddd;border-radius:10px;
  padding:14px 28px;font-weight:700;font-size:0.95rem;
  transition:all 0.3s;
}
.nl-btn-phone:hover{border-color:var(--orange);color:var(--orange);transform:translateY(-2px);}
.nl-btn-outline-white{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:#fff;
  border:2px solid rgba(255,255,255,0.5);border-radius:10px;
  padding:14px 28px;font-weight:700;font-size:0.95rem;
  transition:all 0.3s;
}
.nl-btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,0.1);transform:translateY(-2px);}
.nl-btn-wa{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  background:#25D366;color:#fff;border:none;border-radius:10px;
  padding:16px;font-family:'Outfit',sans-serif;font-weight:800;font-size:0.95rem;
  text-transform:uppercase;letter-spacing:0.06em;cursor:pointer;
  transition:all 0.3s;margin-top:8px;
}
.nl-btn-wa:hover{background:#20b858;transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,211,102,0.35);}

/* ══ HERO ══ */
.nl-hero{
  padding:140px 60px 80px;
  background:var(--darker);
  position:relative;overflow:hidden;
  min-height:100vh;display:flex;align-items:center;
}
.nl-hero::before{
  content:'';position:absolute;top:-200px;right:-200px;
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,93,4,0.18) 0%,transparent 65%);
  pointer-events:none;
}
.nl-hero::after{
  content:'';position:absolute;bottom:-150px;left:-100px;
  width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,93,4,0.08) 0%,transparent 65%);
  pointer-events:none;
}
.nl-hero-content{
  display:grid;grid-template-columns:1fr 1fr;
  gap:70px;align-items:center;
  max-width:1280px;margin:0 auto;
  width:100%;position:relative;z-index:1;
}
.nl-trust-bar{
  display:flex;gap:20px;flex-wrap:wrap;margin-bottom:24px;
}
.nl-trust-bar span{
  background:rgba(232,93,4,0.15);border:1px solid rgba(232,93,4,0.3);
  color:rgba(255,255,255,0.85);padding:5px 14px;border-radius:100px;
  font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;
}
.nl-hero h1{
  font-size:clamp(3.5rem,7vw,6.5rem)!important;
  color:#fff!important;line-height:0.95!important;
  margin-bottom:24px!important;
}
.nl-hero h1 .hl{color:var(--orange);}
.nl-hero-desc{
  font-size:1.1rem;color:rgba(255,255,255,0.65);
  line-height:1.75;margin-bottom:36px;max-width:480px;
}
.nl-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px;}

/* Hero badges */
.nl-hero-badges{
  display:flex;align-items:center;gap:0;
  border-top:1px solid rgba(255,255,255,0.1);
  padding-top:32px;flex-wrap:wrap;
}
.nl-badge{text-align:center;padding:0 28px;}
.nl-badge-sep{width:1px;height:36px;background:rgba(255,255,255,0.12);}
.nl-badge-num{
  font-family:'Bebas Neue',sans-serif;font-size:2.2rem;
  color:var(--orange);line-height:1;display:inline;
}
.nl-badge.static .nl-badge-num,.nl-badge-num.static{font-size:1.8rem;}
.nl-badge-label{display:block;font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.4);margin-top:4px;}

/* Hero image */
.nl-img-card{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,0.6);transition:transform 0.4s ease;}
.nl-img-card:hover{transform:scale(1.02) rotate(-0.3deg);}
.nl-img-card img{width:100%;object-fit:cover;}
.nl-img-tag-top{
  position:absolute;top:16px;left:16px;
  background:var(--orange);color:#fff;
  padding:7px 14px;border-radius:100px;
  font-size:0.78rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;
  animation:pulse 2.2s infinite;
}
.nl-img-tag-bot{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(transparent,rgba(0,0,0,0.85));
  color:rgba(255,255,255,0.9);
  padding:40px 18px 18px;
  font-size:0.85rem;font-weight:700;letter-spacing:0.06em;text-align:center;
}

/* ══ TRUST STRIP ══ */
.nl-trust-strip{
  background:var(--orange);padding:18px 40px;
}
.nl-trust-strip-inner{
  max-width:1280px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:16px;
}
.nl-trust-item{
  display:flex;align-items:center;gap:8px;
  color:#fff;font-size:0.82rem;font-weight:700;
  text-transform:uppercase;letter-spacing:0.08em;
  white-space:nowrap;
}
.nl-trust-item .icon{font-size:1rem;}

/* ══ SECTION BASE ══ */
.nl-section{padding:100px 60px;}
.nl-dark-section{background:var(--dark);}
.nl-gray-section{background:var(--light-gray);}
.nl-about-section{background:#fff;}

.nl-section-head{text-align:center;margin-bottom:64px;}
.nl-label{
  display:inline-block;
  background:rgba(232,93,4,0.1);color:var(--orange);
  padding:5px 16px;border-radius:100px;
  font-size:0.72rem;font-weight:800;text-transform:uppercase;letter-spacing:0.12em;
  margin-bottom:14px;
}
.nl-dark-section .nl-label{background:rgba(232,93,4,0.2);}
.nl-section-head h2{
  font-size:clamp(2.2rem,4.5vw,3.5rem)!important;
  color:var(--dark);margin-bottom:14px!important;
}
.nl-dark-section .nl-section-head h2,.nl-dark-section h2{color:#fff!important;}
.nl-section-head h2 span,.nl-dark-section h2 span{color:var(--orange);}
.nl-section-head p{color:var(--gray);font-size:1rem;max-width:520px;margin:0 auto;line-height:1.75;}
.nl-dark-section .nl-section-head p{color:rgba(255,255,255,0.55);}

/* ══ TWO COL ══ */
.nl-two-col{
  display:grid;grid-template-columns:1fr 1fr;
  gap:70px;align-items:center;
  max-width:1200px;margin:0 auto;
}

/* ══ TRAILER SECTION ══ */
.nl-trailer-img-wrap{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,0.5);}
.nl-trailer-img-wrap img{width:100%;display:block;transition:transform 0.5s ease;}
.nl-trailer-img-wrap:hover img{transform:scale(1.04);}
.nl-official-seal{
  position:absolute;bottom:20px;left:20px;
  background:rgba(26,26,26,0.9);backdrop-filter:blur(8px);
  border-radius:12px;padding:10px 16px;
  display:flex;align-items:center;gap:10px;
  border:1px solid rgba(232,93,4,0.3);
}
.nl-official-seal img{width:36px;height:36px;object-fit:contain;border-radius:50%;}
.nl-official-seal span{font-size:0.75rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.85);}

.nl-trailer-info h2{color:#fff!important;margin-bottom:16px!important;font-size:clamp(2rem,3.5vw,3rem)!important;}
.nl-trailer-info h2 span{color:var(--orange);}
.nl-trailer-info p{color:rgba(255,255,255,0.65);line-height:1.75;margin-bottom:28px;font-size:0.95rem;}

/* Specs row */
.nl-specs-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px;}
.nl-spec{
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);
  border-radius:10px;padding:14px 10px;text-align:center;
  transition:all 0.3s;cursor:default;
}
.nl-spec:hover{background:rgba(232,93,4,0.18);border-color:rgba(232,93,4,0.5);}
.nl-spec-n{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;color:var(--orange);line-height:1;display:block;}
.nl-spec-l{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.45);display:block;margin-top:3px;}

/* Use tags */
.nl-uses{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px;}
.nl-uses span{
  background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.75);padding:6px 14px;border-radius:100px;
  font-size:0.78rem;font-weight:600;transition:all 0.2s;cursor:default;
}
.nl-uses span:hover{background:rgba(232,93,4,0.2);border-color:var(--orange);color:#fff;}

/* ══ STEPS ══ */
.nl-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;max-width:1100px;margin:0 auto;
  position:relative;
}
.nl-steps::before{
  content:'';position:absolute;top:28px;
  left:calc(12.5% + 28px);right:calc(12.5% + 28px);
  height:3px;background:linear-gradient(to right,var(--orange),var(--orange2));
  border-radius:3px;z-index:0;
}
.nl-step{text-align:center;padding:0 16px 24px;position:relative;z-index:1;}
.nl-step-num{
  width:56px;height:56px;border-radius:50%;
  background:var(--orange);color:#fff;
  font-family:'Bebas Neue',sans-serif;font-size:1.5rem;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;box-shadow:0 4px 20px rgba(232,93,4,0.4);
  transition:transform 0.3s,box-shadow 0.3s;
}
.nl-step:hover .nl-step-num{transform:scale(1.15);box-shadow:0 8px 30px rgba(232,93,4,0.55);}
.nl-step h3{font-size:1rem;font-weight:700;margin-bottom:8px;font-family:'Outfit',sans-serif;}
.nl-step p{font-size:0.85rem;color:var(--gray);line-height:1.65;}

/* ══ SERVICES GRID ══ */
.nl-grid-3{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:22px;max-width:1200px;margin:0 auto;
}
.nl-card{
  background:#fff;border-radius:var(--radius);padding:32px 26px;
  box-shadow:0 4px 24px rgba(0,0,0,0.06);
  border-left:5px solid var(--orange);
  transition:transform 0.35s,box-shadow 0.35s;
  cursor:default;position:relative;
}
.nl-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,0.13);}
.nl-card-icon{
  width:54px;height:54px;background:rgba(232,93,4,0.1);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;
  margin-bottom:18px;transition:transform 0.3s;
}
.nl-card:hover .nl-card-icon{transform:scale(1.1) rotate(-5deg);}
.nl-card h3{font-size:1rem;font-weight:700;margin-bottom:10px;font-family:'Outfit',sans-serif;}
.nl-card p{font-size:0.87rem;color:var(--gray);line-height:1.65;}
.nl-card-tag{
  display:inline-block;margin-top:14px;
  background:rgba(232,93,4,0.1);color:var(--orange);
  padding:4px 12px;border-radius:100px;font-size:0.72rem;font-weight:800;
  text-transform:uppercase;letter-spacing:0.08em;
}

/* ══ NOSOTROS ══ */
.nl-about-text h2{font-size:clamp(2rem,3.5vw,3.2rem)!important;margin-bottom:16px!important;}
.nl-about-text h2 span{color:var(--orange);}
.nl-about-text p{font-size:0.95rem;color:var(--gray);line-height:1.75;margin-bottom:24px;}
.nl-about-list{display:flex;flex-direction:column;gap:14px;}
.nl-about-item{
  display:flex;align-items:flex-start;gap:14px;
  background:var(--light-gray);border-radius:12px;padding:18px;
  transition:transform 0.3s,box-shadow 0.3s;cursor:default;
}
.nl-about-item:hover{transform:translateX(6px);box-shadow:0 4px 20px rgba(0,0,0,0.08);}
.nl-about-icon{
  width:44px;height:44px;min-width:44px;background:rgba(232,93,4,0.1);
  border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;
}
.nl-about-item strong{font-size:0.9rem;font-weight:700;display:block;margin-bottom:3px;}
.nl-about-item p{font-size:0.8rem;color:var(--gray);margin:0;}

.nl-about-visual{display:flex;flex-direction:column;align-items:center;gap:20px;}
/* Truck display in About */
.nl-truck-display{
  position:relative;border-radius:20px;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.18);
  transition:transform 0.4s ease,box-shadow 0.4s ease;
}
.nl-truck-display:hover{transform:scale(1.02);box-shadow:0 30px 80px rgba(0,0,0,0.25);}
.nl-truck-display img{width:100%;display:block;object-fit:cover;}
.nl-truck-badge{
  position:absolute;bottom:16px;left:16px;
  background:rgba(26,26,26,0.88);backdrop-filter:blur(8px);
  border-radius:12px;padding:10px 16px;
  display:flex;align-items:center;gap:10px;
  border:1px solid rgba(232,93,4,0.35);
}
.nl-truck-badge img{width:36px;height:36px;object-fit:contain;border-radius:50%;}
.nl-truck-badge span{font-size:0.75rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.85);}
.nl-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;}
.nl-stat-box{
  background:var(--dark);border-radius:12px;padding:20px;
  text-align:center;transition:transform 0.3s;cursor:default;
}
.nl-stat-box:hover{transform:translateY(-4px);}
.nl-stat-box .n{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--orange);display:inline;}
.nl-stat-box .l{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.4);display:block;margin-top:4px;}

/* ══ CTA SECTION ══ */
.nl-cta-section{
  background:var(--darker);padding:80px 60px;
  position:relative;overflow:hidden;
}
.nl-cta-section::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='1.5' fill='%23E85D04' fill-opacity='0.06'/%3E%3C/svg%3E");
  pointer-events:none;
}
.nl-cta-inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:40px;flex-wrap:wrap;position:relative;z-index:1;
}
.nl-cta-logo{width:120px;height:120px;object-fit:contain;border-radius:50%;flex-shrink:0;}
.nl-cta-inner h2{font-size:clamp(2rem,3.5vw,3rem)!important;color:#fff!important;line-height:1.05!important;}
.nl-cta-inner h2 span{color:var(--orange);}
.nl-cta-inner p{color:rgba(255,255,255,0.5);margin-top:8px;font-size:0.95rem;}
.nl-cta-actions{display:flex;gap:14px;flex-wrap:wrap;}

/* ══ CONTACT ══ */
.nl-contact-layout{
  display:grid;grid-template-columns:1fr 1.4fr;
  gap:50px;max-width:1100px;margin:0 auto;align-items:start;
}
.nl-contact-cards{display:flex;flex-direction:column;gap:14px;}
.nl-contact-card{
  display:flex;align-items:center;gap:16px;
  background:#fff;border-radius:12px;padding:20px;
  box-shadow:0 2px 14px rgba(0,0,0,0.07);
  text-decoration:none;color:var(--dark);
  border-left:4px solid transparent;transition:all 0.3s;
}
.nl-contact-card:hover{border-left-color:var(--orange);transform:translateX(4px);box-shadow:0 8px 28px rgba(0,0,0,0.12);}
.nl-contact-card-icon{
  width:48px;height:48px;min-width:48px;background:rgba(232,93,4,0.1);
  border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;
}
.nl-contact-card strong{font-size:0.72rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--gray);display:block;margin-bottom:3px;}
.nl-contact-card span{font-size:0.95rem;font-weight:600;color:var(--dark);}
.nl-contact-form{background:#fff;border-radius:var(--radius);padding:36px;box-shadow:0 6px 30px rgba(0,0,0,0.09);}
.nl-contact-form h3{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;margin-bottom:6px;letter-spacing:0.04em;}
.nl-contact-form p{font-size:0.85rem;color:var(--gray);margin-bottom:24px;}
.nl-field{margin-bottom:16px;}
.nl-field label{display:block;font-size:0.72rem;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--gray);margin-bottom:7px;}
.nl-field input,.nl-field textarea,.nl-field select{
  width:100%;padding:12px 14px;border:1.5px solid #e4e4e4;
  border-radius:8px;font-family:'Outfit',sans-serif;font-size:0.9rem;
  outline:none;transition:border-color 0.2s,box-shadow 0.2s;background:#fafafa;
}
.nl-field input:focus,.nl-field textarea:focus,.nl-field select:focus{
  border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,93,4,0.1);background:#fff;
}
.nl-field textarea{min-height:100px;resize:vertical;}

/* ══ FOOTER ══ */
.nl-footer{background:var(--darker);color:#fff;padding:72px 60px 32px;}
.nl-footer-inner{
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:48px;max-width:1200px;margin:0 auto 48px;
}
.nl-footer-brand{display:flex;align-items:flex-start;gap:16px;}
.nl-footer-logo{width:80px;height:80px;object-fit:contain;border-radius:50%;flex-shrink:0;}
.nl-footer-name{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:#fff;letter-spacing:0.06em;margin-bottom:10px;line-height:1.1;}
.nl-footer-name span{color:var(--orange);}
.nl-footer-brand p{font-size:0.83rem;color:rgba(255,255,255,0.4);line-height:1.7;}
.nl-footer h4{font-size:0.72rem;font-weight:800;text-transform:uppercase;letter-spacing:0.12em;color:rgba(255,255,255,0.3);margin-bottom:18px;font-family:'Outfit',sans-serif;}
.nl-footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.nl-footer ul li a{color:rgba(255,255,255,0.6);font-size:0.87rem;text-decoration:none;transition:all 0.2s;}
.nl-footer ul li a:hover{color:var(--orange);padding-left:5px;}
.nl-footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding-top:24px;text-align:center;font-size:0.78rem;color:rgba(255,255,255,0.2);max-width:1200px;margin:0 auto;}
.nl-footer-bottom a{color:var(--orange);}

/* ══ WHATSAPP FLOAT ══ */
.nl-wa-float{
  position:fixed;bottom:28px;right:28px;z-index:9999;
  width:64px;height:64px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  font-size:2rem;text-decoration:none;
  box-shadow:0 4px 24px rgba(37,211,102,0.5);
  animation:pulse 2.5s infinite;transition:transform 0.25s;
}
.nl-wa-float:hover{transform:scale(1.12);}

/* ══ RESPONSIVE ══ */
@media(max-width:1100px){
  .nl-hero{padding:100px 40px 70px;}
  .nl-section{padding:80px 40px;}
  .nl-grid-3{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:900px){
  .nl-hero-content{grid-template-columns:1fr;gap:48px;}
  .nl-hero-img{order:-1;}
  .nl-hero h1{font-size:3.5rem!important;}
  .nl-two-col{grid-template-columns:1fr;gap:40px;}
  .nl-trailer-img-wrap{order:-1;}
  .nl-steps{grid-template-columns:1fr 1fr;}
  .nl-steps::before{display:none;}
  .nl-contact-layout{grid-template-columns:1fr;}
  .nl-cta-inner{flex-direction:column;text-align:center;}
  .nl-cta-logo{display:none;}
}
@media(max-width:768px){
  .nl-header{padding:0 20px;}
  .nl-nav{display:none;position:absolute;top:76px;left:0;right:0;background:#fff;flex-direction:column;padding:20px;box-shadow:0 8px 30px rgba(0,0,0,0.15);}
  .nl-nav.open{display:flex;}
  .nl-hamburger{display:block;}
  .nl-hero{padding:100px 24px 60px;min-height:auto;}
  .nl-section{padding:60px 24px;}
  .nl-trust-strip{padding:14px 20px;}
  .nl-trust-strip-inner{justify-content:flex-start;}
  .nl-grid-3{grid-template-columns:1fr;}
  .nl-specs-row{grid-template-columns:1fr 1fr;}
  .nl-steps{grid-template-columns:1fr;}
  .nl-hero-badges{gap:0;}
  .nl-badge{padding:0 16px;}
  .nl-footer{padding:50px 24px 24px;}
  .nl-footer-inner{grid-template-columns:1fr;gap:32px;}
  .nl-footer-brand{flex-direction:column;}
  .nl-about-visual{order:-1;}
  .nl-logo-display{width:150px;height:150px;}
  .nl-logo-display img{width:130px;height:130px;}
}
@media(max-width:480px){
  .nl-hero h1{font-size:2.8rem!important;}
  .nl-hero-actions{flex-direction:column;}
  .nl-btn-primary,.nl-btn-phone{width:100%;justify-content:center;}
  .nl-badge-sep{display:none;}
  .nl-hero-badges{gap:10px;}
}

/* ══ NUESTRA FLOTA ══ */
.nl-flota-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:28px;max-width:1200px;margin:0 auto;
}
.nl-flota-card{
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:20px;overflow:hidden;
  transition:transform 0.35s,box-shadow 0.35s;
}
.nl-flota-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(0,0,0,0.4);}
.nl-flota-img{position:relative;overflow:hidden;}
.nl-flota-img img{width:100%;height:280px;object-fit:cover;display:block;transition:transform 0.5s ease;}
.nl-flota-card:hover .nl-flota-img img{transform:scale(1.05);}
.nl-flota-tag{
  position:absolute;top:16px;left:16px;
  background:var(--orange);color:#fff;
  padding:7px 16px;border-radius:100px;
  font-size:0.78rem;font-weight:800;
  text-transform:uppercase;letter-spacing:0.08em;
  animation:pulse 2.2s infinite;
}
.nl-flota-info{padding:28px;}
.nl-flota-info h3{
  font-family:'Bebas Neue',sans-serif;font-size:1.9rem;
  color:#fff;letter-spacing:0.04em;margin-bottom:10px;
}
.nl-flota-info p{font-size:0.88rem;color:rgba(255,255,255,0.6);line-height:1.7;margin-bottom:18px;}
.nl-flota-specs{
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px;
}
.nl-flota-specs span{
  background:rgba(232,93,4,0.15);border:1px solid rgba(232,93,4,0.3);
  color:rgba(255,255,255,0.8);padding:5px 12px;border-radius:100px;
  font-size:0.76rem;font-weight:700;
}

@media(max-width:768px){
  .nl-flota-grid{grid-template-columns:1fr;}
  .nl-flota-img img{height:220px;}
}

/* ══ BLOG PAGE STYLING ══ */

/* Blog page header */
.blog .site-main, .archive .site-main {
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 40px;
}

/* Blog page title */
.blog .page-title, .archive .page-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 2.5rem !important;
  color: var(--dark) !important;
  margin-bottom: 40px !important;
  padding-bottom: 16px;
  border-bottom: 4px solid var(--orange);
  display: inline-block;
}

/* Posts grid */
.blog .posts-container, .blog #primary,
.archive .posts-container, .archive #primary {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 28px;
}

/* Individual post card */
.blog article, .archive article {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
  border-top: 4px solid var(--orange);
  transition: transform 0.3s, box-shadow 0.3s;
}
.blog article:hover, .archive article:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.14);
}

/* Post thumbnail */
.blog article .post-thumbnail img,
.archive article .post-thumbnail img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

/* Post content area */
.blog article .entry-summary,
.blog article .entry-content,
.archive article .entry-summary,
.archive article .entry-content {
  padding: 24px 26px 28px;
}

/* Category tag */
.blog article .cat-links a,
.archive article .cat-links a {
  background: rgba(232,93,4,0.1);
  color: var(--orange);
  padding: 4px 12px;
  border-radius: 100px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-decoration: none;
  display: inline-block;
  margin-bottom: 10px;
}

/* Post title */
.blog article .entry-title,
.archive article .entry-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1.1rem !important;
  font-weight: 800 !important;
  color: var(--dark) !important;
  line-height: 1.4 !important;
  margin: 0 0 12px !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.blog article .entry-title a,
.archive article .entry-title a {
  color: var(--dark) !important;
  text-decoration: none !important;
}
.blog article .entry-title a:hover,
.archive article .entry-title a:hover {
  color: var(--orange) !important;
}

/* Post excerpt */
.blog article .entry-summary p,
.archive article .entry-summary p {
  font-size: 0.87rem;
  color: var(--gray);
  line-height: 1.7;
  margin-bottom: 18px;
}

/* Read more link */
.blog article .more-link,
.archive article .more-link {
  display: inline-block;
  background: var(--orange);
  color: #fff !important;
  padding: 9px 20px;
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 800;
  text-decoration: none !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: all 0.3s;
}
.blog article .more-link:hover,
.archive article .more-link:hover {
  background: var(--orange2);
  transform: translateY(-2px);
}

/* Post meta date */
.blog article .posted-on,
.archive article .posted-on {
  font-size: 0.75rem;
  color: var(--gray);
  margin-bottom: 8px;
  display: block;
}

/* Blog page hero banner */
.blog .ast-archive-description,
.blog-hero-banner {
  background: var(--dark);
  padding: 60px 40px;
  text-align: center;
  margin-bottom: 50px;
}

/* No posts message */
.blog .no-results, .archive .no-results {
  text-align: center;
  padding: 80px 20px;
  color: var(--gray);
}

/* Astra blog overrides */
.ast-article-post {
  background: #fff !important;
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08) !important;
  border-top: 4px solid var(--orange) !important;
  transition: transform 0.3s, box-shadow 0.3s !important;
  margin-bottom: 0 !important;
}
.ast-article-post:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 48px rgba(0,0,0,0.14) !important;
}
.ast-archive-description { display: none; }
.ast-pagination .page-numbers {
  color: var(--orange) !important;
  border-color: var(--orange) !important;
}
.ast-pagination .page-numbers.current {
  background: var(--orange) !important;
  color: #fff !important;
}

/* Blog page background */
.blog, .archive { background: var(--light-gray, #f4f4f4) !important; }
.blog .ast-container, .archive .ast-container {
  max-width: 1200px !important;
  padding: 50px 40px !important;
}

/* Blog page intro banner */
.blog .ast-archive-description { display: none !important; }

@media(max-width: 768px) {
  .blog .ast-container, .archive .ast-container { padding: 30px 20px !important; }
}

/* ══ CUSTOM BLOG ARCHIVE PAGE ══ */
.nl-blog-page { background: #f4f4f4; min-height: 80vh; }

.nl-blog-page-hero {
  background: var(--dark);
  padding: 80px 40px 70px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.nl-blog-page-hero::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(232,93,4,0.15) 0%, transparent 70%);
  border-radius: 50%;
}
.nl-blog-page-hero-inner { position: relative; z-index: 1; }
.nl-blog-page-hero h1 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(2.5rem, 5vw, 4rem) !important;
  color: #fff !important;
  margin: 10px 0 14px !important;
  line-height: 1.05 !important;
}
.nl-blog-page-hero h1 span { color: var(--orange); }
.nl-blog-page-hero p { color: rgba(255,255,255,0.6); font-size: 1rem; max-width: 500px; margin: 0 auto; }

.nl-blog-grid-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 50px 40px;
}

.nl-blog-posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 28px;
  margin-bottom: 50px;
}

.nl-blog-card {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,0.07);
  border-top: 4px solid var(--orange);
  transition: transform 0.3s, box-shadow 0.3s;
}
.nl-blog-card:hover { transform: translateY(-7px); box-shadow: 0 20px 50px rgba(0,0,0,0.13); }

.nl-blog-card-img img {
  width: 100%; height: 220px;
  object-fit: cover; display: block;
  transition: transform 0.4s ease;
}
.nl-blog-card:hover .nl-blog-card-img img { transform: scale(1.04); }

.nl-blog-card-img-placeholder {
  width: 100%; height: 220px;
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange2) 100%);
  display: flex; align-items: center; justify-content: center;
  font-size: 4rem;
}

.nl-blog-card-body { padding: 24px 26px 28px; }
.nl-blog-card-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.nl-blog-cat a {
  background: rgba(232,93,4,0.1); color: var(--orange);
  padding: 4px 12px; border-radius: 100px;
  font-size: 0.72rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.08em;
  text-decoration: none;
}
.nl-blog-date { font-size: 0.75rem; color: var(--gray); }

.nl-blog-card-title {
  font-family: 'Outfit', sans-serif !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  color: var(--dark) !important;
  line-height: 1.4 !important;
  margin: 0 0 12px !important;
  text-transform: none !important;
}
.nl-blog-card-title a { color: var(--dark) !important; text-decoration: none !important; }
.nl-blog-card-title a:hover { color: var(--orange) !important; }

.nl-blog-card-excerpt { font-size: 0.86rem; color: var(--gray); line-height: 1.7; margin-bottom: 18px; }

.nl-blog-read-more {
  display: inline-block;
  background: var(--orange); color: #fff !important;
  padding: 9px 20px; border-radius: 8px;
  font-size: 0.8rem; font-weight: 800;
  text-decoration: none !important;
  text-transform: uppercase; letter-spacing: 0.06em;
  transition: all 0.3s;
}
.nl-blog-read-more:hover { background: var(--orange2); transform: translateY(-2px); }

.nl-blog-pagination { text-align: center; }
.nl-blog-pagination .page-numbers {
  display: inline-block; padding: 8px 14px;
  margin: 0 4px; border-radius: 8px;
  border: 2px solid #e0e0e0; color: var(--dark);
  text-decoration: none; font-weight: 700; font-size: 0.88rem;
  transition: all 0.2s;
}
.nl-blog-pagination .page-numbers.current,
.nl-blog-pagination .page-numbers:hover {
  background: var(--orange); border-color: var(--orange); color: #fff;
}

@media(max-width: 768px) {
  .nl-blog-posts-grid { grid-template-columns: 1fr; }
  .nl-blog-grid-wrap { padding: 30px 20px; }
  .nl-blog-page-hero { padding: 60px 20px; }
}

/* ══ BLOG GRID FIX ══ */
.nl-blog-page { width: 100% !important; }
.nl-blog-grid-wrap { width: 100% !important; max-width: 1200px !important; margin: 0 auto !important; padding: 50px 40px !important; box-sizing: border-box !important; }
.nl-blog-posts-grid { display: grid !important; grid-template-columns: repeat(3, 1fr) !important; gap: 28px !important; width: 100% !important; }
.nl-blog-card { width: 100% !important; min-width: 0 !important; display: flex !important; flex-direction: column !important; word-break: normal !important; overflow-wrap: normal !important; }
.nl-blog-card-title { word-break: normal !important; overflow-wrap: normal !important; hyphens: none !important; white-space: normal !important; }
.nl-blog-card-body { padding: 20px !important; flex: 1 !important; }
.nl-blog-card-img img { width: 100% !important; height: 200px !important; object-fit: cover !important; display: block !important; }

/* Fix Astra container interfering */
.blog .ast-container, .archive .ast-container { max-width: 100% !important; padding: 0 !important; }
.blog #primary, .archive #primary { width: 100% !important; max-width: 100% !important; padding: 0 !important; float: none !important; }
.blog #content, .archive #content { padding: 0 !important; }
.blog .ast-row, .archive .ast-row { margin: 0 !important; }
.blog .site-content, .archive .site-content { padding: 0 !important; }

@media(max-width: 900px) { .nl-blog-posts-grid { grid-template-columns: repeat(2, 1fr) !important; } }
@media(max-width: 600px) { .nl-blog-posts-grid { grid-template-columns: 1fr !important; } .nl-blog-grid-wrap { padding: 24px 16px !important; } }
