*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

body{
    font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background:#ffffff;
    color:#1d1d1f;
    -webkit-font-smoothing:antialiased;
}

.linea-morada{
    background:#A64D79;
    height:56px;
    display:flex;
    align-items:center;
    justify-content:center;
}

.linea-morada a{
    color:#fff;
    text-decoration:none;
    font-size:20px;
    letter-spacing:1px;
    font-weight:500;
    opacity:1.9;
}

.seccion-eventos{
    padding:120px 20px 80px;
    text-align:center;
}

.titulo-eventos{
    font-size:42px;
    font-weight:600;
    letter-spacing:-0.8px;
    margin-bottom:60px;
}

.contenedor-eventos{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:28px;
    max-width:920px;
    margin:auto;
}

.tarjeta{
    position:relative;
    background:#ffffff;
    padding:40px 30px;
    border-radius:20px;
    border:1px solid rgba(0,0,0,0.05);
    transition:all .35s cubic-bezier(.4,0,.2,1);
    cursor:pointer;
    box-shadow:
        0 4px 12px rgba(248, 17, 198, 0.562),
        0 12px 30px rgba(0,0,0,0.06);
}


.tarjeta::after{
    content:"";
    position:absolute;
    inset:0;
    border-radius:20px;
    background:linear-gradient(
        120deg,
        transparent 40%,
        rgba(166,77,121,0.08),
        transparent 60%
    );
    opacity:0;
    transition:.4s;
}


.tarjeta h3{
    font-size:19px;
    font-weight:500;
    color:#2b2b2b;
}


.tarjeta:hover{
    transform:translateY(-10px) scale(1.015);

    border-color:rgba(166,77,121,0.25);

    box-shadow:
        0 10px 25px rgba(0,0,0,0.08),
        0 20px 45px rgba(0,0,0,0.10);
}

.tarjeta:hover::after{
    opacity:1;
}


.formulario{
    text-align:center; 
    position:relative;
    margin:-60px auto 0; 
    max-width:520px; 
    width:100%;
    padding:45px 40px;
    border-radius:26px;
    background:#ffffff;
    border:1px solid rgba(0,0,0,0.05);
  box-shadow:
    0 10px 20px rgba(255, 255, 255, 0.08),
    0 10px 30px rgba(231, 41, 145, 0.459),
    0 10px 10px rgba(172, 11, 126, 0.479);

    animation:entradaCard .7s cubic-bezier(.22,1,.36,1);
    font-family: 'Montserrat', sans-serif;
}

@keyframes entradaCard{
    0%{
        opacity:0;
        transform:translateY(60px) scale(0.95);
    }

    60%{
        opacity:1;
        transform:translateY(-10px) scale(1.02);
    }

    80%{
        transform:translateY(4px) scale(0.99);
    }

    100%{
        transform:translateY(0) scale(1);
    }
}

.formulario h3{
    color:#97165d;
    font-weight:600;
    margin-bottom:20px;
}


.formulario input{
    width:100%;
    padding:14px;
    margin:10px 0;

    border-radius:12px;
    border:1px solid rgba(0,0,0,0.08);

    font-size:14px;

    transition:all .25s ease;
}

.formulario input:focus{
    outline:none;
    border-color:#97165d00;
    box-shadow:0 0 0 4px rgba(255, 147, 237, 0.932);
}

.formulario button{
    width:100%;
    padding:14px;
    margin-top:15px;

    border:none;
    border-radius:12px;

    background:#97165d;
    color:#fff;

    font-size:15px;
    font-weight:500;

    cursor:pointer;
    transition:all .3s ease;
}

.subtitulo-dinamico{
    font-size:26px; 
    font-weight:500;
    color:#222;
    margin:0 0 20px; 
    text-align:center;
}

.formulario button:hover{
    transform:translateY(-2px);
    box-shadow:0 10px 25px rgba(151,22,93,0.25);
}

.formulario button:active{
    transform:scale(0.97);
}

.boton-atras{
    display:inline-block;
    margin-bottom:20px;

    color:#97165d;
    font-weight:500;
    font-size:14px;

    cursor:pointer;
    transition:.25s;
}

