/* ==========================================================================
   M2 Auth — Tech / Control / Speed identity (Batch H v2)
   login.tpl / clientregister.tpl / clientareadetails.tpl
   ========================================================================== */

:root {
    --m2-auth-bg:           #f6f8fc;
    --m2-auth-border:       #e4e9f2;
    --m2-auth-border-hover: #c7d1dd;
    --m2-auth-text:         #0f1b33;
    --m2-auth-muted:        #6b7a90;
    --m2-auth-primary:      var(--m2-cyan, #48c0d8);
    --m2-auth-primary-soft: rgba(72, 192, 216, 0.12);
    --m2-auth-radius:       12px;
    --m2-auth-shadow:       0 2px 14px rgba(15, 32, 58, 0.06);

    /* Front-end (homepage / ecosystem) palette — single source of truth for the brand panel */
    --m2-brand-bg-1:        #05141F;
    --m2-brand-bg-2:        #0a1f38;
    --m2-brand-bg-3:        #030d18;
    --m2-brand-cyan:        #55C8E8;
    --m2-brand-cyan-deep:   #0891b2;
    --m2-brand-blue:        #38bdf8;
    --m2-brand-violet:      #7c3aed;
    --m2-brand-font:        'Cairo', 'Tajawal', sans-serif;
    --m2-brand-font-num:    'Orbitron', sans-serif;
}

/* ==========================================================================
   SHARED — password toggle
   ========================================================================== */
.m2-pw-wrapper { position: relative; }

.m2-pw-toggle {
    position: absolute;
    top: 50%;
    inset-inline-end: 10px;
    transform: translateY(-50%);
    background: transparent;
    border: 0;
    color: var(--m2-auth-muted);
    cursor: pointer;
    padding: 4px 8px;
    font-size: 0.95rem;
    z-index: 4;
    transition: color 0.15s ease;
}
.m2-login-page .m2-pw-toggle:hover,
.m2-login-page .m2-pw-toggle:focus { color: var(--m2-cyan-deep, #3aa5bc); outline: none; }

.m2-register-page .m2-pw-toggle:hover,
.m2-register-page .m2-pw-toggle:focus { color: var(--m2-auth-primary); outline: none; }

.m2-pw-wrapper input.form-control { padding-inline-end: 42px; }

/* ==========================================================================
   LOGIN BRAND STRIP — M2 IST front-end cinematic hero (ink + aurora / blobs / stars)
   ========================================================================== */
.signup-slider-right-side.m2-login-brand {
    overflow: hidden;
    background:
        radial-gradient(120% 90% at 78% 12%, rgba(85, 200, 232, 0.16) 0%, transparent 55%),
        radial-gradient(110% 80% at 12% 88%, rgba(124, 58, 237, 0.18) 0%, transparent 55%),
        linear-gradient(165deg, var(--m2-brand-bg-2) 0%, var(--m2-brand-bg-1) 55%, var(--m2-brand-bg-3) 100%);
}

.m2-login-brand__fx {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

/* Deepest ambient "01 01" binary layer */
.m2-login-brand__binary {
    position: absolute;
    inset: 0;
    background: url("../image/header/binary.svg") no-repeat bottom center;
    background-size: 100% auto;
    opacity: 0.07;
    mix-blend-mode: screen;
}

/* Rotating aurora */
.m2-login-brand__aurora {
    position: absolute;
    inset: -25% -10%;
    background: conic-gradient(from 200deg at 50% 42%,
        transparent 0deg, rgba(85, 200, 232, 0.12) 65deg,
        rgba(124, 58, 237, 0.18) 150deg, rgba(85, 200, 232, 0.1) 235deg, transparent 320deg);
    filter: blur(20px);
    animation: m2-auth-aurora 34s linear infinite;
    mix-blend-mode: screen;
    opacity: 0.8;
}
@keyframes m2-auth-aurora { to { transform: rotate(360deg); } }

/* Drifting blobs */
.m2-login-brand__blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    opacity: 0.5;
    animation: m2-auth-blob 20s ease-in-out infinite alternate;
}
.m2-login-brand__blob--1 {
    width: 460px; height: 400px; top: -8%; inset-inline-end: -6%;
    background: radial-gradient(circle, rgba(85, 200, 232, 0.42) 0%, transparent 70%);
}
.m2-login-brand__blob--2 {
    width: 440px; height: 380px; bottom: -4%; inset-inline-start: -8%;
    background: radial-gradient(circle, rgba(124, 58, 237, 0.46) 0%, transparent 70%);
    animation-delay: -8s;
}
@keyframes m2-auth-blob { to { transform: translate(26px, -20px) scale(1.08); } }

/* Twinkling stars */
.m2-login-brand__stars {
    position: absolute;
    inset: -70px;
    background-image:
        radial-gradient(1.5px 1.5px at 12% 18%, rgba(255, 255, 255, 0.8), transparent),
        radial-gradient(1.5px 1.5px at 28% 62%, rgba(200, 240, 255, 0.7), transparent),
        radial-gradient(1px 1px at 47% 30%, rgba(255, 255, 255, 0.6), transparent),
        radial-gradient(1.5px 1.5px at 66% 72%, rgba(255, 255, 255, 0.7), transparent),
        radial-gradient(1px 1px at 80% 22%, rgba(200, 240, 255, 0.7), transparent),
        radial-gradient(1.5px 1.5px at 92% 56%, rgba(255, 255, 255, 0.6), transparent),
        radial-gradient(1px 1px at 38% 84%, rgba(255, 255, 255, 0.55), transparent),
        radial-gradient(1px 1px at 58% 12%, rgba(255, 255, 255, 0.6), transparent);
    animation: m2-auth-stars 5.5s ease-in-out infinite alternate;
}
@keyframes m2-auth-stars { 0% { opacity: 1; } 100% { opacity: 0.55; } }

.m2-brand-panel__grid {
    position: absolute;
    inset: -2px;
    background-image:
        linear-gradient(rgba(85, 200, 232, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(85, 200, 232, 0.05) 1px, transparent 1px);
    background-size: 48px 48px;
    animation: m2-grid-drift 24s linear infinite;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
@keyframes m2-grid-drift {
    0%   { transform: translate(0, 0); }
    100% { transform: translate(48px, 48px); }
}

/* Eyebrow pill (front-end .m2-hero__badge) */
.m2-login-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--m2-brand-cyan);
    background: rgba(85, 200, 232, 0.1);
    border: 1px solid rgba(85, 200, 232, 0.3);
    padding: 7px 16px;
    border-radius: 999px;
    margin-bottom: 22px;
}
.m2-login-eyebrow__dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--m2-brand-cyan);
    box-shadow: 0 0 0 0 rgba(85, 200, 232, 0.6);
    animation: m2-auth-dot 2s infinite;
}
@keyframes m2-auth-dot {
    0%   { box-shadow: 0 0 0 0 rgba(85, 200, 232, 0.55); }
    70%  { box-shadow: 0 0 0 8px rgba(85, 200, 232, 0); }
    100% { box-shadow: 0 0 0 0 rgba(85, 200, 232, 0); }
}

/* Wordmark M2 ✦ RUN (front-end .m2-hero-brand-line) — always LTR, on its own line below the eyebrow */
.m2-login-wordmark {
    font-family: var(--m2-brand-font-num);
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: clamp(1.6rem, 2.4vw, 2.1rem);
    line-height: 1.1;
    color: #fff;
    display: flex;
    direction: ltr;
    width: max-content;
    max-width: 100%;
    align-items: center;
    gap: 0.28em;
    margin-bottom: 18px;
}
.m2-login-sparkle {
    width: 0.7em;
    height: 0.7em;
    color: var(--m2-brand-cyan);
    filter: drop-shadow(0 0 8px rgba(85, 200, 232, 0.55));
    animation: m2-auth-spark 3.5s ease-in-out infinite;
}
@keyframes m2-auth-spark {
    0%, 100% { transform: scale(1) rotate(0deg); opacity: 0.9; }
    50%      { transform: scale(1.18) rotate(15deg); opacity: 1; }
}

/* Soft glass on native sign-up-features-box rows */
.m2-login-page .sign-up-features-box.m2-login-feature {
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: background 0.2s ease, border-color 0.2s ease;
    gap: 14px;
}
.m2-login-page .sign-up-features-box.m2-login-feature:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(85, 200, 232, 0.32);
}

