/* ============================================================
   Ballour Admin — Login page (v2 premium)
   ============================================================ */

body.bl-login-v2 {
    --bl-brand: #01529a;
    --bl-brand-600: #014a8c;
    --bl-brand-700: #013d73;
    --bl-brand-50: #e6eef7;
    --bl-accent: #33faff;
    --bl-accent-glow: rgba(51, 250, 255, 0.35);
    --bl-bg: #f0f4f9;
    --bl-surface: #ffffff;
    --bl-border: #e2e8f0;
    --bl-text: #1e293b;
    --bl-text-muted: #64748b;
    --bl-heading: #0f172a;
    --bl-radius-sm: 10px;
    --bl-radius: 14px;
    --bl-radius-lg: 20px;
    --bl-radius-xl: 28px;
    --bl-shadow-card: 0 24px 48px rgba(1, 82, 154, 0.12), 0 8px 16px rgba(15, 23, 42, 0.06);
    --bl-font: 'Tajawal', system-ui, sans-serif;

    margin: 0;
    min-height: 100vh;
    font-family: var(--bl-font);
    background: var(--bl-bg) !important;
    color: var(--bl-text);
    overflow-x: hidden;
}

body.bl-login-v2 .preloader {
    background: var(--bl-bg);
}

/* ----- Layout: AR = image left / form right · EN = form left / image right ----- */
body.bl-login-v2 .bl-login {
    display: flex;
    direction: ltr;
    min-height: 100vh;
    width: 100%;
    position: relative;
}

html[dir="rtl"] body.bl-login-v2 .bl-login {
    flex-direction: row;
}

html[dir="ltr"] body.bl-login-v2 .bl-login {
    flex-direction: row-reverse;
}

html[dir="rtl"] body.bl-login-v2 .bl-login__hero-inner {
    direction: rtl;
}

html[dir="rtl"] body.bl-login-v2 .bl-login__main {
    direction: rtl;
}

/* ----- Hero ----- */
body.bl-login-v2 .bl-login__hero {
    flex: 1 1 56%;
    min-height: 100vh;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 40px;
    overflow: hidden;
    background: #0a1628;
}

body.bl-login-v2 .bl-login__hero-bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 60% at 20% 20%, rgba(51, 250, 255, 0.18) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 85% 75%, rgba(1, 82, 154, 0.55) 0%, transparent 50%),
        linear-gradient(155deg, #021a33 0%, #01529a 38%, #013d73 72%, #0a1628 100%);
    z-index: 0;
}

body.bl-login-v2 .bl-login__hero-bg::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 90% 80% at 50% 50%, #000 20%, transparent 75%);
}

body.bl-login-v2 .bl-login__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: 0.55;
    animation: bl-login-float 14s ease-in-out infinite;
    pointer-events: none;
}

body.bl-login-v2 .bl-login__orb--1 {
    width: 320px;
    height: 320px;
    background: var(--bl-accent);
    top: -8%;
    inset-inline-start: -6%;
    animation-delay: 0s;
}

body.bl-login-v2 .bl-login__orb--2 {
    width: 280px;
    height: 280px;
    background: #4d9fff;
    bottom: 5%;
    inset-inline-end: -4%;
    animation-delay: -5s;
}

body.bl-login-v2 .bl-login__orb--3 {
    width: 180px;
    height: 180px;
    background: #fff;
    top: 42%;
    inset-inline-start: 38%;
    opacity: 0.12;
    animation-delay: -9s;
}

@keyframes bl-login-float {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33% { transform: translate(12px, -18px) scale(1.04); }
    66% { transform: translate(-10px, 14px) scale(0.96); }
}

body.bl-login-v2 .bl-login__hero-inner {
    position: relative;
    z-index: 1;
    width: min(100%, 540px);
    text-align: center;
    animation: bl-login-fade-up 0.7s var(--bl-ease, ease) both;
}

@keyframes bl-login-fade-up {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

body.bl-login-v2 .bl-login__hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    margin-bottom: 20px;
    border-radius: var(--bl-radius-pill, 999px);
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: rgba(255, 255, 255, 0.92);
    font-size: 13px;
    font-weight: 600;
    backdrop-filter: blur(8px);
}

body.bl-login-v2 .bl-login__hero-badge::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--bl-accent);
    box-shadow: 0 0 12px var(--bl-accent-glow);
}

