:root{
  --brand-orange:#f5821f;
  /* --brand-ebony:#302926; */
  --text:#ffffff;
  --muted:#6c757d;
  --concrete:#1b1b1b;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial;color:var(--text);margin:0}
h1,h2,h3,h4{letter-spacing:.2px}
.lead{color:#444}
.bg-ebony{background:var(--concrete)}
.text-ebony{color:var(--text)}
.text-orange{color:var(--brand-orange)}
.btn-brand{background:var(--brand-orange);color:#fff;border:none}
.btn-brand:hover{filter:brightness(.9)}
.btn-outline-ebony{border-color:var(--brand-ebony);color:var(--brand-ebony)}
.btn-outline-ebony:hover{background:var(--brand-ebony);color:#fff}
.navbar{transition:background-color .3s ease,box-shadow .3s ease}
.navbar.scrolled{background:rgba(48,41,38,.98)!important;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.hero{min-height:92vh;position:relative}
.hero .slide img,.hero video{height:92vh;object-fit:cover;width:100%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.55),rgba(0,0,0,.25))}
.hero-cta{backdrop-filter:saturate(1.2) blur(2px)}
section{scroll-margin-top:96px}
.section-muted{background:var(--concrete)}
.service-card{border:0;border-radius:1rem;box-shadow:0 8px 24px rgba(0,0,0,.06)}
.service-card .icon{font-size:2rem;color:var(--brand-orange)}
.filter-btn.active{background:var(--brand-orange);color:#fff}
.gallery-item{position:relative;overflow:hidden;border-radius:1rem;display:block}
.gallery-item img{width:100%;display:block;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-badge{position:absolute;top:.75rem;left:.75rem;background:rgba(0,0,0,.65);color:#fff;padding:.25rem .5rem;border-radius:.5rem;font-size:.8rem}
.blog-card{border:0;border-radius:1rem;box-shadow:0 8px 24px rgba(0,0,0,.06)}
.footer-link{color:#ddd}
.footer-link:hover{color:#fff}
.fade-in{opacity:0;transform:translateY(12px);transition:all .6s ease}
.fade-in.visible{opacity:1;transform:none}
.wa-fab{position:fixed;right:16px;bottom:16px;z-index:1050}
:focus-visible{outline:3px solid var(--brand-orange);outline-offset:2px}
.testimonial{border:0;border-left:4px solid var(--brand-orange);background:#fff;border-radius:1rem;box-shadow:0 8px 24px rgba(0,0,0,.06)}
/* Utilities */
.rounded-4{border-radius:1rem}

:root{
  --brand-orange:#f5821f;
  --brand-ebony:#30262f;
  --text:#ffffff;
}

/* ---------- NAV ---------- */
.nav-glass{
  background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.15)) !important;
  backdrop-filter: blur(6px);
}
.brand-wordmark{display:flex; flex-direction:column; line-height:1;}
.brand-wordmark strong{letter-spacing:.5px; font-size:1.05rem; color:#fff;}
.brand-wordmark small{color:#cfd3d6; font-size:.72rem; margin-top:-2px}

/* links con subrayado naranja centrado */
.main-nav .nav-link{
  position:relative; color:#eaeaea; padding:.25rem .75rem; margin:0 .25rem;
}
.main-nav .nav-link:hover{color:#fff;}
.main-nav .nav-link::after{
  content:""; position:absolute; left:50%; bottom:-6px; width:0; height:3px;
  background:var(--brand-orange); border-radius:3px; transform:translateX(-50%);
  transition:width .25s ease;
}
.main-nav .nav-link:hover::after,
.main-nav .nav-link.active::after{ width:60%; }

/* ---------- HERO ---------- */
.hero-cover{min-height:92vh;}
.hero-cover .carousel-inner, .hero-cover img{height:92vh; object-fit:cover;}
/* degradado superior + viñeta oscura */
.hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.65) 0%, rgba(0,0,0,.35) 35%, rgba(0,0,0,.05) 70%, rgba(0,0,0,0) 100%),
    radial-gradient(80% 70% at 20% 40%, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 70%);
  pointer-events:none;
}

/* copia a la izquierda, como en la referencia */
.hero-copy{
  position:absolute; top:50%; left:0; right:0;
  transform:translateY(-50%);
  display:flex; flex-direction:column; gap:1.25rem;
  color:#fff;
}
.hero-title{
  font-weight:800; line-height:1.05; margin:0;
  font-size:clamp(2rem, 4.8vw, 3.5rem);
  text-shadow:0 6px 24px rgba(0,0,0,.45);
  max-width:16ch;
}
.hero-title span{color:#fff;} /* si quieres enfatizar otra línea, cámbiala por var(--brand-orange) */

/* Botón CTA naranja redondeado */
.btn-cta{
  display:inline-flex; align-items:center; gap:.25rem;
  background:var(--brand-orange); color:#fff; border:0;
  padding:.75rem 1.25rem; border-radius:999px; font-weight:700;
  box-shadow:0 8px 24px rgba(245,130,31,.35);
  text-decoration:none;
}
.btn-cta:hover{filter:brightness(.95); color:#fff;}

/* ---------- Responsivo ---------- */
@media (max-width: 992px){
  .brand-wordmark small{display:none;}
  .hero-title{max-width:20ch;}
}
@media (max-width: 576px){
  .hero-title{font-size:clamp(1.6rem, 8vw, 2.2rem);}
}

/* ====== NAV estilo base (si ya lo tienes, mantén) ====== */
.nav-glass{
  background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.15)) !important;
  backdrop-filter: blur(6px);
}
.brand-wordmark{display:flex; flex-direction:column; line-height:1;}
.brand-wordmark strong{letter-spacing:.5px; font-size:1.05rem; color:#fff;}
.brand-wordmark small{color:#cfd3d6; font-size:.72rem; margin-top:-2px}
.main-nav .nav-link{position:relative; color:#eaeaea; padding:.25rem .75rem; margin:0 .25rem;}
.main-nav .nav-link:hover{color:#fff;}
.main-nav .nav-link::after{
  content:""; position:absolute; left:50%; bottom:-6px; width:0; height:3px;
  background:#f5821f; border-radius:3px; transform:translateX(-50%); transition:width .25s ease;
}
.main-nav .nav-link:hover::after, .main-nav .nav-link.active::after{ width:60%; }

/* Estados del logo (importante) */
.logo-mark{display:none;}          /* isotipo oculto por defecto */
.logo-full{display:inline-block;}  /* logo completo visible */

.nav-compact{background:transparent !important; box-shadow:none !important;}
.nav-compact .logo-full{display:none;}
.nav-compact .logo-mark{display:inline-block;}
.nav-compact .brand-wordmark{display:none;} /* por si vuelves a activar el wordmark */

/* Mostrar hamburguesa en desktop cuando está compacto */
.nav-compact .navbar-toggler{display:block !important}

/* Forzar colapso del menú en desktop cuando está compacto */
@media (min-width: 992px){
  .nav-compact .navbar-collapse.collapse{display:none !important;}
  .nav-compact .navbar-collapse.collapse.show{
    display:block !important;
    position:fixed; right:16px; top:72px;
    background:rgba(0,0,0,.92); padding:1rem 1.25rem; border-radius:12px;
    min-width:260px; z-index:1050;
  }
}

.navbar-dark .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255,255,255,0.9)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

.navbar-light .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(48,41,38,0.9)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* (opcional) Si en algún lado quedó este estilo, desactívalo o bórralo:
   .navbar.scrolled { background: ... }  → ya no lo usamos. */

   /* 1) Quitar el vidrio/blur/transparencia del navbar */
.nav-glass{
  background: transparent !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
}

/* 2) Color del ícono hamburguesa según el modo (A: icono cambia de color) */
.navbar-dark .navbar-toggler-icon{
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255,255,255,0.95)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}
.navbar-light .navbar-toggler-icon{
  background-image:url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(48,41,38,0.95)' stroke-width='2' stroke-linecap='round' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

/* 3) Opción B: sombrear el botón hamburguesa con un cuadrito oscuro */
.toggler-shade .navbar-toggler{
  background: rgba(0,0,0,.45);
  border-radius: .6rem;
  padding: .4rem .55rem;
}

/* Estados del logo (por si no los tienes) */
.logo-mark{display:none;}          /* isotipo */
.logo-full{display:inline-block;}  /* logo completo */

.nav-compact{background:transparent !important; box-shadow:none !important;}
.nav-compact .logo-full{display:none;}
.nav-compact .logo-mark{display:inline-block;}
.nav-compact .brand-wordmark{display:none;}
.nav-compact .navbar-toggler{display:block !important}

/* Menú colapsado en desktop cuando está compacto */
@media (min-width: 992px){
  .nav-compact .navbar-collapse.collapse{display:none !important;}
  .nav-compact .navbar-collapse.collapse.show{
    display:block !important;
    position:fixed; right:16px; top:72px;
    background:rgba(0,0,0,.92); padding:1rem 1.25rem; border-radius:12px;
    min-width:260px; z-index:1050;
  }
}

/* ====== Galería tipo carrusel ====== */
.gallery-viewport {
  overflow: hidden;
  position: relative;
}

.gallery-track {
  display: flex;
  will-change: transform;
  transition: transform .45s ease;
}

.gallery-item {
  flex: 0 0 25%;           /* 4 visibles en escritorio */
  padding: .5rem;          /* espacio entre imágenes */
  text-decoration: none;
}

.gallery-item .ratio {
  width: 100%;
  aspect-ratio: 4 / 3; /* relación ancho/alto lógica para fotos horizontales */
}

.gallery-img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* recorta manteniendo proporción */
  display: block;
  border-radius: .5rem;
}

/* Ajustes responsivos */
@media (max-width: 991.98px) {
  .gallery-item { flex-basis: 33.3333%; }  /* 3 visibles */
}
@media (max-width: 767.98px) {
  .gallery-item { flex-basis: 50%; }       /* 2 visibles */
}
@media (max-width: 575.98px) {
  .gallery-item { flex-basis: 100%; }      /* 1 visible */
}



/* Lightbox */
#lightboxModal .modal-content { background:#000; }
#lightboxModal .btn { border-radius:999px; }