/* Three identical tiles — Font Awesome only (no mixed SVG / FA sizes) */
.m2-login-page .m2-login-feature__icon {
    width: 44px;
    height: 44px;
    min-width: 44px;
    flex-shrink: 0;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(85, 200, 232, 0.18), rgba(8, 145, 178, 0.12));
    border: 1px solid rgba(85, 200, 232, 0.28);
    color: var(--m2-brand-cyan);
    font-size: 1.06rem;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.14);
}

/* Brand panel copy — single luminance ramp (no stray theme greys) */
.signup-slider-right-side.m2-login-brand h4.coodiv-text-5 {
    color: rgba(255, 255, 255, 0.98);
    font-family: var(--m2-brand-font);
    font-weight: 800;
    letter-spacing: -0.01em;
}
.signup-slider-right-side.m2-login-brand h4 .coodiv-text-8 {
    color: rgba(255, 255, 255, 0.78) !important;
    font-weight: 600;
}
.signup-slider-right-side.m2-login-brand .m2-login-feature .box-text h6 {
    color: rgba(255, 255, 255, 0.98);
}
.signup-slider-right-side.m2-login-brand .m2-login-feature .box-text p {
    color: rgba(255, 255, 255, 0.74) !important;
}
.signup-slider-right-side.m2-login-brand .m2-brand-stat__label {
    color: rgba(255, 255, 255, 0.62);
}