body.bl-login-v2 .bl-login__hero-title {
    margin: 0 0 12px;
    font-size: clamp(1.75rem, 3.5vw, 2.35rem);
    font-weight: 800;
    line-height: 1.25;
    color: #fff;
    letter-spacing: -0.02em;
}

body.bl-login-v2 .bl-login__hero-desc {
    margin: 0 auto 28px;
    max-width: 380px;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.72);
}

body.bl-login-v2 .bl-login__hero-art {
    width: min(88%, 440px);
    height: auto;
    max-height: 42vh;
    object-fit: contain;
    filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.25));
    animation: bl-login-art-float 6s ease-in-out infinite;
}

@keyframes bl-login-art-float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

body.bl-login-v2 .bl-login__hero-stats {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    margin: 28px 0 0;
    padding: 0;
    list-style: none;
}

body.bl-login-v2 .bl-login__hero-stats li {
    padding: 10px 18px;
    border-radius: var(--bl-radius);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    backdrop-filter: blur(6px);
}

body.bl-login-v2 .bl-login__hero-stats strong {
    display: block;
    font-size: 15px;
    font-weight: 800;
    color: var(--bl-accent);
    margin-bottom: 2px;
}

/* ----- Form side ----- */
body.bl-login-v2 .bl-login__main {
    flex: 1 1 44%;
    min-width: 0;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 32px;
    position: relative;
    background:
        radial-gradient(circle at 100% 0%, rgba(1, 82, 154, 0.06) 0%, transparent 42%),
        radial-gradient(circle at 0% 100%, rgba(51, 250, 255, 0.05) 0%, transparent 38%),
        var(--bl-bg);
}

body.bl-login-v2 .bl-login__main::before {
    content: "";
    position: absolute;
    top: 24px;
    inset-inline-end: 24px;
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(1, 82, 154, 0.08), transparent);
    pointer-events: none;
}

body.bl-login-v2 .bl-login__panel {
    width: min(100%, 420px);
    margin: 0 auto;
    position: relative;
    z-index: 1;
    animation: bl-login-fade-up 0.7s 0.12s ease both;
}

body.bl-login-v2 .bl-login__lang {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-bottom: 20px;
    padding: 4px;
    background: rgba(1, 82, 154, 0.06);
    border: 1px solid var(--bl-border);
    border-radius: 999px;
}

body.bl-login-v2 .bl-login__lang-btn {
    flex: 1 1 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 700;
    color: var(--bl-text-muted);
    text-decoration: none;
    border-radius: 999px;
    transition: color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

body.bl-login-v2 .bl-login__lang-btn:hover {
    color: var(--bl-brand);
    text-decoration: none;
}

body.bl-login-v2 .bl-login__lang-btn.is-active {
    color: #fff;
    background: linear-gradient(135deg, var(--bl-brand) 0%, var(--bl-brand-600) 100%);
    box-shadow: 0 4px 12px rgba(1, 82, 154, 0.28);
}

body.bl-login-v2 .bl-login__lang-btn:focus-visible {
    outline: 2px solid var(--bl-brand);
    outline-offset: 2px;
}

body.bl-login-v2 .bl-login__intro {
    text-align: center;
    margin-bottom: 24px;
}

body.bl-login-v2 .bl-login__intro h2 {
    margin: 0 0 6px;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--bl-heading);
    letter-spacing: -0.02em;
}

body.bl-login-v2 .bl-login__intro p {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
    color: var(--bl-text-muted);
}

body.bl-login-v2 .bl-login__logo-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
}

body.bl-login-v2 .bl-login__logo {
    display: block;
    max-width: 120px;
    height: auto;
    filter: drop-shadow(0 4px 12px rgba(1, 82, 154, 0.15));
}

/* ----- Glass card ----- */
body.bl-login-v2 .bl-login__card,
body.bl-login-v2 .customBackground {
    margin-top: 0;
    padding: 28px 26px 32px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid rgba(255, 255, 255, 0.9);
    border-radius: var(--bl-radius-xl);
    box-shadow: var(--bl-shadow-card);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    position: relative;
    overflow: hidden;
}

body.bl-login-v2 .bl-login__card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--bl-brand), var(--bl-accent), var(--bl-brand));
    border-radius: var(--bl-radius-xl) var(--bl-radius-xl) 0 0;
}

/* ----- Role tabs (segmented control) ----- */
body.bl-login-v2 .bl-login__tabs,
body.bl-login-v2 .loginStatus {
    margin: 0 0 24px;
    display: flex;
    gap: 0;
    width: 100%;
    padding: 5px;
    border: none;
    border-radius: var(--bl-radius);
    background: var(--bl-brand-50);
    box-shadow: inset 0 1px 3px rgba(1, 82, 154, 0.08);
}