.boton-atras:hover{
    transform:translateX(-4px);
}


.selector-evento{
    text-align:center;
    padding:70px 20px 50px;
    max-width:1200px;
    margin:auto;
}

.titulo-evento{
    font-size:42px;
    font-weight:700;
    color:#111;
    margin-bottom:18px;
    letter-spacing:-0.5px;
    font-family: 'Montserrat', sans-serif;
}

.pasos{
    display:flex;
    justify-content:center;
    align-items:center;
    gap:28px;
    margin-bottom:60px;
    font-size:17px;
    color:#5f5f5f;
     font-family: 'Montserrat', sans-serif;
}
.pasos::after{
    content:"→";
    position:absolute;
    bottom:-18px;
    left:50%;
    transform:translateX(-50%);
    font-size:20px;
    color:#A64D79;
    opacity:0.7;
}

.pasos span{
    position:relative;
}

.pasos .activo{
    color:#A64D79;
    font-weight:600;
}

.subtitulo-evento{
    font-size:24px;
    font-weight:500;
    color:#353535;
    margin-bottom:30px;
     font-family: 'Montserrat', sans-serif;
}

.opciones-evento{

    display:grid;

    grid-template-columns:repeat(3,250px);

    justify-content:center;

    gap:18px;

}

@media(max-width:900px){

    .opciones-evento{

        grid-template-columns:1fr;

        max-width:350px;

        margin:auto;

    }

}

.opciones-evento button{
    background:#ffffff;
    border:2.3px solid #f3c1d4;
    padding:40px 15px; 
    border-radius:16px;
    font-size:22px; 
    font-weight:600;
    color:#833a5e;
    cursor:pointer;
    transition:all .25s ease;
    font-family: 'Montserrat', sans-serif;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:10px; 
}

.opciones-evento button:nth-child(1)::before{
    content:"♡";
}

.opciones-evento button:nth-child(2)::before{
    content:"✧"; 
}

.opciones-evento button:nth-child(3)::before{
    content:"◌"; 
}

.opciones-evento button:nth-child(4)::before{
    content:"✿";
}

.opciones-evento button::before{
    font-size:33px;
    display:block;
    color:#A64D79;
    opacity:0.9;
}

.opciones-evento button:hover{
    background:#fff5f8;
    border-color:#A64D79;
    transform:translateY(-2px);
}

.opciones-evento button:active{
    transform:scale(0.97);
}

.opciones-evento button.active{
    background:#ffe9f0;
    border-color:#A64D79;
    color:#97165d;
}

#mensaje-formulario{
    display:none;
    font-size:23px;
    font-weight:500;
    color:#222;
    margin:30px 0;

    opacity:0;
    transform:translateY(15px);
    transition:all .5s cubic-bezier(.22,1,.36,1);
}

#mensaje-formulario.mostrar{
    opacity:1;
    transform:translateY(0);
}

.alerta{
    position:fixed;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%) scale(0.9);

    background:linear-gradient(135deg,#A64D79,#97165d);
    color:#fff;

    padding:22px 35px;
    border-radius:18px;

    font-size:18px;
    font-weight:500;
    text-align:center;

    box-shadow:
        0 25px 80px rgba(0,0,0,0.25),
        0 10px 30px rgba(151,22,93,0.3);

    opacity:0;
    pointer-events:none;

    transition:all .35s cubic-bezier(.22,1,.36,1);

    z-index:9999;
}


.alerta.show{
    opacity:1;
    transform:translate(-50%, -50%) scale(1);
}

.input-fecha{
    display:flex;
    flex-direction:column;
    gap:8px;
    margin:15px 0;
}

.input-fecha label{
    font-size:14px;
    font-weight:500;
    color:#6e6e73;
}


.input-fecha input{
    padding:16px 18px;
    border-radius:14px;
    border:1px solid rgba(0,0,0,0.08);

    font-size:15px;
    font-family:'Montserrat', sans-serif;

    background:#fff;

    transition:all .25s ease;
}


