:root{

    --blue-dark:#03152f;
    --blue-primary:#0d63ff;
    --blue-light:#7ad8ff;
    --text:#eef8ff;
}

*{

    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{

    scroll-behavior:smooth;
}

body{

    min-height:100vh;

    overflow-x:hidden;

    font-family:'Playfair Display',sans-serif;

    color:var(--text);

    background:
        linear-gradient(
            135deg,
            #021122 0%,
            #063f96 45%,
            #87d9ff 100%
        );
}

.lux-auth-body{

    position:relative;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:40px 20px;
}

.lux-auth-bg{

    position:fixed;
    inset:0;

    background:
        radial-gradient(
            circle at top left,
            rgba(126,219,255,.25),
            transparent 35%
        ),
        radial-gradient(
            circle at bottom right,
            rgba(0,102,255,.28),
            transparent 35%
        );

    z-index:1;
}

.lux-auth-noise{

    position:fixed;
    inset:0;

    background-image:
        radial-gradient(
            rgba(255,255,255,.06) 1px,
            transparent 1px
        );

    background-size:4px 4px;

    opacity:.2;

    z-index:1;
}

.lux-auth-light{

    position:fixed;

    border-radius:50%;

    filter:blur(80px);

    z-index:1;

    animation:
        floatingLight 10s ease-in-out infinite;
}

.light-1{

    width:260px;
    height:260px;

    top:5%;
    left:5%;

    background:
        rgba(89,204,255,.35);
}

.light-2{

    width:320px;
    height:320px;

    right:-60px;
    top:20%;

    background:
        rgba(0,102,255,.28);

    animation-delay:2s;
}

.light-3{

    width:280px;
    height:280px;

    bottom:-50px;
    left:30%;

    background:
        rgba(120,220,255,.25);

    animation-delay:4s;
}

.lux-auth-wrapper{

    position:relative;

    z-index:5;

    width:100%;
    max-width:1200px;
}

.lux-auth-logo{

    display:flex;
    align-items:center;
    gap:18px;

    width:max-content;

    margin:0 auto 30px;

    text-decoration:none;

    color:white;
}

.lux-auth-logo-icon img{

    width:76px;
    height:76px;

    border-radius:50px;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:24px;
    font-weight:800;

    background:
        linear-gradient(
            135deg,
            #9be8ff,
            #0d63ff
        );

    box-shadow:
        0 0 40px rgba(120,220,255,.55),
        0 25px 50px rgba(0,0,0,.35);

    transform:
        perspective(600px)
        rotateX(12deg);
}

.lux-auth-logo h2{

    font-size:34px;

    font-family:'Playfair Display',serif;

    letter-spacing:.08em;

    text-shadow:
        0 6px 18px rgba(0,0,0,.35),
        0 0 22px rgba(120,220,255,.45);
}

.lux-auth-logo span{

    font-size:11px;

    letter-spacing:.4em;

    opacity:.8;
}

.lux-auth-card{

    position:relative;

    width:100%;
    max-width:600px;

    margin:auto;

    padding:30px;

    border-radius:42px;

    overflow:hidden;

    background:
        linear-gradient(
            135deg,
            rgba(255,255,255,.12),
            rgba(255,255,255,.05)
        );

    backdrop-filter:blur(28px);

    border:
        1px solid rgba(255,255,255,.12);

    box-shadow:
        0 40px 90px rgba(0,0,0,.35);
}

.lux-auth-card.large{

    max-width:800px;
}

.lux-auth-card::before{

    content:'';

    position:absolute;

    inset:0;

    background:
        linear-gradient(
            135deg,
            rgba(255,255,255,.12),
            transparent 50%
        );

    pointer-events:none;
}

.lux-auth-top{

    margin-bottom:36px;

    text-align:center;
}

.lux-auth-badge{

    display:inline-flex;

    padding:12px 22px;

    border-radius:999px;

    margin-bottom:24px;

    background:
        rgba(255,255,255,.12);

    border:
        1px solid rgba(255,255,255,.14);

    font-size:12px;

    font-weight:700;

    letter-spacing:.3em;

    color:#a9ecff;

    text-transform:uppercase;
}

.lux-auth-top h1{

    font-size:58px;

    line-height:1.05;

    margin-bottom:18px;

    font-family:'Playfair Display',serif;

    text-shadow:
        0 5px 0 rgba(255,255,255,.08),
        0 12px 30px rgba(0,0,0,.45),
        0 0 25px rgba(120,220,255,.25);
}

.lux-auth-top p{

    max-width:580px;

    margin:auto;

    line-height:1.9;

    color:
        rgba(255,255,255,.82);
}

.lux-alert{

    padding:18px 22px;

    border-radius:22px;

    margin-bottom:28px;

    font-weight:600;
}

.lux-alert.success{

    background:
        rgba(16,185,129,.15);

    border:
        1px solid rgba(16,185,129,.35);

    color:#b9ffe5;
}

.lux-alert.danger{

    background:
        rgba(239,68,68,.16);

    border:
        1px solid rgba(239,68,68,.35);

    color:#ffd1d1;
}

.lux-auth-form{

    display:flex;
    flex-direction:column;

    gap:24px;
}

.lux-form-grid{

    display:grid;

    grid-template-columns:
        repeat(2,1fr);

    gap:24px;
}

.lux-form-group{

    display:flex;
    flex-direction:column;

    gap:12px;
}

.lux-form-group label{

    font-size:13px;

    font-weight:700;

    letter-spacing:.18em;

    text-transform:capitalize;

    color:#bdefff;
}

.lux-input,
.lux-textarea,
.auth-form input{

    width:100%;

    border:none;

    outline:none;

    border-radius:24px;

    padding:20px 22px;

    font-size:15px;

    font-weight:600;

    color:white;

    background:
        rgba(255,255,255,.09);

    border:
        1px solid rgba(255,255,255,.12);

    backdrop-filter:blur(12px);

    transition:.35s;
}

.lux-input::placeholder,
.lux-textarea::placeholder{

    color:
        rgba(255,255,255,.45);
}

.lux-input:focus,
.lux-textarea:focus,
.auth-form input:focus{

    border:
        1px solid rgba(120,220,255,.55);

    box-shadow:
        0 0 0 4px rgba(120,220,255,.12),
        0 15px 35px rgba(0,0,0,.25);

    transform:
        translateY(-2px);
}

.lux-textarea{

    resize:none;
}

.lux-auth-btn,
.btn-auth{

    position:relative;

    overflow:hidden;

    height:62px;

    border:none;

    border-radius:999px;

    cursor:pointer;

    font-size:16px;

    font-weight:700;

    letter-spacing:.06em;

    color:#042046;

    background:
        linear-gradient(
            135deg,
            #8ce4ff,
            #0d63ff
        );

    box-shadow:
        0 20px 40px rgba(0,102,255,.35),
        0 0 24px rgba(120,220,255,.25);

    transition:.35s;
    text-transform:uppercase;
}

.lux-auth-btn::before,
.btn-auth::before{

    content:'';

    position:absolute;
    inset:0;

    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(255,255,255,.55),
            transparent
        );

    transform:translateX(-120%);
}