body.bl-login-v2 .bl-login__tabs button,
body.bl-login-v2 .loginStatus button {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--bl-text-muted);
    font-family: var(--bl-font);
    font-size: 13px;
    font-weight: 700;
    padding: 11px 10px;
    border-radius: calc(var(--bl-radius) - 4px);
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    white-space: nowrap;
    position: relative;
    z-index: 1;
}

body.bl-login-v2 .bl-login__tabs button.active,
body.bl-login-v2 .loginStatus button.active {
    background: var(--bl-surface);
    color: var(--bl-brand);
    box-shadow: 0 4px 12px rgba(1, 82, 154, 0.15);
}

body.bl-login-v2 .bl-login__tabs button i {
    margin-inline-end: 6px;
    font-size: 14px;
    opacity: 0.85;
}

body.bl-login-v2 .bl-login__submit i {
    margin-inline-end: 8px;
}

/* ----- Input with start icon (store code, etc.) ----- */
body.bl-login-v2 .bl-login__input-wrap {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    grid-template-rows: minmax(48px, auto);
    align-items: center;
    width: 100%;
    border: 1.5px solid var(--bl-border);
    border-radius: var(--bl-radius-sm);
    background: var(--bl-surface);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    overflow: hidden;
}

body.bl-login-v2 .bl-login__input-wrap:focus-within {
    border-color: var(--bl-brand);
    box-shadow: 0 0 0 4px rgba(1, 82, 154, 0.1);
}

body.bl-login-v2 .bl-login__input-icon {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bl-text-muted);
    font-size: 16px;
    pointer-events: none;
    z-index: 2;
    transition: color 0.2s ease;
}

body.bl-login-v2 .bl-login__input-wrap:focus-within .bl-login__input-icon {
    color: var(--bl-brand);
}

body.bl-login-v2 .bl-login__input-with-icon {
    grid-column: 1 / -1;
    grid-row: 1;
    display: block;
    width: 100% !important;
    min-height: 48px !important;
    height: 48px;
    margin: 0 !important;
    padding-inline-start: 42px !important;
    padding-inline-end: 14px !important;
    border: none !important;
    border-radius: 0 !important;
    font-size: 14px;
    font-weight: 500;
    text-align: start;
    background: transparent !important;
    box-shadow: none !important;
    position: relative;
    z-index: 1;
}

body.bl-login-v2 .bl-login__input-with-icon:focus {
    outline: none !important;
    box-shadow: none !important;
}

/* ----- Password field: 3-column grid (lock | text | eye) — RTL/LTR safe ----- */
body.bl-login-v2 .bl-login__password {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 42px;
    grid-template-rows: minmax(48px, auto);
    align-items: center;
    width: 100%;
    border: 1.5px solid var(--bl-border);
    border-radius: var(--bl-radius-sm);
    background: var(--bl-surface);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    overflow: hidden;
}

body.bl-login-v2 .bl-login__password:focus-within {
    border-color: var(--bl-brand);
    box-shadow: 0 0 0 4px rgba(1, 82, 154, 0.1);
}

body.bl-login-v2 .bl-login__password-icon {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bl-text-muted);
    font-size: 15px;
    pointer-events: none;
    z-index: 2;
    position: static !important;
    width: auto !important;
    height: auto !important;
    transition: color 0.2s ease;
}

body.bl-login-v2 .bl-login__password-input,
body.bl-login-v2 .bl-login__password .form-control.password_input {
    grid-column: 1 / -1;
    grid-row: 1;
    display: block;
    width: 100% !important;
    min-height: 48px !important;
    height: 48px;
    margin: 0 !important;
    padding: 0 42px !important;
    border: none !important;
    border-radius: 0 !important;
    font-size: 14px;
    font-weight: 500;
    text-align: start;
    letter-spacing: 0.08em;
    background: transparent !important;
    box-shadow: none !important;
    position: relative;
    z-index: 1;
}

body.bl-login-v2 .bl-login__password:focus-within .bl-login__password-icon {
    color: var(--bl-brand);
}

body.bl-login-v2 .bl-login__password-toggle,
body.bl-login-v2 .bl-login__password .Show_password {
    grid-column: 3;
    grid-row: 1;
    justify-self: center;
    align-self: center;
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    transform: none !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    border-radius: 8px !important;
    background: transparent !important;
    color: var(--bl-text-muted) !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    z-index: 2;
    transition: color 0.2s ease, background 0.2s ease;
}

