/* ============================================================
   RESET GENERAL (Limpia estilos por defecto del navegador)
   ============================================================ */
* {
    margin: 0;                  /* Quita márgenes por defecto */
    padding: 0;                 /* Quita rellenos por defecto */
    box-sizing: border-box;     /* Hace que width/height incluyan bordes y padding */
    font-family: Arial, Helvetica, sans-serif; /* Fuente global */
}

/* ============================================================
   BODY (Ajustes generales del documento)
   ============================================================ */
body {
    background-color: #f5f5f5;  /* Color gris claro de fondo */
    padding-top: 90px;          /* Compensa el header fijo para evitar descuadre */
}

/* ============================================================
   HEADER / MENÚ SUPERIOR
   ============================================================ */
header {
    width: 100%;                          /* Ocupa todo el ancho */
    padding: 15px 40px;                   /* Espaciado interno */
    background: #ffffff;                  /* Fondo blanco */
    display: flex;                        /* Activa Flexbox */
    justify-content: space-between;       /* Logo a la izquierda, menú a la derecha */
    align-items: center;                  /* Centrado vertical */
    position: fixed;                      /* Fijo arriba */
    top: 0;                               /* Posición superior */
    left: 0;                              /* Pegado a la izquierda */
    box-shadow: 0px 3px 8px rgba(0,0,0,0.1); /* Sombra elegante */
    z-index: 1000;                        /* Se mantiene encima de todo */
}

.logo {
    font-size: 24px;          /* Tamaño del texto del logo */
    font-weight: bold;        /* Negrita */
    color: #333;              /* Gris oscuro */
}

/* ============================================================
   NAV / MENU DE NAVEGACIÓN
   ============================================================ */
nav a {
    margin-left: 25px;        /* Separación entre enlaces */
    text-decoration: none;    /* Quita el subrayado */
    color: #444;              /* Color gris */
    font-size: 16px;          /* Tamaño de texto */
    transition: 0.3s ease;    /* Animación suave en hover */
}

nav a:hover {
    color: #0078ff;           /* Azul moderno cuando el mouse pasa */
}

/* ============================================================
   SECCIÓN HERO / PORTADA CON VIDEO
   ============================================================ */
.hero {
    width: 100%;              /* Abarca todo el ancho */
    min-height: 80vh;         /* 80% de la pantalla, ya no 100vh para evitar descuadres */
    position: relative;       /* Para posicionar el video y overlay */
    display: flex;            /* Activa Flexbox */
    align-items: center;      /* Centra verticalmente */
    justify-content: flex-start; /* Texto a la izquierda */
    padding-left: 50px;       /* Separación del borde izquierdo */
    overflow: hidden;         /* Oculta partes del video que sobresalgan */
}

/* =======================
   VIDEO DE FONDO
   ======================= */
.hero-video {
    position: absolute;       /* Para colocarlo detrás del texto */
    top: 0;                   /* Alineado arriba */
    left: 0;                  /* Pegado a la izquierda */
    width: 100%;              /* Abarca todo el ancho */
    height: 100%;             /* Abarca toda la altura */
    object-fit: cover;        /* Se adapta a la forma del contenedor sin deformarse */
    z-index: -1;              /* Se coloca detrás de todo */
}

/* =======================
   CAPA OSCURA (overlay)
   ======================= */
.hero-overlay {
    position: absolute;                    /* Encima del video */
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.45);       /* Oscurece el video */
    top: 0;
    left: 0;
    z-index: 0;                            /* Debajo del texto, encima del video */
}

/* =======================
   TEXTO EN EL HERO
   ======================= */
.hero-text {
    position: relative;       /* Para que esté encima del overlay */
    color: white;             /* Texto blanco */
    max-width: 500px;         /* Ancho máximo */
    z-index: 1;               /* Texto por encima del overlay */
}

.hero h1 {
    font-size: 48px;          /* Título grande */
    margin-bottom: 15px;      /* Separación */
}

.hero p {
    font-size: 20px;          /* Subtítulo */
    margin-bottom: 30px;      /* Separación con el botón */
}

/* ============================================================
   BOTÓN DE WHATSAPP
   ============================================================ */
.btn-whatsapp {
    display: inline-block;     /* Permite margen y padding */
    padding: 12px 25px;        /* Tamaño del botón */
    background: #25d366;       /* Verde oficial de WhatsApp */
    color: #fff;               /* Texto blanco */
    font-size: 18px;           /* Tamaño del texto */
    border-radius: 8px;        /* Bordes redondeados */
    text-decoration: none;     /* Quita subrayado */
    transition: 0.3s;          /* Animación suave */
}

.btn-whatsapp:hover {
    background: #1ea955;       /* Verde más oscuro al pasar el mouse */
}
