/* portal-dj.css - Estilos del Portal DJ */
:root { 
    --bg-base: #040d13; 
    --bg-surface: rgba(14, 44, 64, 0.4); 
    --accent-teal: #148D8D; 
    --accent-sand: #EFBC75; 
    --text-white: #ffffff; 
    --text-muted: #9CA3AF; 
    --border-glass: rgba(255, 255, 255, 0.08); 
}

body { 
    font-family: 'Inter', sans-serif; 
    background-color: var(--bg-base); 
    background-image: radial-gradient(circle at 50% 0%, rgba(20, 141, 141, 0.1) 0%, transparent 50%); 
    color: var(--text-white); 
    margin: 0; 
    min-height: 100vh; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    padding: 20px;
}

.glass-panel { 
    background: var(--bg-surface); 
    border: 1px solid var(--border-glass); 
    backdrop-filter: blur(16px); 
    -webkit-backdrop-filter: blur(16px);
    padding: 40px; 
    border-radius: 16px; 
    width: 100%; 
    max-width: 500px; 
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.5); 
    position: relative;
}

h1 { font-family: 'Montserrat', sans-serif; font-size: 2rem; margin-top: 0; color: var(--text-white); text-align: center; }

label { display: block; margin-top: 20px; margin-bottom: 5px; color: var(--text-muted); font-size: 0.85rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px;}

input, textarea { 
    width: 100%; 
    background: rgba(255,255,255,0.05); 
    border: 1px solid var(--border-glass); 
    padding: 12px 15px; 
    color: white; 
    border-radius: 8px; 
    outline: none; 
    transition: 0.3s ease; 
    box-sizing: border-box;
    border-radius: 12px;
}

input:focus, textarea:focus { border-color: var(--accent-teal); }

select.dropdown-dark {
    width: 100%; 
    background: rgba(255,255,255,0.05); 
    border: 1px solid var(--border-glass); 
    padding: 12px 15px; 
    color: var(--text-muted); 
    border-radius: 8px; 
    outline: none; 
    cursor: pointer;
    border-radius: 12px;
}

.genre-tag {
    background: rgba(20, 141, 141, 0.2); 
    border: 1px solid var(--accent-teal); 
    color: white;
    padding: 6px 14px; 
    border-radius: 50px; 
    font-size: 0.8rem; 
    display: inline-flex; 
    align-items: center; 
    gap: 8px; 
    margin-top: 10px; 
    margin-right: 8px;
}


#success-overlay { 
    display: none; 
    position: fixed !important; /* Ahora sí se anclará a la pantalla */
    top: 0; left: 0; 
    width: 100vw; height: 100vh; /* 100% de la pantalla exacta */
    background: rgba(4, 13, 19, 0.95); 
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    flex-direction: column; 
    justify-content: center; 
    align-items: center; 
    padding: 20px; 
    box-sizing: border-box !important; /* Evita que el padding genere scroll */
    z-index: 999999 !important; /* Por encima de todo el sitio */
}

.action-btn { 
    display: block; width: 100%; padding: 15px; margin-bottom: 10px; border-radius: 8px; 
    text-decoration: none; font-weight: bold; font-size: 0.9rem; text-align: center; border:none;
}
.btn-epk { background: var(--accent-sand); color: #000; }
.btn-rank { background: transparent; color: var(--text-white); border: 1px solid var(--border-glass); }