:root{
  --body-background-color: #ebdede;
  --body-background-color-2:#dfd1d1;
  --body-color: #645a5a;
  --nav-color:#504747;

  --navbar-bg-color: transparent;
  --navbar-toggler-bg-color: #a63c3ac7;
  --navbar-scroll-bg-color: linear-gradient(to bottom, #fff,#ebdede);
  --navbar-brand-color: #e3e6f1;
  --navbar-brand-shadow: #605c5c75;
  --navbar-brand-scrolling-color: #e3e6f1;
  --navbar-links-color: #b2c1ec;
  --navbar-links-shadow-color:#fff;
  --navbar-hamburgericon-up-color:  #e6e60b;
  --navbar-hamburgericon-middle-color: #e6e60b;
  --navbar-hamburgericon-down-color: #e6e60b;
  --navbar-hamburgericon-up-scrolling-color:  #d6d619;
  --navbar-hamburgericon-middle-scrolling-color: #d6d619;
  --navbar-hamburgericon-down-scrolling-color: #d6d619;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Poppins', sans-serif;
  }

  body {
    background: var(--body-background-color);
    color: var(--body-color);
    overflow-x: hidden;
  }

  /* HEADER */
  header {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    padding: 20px 60px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 1000;
    background: transparent;
    backdrop-filter: blur(10px);
  }

  header img {
    height: 40px;
  }

  nav a {
    margin-left: 30px;
    text-decoration: none;
    color: var(--nav-color);
    font-weight: 300;
    position: relative;
  }

  nav a::after {
    content: '';
    position: absolute;
    width: 0%;
    height: 2px;
    background: #ff4d6d;
    bottom: -5px;
    left: 0;
    transition: 0.3s;
  }

  nav a:hover::after {
    width: 100%;
  }

  
  /* Navbar */
  .navbar {
    width: 100%;
    max-width: 100vw;
    overflow: hidden;
    background: var(--navbar-bg-color);
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
  }

  .navbar.scrolled {
    background: var(--navbar-scroll-bg-color); 
    box-shadow: 0 2px 10px rgba(0,0,0,0.2);
  }

  .navbar-brand{
    color: var(--navbar-brand-color) !important;
    text-shadow: 0px 4px 4px var(--navbar-brand-shadow);
  }

  .navbar-brand:hover{
    color: var(--navbar-brand-color) !important;
  }

  .navbar-toggler {
    border: none;
  }

  .nav-link{
    color:var(--navbar-links-color) !important;
  }

  .navbar-toggler:focus { box-shadow: none; }
  .navbar-toggler-icon {
    background-image: none !important;
    background-color: var(--navbar-hamburgericon-middle-color) !important;
    width: 24px; height: 2px;
    display: block;
    position: relative;
    transition: all 0.3s;
  }

  .navbar-toggler-icon::before {
    content: '';
    width: 24px; height: 2px;
    background-color: var(--navbar-hamburgericon-up-color);
    position: absolute; left: 0;
    transition: all 0.3s;
  }

  .navbar-toggler-icon::after {
    content: '';
    width: 24px; height: 2px;
    background-color: var(--navbar-hamburgericon-down-color);
    position: absolute; left: 0;
    transition: all 0.3s;
  }
  .navbar-toggler-icon::before { top: -8px; }
  .navbar-toggler-icon::after { top: 8px; }

  .navbar-toggler:not(.collapsed) .navbar-toggler-icon {
    background-color: var(--navbar-toggler-bg-color);
  }
  .navbar-toggler:not(.collapsed) .navbar-toggler-icon::before {
    transform: rotate(45deg); top: 0;
  }
  .navbar-toggler:not(.collapsed) .navbar-toggler-icon::after {
    transform: rotate(-45deg); top: 0;
  }

  /* Navbar links default (on top of hero video/image) */
  .navbar .nav-link,
  .navbar .navbar-brand,
  .navbar .navbar-toggler-icon {
    transition: color 0.3s ease;
  }

  /* When scrolled (dark text on white bg, for example) */
  .navbar.scrolled .nav-link,
  .navbar.scrolled .navbar-brand {
    color: var(--navbar-brand-scrolling-color) !important; 
  }

  /* Custom hamburger icon color when scrolled */
  .navbar.scrolled .navbar-toggler-icon {
    background-color: var(--navbar-hamburgericon-middle-scrolling-color) !important;
  }

  .navbar.scrolled .navbar-toggler-icon::after {
    background-color: var(--navbar-hamburgericon-up-scrolling-color);
  }

  .navbar.scrolled .navbar-toggler-icon::before {
    background-color: var(--navbar-hamburgericon-down-scrolling-color);
  }

  .nav-link{
    text-shadow: 2px 2px 5px var(--navbar-brand-shadow);
  }

  /* nav bar logo */

.navbar-logo {
  height: 60px !important;
  width: auto;
  margin-right: 8px;
  vertical-align: middle;
  transition: transform 0.3s ease;
}

/* Optional hover effect */
.navbar-brand:hover .navbar-logo {
  transform: scale(1.05);
}

.dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background-color: var(--navbar-bg-color);
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  list-style: none;
  padding: 8px 0;
  min-width: 180px;
  margin-top: 8px;
  opacity: 0;
  transform: translateY(-5px);
  transition: all 0.25s ease;
}

