<!-- ================= CSS ================= -->

/* =========================================================
   PAGE HEADER
========================================================= */

.page-header-section{
    padding:70px 0 40px;
    position:relative;
    overflow:hidden;
}

.page-header-card{
    position:relative;
    overflow:hidden;

    padding:70px 50px;
    border-radius:30px;

    background:
    linear-gradient(
    135deg,
    rgba(49,46,129,0.96) 0%,
    rgba(67,56,202,0.94) 35%,
    rgba(79,70,229,0.92) 65%,
    rgba(6,182,212,0.88) 100%);

    box-shadow:
    0 25px 60px rgba(79,70,229,0.28);

    animation:
    floatHeader 6s ease-in-out infinite;
}

.page-header-card::before{
    content:"";

    position:absolute;

    width:420px;
    height:420px;

    top:-180px;
    right:-120px;

    border-radius:50%;

    background:
    rgba(255,255,255,0.08);
}

.page-header-card::after{
    content:"";

    position:absolute;

    width:280px;
    height:280px;

    bottom:-120px;
    left:-100px;

    border-radius:50%;

    background:
    rgba(255,255,255,0.06);
}

.page-header-content{
    position:relative;
    z-index:2;

    text-align:center;
    color:#ffffff;

    animation:
    fadeSlideUp 0.8s ease both;
}

.page-badge{
    display:inline-flex;
    align-items:center;
    gap:8px;

    padding:10px 18px;
    margin-bottom:22px;

    border-radius:50px;

    background:
    rgba(255,255,255,0.16);

    backdrop-filter:blur(12px);

    color:#ffffff;

    font-size:14px;
    font-weight:700;

    border:
    1px solid rgba(255,255,255,0.18);

    transition:
    transform 0.35s ease,
    background 0.35s ease;
}

.page-badge:hover{
    transform:
    translateY(-2px)
    scale(1.03);

    background:
    rgba(255,255,255,0.22);
}

.page-badge i{
    font-size:15px;
}

.page-header-content h1{
    font-size:56px;
    font-weight:900;

    margin-bottom:18px;

    letter-spacing:-1px;
}

.page-header-content p{
    max-width:720px;

    margin:auto;

    font-size:17px;
    line-height:1.9;

    opacity:0.96;
}


/* =========================================================
   LOGIN SECTION
========================================================= */

.member-login-section{
    padding:20px 0 90px;
}

.login-wrapper{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:35px;
}


/* =========================================================
   CARDS
========================================================= */

.login-info-card,
.login-card{
    position:relative;
    overflow:hidden;

    padding:45px;
    border-radius:30px;

    background:
    rgba(255,255,255,0.78);

    backdrop-filter:
    blur(18px);

    border:
    1px solid rgba(255,255,255,0.55);

    box-shadow:
    0 20px 45px rgba(15,23,42,0.08);

    transition:
    transform 0.4s ease,
    box-shadow 0.4s ease,
    border-color 0.4s ease;

    animation:
    fadeSlideUp 0.8s ease both;
}

.login-card{
    animation-delay:0.2s;
}

.login-info-card::before,
.login-card::before{
    content:"";

    position:absolute;
    inset:0;

    background:
    linear-gradient(
    135deg,
    rgba(79,70,229,0.04),
    rgba(6,182,212,0.03));

    z-index:0;
}

.login-info-card > *,
.login-card > *{
    position:relative;
    z-index:2;
}

.login-card:hover,
.login-info-card:hover{
    transform:
    translateY(-8px);

    border-color:
    rgba(79,70,229,0.24);

    box-shadow:
    0 30px 60px rgba(15,23,42,0.12);
}


/* =========================================================
   ICON BOXES
========================================================= */