body.bl-login-v2 .bl-login__password-toggle:hover,
body.bl-login-v2 .bl-login__password .Show_password:hover {
    background: var(--bl-brand-50) !important;
    color: var(--bl-brand) !important;
}

body.bl-login-v2 .bl-login__password-toggle i {
    font-size: 16px;
    line-height: 1;
    pointer-events: none;
}

/* Fallback if logical props fail — explicit RTL/LTR columns */
[dir="rtl"] body.bl-login-v2 .bl-login__password-icon {
    grid-column: 1;
}
[dir="rtl"] body.bl-login-v2 .bl-login__password-toggle,
[dir="rtl"] body.bl-login-v2 .bl-login__password .Show_password {
    grid-column: 3;
}
[dir="ltr"] body.bl-login-v2 .bl-login__password-icon {
    grid-column: 1;
}
[dir="ltr"] body.bl-login-v2 .bl-login__password-toggle,
[dir="ltr"] body.bl-login-v2 .bl-login__password .Show_password {
    grid-column: 3;
}

/* ----- Fields ----- */
body.bl-login-v2 .bl-login__panel label {
    font-size: 13px;
    font-weight: 700;
    color: var(--bl-heading);
    margin-bottom: 8px;
    display: block;
}

body.bl-login-v2 .bl-login__panel .form-group,
body.bl-login-v2 .bl-login__panel .mt-2 {
    margin-bottom: 4px;
}

body.bl-login-v2 .bl-login__field {
    position: relative;
    margin-bottom: 16px;
}

body.bl-login-v2 .bl-login__field-icon {
    position: absolute;
    top: 50%;
    inset-inline-start: 14px;
    transform: translateY(-50%);
    color: var(--bl-text-muted);
    font-size: 16px;
    pointer-events: none;
    z-index: 2;
    transition: color 0.2s ease;
}

body.bl-login-v2 .bl-login__panel .form-control {
    min-height: 48px;
    border: 1.5px solid var(--bl-border);
    border-radius: var(--bl-radius-sm);
    font-size: 14px;
    font-weight: 500;
    color: var(--bl-text);
    background: var(--bl-surface);
    padding-inline-start: 44px;
    padding-inline-end: 14px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

body.bl-login-v2 .bl-login__panel .iti + .form-control,
body.bl-login-v2 .bl-login__panel #loginPhone.form-control,
body.bl-login-v2 .bl-login__panel #resetPhone.form-control {
    padding-inline-start: 14px;
}

body.bl-login-v2 .bl-login__panel .form-control:focus {
    border-color: var(--bl-brand);
    background: #fff;
    box-shadow: 0 0 0 4px rgba(1, 82, 154, 0.1), 0 2px 8px rgba(1, 82, 154, 0.06);
    outline: none;
}

body.bl-login-v2 .bl-login__panel .form-control:focus ~ .bl-login__field-icon,
body.bl-login-v2 .bl-login__field:focus-within .bl-login__field-icon {
    color: var(--bl-brand);
}

body.bl-login-v2 .bl-login__panel .actionGroup {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 8px;
}

body.bl-login-v2 .bl-login__panel .bl-login__remember {
    display: flex !important;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 0 !important;
}

body.bl-login-v2 .bl-login__panel .bl-login__remember label::before,
body.bl-login-v2 .bl-login__panel .bl-login__remember label::after {
    display: none !important;
    content: none !important;
}

