/* ===== GLOBAL ===== */
body{
    margin:0;
    font-family:'Segoe UI';
    color:white;
    overflow:hidden;
}

/* ===== FONDO EPICO ===== */
.bg{
    position:fixed;
    width:100%;
    height:100%;
    background:
        radial-gradient(circle at 20% 30%, #1a0033, transparent),
        radial-gradient(circle at 80% 70%, #34006e, transparent),
        radial-gradient(circle at 50% 50%, #00330055, transparent),
        #020003;
    animation:bgMove 12s infinite alternate;
}

@keyframes bgMove{
    0%{filter:hue-rotate(0deg);}
    100%{filter:hue-rotate(20deg);}
}

/* ===== LAYOUT ===== */
.container{
    display:flex;
    justify-content:center;
    align-items:center;
    height:100vh;
}

/* ===== CARD ===== */
.card{
    width:400px;
    padding:35px;
    border-radius:20px;

    background:rgba(20,20,30,0.6);
    backdrop-filter:blur(20px);

    border:1px solid rgba(255,255,255,0.05);

    box-shadow:
        0 0 30px rgba(128,0,255,0.3),
        0 0 60px rgba(128,0,255,0.2);

    transition:0.3s;
}

/* 🔥 HOVER */
.card:hover{
    transform:translateY(-3px);
}

/* ===== LOGO ===== */
.logo{
    width:100px;
    display:block;
    margin:auto;
    margin-bottom:5px;
    filter:drop-shadow(0 0 15px #8000ff);
}

/* ===== TEXTOS ===== */
h2{
    text-align:center;
    margin-top:10px;
}

.subtitle{
    text-align:center;
    color:#aaa;
    font-size:14px;
}

/* ===== INPUT ===== */
input{
    width:100%;
    margin:10px 0;
    padding:12px;
    border-radius:10px;
    border:1px solid #333;
    background:#1a1a1a;
    color:white;
    transition:0.3s;
}

/* 🔥 FOCUS PRO */
input:focus{
    border-color:#a855f7;
    box-shadow:0 0 15px #8000ff;
    outline:none;
}

/* ===== BOTON ===== */
button{
    width:100%;
    padding:12px;
    border:none;
    border-radius:10px;
    background:linear-gradient(45deg,#8000ff,#ff00ff);
    color:white;
    cursor:pointer;
    margin-top:10px;
    transition:0.3s;
}

button:hover{
    box-shadow:0 0 20px #8000ff;
    transform:scale(1.03);
}

.google-btn{
    background:linear-gradient(45deg,#ffffff,#dcffe7);
    color:#10131d;
    font-weight:700;
}

.google-btn:hover{
    box-shadow:0 0 18px rgba(105,255,174,0.42);
}

/* ===== BOTON SECUNDARIO ===== */
.ghost{
    background:transparent;
    border:1px solid #8000ff;
}

/* ===== MENSAJES ===== */
.success{
    color:#00ff88;
    text-align:center;
    animation:fadeIn 0.3s;
}

.error{
    color:#ff3c3c;
    text-align:center;
    animation:shake 0.3s;
}

/* ===== HR ===== */
hr{
    margin:15px 0;
    border:0;
    border-top:1px solid #333;
}

/* =========================
   🎉 ÉXITO OVERLAY
========================= */
.success-overlay{
    position:fixed;
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.85);
    display:none;
    justify-content:center;
    align-items:center;
    z-index:10;
}

.success-box{
    text-align:center;
    animation:pop 0.4s ease;
}

.success-box h1{
    font-size:80px;
    color:#00ff88;
    text-shadow:0 0 30px #00ff88;
}

.success-box p{
    font-size:18px;
}

/* ===== ANIMACIONES ===== */
@keyframes pop{
    0%{transform:scale(0.5);opacity:0;}
    100%{transform:scale(1);opacity:1;}
}

@keyframes fadeIn{
    from{opacity:0;}
    to{opacity:1;}
}

@keyframes shake{
    0%{transform:translateX(0);}
    25%{transform:translateX(-5px);}
    50%{transform:translateX(5px);}
    75%{transform:translateX(-5px);}
    100%{transform:translateX(0);}
}

/* 🔥 GLOW CUANDO REGISTRA */
.success-glow{
    box-shadow:0 0 40px #00ff88 !important;
}

/* ⚡ BORDE LASER */
.card::before {
    content: "";
    position: absolute;
    inset: -4px; /* tamaño del borde */
    border-radius: 22px;

    background: linear-gradient(
        90deg,
        #8000ff,
        #002fff,
        #02d0d0,
        #05ee85,
        #00ff73,
        #00ff73,
        #05ee85,
        #02d0d0,
        #002fff,
        #8000ff  
    );

    background-size: 300% 300%;

    animation: laserMove 4s linear infinite;

    z-index: -1;
}

.card::before {
    filter: blur(10px);
    opacity: 10;
}

/* 🧊 INTERIOR (para que no tape el fondo) */
.card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 20px;
    background: rgba(10,10,20,0.95);
    z-index: -1;
}

/* 🎯 ANIMACIÓN */
@keyframes laserMove {
    0% { background-position: 0% 50%; }
    100% { background-position: 300% 50%; }
}

