body{
    background-color: #000;
    color: #fff;
    font-size: 26px;
    font-weight: 300;
    font-family: "Inter", "Roboto", Arial, sans-serif;
    line-height: 1.3;
}
/* Línea vertical */
.vertical-divider {
    width: 3px;
    height: 250px; 
    background: rgba(255,255,255,0.9);
    margin: auto; /* centra verticalmente */
}

h2 {
    font-size: 36px;
    font-weight: 300;
    line-height: 1.2;
}

/* HERO */

.hero {
    position: relative;
    background-image: url('../images/banner-hero.webp');
    background-size: cover;
    background-position: center;
    height: 100vh;
    color: #fff;
    display: flex;
    align-items: center;
    /*min-height: 100vh;    */        
}

.hero h1 {
    font-size: 55px;
    font-weight: 300;
    line-height: 1.2 !important;
}
.hero .text-small{
    font-size: 18px;
    font-weight: bold;
}
.hero-content {
    position: relative;
    z-index: 3;
}
.logo-fortinet{
    width: 280px;
}
.logo-arcade{
    width: 360px;

}
.hero .col-lg-6 {
    padding-left: 0.1rem; 
}

.hero .col-lg-5 {
    padding-right: 0.6rem; 
}
/* Mejorar hero en pantallas grandes (1920px+) */
@media (min-width: 1920px) {

    /* Título principal */
    .hero h1 {
        font-size: 86px;     
        line-height: 1.05;
    }

    /* Subtítulo LAS VEGAS */
    .hero p.text-uppercase {
        font-size: 20px;
        letter-spacing: 2px;
    }

    /* Logo Fortinet */
    .logo-fortinet {
        width: 500px !important; 
    }

    /* Logo F1 Arcade */
    .logo-arcade {
        width: 850px !important; /
    }
    .hero-content {
        padding-top: 40px;
    }
    .vertical-divider {
        width: 3px;                   
        height: 320px;               
        background: rgba(255,255,255,0.85);
    } 
    .evento-section {
        font-size: 26px;
    }  
}
@media (max-width: 992px) {
    body{
        font-size:20px !important;
    }
    .titulo-principal,
    .registro-titulo,
    .pill,
    .btn-confirmar,
    .evento-section{
        font-size:22px !important;
    }
    .evento-section h3,
    .evento-section p{
        margin-bottom: 40px !important;
    }
    .registro-section{
        padding: 0 !important;
    }
    .badge-exclusivo,
    .campo{
        font-size: 20px !important;
    }
    .sponsor,
    .cupos{
        font-size: 22px;
    }
    .sponsor-logo{
        height: 40px !important;
    }
    .sponsors{
        gap: 30px;
    }

}
@media (max-width: 768px) {
    .hero {
        height: 40vh;
        background-position: center top;
    }
}

/* Selector idioma */
.language-switcher {
    position: absolute;
    top: 20px;
    right: 25px;
    z-index: 4;
    display: flex;
    gap: 6px;            
}

.language-switcher a {
    border: 1px solid #ffffffaa;
    background: rgba(0,0,0,0.5);
    color: #fff;
    padding: 4px 14px;
    font-size: 12px;
    border-radius: 20px; 
    font-weight: 500;
    transition: all .2s ease;
    text-decoration: none;
}
.language-switcher a:hover {
    background: #fff;
    border-color: #fff;
    color: #000;
}
/* Bloque de contenido inferior */

.flecha-roja {
    width: 40px;
    height: auto;
    margin-right:20px !important;

}

/* Puntitos + rectangulos */
.decoracion-hero {
    position: absolute;
    right: 10px;            
    top: 95%;               

    transform: translateY(-50%);
    width: 200px;           
    z-index: 10;             
    pointer-events: none;   
}

@media (max-width: 992px) {
    .decoracion-hero {
        display: none; 
    }
}


.linea-separadora {
    border-top: 2px solid rgba(255,255,255,0.5);
    opacity: 1;                    
}