.dropdown-menu.show {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.dropdown-item {
  display: block;
  padding: 10px 16px;
  text-decoration: none;
  color: #333;
  font-size: 0.95rem;
  transition: background-color 0.25s;
}

.dropdown-item:hover {
  background-color: #f3f8fa;
  color: #00a2d3;
}

/* Optional: smaller logo on mobile */
@media (max-width: 768px) {
  .navbar-logo {
    height: 26px;
  }
}

.navbar.scrolled .navbar-logo {
  content: url('/assets/images/navbar-logo.webp');
}



  /* HERO */
  .hero {
    height: 100vh;
    background: url('https://images.unsplash.com/photo-1522202176988-66273c2fd55f') center/cover no-repeat;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--body-background-color);
  }

  .hero video {
    width: 70%;
    max-width: 900px;
    border-radius: 20px;
    z-index: 2;
    box-shadow: 0 30px 80px rgba(0,0,0,0.8);
    animation: float 6s ease-in-out infinite;
  }

  @keyframes float {
    0%,100% { transform: translateY(0); }
    50% { transform: translateY(-15px); }
  }

  /* CAROUSEL */
  .carousel {
    padding: 100px 0;
    background: var(--body-background-color);
  }

  .swiper {
    width: 80%;
  }

  .swiper-slide {
    background-size: cover;
    background-position: center;
    height: 400px;
    border-radius: 20px;
    position: relative;
    overflow: hidden;
  }

  .swiper-slide::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
  }

  .slide-text {
    position: absolute;
    bottom: 30px;
    left: 30px;
    z-index: 2;
    font-size: 24px;
    font-weight: 600;
  }

  /* ANIMACIONES SCROLL */
  .fade-up {
    opacity: 0;
    transform: translateY(50px);
    transition: 0.8s ease;
  }

  .fade-up.show {
    opacity: 1;
    transform: translateY(0);
  }

  /* MCHIC */

  .section {
padding: 140px 80px;
text-align: center;
}

.reveal {
background: var(--body-background-color);
}

.glitch {
font-size: 90px;
font-weight: 600;
position: relative;
color: #fff;
}

.glitch::before,
.glitch::after {
content: attr(data-text);
position: absolute;
left: 0;
width: 100%;
overflow: hidden;
}

.glitch::before {
color: #ff4d6d;
clip-path: inset(0 0 50% 0);
animation: glitchTop 2s infinite;
}

.glitch::after {
color: #00f5d4;
clip-path: inset(50% 0 0 0);
animation: glitchBottom 2s infinite;
}

@keyframes glitchTop {
0% { transform: translate(0); }
50% { transform: translate(-4px, -4px); }
100% { transform: translate(0); }
}

@keyframes glitchBottom {
0% { transform: translate(0); }
50% { transform: translate(4px, 4px); }
100% { transform: translate(0); }
}

/* SERVICIOS */

.services {
display: flex;
justify-content: center;
gap: 40px;
padding: 120px;
background: var(--body-background-color);
}

.card {
width: 280px;
height: 180px;
background: linear-gradient(135deg, #ff4d6d, #6a00ff);
border-radius: 20px;
display: flex;
align-items: center;
justify-content: center;
font-size: 22px;
font-weight: 500;
cursor: pointer;
transform-style: preserve-3d;
transition: 0.5s;
}

.card:hover {
transform: rotateY(15deg) rotateX(10deg) scale(1.05);
}

/* CLIENTES */

.clients {
background: var(--body-background-color);
padding: 120px 0;
overflow: hidden;
}

.logos {
display: flex;
gap: 80px;
animation: scroll 15s linear infinite;
font-size: 32px;
opacity: 0.6;
}

@keyframes scroll {
0% { transform: translateX(100%); }
100% { transform: translateX(-100%); }
}

/* CONTACTO */

.contact {
background: linear-gradient(to bottom, var(--body-background-color), var(--body-background-color-2));
padding: 140px;
display: flex;
justify-content: center;
}

form {
width: 400px;
display: flex;
flex-direction: column;
gap: 20px;
}

input, textarea {
background: transparent;
border: 1px solid #444;
padding: 14px;
color: #fff;
border-radius: 10px;
transition: 0.3s;
}

input:focus, textarea:focus {
border-color: #ff4d6d;
box-shadow: 0 0 15px rgba(255,77,109,0.5);
outline: none;
}

button {
padding: 14px;
background: #ff4d6d;
border: none;
color: #fff;
border-radius: 30px;
cursor: pointer;
transition: 0.4s;
}

button:hover {
background: #fff;
color: #000;
}