.input-fecha input:focus{
    outline:none;
    border-color:#97165d;

    box-shadow:
        0 0 0 4px rgba(151,22,93,0.10),
        0 10px 30px rgba(151,22,93,0.15);
}

.itinerario-container {
    width: 100%;
    max-width: 1100px;
    margin: auto;
    font-family: 'Montserrat', sans-serif;
}

.vestimenta-container {
    margin-top: 15px;
}

.vestimenta-box {
    display: flex;
    flex-direction: column;
    gap: 10px;

    padding: 16px 20px;
    border-radius: 14px;

    background: rgba(255,255,255,0.75);
    border: 1px solid rgba(0,0,0,0.08);

    box-shadow: 0 10px 25px rgba(0,0,0,0.08);

    backdrop-filter: blur(10px);

    font-size: 16px;
    font-weight: 500;
}

.vestimenta-box i {
    margin-right: 8px;
    font-size: 18px;

    
}


.btn-volver{

    position:fixed;

    top:100px;

    right:40px;

    width:55px;
    height:55px;

    display:none;

    justify-content:center;
    align-items:center;

    background:#A64D79;

    color:white;

    font-size:28px;

    border-radius:50%;

    cursor:pointer;

    z-index:999;

    box-shadow:
    0 10px 25px rgba(166,77,121,.25);

    transition:.3s;

}

.btn-volver:hover{

    transform:translateY(-3px);

    background:#97165d;

}

.btn-inicio-texto{

    position: fixed !important;

    top: 90px !important;

    left: 30px !important;

    width: 50px !important;
    height: 50px !important;

    display: flex !important;

    align-items: center !important;
    justify-content: center !important;

    background: #A64D79 !important;

    color: white !important;

    text-decoration: none !important;

    border-radius: 50% !important;

    font-size: 24px !important;

    z-index: 9999 !important;

    box-shadow: 0 8px 20px rgba(166,77,121,.25) !important;

    transition: .3s ease !important;
}

.btn-inicio-texto:hover{

    background: #97165d !important;

    transform: translateY(-3px) !important;
}

.btn-inicio-texto i{

    color:white !important;

    font-size:24px !important;

}

.btn-inicio-texto{
    display:none;
}

.alerta-bienvenida{

    position:fixed;

    top:0;
    left:0;

    width:100%;
    height:100%;

    background:rgba(0,0,0,.45);

    display:none;

    justify-content:center;
    align-items:center;

    z-index:9999;

    backdrop-filter:blur(5px);

}

.alerta-bienvenida-card{

    width:90%;
    max-width:520px;

    background:white;

    padding:35px;

    border-radius:25px;

    text-align:center;

    border-top:6px solid #b32678;

    box-shadow:
    0 20px 50px rgba(179,38,120,.25);

    animation:aparecer .4s ease;

}

.icono-alerta-bienvenida{

    font-size:55px;

    margin-bottom:15px;

}

.alerta-bienvenida-card h3{

    color:#b32678;

    margin-bottom:15px;

    font-size:28px;

}

.alerta-bienvenida-card p{

    color:#555;

    line-height:1.8;

}

@keyframes aparecer{

    from{
        opacity:0;
        transform:translateY(20px);
    }

    to{
        opacity:1;
        transform:translateY(0);
    }

}

#vestimentaSelect,
#vestimentaOtro{

    width:100%;

    padding:14px 16px;

    margin-top:12px;

    border:2px solid #f3c1d4;

    border-radius:14px;

    font-size:15px;

    font-family:'Montserrat', sans-serif;

    color:#5c3552;

    background:#fff;

    box-sizing:border-box;

    transition:.3s;

    outline:none;

}

#vestimentaSelect:focus,
#vestimentaOtro:focus{

    border-color:#A64D79;

    box-shadow:
    0 0 0 4px rgba(166,77,121,.12);

}

#vestimentaSelect:hover,
#vestimentaOtro:hover{

    border-color:#A64D79;

}

#vestimentaSelect{

    cursor:pointer;

}