:root{
  --bg:#343430;
  --bg2:#2a2a26;
  --textInv:#f5f7fb;
  --muted:#6b7280;
  --mutedInv:#a8b0bf;
  --accent:#d0a12b; /* mostaza TREKO */
  --line:rgba(255,255,255,.10);
  --line2:rgba(15,17,20,.10);
  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.18);
  --max:1160px;

/* =========================================
   FIX HERO ALTURA - TREKO MOBILE
   ========================================= */


/* MOBILE FIX – elimina bloque gris vacío */
@media (max-width: 768px){

  .hero-full{
    min-height: auto !important;
    height: auto !important;
    padding: 90px 0 40px !important;
  }

  .hero-overlay{
    padding-bottom: 0 !important;
  }

  .hero-center{
    padding-bottom: 0 !important;
  }

  .hero-content{
    margin-bottom: 0 !important;
  }

}

/* Ajuste visual título mobile */
@media (max-width: 768px){
  .hero-title{
    font-size: 28px;
    line-height: 1.2;
  }
}

  --pad:18px;
  --font: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:var(--font);color:#2a2a26;background:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(var(--max), calc(100% - 2*var(--pad))); margin:0 auto}

.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--line2);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{display:flex; flex-direction:column; gap:2px}
.brand-mark{font-weight:800; letter-spacing:.08em; font-size:18px}
.brand-sub{font-size:12px; color:var(--muted)}