.lux-auth-btn:hover::before,
.btn-auth:hover::before{

    animation:
        shine .9s linear;
}

.lux-auth-btn:hover,
.btn-auth:hover{

    transform:
        translateY(-4px)
        scale(1.02);
}

.lux-auth-footer{

    display:flex;

    align-items:center;
    justify-content:space-between;

    gap:20px;

    margin-top:32px;
}

.lux-auth-footer.center{

    justify-content:center;
}

.lux-auth-footer a{

    position:relative;

    color:#bdefff;

    text-decoration:none;

    font-weight:700;

    transition:.3s;
}

.lux-auth-footer a::after{

    content:'';

    position:absolute;

    left:0;
    bottom:-6px;

    width:0;
    height:2px;

    background:#8ce4ff;

    transition:.3s;
}

.lux-auth-footer a:hover{

    color:white;
}

.lux-auth-footer a:hover::after{

    width:100%;
}

.auth-header{

    text-align:center;

    margin-bottom:34px;
}

.auth-header h1{

    font-size:56px;

    font-family:'Playfair Display',serif;

    margin-bottom:16px;

    text-shadow:
        0 12px 30px rgba(0,0,0,.35);
}

.auth-header p{

    color:
        rgba(255,255,255,.82);

    line-height:1.8;
}

.auth-form{

    display:flex;
    flex-direction:column;

    gap:24px;
}

.form-group{

    display:flex;
    flex-direction:column;

    gap:12px;
}

.form-group label{

    font-size:13px;

    font-weight:700;

    letter-spacing:.18em;

    color:#bdefff;

    text-transform:capitalize;
}

@keyframes floatingLight{

    0%,100%{

        transform:
            translateY(0)
            translateX(0);
    }

    50%{

        transform:
            translateY(-24px)
            translateX(12px);
    }
}

@keyframes shine{

    100%{

        transform:translateX(120%);
    }
}

@media(max-width:768px){

    .lux-auth-body{

        padding:20px 14px 120px;
    }

    .lux-auth-card{

        padding:34px 22px;

        border-radius:30px;
    }

    .lux-auth-card.large{

        padding:34px 22px;
    }

    .lux-auth-top h1,
    .auth-header h1{

        font-size:38px;
    }

    .lux-form-grid{

        grid-template-columns:1fr;
    }

    .lux-auth-footer{

        flex-direction:column;
    }

    .lux-auth-logo{

        transform:scale(.9);
    }
}