.evento-section{
    font-size: 22px;
}
.foto-evento{
    width:100%;
    height:260px;
    object-fit:cover;
}

.pill {
    position: relative;

    border: 1px solid rgba(255,255,255,0.8);
    border-radius: 40px;
    padding: 10px 20px 10px 80px; 
    font-size: 22px;
    font-weight: 300;
    color: #fff;
    line-height: 1.3;
    max-width: 540px;
    margin-bottom: 20px;
}

/* Icono dentro del pill */
.pill-icon {
    position: absolute;
    left: -2px;
    top: 30px;
    transform: translateY(-50%);
    width: 61px; 
    height: 61px;
}

/* Pill multilínea */
.pill-largo {
    border-radius: 40px; 
    padding-top: 20px;
    padding-bottom: 20px;
    padding-left: 80px;
    line-height: 1.35;
}

/* separación de columnas en mobile */
@media (max-width: 992px) {
    .evento-section h3 {
        font-size: 22px;
    }
}

/* Título */
.registro-titulo {
    color: #ff3b3b;
    font-size: 36px;
    font-weight: 600;
    padding-bottom: 40px;
}

/* Caja del “formulario” */
.form-box {
    border: 1px solid white;
    border-radius: 18px;
    background-color: #171717;
    padding-bottom:50px !important;
    padding-top: 50px !important;
}
.form-box .campo {
    padding-left: 10px !important;
    padding-right: 10px !important;
}
.campo {
    background: transparent;
    border: none;
    border-bottom: 1px solid white;
    border-radius: 0;
    color: #fff;
    font-size: 22px;
}
.campo::placeholder {
    color: white;
}
.campo:focus {
    background: transparent;
    box-shadow: none;
    border-bottom-color: #fff;
    color: #fff;
}
/* Quitar estilos feos del navegador */
select {
    background-color: transparent;
    color: #fff;
    border: none;
    border-bottom: 1px solid #fff;
    font-size: 22px;
    padding: 6px 0;
    appearance: none;
}



select.campo {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-left: 0;
    background-position: right 0px center;
    background-repeat: no-repeat;
    color: #fff;              
    background-color: transparent;    
}
select.campo option {
    background-color: #000;   /* fondo negro */
    color: #fff;              /* texto blanco */
}
/* Color del texto placeholder */
select.campo option[value=""] {
    color: rgba(255,255,255,0.6);
}
select.campo:focus {
    color: #000 !important;
    background-color: #fff !important;
}
select option:hover {
    background-color: #ff3b3b !important;
    color: #fff !important;
}

/* Botón rojo */
.btn-container {
    position: relative;
    margin-top: 30px; 
    text-align: center;
    z-index: 5;
}
.btn-confirmar {
    background: #ff3b3b;
    color: #fff;
    padding: 12px 50px;
    border-radius: 40px;
    font-weight: 600;
    transition: 0.2s;
    font-size: 24px;
}
.btn-confirmar:hover {
    background: #ff5c5c;
}

/* Texto explicativo */
.texto-explicacion {
    opacity: 0.9;
}

/* Badge gris */
.badge-exclusivo {

    border: 1px solid white;
    padding: 10px 20px;
    border-radius: 20px;
    display: inline-block;
    font-size: 24px;
    font-weight: bold;
    color: #ddd;
    margin-top:25px;
}

/* Separador */
.separador {
    border-top: 2px solid white;
    opacity: 1; 
}
.cupos,
.sponsor{
    font-size: 30px;
}
.cupos{
    margin: 50px 0 40px 0;
}
.sponsors{
    margin-top:80px;
    gap: 80px;
}
/* Logos sponsors */
.sponsor-logo {
    height: 65px;
    column-gap: 5;
    object-fit: contain;
    filter: brightness(0) invert(1);
}

.footer-line {
    width: 100%;
    height: 12px; 
    background: #8B3EFF; 
    margin-top: 40px; 
}