.nav{display:flex; align-items:center; gap:14px}
.nav a{font-size:14px; color:#2a2a26; padding:8px 10px; border-radius:10px}
.nav a:hover{background:rgba(208,161,43,.10)}
.btn{display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:12px 16px; border-radius:14px; border:1px solid transparent; font-weight:600; font-size:14px; line-height:1}
.btn-small{padding:10px 12px; border-radius:12px; font-size:13px}
.btn-primary{background:var(--accent); color:#2a2a26; border-color:rgba(0,0,0,.08)}
.btn-primary:hover{filter:brightness(.98)}
.btn-ghost{background:transparent; border-color:rgba(17,17,17,.16)}
.btn-ghost:hover{background:rgba(17,17,17,.04)}
.btn-wa{background:#343430; color:#ffffff; border-color:#2a2a26}
.btn-wa:hover{filter:brightness(1.05)}

.nav-toggle{
  display:none; width:42px; height:42px; border-radius:12px;
  border:1px solid rgba(17,17,17,.14); background:#fff; cursor:pointer;
}
.nav-toggle span{display:block; height:2px; background:#343430; margin:6px 9px; border-radius:2px}

.hero{position:relative; overflow:hidden}
.hero-inner{display:grid; grid-template-columns: 1fr 1fr; gap:22px; padding:44px 0}
.hero-compact .hero-inner{padding:38px 0}
.kicker{display:inline-block; font-weight:800; letter-spacing:.12em; font-size:12px; color:var(--accent)}
.hero h1{margin:10px 0 10px; font-size:44px; line-height:1.05}
.lead{margin:0 0 16px; font-size:16px; color:rgba(17,17,17,.75); max-width:52ch}
.hero-cta{display:flex; gap:10px; flex-wrap:wrap; margin:18px 0}
.hero-bullets{margin:16px 0 0; padding-left:18px; color:rgba(17,17,17,.72)}
.hero-media{position:relative}
.hero-media img{width:100%; height:100%; object-fit:cover; border-radius:var(--radius); box-shadow:var(--shadow)}
.hero-diagonal{
  position:absolute; inset:-40% -40% auto auto;
  width:260px; height:260px; transform:rotate(35deg);
  background:rgba(208,161,43,.18);
  border:1px solid rgba(208,161,43,.20);
  border-radius:26px;
  z-index:0;
}
.hero-media img{position:relative; z-index:1}

.hero-light{background:linear-gradient(180deg,#fff, #fbfbfd)}
.hero-dark{background:linear-gradient(180deg, var(--bg), var(--bg2)); color:var(--textInv)}
.hero-dark .lead{color:var(--mutedInv)}
.hero-dark .hero-bullets{color:var(--mutedInv)}
.hero-dark .btn-ghost{border-color:rgba(255,255,255,.22); color:var(--textInv)}
.hero-dark .btn-ghost:hover{background:rgba(255,255,255,.06)}

.section{padding:52px 0}
.section-alt{background:#fafbfc; border-top:1px solid var(--line2); border-bottom:1px solid var(--line2)}
.section h2{margin:0 0 18px; font-size:28px}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:18px}
.muted{color:var(--muted)}
.small{font-size:12px}

.grid-3{display:grid; grid-template-columns:repeat(3, 1fr); gap:16px}
.grid-4{display:grid; grid-template-columns:repeat(4, 1fr); gap:14px}
.card{
  border:1px solid var(--line2);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:0 12px 26px rgba(0,0,0,.06);
}


.card img{
  width: 100%;
  height: 260px;
  object-fit: cover;
  object-position: center 55%;
  border-radius: 16px 16px 0 0;
}


.card-body{padding:16px}
.card-body h3{margin:0 0 8px}
.card-body p{margin:0 0 14px; color:rgba(17,17,17,.70)}

.caps{display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; margin-top:18px}
.cap{
  border: 1px solid rgba(0,0,0,.08);
  border-radius: var(--radius);
  padding: 16px;
  background: rgba(208,161,43,.10); /* más presente pero suave */
}
.caps .cap:nth-child(2){ background: rgba(122,30,44,.08); }
.caps .cap:nth-child(3){ background: rgba(0,0,0,.045); }
.caps .cap:nth-child(4){ background: rgba(208,161,43,.08); }

.cap h4{margin:0 0 6px; font-size:14px}

.tile{position:relative; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line2); background:#fff}
.tile img{height:180px; width:100%; object-fit:cover}
.tile-label{
  position:absolute; left:12px; bottom:12px;
  background:rgba(15,17,20,.80);
  color:#ffffff; padding:8px 10px; border-radius:12px;
  font-size:12px; font-weight:600;
}

.cta-banner{
  margin-top:22px;
  border:1px solid rgba(208,161,43,.30);
  background:linear-gradient(180deg, rgba(208,161,43,.12), rgba(208,161,43,.05));
  border-radius:22px;
  padding:18px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
}
.cta-banner h3{margin:0 0 6px}
.cta-actions{display:flex; gap:10px; flex-wrap:wrap}

/* Service blocks */
.service-block{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:18px;
  padding:18px;
  border-radius:22px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
  margin-bottom:16px;
}
.hero-dark + .section .service-block{background:rgba(255,255,255,.03)}
.service-media{border-radius:18px; overflow:hidden; aspect-ratio:16/9;}
.service-media img{width:100%; height:100%; min-height:100%; object-fit:cover; border-radius:18px}
.service-copy{display:flex; flex-direction:column}
.service-copy h2{margin:0 0 10px; font-size:22px}
.service-copy p{margin:0 0 12px; color:var(--mutedInv)}
.hero-light + .section .service-copy p{color:rgba(17,17,17,.70)}
.bullets{margin:0; padding-left:18px}
.bullets li{margin:6px 0}
.hero-dark .bullets{color:var(--mutedInv)}
.actions{margin-top:auto; padding-top:14px}

.split{margin-top:16px}
.split-head h2{margin:0 0 8px}
.split-head p{margin:0 0 14px; color:var(--mutedInv)}

.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:12px}
.mini-card{
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}
.mini-card img{height:160px; width:100%; object-fit:cover}
.mini-card-body{padding:14px}
.mini-card-body h3{margin:0 0 8px}
.hero-dark .mini-card-body{color:var(--textInv)}
.hero-dark .mini-card-body .bullets{color:var(--mutedInv)}

/* Contact form */
.form-wrap{display:grid; grid-template-columns:1.2fr .8fr; gap:16px}
.form{
  border:1px solid var(--line2);
  border-radius:22px;
  padding:18px;
  background:#fff;
  box-shadow:0 12px 26px rgba(0,0,0,.06);
}
label{display:flex; flex-direction:column; gap:6px; font-size:13px; font-weight:600}
input, select, textarea{
  font:inherit;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(17,17,17,.14);
  outline:none;
}
input:focus, select:focus, textarea:focus{border-color:rgba(208,161,43,.75); box-shadow:0 0 0 4px rgba(208,161,43,.18)}
textarea{resize:vertical}
.form-actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}

.panel{
  border-radius:22px;
  padding:18px;
  border:1px solid var(--line2);
  background:#fafbfc;
}
.panel h3{margin:0 0 8px}

/* Footer */
.site-footer{background:#2a2a26; color:#fff; padding:28px 0 18px; margin-top:44px}
.footer-inner{display:grid; grid-template-columns:1.2fr 1fr 1.1fr; gap:16px; align-items:start}
.footer-brand{font-weight:800; letter-spacing:.08em}
.footer-links{display:flex; flex-direction:column; gap:8px}
.footer-links a{color:#ffffff; opacity:.9}
.footer-links a:hover{opacity:1}
.footer-contact a{color:#ffffff; text-decoration:underline}
.footer-bottom{margin-top:18px; padding-top:14px; border-top:1px solid rgba(255,255,255,.10)}

/* WhatsApp floating */
.wa-float{
  position:fixed; right:16px; bottom:16px; z-index:60;
  display:flex; align-items:center; gap:10px;
  background:#25D366; color:#ffffff;
  border:1px solid rgba(0,0,0,.10);
  padding:12px 14px; border-radius:999px;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.wa-float-dot{width:10px; height:10px; background:#ffffff; border-radius:50%}
.wa-float-text{font-weight:700; font-size:13px}

/* Responsive */
@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr; padding:34px 0}
  .hero h1{font-size:34px}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr 1fr}
  .caps{grid-template-columns:1fr 1fr}
  .service-block{grid-template-columns:1fr}
  .form-wrap{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .nav{position:fixed; left:14px; right:14px; top:70px; display:none;
       flex-direction:column; gap:8px; padding:12px; background:#fff; border:1px solid var(--line2);
       border-radius:18px; box-shadow:0 18px 50px rgba(0,0,0,.15)}
  .nav a{width:100%}
  .nav .btn{width:100%}
  .nav-toggle{display:block}
  .nav.is-open{display:flex}
}
@media (max-width: 520px){
  .grid-4{grid-template-columns:1fr}
  .caps{grid-template-columns:1fr}
  .wa-float{
  position:fixed; right:16px; bottom:16px; z-index:60;
  display:flex; align-items:center; gap:10px;
  background:#25D366; color:#ffffff;
  border:1px solid rgba(0,0,0,.10);
  padding:12px 14px; border-radius:999px;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
 }
}

  .hero-content h1 { font-size: 32px; }
  .hero-sub { font-size: 16px; }
}
.hero-full {
  position: relative;
  min-height: 100vh;
    background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}

 .hero-overlay {
  position: relative;
width: 100%;
  height: 100%;
  background: linear-gradient(90deg, rgba(0,0,0,.50) 0%, rgba(0,0,0,.25) 45%, rgba(0,0,0,0) 75%);
  display: flex;
  align-items: center;
}

.hero-center {
  display: flex;
  align-items: center;
}

.hero-content {
  max-width: 680px;
  color: #ffffff;
}

.hero-content h1 {
  font-size: 54px;
  line-height: 1.05;
  margin-bottom: 20px;
}

.hero-sub {
  font-size: 18px;
  margin-bottom: 28px;
  opacity: 0.9;
}

@media (max-width: 1024px) {
  .hero-content h1 { font-size: 42px; }
}

@media (max-width: 768px) {
  .hero-full {
    min-height: 85vh;
    background-position: 65% center;
  }
  .hero-content h1 { font-size: 32px; }
  .hero-sub { font-size: 16px; }
}

/* ===== SERVICE LAYOUT TUNING (balance text vs image) ===== */
.service-block{
  grid-template-columns: .75fr 1.25fr !important;
  align-items:start !important;
  gap:16px !important;
  padding:16px !important;
  margin-bottom:14px !important;
}
.service-media{border-radius:18px; overflow:hidden; aspect-ratio:16/9;}
.service-media img{
  max-height:280px !important;
  min-height:180px !important;
  object-fit:cover !important;
}
.service-copy p{margin:0 0 10px !important;}
.service-copy .subline{margin:-2px 0 10px !important; font-size:13px; opacity:.9}
@media (max-width: 980px){
  .service-media{border-radius:18px; overflow:hidden; aspect-ratio:16/9;}
.service-media img{max-height:240px !important; min-height:160px !important;}
}

/* ===== CHIPS ===== */
.chips{display:flex; flex-wrap:wrap; gap:8px; margin:10px 0 12px}
.chip{
  display:inline-flex; align-items:center;
  padding:7px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.01em;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
}
.hero-light + .section .chip{
  border-color:rgba(17,17,17,.14);
  background:rgba(122,30,44,.06);
}
.hero-dark .chip{color:#fff}

/* ===== ACCORDION (details/summary) ===== */
.accordion{
  margin-top:10px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
}
.hero-light + .section .accordion{
  border-color:rgba(17,17,17,.12);
  background:#fff;
}
.accordion details{border-top:1px solid rgba(255,255,255,.10)}
.hero-light + .section .accordion details{border-top:1px solid rgba(17,17,17,.08)}
.accordion details:first-child{border-top:none}
.accordion summary{
  cursor:pointer;
  list-style:none;
  padding:12px 14px;
  font-weight:800;
  font-size:13px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary .acc-icon{
  width:26px; height:26px;
  border-radius:10px;
  display:grid; place-items:center;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
}
.hero-light + .section .accordion summary .acc-icon{
  border-color:rgba(17,17,17,.12);
  background:rgba(122,30,44,.06);
}
.accordion details[open] summary .acc-icon{transform:rotate(180deg)}
.accordion .acc-body{padding:0 14px 14px; color:rgba(255,255,255,.82); font-size:13px}
.hero-light + .section .accordion .acc-body{color:rgba(17,17,17,.72)}
.accordion .acc-body p{margin:10px 0 0}

/* ===== HERO BALANCE (dark sections) ===== */
.hero-dark .hero-copy{max-width:58ch}
.hero-dark .lead{font-size:17px}
.hero-dark .hero-media img{max-height:520px}
@media (max-width: 980px){
  .hero-inner{grid-template-columns:1fr; padding:34px 0}
  .hero-dark .hero-media img{max-height:420px}
}


/* ===== WARM GRAY TEXTURE BACKGROUNDS ===== */
:root{
  --warm-main:#343430;
  --warm-deep:#2a2a26;
  --warm-card:#3a3a35;
  --bordo:#7a1e2c;
}

/* Apply a subtle "grain" texture via layered gradients */
.bg-warm-texture{
  background-color: var(--warm-main);
  background-image:
    radial-gradient(1200px 600px at 20% 10%, rgba(255,255,255,.06), rgba(255,255,255,0) 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,0,0,.16), rgba(0,0,0,0) 60%),
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(0,0,0,.10));
}

/* Use on dark hero + footer + dark sections */
.hero-dark, .site-footer, .section-dark, .band-dark{
  background-color: var(--warm-main);
  background-image:
    radial-gradient(1200px 600px at 20% 10%, rgba(255,255,255,.06), rgba(255,255,255,0) 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,0,0,.16), rgba(0,0,0,0) 60%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.12));
}

/* Cards/panels slightly lighter for separation */
.service-block, .card, .panel, .accordion{
  background: rgba(255,255,255,.035) !important;
  border-color: rgba(255,255,255,.12) !important;
}

/* Optional premium touch: subtle gradient gray -> bordo on hero overlay */
.hero-overlay{
  background: linear-gradient(180deg,
    rgba(52,52,48,0.72) 0%,
    rgba(52,52,48,0.52) 55%,
    rgba(122,30,44,0.28) 100%);
}

@media (max-width: 768px){
  .hero-overlay{
    background: linear-gradient(0deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.25) 60%, rgba(0,0,0,0) 100%);
  }
}

/* ===== HERO POR SECCIÓN ===== */
.hero-home{
  background-image:url('../img/hero-home-institucional-2560x1440.jpg');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}
.hero-logistica{
  background-image:url('../img/hero-logistica-desktop.jpg');
  background-size:cover;
  background-position:70% center;
  background-repeat:no-repeat;
}
.hero-obras{
  background-image:url('../img/hero-obras-desktop.jpg');
  background-size:cover;
  background-position:65% center;
  background-repeat:no-repeat;
}
.hero-alquiler{
  background-image:url('../img/hero-alquiler-desktop.jpg');
  background-size:cover;
  background-position:65% center;
  background-repeat:no-repeat;
}
@media (max-width: 768px){
  .hero-home{ background-position:65% center; }
  .hero-logistica{
    background-image:url('../img/hero-logistica-mobile.jpg');
    background-position:55% center;
  }
  .hero-obras{
    background-image:url('../img/hero-obras-mobile.jpg');
    background-position:center center;
  }
  .hero-alquiler{
    background-image:url('../img/hero-alquiler-mobile.jpg');
    background-position:55% center;
  }
}

/* ===== HOME HERO: diferenciación sutil (institucional) ===== */
.hero-home .hero-overlay{
  background: linear-gradient(90deg, rgba(52,52,48,.52) 0%, rgba(52,52,48,.22) 45%, rgba(52,52,48,0) 75%);
}
.hero-home .hero-overlay::after{
  content:"";
  position:absolute;
  left:-12%;
  bottom:-35%;
  width:55%;
  height:85%;
  background: linear-gradient(135deg, rgba(208,161,43,.18), rgba(208,161,43,0));
  transform: rotate(-10deg);
  pointer-events:none;
}

/* ===== Home: CTA en cards (Servicios) ===== */
.card-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 14px;
  padding: 10px 16px;
  border-radius: 10px;
  background: rgba(0,0,0,.06);
  color: #2b2b2b;
  font-weight: 700;
  text-decoration: none;
  transition: all .22s ease;
}
.card-cta:hover{
  background: rgba(208,161,43,.18);
  color: #2b2b2b;
  transform: translateY(-1px);
}

.card .card-body{
  text-align: left;
}
.card .card-body .card-cta{
  align-self: flex-start;
}

/* ===== Diferenciales: caps con color sutil ===== */
.caps .cap{
  border: 1px solid rgba(0,0,0,.06);
}
.caps .cap:nth-child(1){
  background: rgba(208,161,43,.08);
}
.caps .cap:nth-child(2){
  background: rgba(94,47,55,.07);
}
.caps .cap:nth-child(3){
  background: rgba(0,0,0,.03);
}
.caps .cap:nth-child(4){
  background: rgba(208,161,43,.05);
}

.cta-banner .cta-actions{ justify-content:flex-end; }



/* ===== Ajuste: fondo detrás del título (Hero) ===== */
/* Objetivo: más contraste sin negro; gradiente a gris claro (no blanco) */
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: linear-gradient(90deg,
    rgba(46, 46, 50, 0.68) 0%,
    rgba(46, 46, 50, 0.44) 35%,
    rgba(46, 46, 50, 0.18) 70%,
    rgba(240, 242, 246, 1.00) 100%
  );
}
/* Si ya existe overlay, priorizamos este */
.hero{ position: relative; overflow:hidden; }
.hero > *{ position: relative; z-index: 1; }

/* ===== Contacto: iconos y datos ===== */
.contact-item{ display:flex; gap:14px; align-items:flex-start; }
.contact-icon{
  width:40px; height:40px;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(0,0,0,.06);
  font-size:18px;
}
.contact-label{ font-weight:800; }
.contact-value{ opacity:.92; }



/* ===== Contacto - jerarquía visual ===== */
.contact-hero-info div{
  margin-bottom: 10px;
  line-height: 1.6;
}

.contact-hero-info strong{
  display:block;
  font-weight: 700;
  margin-bottom: 4px;
}

.contact-hero-info{
  margin-top: 14px;
}


/* Contacto: mostrar dirección con misma jerarquía */
.contact-quick div{ line-height: 1.25; }


/* Logo size +15% */
.header-logo img{
  transform: scale(1.15);
}


/* Accesibilidad: reducir animaciones */
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto!}
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1! transition-duration:0.01ms!}
} 

