@font-face {
  font-family: "Caviar Dreams";
  src: url("../assets/fonts/CaviarDreams_Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

.font-brand {
  font-family: "Caviar Dreams", "Outfit", system-ui, sans-serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

:root{
  --brand-navy:#0B1B2B;
  --brand-teal:#0FB9B1;
  --brand-green:#16a34a;
  --brand-gold:#C9A227;
  --brand-light:#F6F8FB;
}
.navbar, .bg-dark{background:var(--brand-navy)!important;}
.btn-primary{background:var(--brand-teal)!important;border-color:var(--brand-teal)!important;}
.btn-primary:hover{filter:brightness(.95);}
.kicker{color:var(--brand-gold)!important;}

:root{
  --primary:#25d366;
  --primary-dark:#1ebe5d;
  --bg-0:#020617;
  --bg-1:#0b1220;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --glass:rgba(15,23,42,.45);
  --glass-border:rgba(148,163,184,.45);
  --shadow:0 18px 50px rgba(0,0,0,.55);
}

html{scroll-behavior:smooth;}
body{font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);background:linear-gradient(135deg,var(--bg-0),#020617 55%, var(--bg-1));}
h1,h2,h3,h4,h5,h6{font-family:"Outfit",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;}
a{text-decoration:none}
.section{padding:5rem 0}
.section-light{background:#f3f4f6;color:#0b1220}
.section-light .text-muted{color:#475569!important}
.section-dark{background:linear-gradient(135deg,#020617 0,#020617 45%,#0f172a 100%);color:var(--text)}

.nav-glass{background:rgba(2,6,23,.78)!important;backdrop-filter:blur(14px);border-bottom:1px solid rgba(148,163,184,.12)}
.brand-badge{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;background:radial-gradient(circle at top left,#a7f3d0,#059669);color:#fff;font-weight:700;letter-spacing:.02em;box-shadow:0 10px 30px rgba(16,185,129,.25)}
.navbar .nav-link{color:#cbd5f5!important;opacity:.92}
.navbar .nav-link:hover{color:#fff!important;opacity:1}

.btn-whatsapp{background:var(--primary);color:#fff;border-radius:999px;border:none}
.btn-whatsapp:hover{background:var(--primary-dark);color:#fff}
.btn-soft{background:rgba(37,211,102,.12);border:1px solid rgba(16,185,129,.35);color:#a7f3d0;border-radius:999px}
.btn-soft:hover{background:rgba(37,211,102,.18);color:#d1fae5}

.glass-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:18px;backdrop-filter:blur(18px);box-shadow:var(--shadow)}
.glass-card.light{background:rgba(255,255,255,.7);border:1px solid rgba(148,163,184,.35);box-shadow:0 18px 50px rgba(2,6,23,.18)}
.icon-pill{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(37,211,102,.12);border:1px solid rgba(16,185,129,.35);font-size:20px}

.hero{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.18;transform:translateY(0);will-change:transform}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at top, rgba(15,23,42,.35), rgba(2,6,23,.95))}
.hero-content{position:relative;z-index:1}
.hero-img{border-radius:22px;box-shadow:var(--shadow)}
.badge-custom{display:inline-flex;align-items:center;gap:.5rem;background:rgba(37,211,102,.12);padding:.45rem .9rem;border-radius:999px;border:1px solid rgba(16,185,129,.35);color:#a7f3d0;font-size:.82rem}
.kicker{color:#a5b4fc;font-size:.9rem;letter-spacing:.09em;text-transform:uppercase}
.lead{color:#d1d5db}

.service-card{transition:transform .25s ease, box-shadow .25s ease}
.service-card:hover{transform:translateY(-6px)}
.gallery img{border-radius:16px;transition:transform .25s ease, box-shadow .25s ease}
.gallery img:hover{transform:scale(1.03);box-shadow:0 16px 45px rgba(2,6,23,.5)}

.counter-number{font-size:2.4rem;font-weight:700}
.counter-label{font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;color:#a5b4fc}

#preloader{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;background:radial-gradient(circle at top,#259983 0,#050816 55%);color:#fff;transition:opacity .35s ease, visibility .35s ease}
#preloader.hide{opacity:0;visibility:hidden}
.loader-circle{width:62px;height:62px;border-radius:50%;border:4px solid rgba(255,255,255,.25);border-top-color:#fff;animation:spin .8s linear infinite;margin-bottom:1rem}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{opacity:.92}

.footer-corp{background:#020617}
.footer-links a{color:#e5e7eb;opacity:.9}
.footer-links a:hover{opacity:1;text-decoration:underline}

.form-control, .form-select{border-radius:14px}

/* Hero video */
.hero-video{position:relative;min-height:100vh;overflow:hidden;display:flex;align-items:center}
.hero-video__media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-video__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(2,6,23,.25),rgba(2,6,23,.78))}
.hero__content{position:relative;z-index:2;padding-top:6rem;padding-bottom:6rem}

.brand-logo {
  height: 60px;
  width: auto;
  object-fit: contain;
}

.brand-text {
  font-size: 1rem;
  letter-spacing: 0.3px;
}

@media (max-width: 576px) {
  .brand-text {
    display: none; /* en móvil queda solo el ícono */
  }

  .brand-logo {
    height: 30px;
  }
}

/* Lightbox */
.gallery-img {
  cursor: zoom-in;
}

/* Imagen dentro del modal */
#lightboxImage {
  max-height: 90vh;
  object-fit: contain;
}

/* Flechas */
.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
  height: 54px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 2.2rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox-prev { left: 16px; }
.lightbox-next { right: 16px; }

.lightbox-nav:hover {
  background: rgba(0,0,0,.8);
}

/* Mobile: flechas un poco más pequeñas */
@media (max-width: 768px) {
  .lightbox-nav {
    width: 44px;
    height: 44px;
    font-size: 1.8rem;
  }
}



/* =========================
   HERO con logo en grande (marca de agua)
   ========================= */

.page-hero{
  position: relative;
  overflow: hidden;
  /* tu gradiente oscuro se mantiene */
  background: radial-gradient(1200px 600px at 15% 20%, rgba(51,102,153,.25) 0%, rgba(2,6,23,.95) 55%),
              linear-gradient(135deg, rgba(2,6,23,1), rgba(11,18,32,1));
}

.page-hero .container{
  position: relative;
  z-index: 2;
}

/* Logo grande a la derecha */
.page-hero::after{
  content:"";
  position:absolute;
  right: -160px;   /* empuja a la derecha para “cortarlo” bonito */
  top: 50%;
  transform: translateY(-50%);
  width: 760px;    /* tamaño del logo */
  height: 300px;
  background-image: url("../assets/images/brand/colibri-blanco.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;

  opacity: 0.16;               /* visibilidad del logo */
  filter: saturate(1.05) contrast(1.05);
  pointer-events: none;
  z-index: 1;
}

/* Un overlay suave para que el texto siempre sea legible */
.page-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg,
    rgba(2,6,23,.90) 0%,
    rgba(2,6,23,.75) 55%,
    rgba(2,6,23,.55) 100%
  );
  z-index: 0;
  pointer-events:none;
}

/* Responsive: en móvil reducimos el logo para que no tape */
@media (max-width: 991.98px){
  .page-hero::after{
    width: 420px;
    height: 440px;
    right: -160px;
    top: 60px;
    opacity: 0.14;
  }
}

@media (max-width: 575.98px){
  .page-hero::after{
    width: 260px;
    height: 280px;
    right: 50%;
    transform: translateX(50%);
    top: 40px;
    opacity: 0.12;
  }
}