body.bl-login-v2 .bl-login__panel .bl-login__checkbox,
body.bl-login-v2 .bl-login__panel .bl-login__remember input[type="checkbox"] {
    -webkit-appearance: none;
    appearance: none;
    position: static !important;
    opacity: 1 !important;
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    margin: 0 !important;
    flex-shrink: 0;
    border: 1.5px solid var(--bl-border) !important;
    border-radius: var(--bl-radius-sm) !important;
    background: var(--bl-surface) !important;
    cursor: pointer;
    vertical-align: middle;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

body.bl-login-v2 .bl-login__panel .bl-login__checkbox:hover,
body.bl-login-v2 .bl-login__panel .bl-login__remember input[type="checkbox"]:hover {
    border-color: var(--bl-border-strong) !important;
}

body.bl-login-v2 .bl-login__panel .bl-login__checkbox:focus,
body.bl-login-v2 .bl-login__panel .bl-login__remember input[type="checkbox"]:focus {
    outline: none !important;
    border-color: var(--bl-brand) !important;
    box-shadow: 0 0 0 3px rgba(1, 82, 154, 0.12) !important;
}

body.bl-login-v2 .bl-login__panel .bl-login__checkbox:checked,
body.bl-login-v2 .bl-login__panel .bl-login__remember input[type="checkbox"]:checked {
    background-color: var(--bl-brand) !important;
    border-color: var(--bl-brand) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M3.5 8.2L6.4 11l6.1-6.5' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 12px 12px !important;
}

body.bl-login-v2 .bl-login__panel .bl-login__remember label {
    font-size: 13px;
    font-weight: 600;
    color: var(--bl-text-muted);
    cursor: pointer;
    position: static !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1.4;
}

body.bl-login-v2 .bl-login__panel .lost_pass {
    background: none;
    border: none;
    color: var(--bl-brand);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    transition: color 0.2s ease;
}

body.bl-login-v2 .bl-login__panel .lost_pass:hover {
    color: var(--bl-brand-700);
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* ----- Submit (gradient + shine) ----- */
body.bl-login-v2 .bl-login__submit,
body.bl-login-v2 .login_sumb.custom_but1 {
    min-height: 50px !important;
    border: none !important;
    border-radius: var(--bl-radius-sm) !important;
    background: linear-gradient(135deg, var(--bl-brand) 0%, #0170c9 50%, var(--bl-brand-600) 100%) !important;
    background-size: 200% auto !important;
    color: #fff !important;
    font-family: var(--bl-font) !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    letter-spacing: 0.02em;
    box-shadow: 0 8px 24px rgba(1, 82, 154, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.2);
    transition: transform 0.2s ease, box-shadow 0.2s ease, background-position 0.4s ease;
    position: relative;
    overflow: hidden;
}

body.bl-login-v2 .bl-login__submit::after,
body.bl-login-v2 .login_sumb.custom_but1::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(105deg, transparent 40%, rgba(255, 255, 255, 0.2) 50%, transparent 60%);
    transform: translateX(-100%);
    transition: transform 0.5s ease;
}

body.bl-login-v2 .bl-login__submit:hover,
body.bl-login-v2 .login_sumb.custom_but1:hover {
    background-position: 100% center !important;
    box-shadow: 0 12px 28px rgba(1, 82, 154, 0.42);
    transform: translateY(-1px);
}

body.bl-login-v2 .bl-login__submit:hover::after,
body.bl-login-v2 .login_sumb.custom_but1:hover::after {
    transform: translateX(100%);
}

body.bl-login-v2 .bl-login__submit:active,
body.bl-login-v2 .login_sumb.custom_but1:active {
    transform: translateY(0) scale(0.99);
}

body.bl-login-v2 .custom_but2 {
    min-height: 48px;
    border-radius: var(--bl-radius-sm) !important;
    border: 1.5px solid var(--bl-border) !important;
    background: var(--bl-surface) !important;
    color: var(--bl-text) !important;
    font-weight: 700;
    transition: border-color 0.2s ease, background 0.2s ease;
}

body.bl-login-v2 .custom_but2:hover {
    border-color: var(--bl-brand) !important;
    color: var(--bl-brand) !important;
    background: var(--bl-brand-50) !important;
}

/* ----- Alerts ----- */
body.bl-login-v2 .custom_login_alert {
    border-radius: var(--bl-radius-sm);
    font-size: 13px;
    margin-bottom: 18px;
    border: none;
}

body.bl-login-v2 .alert-danger.custom_login_alert {
    background: #fef2f2;
    color: #b91c1c;
}

/* ----- OTP ----- */
body.bl-login-v2 .codeInput {
    gap: 8px;
}

body.bl-login-v2 .codeInput input {
    border: 1.5px solid var(--bl-border);
    border-radius: var(--bl-radius-sm);
    background: var(--bl-surface);
    font-weight: 700;
    color: var(--bl-brand);
    transition: all 0.2s ease;
}

body.bl-login-v2 .codeInput input:focus {
    border-color: var(--bl-brand) !important;
    box-shadow: 0 0 0 4px rgba(1, 82, 154, 0.12) !important;
    transform: scale(1.02);
}

body.bl-login-v2 .enter-data h4 {
    font-size: 18px;
    font-weight: 800;
    color: var(--bl-heading);
    margin-bottom: 20px;
}

/* ----- PWA install (matches legacy login button) ----- */
body.bl-login-v2 .bl-login__install-btn:not(.is-hidden),
body.bl-login-v2 #installBtn:not(.is-hidden) {
    display: flex !important;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 100%;
    max-width: 100%;
    margin: 24px auto 12px;
    padding: 10px 16px;
    background: transparent;
    border: 1px solid var(--bl-brand);
    border-radius: 10px;
    font-family: var(--bl-font);
    font-size: 15px;
    font-weight: 600;
    color: var(--bl-brand);
    gap: 10px;
    cursor: pointer;
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.2s ease;
    box-shadow: none;
}

body.bl-login-v2 .bl-login__install-btn.is-hidden,
body.bl-login-v2 #installBtn.is-hidden {
    display: none !important;
}