/* =========================================
   MOBILE: ajustar posición logo TREKO
   ========================================= */
@media (max-width: 768px){

  /* Empuja el logo hacia la derecha */
  .site-header .brand{
    margin-left: 16px !important;   /* ajustable */
  }

  /* Opcional: que el header tenga mismo padding lateral que el resto */
  .header-inner{
    padding-left: 5px !important;
    padding-right: 5px !important;
  }

}
/* ===== MOBILE FIXES (V44) ===== */
html, body { max-width: 100%; overflow-x: hidden; }

@media (max-width: 980px){

  .service-block{ grid-template-columns: 1fr !important; }

  /* Menos recorte: contenedor más “alto” (menos panorámico) */
  .service-media{
    width: 100%;
    aspect-ratio: 4 / 3 !important;  /* antes 16/9: recorta más */
    border-radius: 18px;
    overflow: hidden;
  }

  /* Cover pero con foco arriba/centro (corta menos caras/vehículos) */
  .service-media img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 35% !important; /* probá 30%–45% */
    display:block;
  }
}

/* Tight phones */
@media (max-width: 680px){
  .section-head{ display:block !important; }
  .section-head h2{ margin-bottom: 6px !important; }
  .section-head p{ margin-top: 0 !important; }

  .hero-full{ min-height: 78vh; background-position: 60% center; }
  .hero-content{ padding-top: 6px; }
  .hero-content h1{ font-size: 30px !important; line-height: 1.05; }

  .hero-cta{ flex-direction: column; align-items: stretch; }
  .hero-cta .btn{ width: 100%; }

  .grid-4, .caps{ grid-template-columns: 1fr !important; }
}

/* Very small screens */
@media (max-width: 420px){
  .container{ width: calc(100% - 32px) !important; }
  .hero-content h1{ font-size: 28px !important; }
}

/* HERO overlay cálido (árido) */
.hero-overlay{
  background: linear-gradient(
    to bottom,
    rgba(35, 32, 26, 0.72),
    rgba(60, 52, 38, 0.58)
  ) !important;
}

/* contenido por encima del overlay */
.hero-overlay,
.hero-full{
  position: relative !important;
}
.hero-center,
.hero-content{
  position: relative !important;
  z-index: 2 !important;
}
.hero-content *{
  position: relative !
  z-index: 3 !
}

/* =========================
   FIX HEADER TREKO
   ========================= */

/* HEADER sticky animado */
.site-header{
  position: sticky;
  top: 0;
  z-index: 9999;

  background: #ffffff; 
  border-bottom: 1px solid rgba(0,0,0,.10);

  transition: transform .28s ease, opacity .25s ease;
  will-change: transform;
}

/* Estado oculto */
.site-header.is-hidden{
  transform: translateY(-100%);
  opacity: 0;
}