.login-icon,
.login-card-icon,
.otp-icon{
    width:85px;
    height:85px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:24px;

    background:
    linear-gradient(
    135deg,
    #312e81,
    #4338ca,
    #4f46e5,
    #06b6d4);

    color:#ffffff;

    font-size:34px;

    margin-bottom:28px;

    box-shadow:
    0 16px 35px rgba(79,70,229,0.28);

    transition:
    transform 0.4s ease,
    box-shadow 0.4s ease;
}

.login-card-icon,
.otp-icon{
    margin-left:auto;
    margin-right:auto;
}

.login-icon:hover,
.login-card-icon:hover,
.otp-icon:hover{
    transform:
    rotate(-8deg)
    scale(1.08);

    box-shadow:
    0 22px 45px rgba(79,70,229,0.35);
}

.visually-hidden {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

/* =========================================================
   TEXT
========================================================= */

.login-info-card h2{
    font-size:34px;
    font-weight:900;

    color:var(--dark);

    margin-bottom:18px;
}

.login-info-card p{
    color:#64748b;

    line-height:1.9;

    margin-bottom:35px;
}

.login-card-header{
    text-align:center;
    margin-bottom:35px;
}

.login-card-header h3{
    font-size:34px;
    font-weight:900;

    color:var(--dark);

    margin-bottom:10px;
}

.login-card-header p{
    color:#64748b;
}

.otp-title{
    font-size:30px;
    font-weight:900;

    color:var(--dark);

    margin-bottom:10px;
}

.otp-text{
    color:#64748b;
    margin-bottom:28px;
}


/* =========================================================
   SECURITY POINTS
========================================================= */

.security-points{
    display:flex;
    flex-direction:column;
    gap:18px;
}

.security-item{
    display:flex;
    align-items:flex-start;
    gap:16px;

    padding:18px;
    border-radius:18px;

    background:#ffffff;

    border:
    1px solid rgba(0,0,0,0.04);

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    background 0.35s ease;
}

.security-item:hover{
    transform:
    translateY(-6px)
    scale(1.02);

    background:
    linear-gradient(
    135deg,
    rgba(79,70,229,0.04),
    rgba(6,182,212,0.04));

    box-shadow:
    0 18px 35px rgba(0,0,0,0.08);
}

.security-icon{
    min-width:50px;
    height:50px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:14px;

    background:
    linear-gradient(
    135deg,
    #312e81,
    #4f46e5,
    #06b6d4);

    color:#ffffff;

    font-size:18px;

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease;
}

.security-item:hover .security-icon{
    transform:
    rotate(-8deg)
    scale(1.1);

    box-shadow:
    0 10px 25px rgba(79,70,229,0.35);
}

.security-item h6{
    font-weight:800;
    margin-bottom:4px;

    color:var(--dark);
}

.security-item span{
    color:#64748b;
    font-size:14px;
}

/* =========================================================
   ADMIN TYPE CARDS
========================================================= */

.admin-type-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;
    margin-top:10px;
}

.admin-type-card{
    position:relative;

    display:flex;
    align-items:center;
    gap:16px;

    padding:22px 20px;

    border-radius:22px;

    background:#ffffff;

    border:2px solid rgba(99,102,241,0.10);

    cursor:pointer;

    overflow:hidden;

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease,
    background 0.35s ease;
}

.admin-type-card::before{
    content:"";

    position:absolute;
    inset:0;

    background:
    linear-gradient(
        135deg,
        rgba(79,70,229,0.05),
        rgba(6,182,212,0.04)
    );

    opacity:0;

    transition:opacity 0.35s ease;
}

.admin-type-card:hover{
    transform:
        translateY(-6px)
        scale(1.02);

    border-color:#6366f1;

    box-shadow:
        0 18px 35px rgba(79,70,229,0.18);
}

.admin-type-card:hover::before{
    opacity:1;
}

.admin-type-card.active{
    border-color:#4f46e5;

    background:
    linear-gradient(
        135deg,
        rgba(79,70,229,0.10),
        rgba(6,182,212,0.08)
    );

    box-shadow:
        0 20px 40px rgba(79,70,229,0.20);
}

.admin-card-icon{
    width:60px;
    height:60px;

    min-width:60px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:18px;

    background:
    linear-gradient(
        135deg,
        #312e81,
        #4338ca,
        #06b6d4
    );

    color:#ffffff;

    font-size:24px;

    box-shadow:
        0 12px 25px rgba(79,70,229,0.25);

    transition:
        transform 0.35s ease;
}

.admin-type-card:hover .admin-card-icon{
    transform:
        rotate(-6deg)
        scale(1.08);
}

.admin-card-content{
    flex:1;
}

.admin-card-content h6{
    margin:0 0 4px;

    font-size:18px;
    font-weight:800;

    color:var(--dark);
}

.admin-card-content span{
    font-size:14px;
    color:#64748b;
}

.admin-check{
    font-size:24px;

    color:#4f46e5;

    opacity:0;

    transform:scale(0.5);

    transition:
        opacity 0.35s ease,
        transform 0.35s ease;
}

.admin-type-card.active .admin-check{
    opacity:1;
    transform:scale(1);
}

@media(max-width:768px){

    .admin-type-grid{
        grid-template-columns:1fr;
    }
}


/* =========================================================
   FORM GROUPS
========================================================= */

.form-group-custom{
    margin-bottom:24px;
}

.form-group-custom label{
    display:block;

    margin-bottom:10px;

    font-weight:700;
    color:var(--dark);

    transition:
    color 0.3s ease,
    transform 0.3s ease;
}

.form-group-custom:hover label{
    color:#4338ca;
    transform:translateX(2px);
}


/* =========================================================
   INPUTS
========================================================= */

.input-wrapper{
    position:relative;
}

.input-wrapper i{
    position:absolute;

    left:18px;
    top:50%;

    transform:translateY(-50%);

    color:#4338ca;

    font-size:17px;
    font-weight:700;

    transition:
    transform 0.3s ease,
    color 0.3s ease;
}

.input-wrapper:focus-within i{
    color:#06b6d4;

    transform:
    translateY(-50%)
    scale(1.15);
}

.form-control-custom{
    width:100%;
    height:60px;

    padding:0 52px;

    border-radius:16px;

    border:
    1px solid var(--border);

    background:#ffffff;

    font-size:15px;
    font-weight:500;

    color:var(--dark);

    transition:
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    transform 0.35s ease,
    background 0.35s ease;
}

.form-control-custom::placeholder{
    color:#94a3b8;
}

.form-control-custom:hover{
    border-color:#a5b4fc;
}

.form-control-custom:focus{
    outline:none;

    transform:translateY(-2px);

    border-color:#4f46e5;

    background:#ffffff;

    box-shadow:
    0 0 0 5px rgba(79,70,229,0.10),
    0 10px 25px rgba(79,70,229,0.10);
}


/* =========================================================
   TOGGLE PASSWORD
========================================================= */

.toggle-password{
    position:absolute;

    right:16px;
    top:50%;

    transform:translateY(-50%);

    border:none;
    background:none;

    color:#4338ca;

    font-size:18px;

    cursor:pointer;

    transition:
    transform 0.3s ease,
    color 0.3s ease;
}

.toggle-password:hover{
    color:#06b6d4;

    transform:
    translateY(-50%)
    scale(1.15);
}


/* =========================================================
   BUTTONS
========================================================= */

.login-btn{
    width:100%;
    height:60px;

    position:relative;
    overflow:hidden;

    border:none;
    border-radius:18px;

    background:
    linear-gradient(
    135deg,
    #312e81 0%,
    #4338ca 30%,
    #4f46e5 60%,
    #06b6d4 100%);

    color:#ffffff;

    font-weight:800;
    font-size:16px;
    letter-spacing:0.3px;

    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;

    cursor:pointer;

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    filter 0.35s ease;

    box-shadow:
    0 14px 35px rgba(79,70,229,0.35),
    inset 0 1px 0 rgba(255,255,255,0.25);
}

.login-btn::before{
    content:"";

    position:absolute;

    top:0;
    left:-120%;

    width:80%;
    height:100%;

    background:
    linear-gradient(
    90deg,
    transparent,
    rgba(255,255,255,0.35),
    transparent);

    transform:skewX(-25deg);

    transition:left 0.8s ease;
}

.login-btn:hover::before{
    left:140%;
}

.login-btn:hover{
    transform:
    translateY(-4px)
    scale(1.02);

    box-shadow:
    0 24px 45px rgba(79,70,229,0.45),
    0 10px 20px rgba(6,182,212,0.25);

    filter:brightness(1.05);
}

.login-btn:active{
    transform:scale(0.98);
}

.login-btn:disabled{
    opacity:0.7;
    cursor:not-allowed;
}

.login-btn i{
    font-size:18px;
    color:#ffffff;

    transition:
    transform 0.35s ease;
}

.login-btn:hover i{
    transform:translateX(4px);
}


/* =========================================================
   ERROR
========================================================= */

.error-text{
    display:block;

    margin-top:8px;

    color:#ef4444;

    font-size:13px;
    font-weight:600;
}

.has-error{
    border-color:#ef4444 !important;

    animation:
    shake 0.35s ease;
}


/* =========================================================
   OTP SECTION
========================================================= */

.second_input_group{
    display:none;
    text-align:center;

    animation:
    otpFade 0.5s ease;
}


/* =========================================================
   ANIMATIONS
========================================================= */

@keyframes fadeSlideUp{

    from{
        opacity:0;

        transform:
        translateY(30px);
    }

    to{
        opacity:1;

        transform:
        translateY(0);
    }
}

@keyframes floatHeader{

    0%{
        transform:translateY(0px);
    }

    50%{
        transform:translateY(-6px);
    }

    100%{
        transform:translateY(0px);
    }
}

@keyframes otpFade{

    from{
        opacity:0;

        transform:
        translateY(20px);
    }

    to{
        opacity:1;

        transform:
        translateY(0);
    }
}

@keyframes shake{

    0%{
        transform:translateX(0);
    }

    25%{
        transform:translateX(-4px);
    }

    50%{
        transform:translateX(4px);
    }

    75%{
        transform:translateX(-4px);
    }

    100%{
        transform:translateX(0);
    }
}


/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:991px){

    .login-wrapper{
        grid-template-columns:1fr;
    }

    .page-header-content h1{
        font-size:42px;
    }
}

@media(max-width:768px){

    .page-header-card{
        padding:50px 24px;
    }

    .page-header-content h1{
        font-size:34px;
    }

    .login-info-card,
    .login-card{
        padding:30px 22px;
    }

    .login-info-card h2,
    .login-card-header h3{
        font-size:28px;
    }

    .login-btn{
        height:56px;
        font-size:15px;
    }

    .login-btn:hover{
        transform:translateY(-2px);
    }

    .security-item:hover,
    .login-card:hover,
    .login-info-card:hover{
        transform:none;
    }
}