/* =========================================================
   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;
}


/* =========================================================
   LOGIN OPTION CARDS
========================================================= */

.login-option-cards{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px;

    margin-bottom:32px;
}


/* =========================================================
   LOGIN OPTION CARD
========================================================= */

.login-option-card{
    position:relative;
    overflow:hidden;

    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;

    text-align:center;

    min-height:180px;

    padding:24px 20px;

    border-radius:22px;

    background:
    linear-gradient(
    145deg,
    rgba(255,255,255,0.98),
    rgba(248,250,252,0.95));

    border:
    1px solid rgba(79,70,229,0.10);

    cursor:pointer;

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease,
    border-color 0.35s ease,
    background 0.35s ease;

    box-shadow:
    0 10px 25px rgba(15,23,42,0.06);
}


/* =========================================================
   BACKGROUND EFFECTS
========================================================= */

.login-option-card::before{
    content:"";

    position:absolute;
    inset:0;

    background:
    linear-gradient(
    135deg,
    rgba(79,70,229,0.04),
    rgba(6,182,212,0.03));

    opacity:0;

    transition:
    opacity 0.35s ease;
}

.login-option-card::after{
    content:"";

    position:absolute;

    width:150px;
    height:150px;

    top:-60px;
    right:-50px;

    border-radius:50%;

    background:
    rgba(79,70,229,0.05);

    transition:
    transform 0.4s ease;
}


/* =========================================================
   HOVER EFFECT
========================================================= */

.login-option-card:hover{
    transform:
    translateY(-6px);

    border-color:
    rgba(79,70,229,0.22);

    background:
    linear-gradient(
    145deg,
    rgba(255,255,255,1),
    rgba(241,245,249,0.98));

    box-shadow:
    0 18px 40px rgba(79,70,229,0.14);
}

.login-option-card:hover::before{
    opacity:1;
}

.login-option-card:hover::after{
    transform:scale(1.08);
}


/* =========================================================
   ACTIVE CARD
========================================================= */

.login-option-card.active{
    border-color:
    rgba(79,70,229,0.30);

    background:
    linear-gradient(
    145deg,
    rgba(238,242,255,0.95),
    rgba(224,242,254,0.92));

    box-shadow:
    0 18px 38px rgba(79,70,229,0.14);
}


/* =========================================================
   ICON
========================================================= */

.login-option-icon{
    position:relative;
    z-index:2;

    width:62px;
    height:62px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:18px;

    background:
    linear-gradient(
    135deg,
    #312e81 0%,
    #4338ca 35%,
    #4f46e5 70%,
    #06b6d4 100%);

    color:#ffffff;

    font-size:26px;

    margin-bottom:18px;

    box-shadow:
    0 12px 28px rgba(79,70,229,0.24);

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease;
}

.login-option-card:hover .login-option-icon{
    transform:
    rotate(-5deg)
    scale(1.05);

    box-shadow:
    0 18px 36px rgba(79,70,229,0.30);
}


/* =========================================================
   CONTENT
========================================================= */

.login-option-content{
    position:relative;
    z-index:2;

    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
}

.login-option-content h5{
    margin-bottom:10px;

    font-size:20px;
    font-weight:800;

    color:var(--dark);

    letter-spacing:-0.3px;
}

.login-option-content p{
    margin:0;

    max-width:220px;

    color:#64748b;

    font-size:13px;
    line-height:1.7;
}


/* =========================================================
   ARROW BUTTON
========================================================= */

.login-option-arrow{
    position:relative;
    z-index:2;

    width:42px;
    height:42px;

    margin-top:20px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:
    rgba(79,70,229,0.08);

    color:#4338ca;

    font-size:16px;

    transition:
    transform 0.3s ease,
    background 0.3s ease,
    color 0.3s ease;
}

.login-option-card:hover .login-option-arrow{
    transform:
    translateX(4px);

    background:
    rgba(79,70,229,0.14);

    color:#312e81;
}


/* =========================================================
   RESPONSIVE
========================================================= */

@media(max-width:991px){

    .login-option-cards{
        grid-template-columns:1fr;
    }

    .login-option-card{
        min-height:auto;
    }
}

@media(max-width:576px){

    .login-option-cards{
        gap:14px;
    }

    .login-option-card{
        padding:22px 18px;

        border-radius:20px;
    }

    .login-option-icon{
        width:56px;
        height:56px;

        font-size:24px;

        border-radius:16px;

        margin-bottom:16px;
    }

    .login-option-content h5{
        font-size:18px;
    }

    .login-option-content p{
        font-size:12px;
        line-height:1.7;
    }

    .login-option-arrow{
        width:38px;
        height:38px;

        margin-top:18px;

        font-size:15px;
    }
}


/* =========================================================
   CARDS
========================================================= */

.login-info-card{
    text-align:center;
}

.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 .login-icon{
    margin-left:auto;
    margin-right:auto;
}

.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);
}


/* =========================================================
   ICONS
========================================================= */

.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);
}


/* =========================================================
   TEXT
========================================================= */

.login-info-card h2{
    font-size:34px;
    font-weight:900;
    
    text-align:center;

    color:var(--dark);

    margin-bottom:18px;
}

.login-info-card p{
    color:#64748b;

    line-height:1.9;

    margin-bottom:35px;
    
    max-width:520px;
}

.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;
}

.security-item h6{
    font-weight:800;
    margin-bottom:4px;

    color:var(--dark);
}

.security-item span{
    color:#64748b;
    font-size:14px;
}


/* =========================================================
   FORM
========================================================= */

.form-group-custom{
    margin-bottom:24px;
}

.form-group-custom label{
    display:block;

    margin-bottom:10px;

    font-weight:700;
    color:var(--dark);
}

.input-wrapper{
    position:relative;
}

.input-wrapper i{
    position:absolute;

    left:18px;
    top:50%;

    transform:translateY(-50%);

    color:#4338ca;

    font-size:17px;
}

.form-control-custom{
    width:100%;
    height:60px;

    padding:0 52px;

    border-radius:16px;

    border:
    1px solid #dbe2ea;

    background:#ffffff;

    font-size:15px;
    font-weight:500;

    color:#0f172a;

    transition:
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    transform 0.35s ease;
}

.form-control-custom::placeholder{
    color:#94a3b8;
}

.form-control-custom:focus{
    outline:none;

    transform:translateY(-2px);

    border-color:#4f46e5;

    box-shadow:
    0 0 0 5px rgba(79,70,229,0.10),
    0 10px 25px rgba(79,70,229,0.10);
}

.toggle-password{
    position:absolute;

    right:16px;
    top:50%;

    transform:translateY(-50%);

    border:none;
    background:none;

    color:#4338ca;

    font-size:18px;

    cursor:pointer;
}


/* =========================================================
   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;

    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;

    cursor:pointer;

    transition:
    transform 0.35s ease,
    box-shadow 0.35s ease;

    box-shadow:
    0 14px 35px rgba(79,70,229,0.35);
}

.login-btn:hover{
    transform:
    translateY(-4px)
    scale(1.02);

    box-shadow:
    0 24px 45px rgba(79,70,229,0.45);
}

.login-btn:disabled{
    opacity:0.7;
    cursor:not-allowed;
}

.error-text{
    display:block;

    margin-top:8px;

    color:#ef4444;

    font-size:13px;
    font-weight:600;
}

.has-error{
    border-color:#ef4444 !important;
}

.second_input_group{
    display:none;
    text-align:center;
}


/* =========================================================
   ANIMATION
========================================================= */

@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);
    }
}


/* =========================================================
   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;
    }
}