/* =========================================================
   RETAILER LOGIN PRO 2026
========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{

    --primary:#2563eb;
    --primary-light:#3b82f6;
    --secondary:#06b6d4;

    --success:#10b981;
    --danger:#ef4444;

    --text:#0f172a;
    --muted:#64748b;

    --white:#ffffff;
    --border:#e2e8f0;

    --shadow:
    0 20px 60px rgba(15,23,42,.12);

    --shadow-hover:
    0 25px 70px rgba(37,99,235,.16);

    --radius:24px;
}

/* =========================================================
   RESET
========================================================= */

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

html,
body{
    min-height:100%;
    overflow-x:hidden;
}

/* =========================================================
   BODY
========================================================= */

body{

    font-family:'Inter',sans-serif;

    background:

    radial-gradient(
        circle at top left,
        rgba(37,99,235,.15),
        transparent 25%
    ),

    radial-gradient(
        circle at bottom right,
        rgba(6,182,212,.12),
        transparent 25%
    ),

    linear-gradient(
        135deg,
        #eff6ff,
        #f8fafc,
        #eef2ff
    );

    position:relative;
}

/* =========================================================
   FLOATING BACKGROUND
========================================================= */

body::before{

    content:"";

    position:fixed;

    width:320px;
    height:320px;

    border-radius:50%;

    top:-120px;
    left:-120px;

    background:
    radial-gradient(
        rgba(37,99,235,.15),
        transparent
    );

    filter:blur(40px);

    z-index:-1;
}

body::after{

    content:"";

    position:fixed;

    width:280px;
    height:280px;

    border-radius:50%;

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

    background:
    radial-gradient(
        rgba(6,182,212,.12),
        transparent
    );

    filter:blur(40px);

    z-index:-1;
}

/* =========================================================
   LOGIN WRAPPER
========================================================= */

.parent-login-wrapper{

    min-height:100vh;

    display:flex;

    align-items:center;

    justify-content:center;

    padding:20px;
}

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

.login-card-modern{

    width:100%;

    max-width:520px;

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

    backdrop-filter:
    blur(18px);

    border-radius:28px;

    padding:28px;

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

    box-shadow:
    var(--shadow);

    position:relative;

    overflow:hidden;

    transition:.35s ease;
}

.login-card-modern:hover{

    transform:
    translateY(-4px);

    box-shadow:
    var(--shadow-hover);
}

/* =========================================================
   CARD EFFECTS
========================================================= */

.login-card-modern::before{

    content:"";

    position:absolute;

    width:180px;
    height:180px;

    top:-90px;
    right:-90px;

    border-radius:50%;

    background:
    radial-gradient(
        rgba(37,99,235,.08),
        transparent
    );
}

.login-card-modern::after{

    content:"";

    position:absolute;

    width:150px;
    height:150px;

    bottom:-70px;
    left:-70px;

    border-radius:50%;

    background:
    radial-gradient(
        rgba(6,182,212,.08),
        transparent
    );
}

/* =========================================================
   HEADER
========================================================= */

.login-header{

    text-align:center;

    margin-bottom:22px;
}

.login-logo{

    width:72px;
    height:72px;

    margin:0 auto 14px;

    border-radius:20px;

    display:flex;

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

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    color:#fff;

    font-size:30px;

    box-shadow:
    0 12px 25px rgba(37,99,235,.25);
}

.login-header h1{

    font-size:28px;

    font-weight:900;

    color:var(--text);

    margin-bottom:4px;
}

.login-header p{

    color:var(--muted);

    font-size:13px;
}

/* =========================================================
   FORM GROUP
========================================================= */

.form-group-modern{

    margin-bottom:14px;
}

.form-group-modern label{

    display:block;

    margin-bottom:6px;

    color:var(--text);

    font-size:13px;

    font-weight:700;
}

/* =========================================================
   INPUT
========================================================= */

.input-box{

    position:relative;
}

.input-box i{

    position:absolute;

    left:16px;
    top:50%;

    transform:translateY(-50%);

    color:#94a3b8;

    transition:.3s;
}

.input-box input{

    width:100%;

    height:48px;

    border-radius:14px;

    border:2px solid #e2e8f0;

    background:#f8fafc;

    padding-left:46px;
    padding-right:46px;

    font-size:14px;

    transition:.3s;
}

.input-box input:focus{

    outline:none;

    background:#fff;

    border-color:var(--primary);

    box-shadow:
    0 0 0 4px rgba(37,99,235,.08);
}

.input-box:focus-within i{

    color:var(--primary);
}

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

.toggle-password{

    position:absolute;

    right:16px;

    top:50%;

    transform:translateY(-50%);

    cursor:pointer;

    color:#94a3b8;
}

.toggle-password:hover{

    color:var(--primary);
}

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

.extra-options{

    display:flex;

    justify-content:space-between;

    align-items:center;

    margin:10px 0 14px;
}

.extra-options a{

    text-decoration:none;

    color:var(--primary);

    font-size:13px;

    font-weight:700;
}

.form-check-label{

    font-size:13px;

    color:#475569;
}

/* =========================================================
   CAPTCHA
========================================================= */

.g-recaptcha{

    transform:scale(.90);

    transform-origin:left top;
}

/* =========================================================
   ERROR
========================================================= */

.text-danger{

    display:block;

    margin-top:4px;

    font-size:12px;
}

/* =========================================================
   BUTTON
========================================================= */

.btn-login-parent{

    width:100%;

    height:50px;

    border:none;

    border-radius:14px;

    color:#fff;

    font-size:14px;

    font-weight:800;

    letter-spacing:.3px;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    transition:.3s ease;
}

.btn-login-parent:hover{

    transform:
    translateY(-2px);

    box-shadow:
    0 15px 35px rgba(37,99,235,.25);
}

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

.login-footer{

    margin-top:16px;

    padding-top:16px;

    text-align:center;

    border-top:
    1px solid #eef2f7;

    font-size:12px;

    color:var(--muted);
}

/* =========================================================
   MOBILE
========================================================= */

@media(max-width:576px){

    .parent-login-wrapper{

        padding:12px;
    }

    .login-card-modern{

        padding:22px 18px;

        border-radius:22px;
    }

    .login-logo{

        width:60px;
        height:60px;

        font-size:24px;
    }

    .login-header h1{

        font-size:24px;
    }

    .input-box input{

        height:46px;
    }

    .btn-login-parent{

        height:48px;
    }

    .extra-options{

        flex-direction:column;

        align-items:flex-start;

        gap:8px;
    }

    .g-recaptcha{

        transform:scale(.80);
    }
}