
*{margin:0;padding:0;box-sizing:border-box;font-family:Poppins,sans-serif}
body{background:#ebf1cf;overflow-x:hidden}
.container{display:flex;min-height:100vh}

/* left container */
.left-panel{width:47%;background:#015054;position:relative;overflow:hidden;color:#fff}

/* right container */
.right-panel{width:53%;display:flex;align-items:center;justify-content:center;padding:40px;background:linear-gradient(135deg,#ebf1cf,#f7f9eb)}


/* logo */
.logo{position:absolute;top:35px;left:35px;font-size:46px;font-weight:700;z-index:5}
.logo span{color:#7be1dd}
.logo small{display:block;font-size:12px;font-weight:400;letter-spacing:2px}

/* hero section */
.hero{position:absolute;left:40px;top:340px;max-width:380px;z-index:4}

.hero{
    position:absolute;
    left:40px;
    top:260px;
    max-width:400px;
    z-index:4
}
.hero h1{font-size:44px;line-height:1.05}
.hero span{color:#ebf1cf}
.hero p{margin-top:20px;line-height:1.8;opacity:.9}


/* google sign up */
.google-btn{
    width:100%;
    height:58px;

    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;

    background:#fff;
    border:1px solid #ddd;

    border-radius:12px;

    font-weight:500;

    transition:.3s;
}

.google-btn img{
    width:22px;
}

.google-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 20px rgba(0,0,0,.08);
}



/* animations */
.glass{position:absolute;background:rgba(255,255,255,.08);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:22px;width:250px;box-shadow:0 20px 50px rgba(0,0,0,.2)}
.top-card{top:110px;right:80px;animation:float 6s infinite}
.mid-card{left:100px;bottom:190px;animation:float 7s infinite}
.bottom-card{right:120px;bottom:50px;animation:float 6s infinite}

.bank-card{
position:absolute;left:54%;top:50%;transform:translate(-50%,-50%) rotate(-10deg);
width:300px;height:190px;border-radius:24px;
background:linear-gradient(135deg,#17b8bb,#015054);
box-shadow:0 30px 80px rgba(0,0,0,.4);
overflow:hidden;z-index:3
}
.shine{position:absolute;inset:-100%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.25),transparent);animation:shine 4s linear infinite}
.chip{width:50px;height:40px;background:gold;border-radius:8px;position:absolute;left:25px;top:55px}
.waves{position:absolute;right:25px;top:35px;font-size:28px}
.numbers{position:absolute;left:25px;bottom:55px;letter-spacing:3px}
.holder{position:absolute;left:25px;bottom:25px}
.brand{position:absolute;right:20px;bottom:20px;font-size:34px;font-weight:700}

.radar,.radar:before,.radar:after{
border:1px solid rgba(255,255,255,.08);border-radius:50%;position:absolute
}
.radar1{width:420px;height:420px;left:50%;top:50%;transform:translate(-50%,-50%)}
.radar1:before{content:'';inset:40px}
.radar1:after{content:'';inset:80px}
.radar2{width:260px;height:260px;left:50%;top:50%;transform:translate(-50%,-50%)}
.orbit-line{position:absolute;width:500px;height:500px;border:2px dashed rgba(255,255,255,.18);border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);animation:spin 25s linear infinite}

.particles::before,.particles::after{
content:'';position:absolute;width:100%;height:100%;
background-image:radial-gradient(rgba(255,255,255,.7) 1px,transparent 1px);
background-size:50px 50px;opacity:.25
}


/* header */
.form-card{
width:100%;max-width:700px;
}

.form-card{
    width:100%;
    max-width:620px;
    background:rgba(255,255,255,.75);
backdrop-filter:blur(16px);padding:40px;border-radius:30px;
box-shadow:0 25px 80px rgba(0,0,0,.08)
}


.form-card h2{
    font-size:40px;
    line-height:1.1;
}


.form-card>p{text-align:center;color:#666;margin:10px 0 25px}


/* submit */
.submit-btn{
width:100%;height:58px;border-radius:12px;border:none;cursor:pointer;
background-color: #015054;color: #ebf1cf;
}



.divider{text-align:center;position:relative;margin:22px 0}
.divider:before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:#ddd}
.divider span{background:rgba(255,255,255,.75);padding:0 12px;position:relative}

.row{display:flex;gap:15px}

/* inputs */
input{width:100%;padding:16px;border-radius:12px;border:1px solid #ddd;margin:10px 0}

.password-box{
    position:relative;
}

.password-box input{
    width:100%;
    padding-right:50px;
}

.password-box span{

    position:absolute;

    right:18px;
    top:50%;

    transform:translateY(-50%);

    cursor:pointer;

    user-select:none;

    color:#015054;

    font-size:18px;
}


/* Terms & Conditions */

.terms{
    display:flex;
    align-items:center;
    gap:10px;
    margin-top:15px;
    cursor:pointer;
    font-size:14px;
    color:#555;
}

.terms input[type="checkbox"]{
    width:18px;
    height:18px;
    margin:0;
    padding:0;
    flex-shrink:0;
    accent-color:#015054;
}

.strength{height:6px;background:#ddd;border-radius:20px;margin:10px 0}
#strength-bar{height:100%;width:0;background:#015054;border-radius:20px;transition:.3s}

label{display:block;margin:10px 0;color:#555}
.signin{text-align:center;margin-top:20px}
.signin a{color:#015054;font-weight:600;text-decoration:none}




/* transition */

#loader {
  position: fixed;
  inset: 0;
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.dots {
  display: flex;
  gap: 10px;
}

.dots span {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  animation: bounce 1s infinite ease-in-out;
}

.dots span:nth-child(1),
.dots span:nth-child(3) {
  background: #015054;
}

.dots span:nth-child(2),
.dots span:nth-child(4) {
  background: #EBF1CF;
}

@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
    opacity: 0.4;
  }
  50% {
    transform: translateY(-10px);
    opacity: 1;
  }
}

@keyframes float{50%{transform:translateY(-18px)}}
@keyframes spin{from{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes shine{to{transform:translateX(250%)}}



@media (max-width: 992px){

    .container{
        flex-direction:column;
    }

    .left-panel{
        width:100%;
        min-height:450px;
    }

    .right-panel{
        width:100%;
    }

    .hero{
        top:180px;
        left:25px;
        right:25px;
    }

    .hero h1{
        font-size:42px;
    }

    .bank-card{
        width:260px;
        height:165px;
    }

}

@media (max-width: 768px){

    .left-panel{
        display:none;
    }

    .right-panel{
        width:100%;
        padding:20px;
    }

    .form-card{
        padding:25px;
    }

    .form-card h2{
        font-size:30px;
    }

    .row{
        flex-direction:column;
        gap:0;
    }

    .google-btn,
    .submit-btn{
        height:54px;
    }

}

/* =========================
   LOGIN CARD
========================= */

.form-card{
    width:100%;
    max-width:560px;

    padding:40px;

    background:rgba(255,255,255,.75);
    backdrop-filter:blur(16px);

    border-radius:30px;

    box-shadow:
    0 25px 80px rgba(0,0,0,.08);
}

.form-card h2{
    text-align:center;
    color:#015054;
    font-size:40px;
}

.form-card > p{
    text-align:center;
    margin:12px 0 25px;
    color:#666;
}

/* =========================
   INPUTS
========================= */

.input-group{
    margin-bottom:15px;
}

input[type="email"],
input[type="password"]{
    width:100%;

    padding:16px;

    border:1px solid #ddd;
    border-radius:12px;

    outline:none;

    transition:.3s;
}

input:focus{
    border-color:#015054;
    box-shadow:0 0 12px rgba(1,80,84,.15);
}

/* =========================
   PASSWORD TOGGLE
========================= */

.password-wrap{
    position:relative;
}

.password-wrap input{
    padding-right:50px;
}

#togglePassword{
    position:absolute;

    right:18px;
    top:50%;

    transform:translateY(-50%);

    cursor:pointer;
    color:#015054;
}

/* =========================
   OPTIONS
========================= */

.options{
    display:flex;
    justify-content:space-between;
    align-items:center;

    margin:15px 0 25px;
}

.remember{
    display:flex;
    align-items:center;
    gap:10px;
}

.remember input{
    width:18px;
    height:18px;
}

.options a{
    color:#015054;
    text-decoration:none;
    font-weight:500;
}



.input-group{
    margin-bottom:15px;
}

.password-wrap{
    position:relative;
}

.password-wrap input{
    padding-right:55px;
}

#togglePassword{

    position:absolute;

    right:18px;
    top:50%;

    transform:translateY(-50%);

    cursor:pointer;

    font-size:18px;
}

.options{

    display:flex;

    justify-content:space-between;

    align-items:center;

    margin:15px 0 25px;
}

.remember{

    display:flex;

    align-items:center;

    gap:10px;
}

.remember input{

    width:18px;
    height:18px;

    margin:0;
}

.submit-btn{

    width:100%;

    height:58px;

    background:#015054;

    color:white;

    border:none;

    border-radius:12px;

    cursor:pointer;

    font-weight:600;

    transition:.3s;
}

.submit-btn:hover{

    background:#02686d;

    transform:translateY(-2px);
}


/* =========================
   BUTTONS
========================= */

.submit-btn{
    width:100%;
    height:58px;

    border:none;
    border-radius:12px;

    background:#015054;
    color:white;

    font-weight:600;

    cursor:pointer;

    transition:.3s;
}

.submit-btn:hover{
    background:#02686d;
    transform:translateY(-2px);

    box-shadow:
    0 10px 30px rgba(1,80,84,.25);
}

.google-btn{
    width:100%;
    height:58px;

    display:flex;
    align-items:center;
    justify-content:center;
    gap:12px;

    background:white;

    border:1px solid #ddd;
    border-radius:12px;

    cursor:pointer;

    transition:.3s;
}

.google-btn img{
    width:22px;
}

.google-btn:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 20px rgba(0,0,0,.08);
}

/* =========================
   DIVIDER
========================= */

.divider{
    text-align:center;
    position:relative;
    margin:22px 0;
}

.divider:before{
    content:'';

    position:absolute;
    left:0;
    right:0;
    top:50%;

    height:1px;
    background:#ddd;
}

.divider span{
    position:relative;
    background:white;
    padding:0 12px;
}

/* =========================
   FOOTER LINK
========================= */

.signin{
    text-align:center;
    margin-top:20px;
}

.signin a{
    color:#015054;
    text-decoration:none;
    font-weight:600;
}

/* =========================
   ANIMATIONS
========================= */

@keyframes float{
    50%{
        transform:translateY(-18px);
    }
}

@keyframes spin{
    from{
        transform:translate(-50%,-50%) rotate(0);
    }
    to{
        transform:translate(-50%,-50%) rotate(360deg);
    }
}

@keyframes shine{
    to{
        transform:translateX(250%);
    }
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:992px){

    .left-panel{
        display:none;
    }

    .right-panel{
        width:100%;
        min-height:100vh;
    }
}

@media(max-width:768px){

    .right-panel{
        padding:20px;
    }

    .form-card{
        padding:25px;
        border-radius:20px;
    }

    .form-card h2{
        font-size:30px;
    }

    .options{
        flex-direction:column;
        align-items:flex-start;
        gap:10px;
    }
}
.form-card{
    width:100%;
    max-width:550px;

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

    backdrop-filter:blur(16px);

    padding:40px;

    border-radius:30px;

    box-shadow:0 25px 80px rgba(0,0,0,.08);

    text-align:center;
}

.icon-box{
    width:90px;
    height:90px;
    border-radius:50%;
    background:#015054;
    color:#fff;
    margin:auto;
    display:flex;
    justify-content:center;
    align-items:center;
    font-size:38px;
    margin-bottom:20px;
}

.form-card h2{
    color:#015054;
    font-size:42px;
}

.form-card p{
    color:#666;
    margin:15px 0 25px;
}

.form-card input{
    width:100%;
    padding:16px;
    border:1px solid #ddd;
    border-radius:12px;
    outline:none;
}

.form-card input:focus{
    border-color:#015054;
}

.submit-btn{
    width:100%;
    height:58px;
    margin-top:20px;
    border:none;
    border-radius:12px;
    background:#015054;
    color:#fff;
    cursor:pointer;
    font-weight:600;
    transition:.3s;
}

.submit-btn:hover{
    background:#02686d;
}

.signin{
    margin-top:20px;
}

.signin a{
    color:#015054;
    text-decoration:none;
    font-weight:600;
}

/* ANIMATIONS */

@keyframes float{
    50%{
        transform:translateY(-18px);
    }
}

@keyframes spin{
    from{
        transform:translate(-50%,-50%) rotate(0);
    }
    to{
        transform:translate(-50%,-50%) rotate(360deg);
    }
}

@keyframes cardShine{
    0%{
        left:-150%;
    }

    20%{
        left:180%;
    }

    100%{
        left:180%;
    }
}

/* MOBILE */

@media(max-width:992px){

    .left-panel{
        display:none;
    }

    .right-panel{
        width:100%;
    }
}

@media(max-width:768px){

    .right-panel{
        padding:20px;
    }

    .form-card{
        padding:25px;
    }

    .form-card h2{
        font-size:32px;
    }
}
.options{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 15px 0 25px;
    gap: 20px;
}

.remember{
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    white-space: nowrap;
    color: #555;
    font-size: 14px;
}

.remember input[type="checkbox"]{
    width: 18px;
    height: 18px;
    margin: 0;
    flex-shrink: 0;
    accent-color: #015054;
}

.dots {
    display: flex;
    gap: 10px;
}

.dots span {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    animation: bounce 1s infinite ease-in-out;
}

.dots span:nth-child(1),
.dots span:nth-child(3) {
    background: #015054;
}

.dots span:nth-child(2),
.dots span:nth-child(4) {
    background: #EBF1CF;
}
.dots{
    display:flex;
    gap:12px;
}

.dots span{
    width:14px;
    height:14px;
    border-radius:50%;
    background:#015054;
    opacity:0.25;
    transform:scale(.8);
    animation:dotPulse 1.2s infinite ease-in-out;
}

.dots span:nth-child(1){
    animation-delay:0s;
}

.dots span:nth-child(2){
    animation-delay:0.2s;
}

.dots span:nth-child(3){
    animation-delay:0.4s;
}

.dots span:nth-child(4){
    animation-delay:0.6s;
}

@keyframes dotPulse{
    0%, 100%{
        opacity:0.25;
        transform:scale(.8);
        background:#015054;
    }

    50%{
        opacity:1;
        transform:scale(1.3);
        background:#17b8bb;
    }
}
.auth-alert{
    width:100%;
    padding:12px 14px;
    border-radius:12px;
    font-size:14px;
    margin-bottom:14px;
    text-align:left;
}

.auth-alert-error{
    background:#fdecec;
    color:#b42318;
    border:1px solid #f5b5b5;
}

.auth-alert-success{
    background:#e8f7ee;
    color:#137333;
    border:1px solid #b7e4c7;
}








/* forgot password */
/* Background Glow */

.background-circle{
    position:absolute;

    border-radius:50%;

    filter:blur(100px);

    opacity:.3;

    animation:float 8s ease-in-out infinite;
}

.circle1{
    width:300px;
    height:300px;

    background:#015054;

    top:-80px;
    left:-80px;
}

.circle2{
    width:350px;
    height:350px;

    background:#17b8bb;

    right:-100px;
    bottom:-100px;

    animation-delay:2s;
}

/* Card */

.reset-card{

    width:90%;
    max-width:500px;

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

    backdrop-filter:blur(20px);

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

    border-radius:30px;

    padding:40px;

    text-align:center;

    box-shadow:
    0 25px 80px rgba(0,0,0,.08);

    animation:slideUp .8s ease;
}

/* Icon */

.lock-icon{

    width:90px;
    height:90px;

    background:#015054;

    color:white;

    border-radius:50%;

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

    margin:auto;

    font-size:40px;

    margin-bottom:20px;
}

h1{
    color:#015054;
    margin-bottom:10px;
}

p{
    color:#666;
    margin-bottom:25px;
}

/* Inputs */

.password-box{

    position:relative;

    margin-bottom:15px;
}

.password-box input{

    width:100%;

    padding:16px;

    padding-right:55px;

    border:1px solid #ddd;

    border-radius:12px;

    outline:none;

    transition:.3s;
}

.password-box input:focus{

    border-color:#015054;

    box-shadow:
    0 0 15px rgba(1,80,84,.15);
}

.password-box span{

    position:absolute;

    right:18px;
    top:50%;

    transform:translateY(-50%);

    cursor:pointer;

    user-select:none;
}

/* Strength Bar */

.strength{

    width:100%;
    height:6px;

    background:#ddd;

    border-radius:20px;

    margin-bottom:20px;
}

#strength-bar{

    width:0;

    height:100%;

    border-radius:20px;

    transition:.3s;
}

/* Button */

.submit-btn{

    width:100%;
    height:58px;

    border:none;

    border-radius:12px;

    background:#015054;

    color:white;

    font-size:15px;

    font-weight:600;

    cursor:pointer;

    transition:.3s;
}

.submit-btn:hover{

    background:#02686d;

    transform:translateY(-2px);
}

/* Link */

.login-link{

    margin-top:20px;

    color:#666;
}

.login-link a{

    color:#015054;

    text-decoration:none;

    font-weight:600;
}

/* Animations */

@keyframes slideUp{

    from{
        opacity:0;
        transform:translateY(40px);
    }

    to{
        opacity:1;
        transform:translateY(0);
    }
}

@keyframes float{

    0%,100%{
        transform:translateY(0);
    }

    50%{
        transform:translateY(-20px);
    }
}

/* Mobile */

@media(max-width:600px){

    .reset-card{
        padding:25px;
    }

    h1{
        font-size:28px;
    }
}
/* =========================
   LEFT PANEL WHITE TEXT FIX
========================= */

.left-panel,
.left-panel *{
    color:#fff !important;
}

.left-panel .hero span{
    color:#EBF1CF !important;
}

.left-panel .logo-text,
.left-panel .logo span{
    color:#fff !important;
}

.left-panel .logo small,
.left-panel .hero p,
.left-panel .glass p{
    color:rgba(255,255,255,.85) !important;
}

.left-panel .glass h3,
.left-panel .bank-carad,
.left-panel .bank-card *{
    color:#fff !important;
}
.auth-mobile-language-wrap{
    position:fixed;
    top:18px;
    right:18px;
    z-index:10000;
}

.auth-mobile-language-btn{
    width:42px;
    height:42px;
    border:none;
    border-radius:50%;
    background:#ffffff;
    color:#015054;
    font-size:20px;
    cursor:pointer;
    box-shadow:0 10px 25px rgba(0,0,0,.12);
}

.auth-mobile-language-dropdown{
    position:absolute;
    top:52px;
    right:0;
    width:240px;
    max-height:340px;
    overflow-y:auto;
    display:none;
    background:#fff;
    border:1px solid rgba(1,80,84,.12);
    border-radius:16px;
    box-shadow:0 18px 45px rgba(0,0,0,.15);
    padding:8px;
}

.auth-mobile-language-dropdown.show{
    display:grid;
    gap:4px;
}

.auth-mobile-language-dropdown button{
    border:0;
    background:transparent;
    cursor:pointer;
    padding:10px 12px;
    border-radius:10px;
    text-align:left;
    font:inherit;
    color:#015054;
}

.auth-mobile-language-dropdown button:hover{
    background:#EBF1CF;
}

@media(min-width:769px){
    .auth-mobile-language-wrap{
        display:none;
    }
}
.auth-mobile-language-wrap{
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 999999;
}

.auth-mobile-language-btn{
    display: flex;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    border: none;
    border-radius: 50%;
    background: #ffffff;
    color: #015054;
    font-size: 22px;
    cursor: pointer;
    box-shadow: 0 10px 25px rgba(0,0,0,.15);
}
/* Hide Google Translate banner */
.goog-te-banner-frame.skiptranslate {
    display: none !important;
}

body {
    top: 0 !important;
}

/* Hide Google branding */
.goog-logo-link,
.goog-te-gadget span,
.goog-te-gadget-icon {
    display: none !important;
}

/* Hide the default Google Translate widget */
.goog-te-gadget {
    font-size: 0 !important;
}

#google_translate_element {
    display: none !important;
}

/* Prevent page from shifting down */
html {
    margin-top: 0 !important;
}

body {
    position: static !important;
}
/* Hide Google Translate top toolbar */
iframe.goog-te-banner-frame,
.goog-te-banner-frame,
.goog-te-banner-frame.skiptranslate {
    display: none !important;
    visibility: hidden !important;
}

/* Prevent Google from pushing the page down */
body {
    top: 0 !important;
    position: static !important;
}

html {
    margin-top: 0 !important;
}

/* Hide Google gadget */
.goog-te-gadget,
.goog-logo-link,
.goog-te-gadget span,
.goog-te-gadget-icon {
    display: none !important;
}

#google_translate_element {
    display: none !important;
}