body.bl-login-v2 .bl-login__install-btn:hover,
body.bl-login-v2 #installBtn:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
    border-color: var(--bl-brand-700);
}

body.bl-login-v2 .bl-login__install-btn img,
body.bl-login-v2 #installBtn img {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    object-fit: contain;
}

body.bl-login-v2 .bl-login__install-text {
    line-height: 1.35;
}

html[dir="rtl"] body.bl-login-v2 .bl-login__install-btn,
html[dir="rtl"] body.bl-login-v2 #installBtn {
    flex-direction: row;
}

html[dir="ltr"] body.bl-login-v2 .bl-login__install-btn,
html[dir="ltr"] body.bl-login-v2 #installBtn {
    flex-direction: row-reverse;
}

/* ----- Phone input ----- */
body.bl-login-v2 .iti {
    width: 100%;
    margin-bottom: 4px;
}

body.bl-login-v2 .iti__tel-input {
    min-height: 48px !important;
    border-radius: var(--bl-radius-sm) !important;
    border: 1.5px solid var(--bl-border) !important;
}

body.bl-login-v2 .iti__tel-input:focus {
    border-color: var(--bl-brand) !important;
    box-shadow: 0 0 0 4px rgba(1, 82, 154, 0.1) !important;
}

body.bl-login-v2 #loginPhone::placeholder {
    color: #94a3b8 !important;
}

body.bl-login-v2 .bl-login__footer-note {
    margin-top: 0;
    text-align: center;
    font-size: 12px;
    font-weight: 500;
    color: var(--bl-text-muted);
}

body.bl-login-v2 .bl-login__install-btn.is-hidden + .bl-login__footer-note,
body.bl-login-v2 #installBtn.is-hidden + .bl-login__footer-note {
    margin-top: 24px;
}

body.bl-login-v2 .bl-login__footer-note a {
    color: var(--bl-brand);
    font-weight: 700;
    text-decoration: none;
}

/* ----- Reduced motion ----- */
@media (prefers-reduced-motion: reduce) {
    body.bl-login-v2 .bl-login__orb,
    body.bl-login-v2 .bl-login__hero-art,
    body.bl-login-v2 .bl-login__hero-inner,
    body.bl-login-v2 .bl-login__panel {
        animation: none;
    }
}

/* ----- Responsive ----- */
@media (max-width: 991.98px) {
    html[dir="rtl"] body.bl-login-v2 .bl-login {
        flex-direction: column;
    }

    html[dir="ltr"] body.bl-login-v2 .bl-login {
        flex-direction: column-reverse;
    }

    body.bl-login-v2 .bl-login__hero {
        flex: 0 0 auto;
        min-height: auto;
        padding: 36px 24px 28px;
    }

    body.bl-login-v2 .bl-login__hero-title {
        font-size: 1.5rem;
    }

    body.bl-login-v2 .bl-login__hero-desc {
        margin-bottom: 16px;
        font-size: 14px;
    }

    body.bl-login-v2 .bl-login__hero-art {
        max-height: 180px;
    }

    body.bl-login-v2 .bl-login__hero-stats {
        display: none;
    }

    body.bl-login-v2 .bl-login__main {
        flex: 1 1 auto;
        min-height: auto;
        padding: 28px 20px 40px;
    }
}

@media (max-width: 575.98px) {
    body.bl-login-v2 .bl-login__card,
    body.bl-login-v2 .customBackground {
        padding: 22px 18px 26px;
        border-radius: var(--bl-radius-lg);
    }

    body.bl-login-v2 .bl-login__intro h2 {
        font-size: 1.25rem;
    }

    body.bl-login-v2 .bl-login__tabs button,
    body.bl-login-v2 .loginStatus button {
        font-size: 11px;
        padding: 10px 6px;
    }
}