.signup-slider-right-side.m2-login-brand .m2-brand-panel__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    padding: 16px 12px;
    background: rgba(0, 0, 0, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 14px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.m2-brand-stat { text-align: center; padding: 0 8px; }
.m2-brand-stat--divider {
    border-inline-start: 1px solid rgba(255, 255, 255, 0.1);
    border-inline-end: 1px solid rgba(255, 255, 255, 0.1);
}
.m2-brand-stat__value {
    font-family: var(--m2-brand-font-num);
    font-size: 1.3rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.98);
    text-shadow: 0 2px 18px rgba(85, 200, 232, 0.4);
    line-height: 1.1;
    letter-spacing: -0.02em;
}
.m2-brand-stat__value span {
    font-size: 0.78rem;
    opacity: 0.7;
    margin-inline-start: 2px;
    font-weight: 700;
}
.m2-brand-stat__label {
    font-size: 0.68rem;
    color: rgba(255, 255, 255, 0.55);
    margin-top: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

/* ==========================================================================
   LOGIN FORM — white column centered (does not rely on body.this-is-login-page)
   ========================================================================== */
.m2-login-page {
    background: var(--m2-auth-bg);
    min-height: 100vh;
    min-height: 100dvh;
}

body.this-is-login-page .site-wrapper,
.site-wrapper:has(.m2-login-page) {
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

body.this-is-login-page .m2-login-page.container-fluid,
.m2-login-page.container-fluid {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    min-height: 100dvh;
}

@media (min-width: 992px) {
    body.this-is-login-page .m2-login-page.container-fluid,
    .m2-login-page.container-fluid {
        flex-direction: row;
        align-items: stretch;
    }

    /*
     * Strip = full viewport minus fixed gradient (~5/12).
     * Row is narrow (~58% vw); use full-width col inside it — col-lg-7 was ~34% vw total (nested fraction bug).
     * Now: row width matches white band + grid centers the form block.
     */
    .m2-login-page .main-signup-row.not-register-page {
        flex: 1 1 auto !important;
        width: 58.333333% !important;
        max-width: 58.333333% !important;
        margin-inline-start: 41.666667% !important;
        margin-inline-end: 0 !important;
        min-height: 100vh !important;
        min-height: 100dvh !important;
        display: flex !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        justify-content: center !important;
        align-content: center !important;
        padding-top: 0 !important;
    }

    .m2-login-page .main-signup-row.not-register-page > .m2-login-form-column {
        flex: 0 1 100% !important;
        max-width: 100% !important;
        width: 100% !important;
        position: relative !important;
        display: block !important;
        min-height: min(100vh, 100dvh) !important;
        padding: clamp(1rem, 4vh, 2.5rem) clamp(0.75rem, 2vw, 1.5rem) !important;
        margin: 0 !important;
    }

    /* Absolute center — survives Bootstrap row/col gutters + RTL */
    .m2-login-page .main-signup-block {
        position: absolute !important;
        top: 50% !important;
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        width: min(460px, calc(100% - 32px)) !important;
        max-width: 460px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        justify-content: flex-start !important;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }

    .m2-login-page .form-holder {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        max-width: 420px !important;
        margin-inline: auto !important;
        padding: clamp(16px, 2.5vh, 28px) 14px !important;
        min-height: 0 !important;
    }

    .m2-login-page .form-holder .form-items {
        width: 100% !important;
        max-width: 400px !important;
        margin-inline: auto !important;
        text-align: start !important;
    }

    .m2-login-brand__content {
        margin-top: 0 !important;
        padding-top: 96px;
        padding-bottom: 48px;
        min-height: 100vh;
        min-height: 100dvh;
        box-sizing: border-box;
    }
}

@media (max-width: 991px) {
    .m2-login-page .main-signup-row > .m2-login-form-column {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        min-height: min(85vh, 720px);
        padding-top: 2rem !important;
        padding-bottom: 2rem !important;
    }
    .m2-login-page .main-signup-block {
        width: 100%;
        max-width: 440px;
        margin-inline: auto;
        padding-bottom: 2rem !important;
    }
    .m2-login-page .form-holder {
        margin-inline: auto;
        padding: 40px 16px !important;
    }
}

/* Kill Bootstrap col width drift next to fixed strip (RTL/LTR) */
.m2-login-page .m2-login-form-shell {
    /* Never width:100% here — it stretches to full white band and content hugs one edge */
    width: min(100%, 460px);
    max-width: 460px;
    margin-inline: auto;
    flex: 0 1 auto;
    align-self: center;
}

.m2-login-form-title {
    text-align: start;
}

.m2-login-page .form-holder .form-items {
    text-align: start !important;
}

.m2-login-form-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 5px 13px;
    background: rgba(72, 192, 216, 0.12);
    color: var(--m2-cyan-deep, #3aa5bc);
    border: 1px solid rgba(72, 192, 216, 0.22);
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.3px;
}

/* Label + forgot on one row — fixes awkward spacing / RTL */
.m2-login-password-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 0.45rem;
}
.m2-login-password-head__label {
    flex: 1 1 auto;
    min-width: 0;
    text-align: start;
}
.m2-login-forgot-link {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--m2-cyan-deep, #3aa5bc) !important;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
}
.m2-login-forgot-link:hover {
    text-decoration: underline;
    color: var(--m2-cyan, #48c0d8) !important;
}
.m2-login-password-field {
    margin-top: 0 !important;
}

.m2-login-page .m2-login-inputgroup {
    position: relative;
    display: flex;
    align-items: center;
    border: 1px solid var(--m2-auth-border);
    border-radius: var(--m2-auth-radius);
    background: #fff;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.m2-login-page .m2-login-inputgroup.is-focused,
.m2-login-page .m2-login-inputgroup:focus-within {
    border-color: var(--m2-cyan, #48c0d8);
    box-shadow: 0 0 0 3px rgba(72, 192, 216, 0.2);
}

.m2-login-page .m2-login-inputgroup__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    min-width: 42px;
    height: 46px;
    color: var(--m2-auth-muted);
    font-size: 0.95rem;
    transition: color 0.15s ease;
}
.m2-login-page .m2-login-inputgroup.is-focused .m2-login-inputgroup__icon {
    color: var(--m2-cyan-deep, #3aa5bc);
}

.m2-login-page .m2-login-input {
    flex: 1 1 auto;
    border: 0 !important;
    background: transparent;
    height: 46px;
    padding: 0 12px;
    font-size: 0.95rem;
    color: var(--m2-auth-text);
    box-shadow: none !important;
    outline: none;
}
.m2-login-page .m2-login-input:focus {
    border: 0 !important;
    box-shadow: none !important;
}

.m2-login-page .m2-login-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-direction: row;
}
/* Bridge brand cyan (tokens) with panel blues — one cohesive action */
body.this-is-login-page .m2-login-page .btn-primary.m2-login-submit {
    background: linear-gradient(135deg, var(--m2-cyan, #48c0d8) 0%, #4f7dff 52%, #6366f1 100%) !important;
    border-color: rgba(58, 165, 188, 0.9) !important;
    box-shadow: 0 6px 18px rgba(72, 192, 216, 0.26);
}
body.this-is-login-page .m2-login-page .btn-primary.m2-login-submit:hover,
body.this-is-login-page .m2-login-page .btn-primary.m2-login-submit:focus {
    background: linear-gradient(135deg, var(--m2-cyan-bright, #5ac8e6) 0%, #5f89ff 52%, #7c6df0 100%) !important;
    border-color: var(--m2-cyan, #48c0d8) !important;
    box-shadow: 0 8px 22px rgba(72, 192, 216, 0.32);
}
.m2-login-page .m2-login-submit__arrow {
    font-size: 0.88rem;
    transition: transform 0.2s ease;
    opacity: 0.95;
}
.m2-login-page .m2-login-submit:hover .m2-login-submit__arrow {
    transform: translateX(4px);
}
html[dir="rtl"] .m2-login-page .m2-login-submit__arrow {
    transform: scaleX(-1);
}
html[dir="rtl"] .m2-login-page .m2-login-submit:hover .m2-login-submit__arrow {
    transform: scaleX(-1) translateX(4px);
}

/* ==========================================================================
   REGISTER PAGE (inside client-area layout — no standalone hero card)
   ========================================================================== */
.m2-page-register {
    --m2-register-sticky-top: 12px;
    background: linear-gradient(180deg, #e8f4f8 0%, #f4f8fb 28%, #f6f8fc 100%);
}

.m2-page-register .site-header,
.m2-page-register .hero-area-coodiv,
.m2-page-register .footer-gradient-default {
    display: none !important;
}

.m2-register-main-body,
section#main-body.m2-register-main-body,
.m2-page-register section#main-body {
    padding-top: 2.5rem !important;
    padding-bottom: 3.5rem !important;
    background: transparent !important;
    scroll-margin-top: var(--m2-register-sticky-top);
}

.m2-page-register .main-page-container.container {
    max-width: 900px;
}

.m2-register-shell {
    position: relative;
    overflow: hidden;
    background: #fff;
    border: 1px solid rgba(72, 192, 216, 0.2);
    border-radius: 20px;
    box-shadow: 0 4px 28px rgba(5, 20, 31, 0.07);
    padding: 1.75rem 1.75rem 2rem;
}

.m2-register-shell::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--m2-cyan, #48c0d8) 0%, var(--m2-cyan-deep, #3aa5bc) 100%);
}

.m2-register-existing {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px 16px;
    margin-bottom: 1.75rem;
    padding: 14px 18px;
    background: linear-gradient(135deg, rgba(72, 192, 216, 0.08) 0%, rgba(255, 255, 255, 0.95) 100%);
    border: 1px solid rgba(72, 192, 216, 0.24);
    border-radius: 14px;
}

.m2-register-existing__text {
    flex: 1 1 220px;
    min-width: 0;
}

.m2-register-existing__title {
    display: block;
    font-weight: 700;
    font-size: 0.92rem;
    color: var(--m2-ink, #05141f);
    margin-bottom: 4px;
}

.m2-register-existing__hint {
    display: block;
    font-size: 0.8rem;
    color: var(--m2-auth-muted);
    line-height: 1.55;
}

.m2-register-existing__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    flex-shrink: 0;
}

.m2-register-existing__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 0.45rem 1rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.2;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.m2-register-existing__btn--login {
    background: linear-gradient(135deg, var(--m2-cyan-bright, #5ac8e6) 0%, var(--m2-cyan-deep, #3aa5bc) 100%);
    border: 1px solid var(--m2-cyan-deep, #3aa5bc);
    color: #05141f !important;
    box-shadow: 0 2px 10px rgba(72, 192, 216, 0.28);
}

.m2-register-existing__btn--login:hover,
.m2-register-existing__btn--login:focus {
    background: linear-gradient(135deg, #6dd4ef 0%, var(--m2-cyan, #48c0d8) 100%);
    border-color: var(--m2-cyan, #48c0d8);
    color: #05141f !important;
    box-shadow: 0 4px 14px rgba(72, 192, 216, 0.34);
}

.m2-register-existing__btn--reset {
    background: #fff;
    border: 1px solid rgba(72, 192, 216, 0.35);
    color: var(--m2-cyan-deep, #3aa5bc) !important;
}

.m2-register-existing__btn--reset:hover,
.m2-register-existing__btn--reset:focus {
    border-color: var(--m2-cyan, #48c0d8);
    background: rgba(72, 192, 216, 0.08);
    color: var(--m2-ink, #05141f) !important;
}

.m2-register-page {
    padding-bottom: 0.25rem;
    text-align: start;
}

.m2-register-intro {
    text-align: center;
}
.m2-register-intro .title {
    color: var(--m2-ink, #05141f);
    font-weight: 800;
}
.m2-register-intro__sub {
    max-width: 40rem;
    margin-inline: auto;
    line-height: 1.75;
    text-align: center;
    color: var(--m2-auth-muted);
}

.m2-register-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 14px;
    background: rgba(72, 192, 216, 0.1);
    border: 1px solid rgba(72, 192, 216, 0.22);
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--m2-cyan-deep, #3aa5bc);
}

.m2-register-stepper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 24px;
    padding: 14px 16px;
    background: var(--m2-auth-bg);
    border: 1px solid var(--m2-auth-border);
    border-radius: var(--m2-auth-radius);
    position: sticky;
    top: var(--m2-register-sticky-top, 12px);
    z-index: 20;
    direction: inherit;
}
.m2-register-step {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1 1 auto;
    min-width: 0;
    direction: inherit;
}
.m2-register-step__num {
    width: 28px;
    height: 28px;
    min-width: 28px;
    border-radius: 50%;
    background: #fff;
    border: 1px solid var(--m2-auth-border);
    color: var(--m2-auth-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.82rem;
    transition: all 0.2s ease;
}
.m2-register-step__label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--m2-auth-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: start;
    flex: 1 1 auto;
    min-width: 0;
}
.m2-register-step.is-active .m2-register-step__num {
    background: linear-gradient(135deg, var(--m2-cyan-bright, #5ac8e6) 0%, var(--m2-cyan-deep, #3aa5bc) 100%);
    color: #05141f;
    border-color: transparent;
    box-shadow: 0 2px 8px rgba(72, 192, 216, 0.32);
}
.m2-register-step.is-active .m2-register-step__label { color: var(--m2-ink, #05141f); }

.m2-register-section {
    padding: 20px 0;
    border-top: 1px dashed var(--m2-auth-border);
}
.m2-register-section:first-of-type {
    border-top: 0;
    padding-top: 4px;
}

.m2-register-section__head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
    text-align: start;
    flex-wrap: wrap;
}
.m2-register-section__chip {
    position: relative;
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 12px;
    background:
        radial-gradient(120% 100% at 78% 8%, rgba(85, 200, 232, 0.22) 0%, rgba(85, 200, 232, 0) 52%),
        linear-gradient(145deg, #07283a 0%, #05141f 58%, #030c14 100%);
    border: 1px solid rgba(85, 200, 232, 0.32);
    color: var(--m2-cyan-bright, #5ac8e6);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    box-shadow: 0 4px 14px rgba(5, 20, 31, 0.14), inset 0 1px 0 rgba(85, 200, 232, 0.12);
    overflow: hidden;
}

.m2-register-section__chip i {
    position: relative;
    z-index: 1;
    filter: drop-shadow(0 0 6px rgba(85, 200, 232, 0.35));
}
.m2-register-section__title {
    flex: 1 1 auto;
    font-size: 1rem;
    font-weight: 700;
    color: var(--m2-auth-text);
    text-align: start;
}

.m2-register-field { margin-bottom: 1rem; }

/* Billing: region + country — strict equal widths (grid beats Bootstrap/RTL flex quirks) */
#m2-reg-step-billing .m2-register-locality-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem 1rem;
    width: 100%;
    box-sizing: border-box;
}
#m2-reg-step-billing .m2-register-locality-cell {
    min-width: 0;
    margin-bottom: 0;
    display: flex;
    flex-direction: column;
}
@media (max-width: 767.98px) {
    #m2-reg-step-billing .m2-register-locality-grid {
        grid-template-columns: 1fr;
    }
}

/* Payment + currency: same gutter rhythm as billing (two equal columns) */
.m2-register-payment-row {
    align-items: flex-end;
}

.m2-register-label {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--m2-auth-text);
    margin-bottom: 0.35rem;
    display: block;
    width: 100%;
    text-align: start;
}
.m2-register-label-hint {
    color: var(--m2-auth-muted);
    font-weight: 500;
    font-size: 0.78rem;
}

.m2-register-input {
    border: 1px solid var(--m2-auth-border) !important;
    border-radius: var(--m2-auth-radius);
    padding: 0.7rem 0.95rem;
    font-size: 0.95rem;
    height: auto;
    background: #fff;
    color: var(--m2-auth-text);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    width: 100%;
}
.m2-register-input:focus {
    border-color: var(--m2-auth-primary) !important;
    box-shadow: 0 0 0 3px var(--m2-auth-primary-soft);
    outline: none;
}

.m2-register-page input.form-control.m2-register-input,
.m2-register-page select.form-control.m2-register-input {
    text-align: start;
}
.m2-register-page select.form-control.m2-register-input {
    min-height: unset;
    cursor: pointer;
    appearance: auto;
    line-height: 1.45;
    padding-top: 0.62rem;
    padding-bottom: 0.62rem;
}
html[dir="rtl"] .m2-register-page select.form-control.m2-register-input {
    padding-inline-start: 0.95rem;
    padding-inline-end: 2.35rem;
    background-position: left 0.65rem center;
}

/* Billing locality — must follow global select rules: force matching height */
#m2-reg-step-billing .m2-register-locality-grid input.form-control.m2-register-input,
#m2-reg-step-billing .m2-register-locality-grid select.form-control.m2-register-input {
    box-sizing: border-box;
    height: 2.75rem !important;
    min-height: 2.75rem !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    padding-inline: 0.95rem !important;
    line-height: 1.35 !important;
    font-size: 0.95rem !important;
}
html[dir="rtl"] #m2-reg-step-billing .m2-register-locality-grid select.form-control.m2-register-input {
    padding-inline-start: 0.95rem !important;
    padding-inline-end: 2rem !important;
    background-position: left 0.55rem center !important;
}

.m2-register-field--payment-pref {
    max-width: none;
}
html[dir="rtl"] .m2-register-page input[type="email"] {
    direction: ltr;
    text-align: right;
}
html[dir="rtl"] .m2-register-page input[type="tel"],
html[dir="rtl"] .m2-register-page .m2-phone-field input[type="tel"] {
    direction: ltr;
    text-align: left;
}
.m2-register-field.is-focused .m2-register-label {
    color: var(--m2-auth-primary);
}

.m2-register-genpw {
    background: rgba(255, 255, 255, 0.92);
    color: var(--m2-cyan-deep, #3aa5bc);
    border: 1px solid rgba(72, 192, 216, 0.35);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
    box-shadow: 0 1px 2px rgba(15, 27, 51, 0.06);
}
.m2-register-genpw:hover {
    background: linear-gradient(135deg, var(--m2-cyan-bright, #5ac8e6) 0%, var(--m2-cyan-deep, #3aa5bc) 100%);
    color: #05141f;
    border-color: var(--m2-cyan-deep, #3aa5bc);
    box-shadow: 0 4px 12px rgba(72, 192, 216, 0.28);
}

.m2-register-turnstile {
    width: 100%;
    justify-content: center !important;
}
.m2-register-turnstile .cf-turnstile {
    display: inline-block;
}

.m2-register-tos {
    margin-top: 1rem;
    padding: 12px 14px;
    background: var(--m2-auth-bg);
    border: 1px solid var(--m2-auth-border);
    border-radius: var(--m2-auth-radius);
    font-size: 0.88rem;
    color: var(--m2-auth-text);
    text-align: start !important;
    text-justify: auto;
}
/*
 * ToS row: إزالة .form-check من القالب — كان موضع checkbox مطلق + padding يسبب تداخلاً مع flex
 * ويُفسَّر أحياناً كتوزيع على عرض السطر. الصف = flex بسيط: checkbox ثابت نسبياً + جملة inline.
 */
.m2-register-tos__label {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    gap: 0.45rem !important;
    margin: 0 !important;
    padding: 0 !important;
    width: max-content !important;
    max-width: 100% !important;
    box-sizing: border-box;
    cursor: pointer;
}
.m2-register-tos .form-check-input.m2-register-tos__check {
    position: static !important;
    float: none !important;
    margin: 0.15rem 0 0 0 !important;
    margin-inline: 0 !important;
    flex: 0 0 auto !important;
    width: 1rem !important;
    height: 1rem !important;
    transform: none !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
}
.m2-register-tos__check {
    flex-shrink: 0;
}
.m2-register-tos__text {
    flex: 0 1 auto !important;
    min-width: 0 !important;
    line-height: 1.55;
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    text-align: start !important;
    word-spacing: normal !important;
    letter-spacing: normal !important;
}
.m2-register-tos__sentence {
    display: inline !important;
    text-align: start !important;
    word-spacing: normal !important;
    /* سطر واحد متماسك — يمنع تمدداً يشبه justify على العرض الكامل */
    white-space: nowrap;
}
@media (max-width: 480px) {
    .m2-register-tos__sentence {
        white-space: normal;
    }
}
.m2-register-tos__text .m2-register-tos__modal-link {
    display: inline !important;
    vertical-align: baseline !important;
    white-space: normal !important;
}
.m2-register-tos .m2-register-tos__modal-link.btn-link {
    flex: none !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
}
.m2-register-tos__modal-link.btn-link {
    font-size: inherit;
    line-height: inherit;
    font-weight: 600;
    color: var(--m2-cyan-deep, #3aa5bc);
    text-decoration: none;
    border: 0;
    box-shadow: none;
}
.m2-register-tos__modal-link.btn-link:hover,
.m2-register-tos__modal-link.btn-link:focus {
    color: var(--m2-cyan, #48c0d8);
    text-decoration: underline;
}

.m2-register-terms-modal .modal-body {
    max-height: min(70vh, 520px);
}
.m2-register-terms-modal__list li {
    margin-bottom: 0.65rem;
    line-height: 1.65;
}

/* M2 register CTA — ink text on cyan gradient, arrow affordance */
.m2-register-page .btn-primary.m2-register-submit {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 12px;
    min-height: 54px;
    padding: 0.85rem 1.5rem !important;
    border-radius: 14px !important;
    color: #05141f !important;
    background: linear-gradient(135deg, var(--m2-cyan-bright, #5ac8e6) 0%, var(--m2-cyan-deep, #3aa5bc) 100%) !important;
    border: 1px solid var(--m2-cyan-deep, #3aa5bc) !important;
    font-weight: 800 !important;
    font-size: 1rem !important;
    letter-spacing: 0.01em;
    box-shadow: 0 6px 20px rgba(72, 192, 216, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.28) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease !important;
}

.m2-register-page .m2-register-submit__text {
    line-height: 1.2;
}

.m2-register-page .m2-register-submit__arrow {
    font-size: 0.92rem;
    opacity: 0.92;
    transition: transform 0.2s ease;
}

html[dir="rtl"] .m2-register-page .m2-register-submit__arrow {
    transform: scaleX(-1);
}

.m2-register-page .btn-primary.m2-register-submit:hover,
.m2-register-page .btn-primary.m2-register-submit:focus {
    color: #05141f !important;
    background: linear-gradient(135deg, #6dd4ef 0%, var(--m2-cyan, #48c0d8) 100%) !important;
    border-color: var(--m2-cyan, #48c0d8) !important;
    box-shadow: 0 10px 28px rgba(72, 192, 216, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.34) !important;
    transform: translateY(-2px);
}

.m2-register-page .btn-primary.m2-register-submit:hover .m2-register-submit__arrow,
.m2-register-page .btn-primary.m2-register-submit:focus .m2-register-submit__arrow {
    transform: translateX(-4px);
}

html[dir="rtl"] .m2-register-page .btn-primary.m2-register-submit:hover .m2-register-submit__arrow,
html[dir="rtl"] .m2-register-page .btn-primary.m2-register-submit:focus .m2-register-submit__arrow {
    transform: scaleX(-1) translateX(4px);
}

/* ==========================================================================
   ACCOUNT DETAILS PAGE
   ========================================================================== */
.m2-details-card {
    border: 1px solid var(--m2-auth-border);
    border-radius: 12px;
    box-shadow: var(--m2-auth-shadow);
    overflow: hidden;
}
.m2-details-card .card-body { padding: 1.5rem; }

.m2-details-card__title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--m2-auth-text);
    margin-bottom: 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--m2-auth-border);
}
.m2-details-card__title i {
    color: var(--m2-auth-primary);
    font-size: 1.05rem;
    width: 24px;
    text-align: center;
}

.m2-details-form .form-control {
    border: 1px solid var(--m2-auth-border);
    border-radius: 8px;
    padding: 0.55rem 0.85rem;
    font-size: 0.95rem;
    height: auto;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.m2-details-form .form-control:focus {
    border-color: var(--m2-auth-primary);
    box-shadow: 0 0 0 3px var(--m2-auth-primary-soft);
}
.m2-details-form .form-control:disabled {
    background: var(--m2-auth-bg);
    color: var(--m2-auth-muted);
}

.m2-details-form .col-form-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--m2-auth-text);
    padding-bottom: 0.25rem;
}

.m2-details-email-prefs {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}
.m2-details-email-pref {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.9rem;
    color: var(--m2-auth-text);
    cursor: pointer;
    margin-bottom: 0;
}
.m2-details-email-pref input[type="checkbox"] { margin: 0; position: static; }

.m2-details-actions { gap: 10px; }
.m2-details-actions .m2-details-save,
.m2-details-actions .m2-details-cancel {
    min-width: 140px;
    padding: 0.65rem 1.25rem;
    border-radius: var(--m2-auth-radius);
    font-weight: 600;
}

/* ==========================================================================
   RTL
   ========================================================================== */
html[dir="rtl"] .m2-register-genpw i.fa-magic { transform: scaleX(-1); }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 991px) {
    .signup-slider-right-side.m2-login-brand {
        position: relative;
        left: auto;
        top: auto;
        bottom: auto;
        height: auto;
        border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    }
    .signup-slider-right-side.m2-login-brand .m2-brand-panel__stats { padding: 12px 8px; }
    .m2-brand-stat__value { font-size: 1.15rem; }

    .m2-register-stepper { flex-wrap: wrap; gap: 12px; }
    .m2-register-step__label { font-size: 0.76rem; }
}

@media (max-width: 576px) {
    .signup-slider-right-side.m2-login-brand .m2-brand-panel__stats { grid-template-columns: 1fr 1fr 1fr; gap: 0; }
    .m2-brand-stat { padding: 0 4px; }
    .m2-brand-stat__value { font-size: 1rem; }
    .m2-brand-stat__label { font-size: 0.6rem; }

    .m2-details-card .card-body { padding: 1.1rem; }
    .m2-details-actions { flex-direction: column-reverse; align-items: stretch !important; }
    .m2-details-actions .m2-details-save,
    .m2-details-actions .m2-details-cancel { width: 100%; }
    .m2-register-section__head { flex-wrap: wrap; }
    .m2-register-genpw { margin-inline-start: auto; }

    .m2-page-register section#main-body {
        padding-top: 1.75rem !important;
    }
    .m2-register-shell { padding: 1.25rem 1rem 1.5rem; }
    .m2-register-existing { flex-direction: column; align-items: stretch; }
    .m2-register-existing__actions { justify-content: stretch; }
    .m2-register-existing__btn { flex: 1 1 auto; justify-content: center; }
}

/* ---------------------------------------------------------------------------
   Register: rtl.css loads BEFORE this file — reinforce layout + ToS line wrap.
   Country uses native <select.m2-native-select> so theme niceSelect() does not
   break the 50/50 grid next to region (#inputCountry would become .nice-select).
   --------------------------------------------------------------------------- */
html[dir="rtl"] .m2-register-page .m2-register-tos__text,
html[dir="rtl"] .m2-register-page .m2-register-tos__sentence,
html[dir="rtl"] .m2-register-page .m2-register-tos__label {
    text-align: start !important;
    word-spacing: normal !important;
    letter-spacing: normal !important;
    justify-content: flex-start !important;
}

#m2-reg-step-billing .m2-register-locality-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

/* ==========================================================================
   REDUCED MOTION — brand panel cinematic layers
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    .m2-login-brand__aurora,
    .m2-login-brand__blob,
    .m2-login-brand__stars,
    .m2-brand-panel__grid,
    .m2-login-eyebrow__dot,
    .m2-login-sparkle {
        animation: none !important;
    }
}
