/* ════════════════════════════════════════════════════════════════════
   AFFILIATE REGISTRATION — Modern split-screen design
   Left panel: brand + value proposition + benefits + social proof
   Right panel: registration form
   Mobile (<860px): stacks vertically, form first.

   Tokens (`--di-*`) inherit from the plugin's brand stylesheet so the
   admin's Brand Color setting flows through automatically.
   ════════════════════════════════════════════════════════════════════ */

.dimi-affiliate-register-wrap {
    /* Reset host context — themes often wrap pages in padded
       containers that fight a full-width registration card. */
    --reg-radius: 20px;
    --reg-gap: 0;
    --reg-pane-pad: clamp(32px, 4.5vw, 72px);
    --reg-form-pad: clamp(32px, 4.5vw, 72px);

    width: 100%;
    max-width: 1200px;
    margin: clamp(24px, 5vw, 72px) auto;
    padding: 0 16px;
    box-sizing: border-box;
    color: var(--di-text, #0F172A);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", Roboto, sans-serif;
    line-height: 1.5;
}

.dimi-affiliate-registration-form {
    background: var(--di-surface, #FFFFFF);
    border: 1px solid var(--di-border, #E2E8F0);
    border-radius: var(--reg-radius);
    box-shadow: 0 24px 64px -32px rgba(15, 23, 42, 0.18),
                0 2px 8px -2px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1fr);
}

/* ─────────────────────────────────────────────────────────────────
   LEFT PANE — Value proposition
   ───────────────────────────────────────────────────────────────── */
.reg-pane {
    position: relative;
    padding: var(--reg-pane-pad);
    background:
        radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--di-primary, #2563EB) 18%, transparent), transparent 50%),
        radial-gradient(circle at 100% 100%, color-mix(in srgb, var(--di-primary, #2563EB) 12%, transparent), transparent 50%),
        linear-gradient(180deg, var(--di-surface, #FFFFFF) 0%, color-mix(in srgb, var(--di-primary, #2563EB) 4%, var(--di-surface, #FFFFFF)) 100%);
    border-right: 1px solid var(--di-border, #E2E8F0);
    display: flex;
    flex-direction: column;
    gap: 28px;
    overflow: hidden;
}

.reg-pane__brand {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: 1.0625rem;
    color: var(--di-text, #0F172A);
    letter-spacing: -0.01em;
}
.reg-pane__brand-mark {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--di-primary, #2563EB);
    color: #fff;
    box-shadow: 0 4px 12px -2px color-mix(in srgb, var(--di-primary, #2563EB) 45%, transparent);
}
.reg-pane__brand-mark .di-icon {
    width: 20px;
    height: 20px;
}
/* Full brand lockup (icon + wordmark) in the login/register left pane. */
.reg-pane__brand-logo {
    height: 40px;
    width: auto;
    max-width: min(260px, 70%);
    object-fit: contain;
    display: block;
}
/* Icon-only mark beside the custom brand name (when admin set a Brand Name). */
.reg-pane__brand-icon {
    height: 36px;
    width: auto;
    object-fit: contain;
    display: block;
    flex-shrink: 0;
}

.reg-pane__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    align-self: flex-start;
    padding: 6px 12px;
    background: color-mix(in srgb, var(--di-primary, #2563EB) 10%, transparent);
    color: var(--di-primary, #2563EB);
    border: 1px solid color-mix(in srgb, var(--di-primary, #2563EB) 22%, transparent);
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.reg-pane__eyebrow .di-icon {
    width: 14px;
    height: 14px;
}

.reg-pane__headline {
    margin: 0;
    font-size: clamp(1.6rem, 2.4vw, 2.125rem);
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--di-text, #0F172A);
}
.reg-pane__headline em {
    font-style: normal;
    background: linear-gradient(135deg, var(--di-primary, #2563EB), color-mix(in srgb, var(--di-primary, #2563EB) 65%, #8B5CF6));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--di-primary, #2563EB);
}

.reg-pane__lede {
    margin: 0;
    font-size: 0.9375rem;
    color: var(--di-text-muted, #475569);
    line-height: 1.6;
    max-width: 38ch;
}

.reg-benefits {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.reg-benefits li {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 12px;
    align-items: start;
}
.reg-benefits__icon {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--di-surface, #FFFFFF);
    border: 1px solid var(--di-border, #E2E8F0);
    border-radius: 10px;
    color: var(--di-primary, #2563EB);
    box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}
.reg-benefits__icon .di-icon {
    width: 18px;
    height: 18px;
}
.reg-benefits__title {
    margin: 0 0 2px;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--di-text, #0F172A);
    line-height: 1.3;
}
.reg-benefits__desc {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--di-text-muted, #475569);
    line-height: 1.5;
}

.reg-stats {
    margin-top: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    padding-top: 20px;
    border-top: 1px dashed var(--di-border, #E2E8F0);
}
.reg-stats__cell {
    padding: 4px 0;
}
.reg-stats__cell + .reg-stats__cell {
    border-left: 1px dashed var(--di-border, #E2E8F0);
    padding-left: 16px;
}
.reg-stats__value {
    margin: 0 0 2px;
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--di-primary, #2563EB);
    letter-spacing: -0.02em;
    line-height: 1;
}
.reg-stats__label {
    margin: 0;
    font-size: 0.75rem;
    color: var(--di-text-muted, #475569);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 500;
}

/* ─────────────────────────────────────────────────────────────────
   RIGHT PANE — The form
   ───────────────────────────────────────────────────────────────── */
.reg-form {
    padding: var(--reg-form-pad);
    background: var(--di-surface, #FFFFFF);
    display: flex;
    flex-direction: column;
    gap: 22px;
}

.reg-form__head {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.reg-form__title {
    margin: 0;
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--di-text, #0F172A);
    letter-spacing: -0.01em;
}
.reg-form__subtitle {
    margin: 0;
    font-size: 0.875rem;
    color: var(--di-text-muted, #475569);
}

.reg-form form {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin: 0;
}

.reg-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.reg-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.reg-field--full {
    grid-column: 1 / -1;
}
.reg-field__label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--di-text, #0F172A);
    letter-spacing: 0.005em;
}
.reg-field__label-hint {
    font-weight: 400;
    font-size: 0.75rem;
    color: var(--di-text-muted, #475569);
}

.reg-field__control {
    position: relative;
    display: flex;
    align-items: center;
}
.reg-field__icon {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--di-text-subtle, #94A3B8);
    pointer-events: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.reg-field__icon .di-icon {
    width: 16px;
    height: 16px;
}
.reg-field input[type="text"],
.reg-field input[type="email"],
.reg-field input[type="password"],
.reg-field textarea {
    width: 100%;
    padding: 11px 14px 11px 40px;
    background: var(--di-surface, #FFFFFF);
    border: 1px solid var(--di-border, #E2E8F0);
    border-radius: 10px;
    color: var(--di-text, #0F172A);
    font-size: 0.9375rem;
    line-height: 1.4;
    font-family: inherit;
    transition: border-color 150ms ease-out, box-shadow 150ms ease-out, background 150ms ease-out;
    box-sizing: border-box;
    appearance: none;
    -webkit-appearance: none;
    box-shadow: 0 1px 0 rgba(15, 23, 42, 0.02);
}
.reg-field textarea {
    padding-left: 14px;
    padding-top: 12px;
    min-height: 88px;
    resize: vertical;
    line-height: 1.55;
}
.reg-field--no-icon input {
    padding-left: 14px !important;
}
.reg-field input::placeholder,
.reg-field textarea::placeholder {
    color: var(--di-text-subtle, #94A3B8);
}
.reg-field input:hover,
.reg-field textarea:hover {
    border-color: var(--di-border-strong, #CBD5E1);
}
.reg-field input:focus,
.reg-field textarea:focus {
    outline: 0;
    border-color: var(--di-primary, #2563EB);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--di-primary, #2563EB) 16%, transparent);
}
.reg-field__help {
    margin: 0;
    font-size: 0.75rem;
    color: var(--di-text-muted, #475569);
    line-height: 1.45;
}

.reg-terms {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    align-items: start;
    padding: 12px 14px;
    background: var(--di-surface-alt, #F8FAFC);
    border: 1px solid var(--di-border, #E2E8F0);
    border-radius: 10px;
}
.reg-terms input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 1px 0 0;
    accent-color: var(--di-primary, #2563EB);
    cursor: pointer;
    flex-shrink: 0;
}
.reg-terms__label {
    font-size: 0.8125rem;
    color: var(--di-text, #0F172A);
    line-height: 1.5;
    cursor: pointer;
}
.reg-terms__label a {
    color: var(--di-primary, #2563EB);
    text-decoration: none;
    font-weight: 500;
}
.reg-terms__label a:hover {
    text-decoration: underline;
}

.reg-submit {
    width: 100%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 13px 20px;
    background: var(--di-primary, #2563EB);
    color: #fff;
    border: 0;
    border-radius: 10px;
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 150ms ease-out, transform 100ms ease-out, box-shadow 150ms ease-out;
    box-shadow: 0 6px 16px -6px color-mix(in srgb, var(--di-primary, #2563EB) 55%, transparent),
                inset 0 1px 0 rgba(255, 255, 255, 0.15);
    font-family: inherit;
    letter-spacing: 0.005em;
}
.reg-submit:hover {
    background: var(--di-primary-hover, color-mix(in srgb, var(--di-primary, #2563EB) 88%, #000));
    box-shadow: 0 10px 24px -8px color-mix(in srgb, var(--di-primary, #2563EB) 60%, transparent),
                inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
.reg-submit:active {
    transform: translateY(1px);
}
.reg-submit .di-icon {
    width: 16px;
    height: 16px;
}

.reg-form__foot {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-size: 0.8125rem;
    color: var(--di-text-muted, #475569);
}
.reg-form__foot a {
    color: var(--di-primary, #2563EB);
    text-decoration: none;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.reg-form__foot a:hover {
    text-decoration: underline;
}
.reg-form__foot .di-icon {
    width: 12px;
    height: 12px;
}

/* ─────────────────────────────────────────────────────────────────
   ALERT BANNER — appears at top of form after a failed submission.
   Variants:
     .reg-alert--error    red/destructive (default)
     .reg-alert--info     informational (future use)
   ───────────────────────────────────────────────────────────────── */
.reg-alert {
    display: grid;
    grid-template-columns: 36px 1fr;
    gap: 12px;
    align-items: start;
    padding: 14px 16px;
    border-radius: 12px;
    border: 1px solid transparent;
    animation: reg-alert-in 220ms ease-out both;
}
.reg-alert--error {
    background: color-mix(in srgb, var(--di-danger, #DC2626) 8%, var(--di-surface, #FFFFFF));
    border-color: color-mix(in srgb, var(--di-danger, #DC2626) 28%, transparent);
    color: color-mix(in srgb, var(--di-danger, #DC2626) 70%, var(--di-text, #0F172A));
}
.reg-alert__icon {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: var(--di-surface, #FFFFFF);
    color: var(--di-danger, #DC2626);
    border: 1px solid color-mix(in srgb, var(--di-danger, #DC2626) 22%, transparent);
    flex-shrink: 0;
}
.reg-alert__icon .di-icon {
    width: 18px;
    height: 18px;
}
.reg-alert__body {
    min-width: 0;
}
.reg-alert__title {
    margin: 0 0 2px;
    font-size: 0.875rem;
    font-weight: 600;
    color: color-mix(in srgb, var(--di-danger, #DC2626) 75%, var(--di-text, #0F172A));
    line-height: 1.35;
}
.reg-alert__message {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--di-text-muted, #475569);
    line-height: 1.5;
}
.reg-alert__list {
    margin: 4px 0 0;
    padding: 0 0 0 1rem;
    font-size: 0.8125rem;
    color: var(--di-text-muted, #475569);
    line-height: 1.55;
}
.reg-alert__list li {
    margin: 0;
    padding: 0;
}
.reg-alert__list li + li {
    margin-top: 2px;
}

@keyframes reg-alert-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
    .reg-alert { animation: none; }
}

/* ─────────────────────────────────────────────────────────────────
   SUCCESS & EXISTING-AFFILIATE STATES
   ───────────────────────────────────────────────────────────────── */
.dimi-affiliate-message {
    max-width: 560px;
    margin: clamp(20px, 5vw, 64px) auto;
    background: var(--di-surface, #FFFFFF);
    border: 1px solid var(--di-border, #E2E8F0);
    border-radius: 20px;
    padding: clamp(28px, 4vw, 48px);
    box-shadow: 0 24px 64px -32px rgba(15, 23, 42, 0.18),
                0 2px 8px -2px rgba(15, 23, 42, 0.06);
    text-align: center;
    color: var(--di-text, #0F172A);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", Roboto, sans-serif;
}
.dimi-affiliate-message__icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: color-mix(in srgb, var(--di-success, #10B981) 14%, transparent);
    color: var(--di-success, #10B981);
}
.dimi-affiliate-message__icon .di-icon {
    width: 28px;
    height: 28px;
}
.dimi-affiliate-message h3 {
    margin: 0 0 8px;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--di-text, #0F172A);
    letter-spacing: -0.01em;
}
.dimi-affiliate-message p {
    margin: 0 0 20px;
    font-size: 0.9375rem;
    color: var(--di-text-muted, #475569);
    line-height: 1.55;
}
.dimi-affiliate-message p:last-child {
    margin-bottom: 0;
}
.dimi-affiliate-message .button,
.dimi-affiliate-message a.button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 11px 22px;
    background: var(--di-primary, #2563EB);
    color: #fff;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.9375rem;
    transition: background 150ms ease-out, box-shadow 150ms ease-out;
    box-shadow: 0 6px 16px -6px color-mix(in srgb, var(--di-primary, #2563EB) 55%, transparent);
}
.dimi-affiliate-message .button:hover {
    background: var(--di-primary-hover, color-mix(in srgb, var(--di-primary, #2563EB) 88%, #000));
}

/* ─────────────────────────────────────────────────────────────────
   RESPONSIVE — Stack at <860px (form first, hide stats on small)
   ───────────────────────────────────────────────────────────────── */
@media (max-width: 860px) {
    .dimi-affiliate-registration-form {
        grid-template-columns: 1fr;
    }
    .reg-pane {
        order: 2;
        border-right: 0;
        border-top: 1px solid var(--di-border, #E2E8F0);
        padding: 28px;
        gap: 20px;
    }
    .reg-form {
        order: 1;
        padding: 28px;
    }
    .reg-pane__headline {
        font-size: 1.5rem;
    }
    .reg-stats {
        margin-top: 8px;
    }
}

@media (max-width: 520px) {
    .reg-grid {
        grid-template-columns: 1fr;
    }
    .reg-pane__brand {
        font-size: 1rem;
    }
    .reg-pane__brand-mark {
        width: 32px;
        height: 32px;
    }
    .reg-stats {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .reg-stats__cell + .reg-stats__cell {
        border-left: 0;
        border-top: 1px dashed var(--di-border, #E2E8F0);
        padding-left: 0;
        padding-top: 12px;
    }
}

/* ─────────────────────────────────────────────────────────────────
   ACCESSIBILITY — Reduced motion
   ───────────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .reg-submit,
    .reg-field input,
    .reg-field textarea,
    .dimi-affiliate-message .button {
        transition: none;
    }
    .reg-submit:active {
        transform: none;
    }
}

/* ─────────────────────────────────────────────────────────────────
   AFFILIATE LOGIN — reuses the split layout above. Extra bits the
   register form doesn't have: a forgot-password row, a password
   show/hide toggle, and a submit with a trailing icon.
   ───────────────────────────────────────────────────────────────── */
.reg-field--inline {
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
}
.reg-forgot {
    font-size: 0.8125rem;
    color: var(--di-primary, #2563EB);
    text-decoration: none;
    font-weight: 500;
}
.reg-forgot:hover {
    text-decoration: underline;
}

/* Password show/hide toggle sits inside the field, on the right. The
   field's left icon already lives at left:14px; this one mirrors it. */
.reg-field__control .reg-field__toggle {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    padding: 0;
    border: 0;
    background: transparent;
    border-radius: 8px;
    color: var(--di-text-subtle, #94A3B8);
    cursor: pointer;
    transition: color 150ms ease-out, background 150ms ease-out;
}
.reg-field__control .reg-field__toggle:hover {
    color: var(--di-text, #0F172A);
    background: var(--di-surface-alt, #F1F5F9);
}
.reg-field__control .reg-field__toggle .di-icon {
    width: 16px;
    height: 16px;
}
/* Reserve room so typed text doesn't slide under the toggle. */
.reg-field__control input[type="password"],
.reg-field__control input[type="text"] {
    padding-right: 44px;
}

/* ─────────────────────────────────────────────────────────────────
   LOGIN SCREEN BACKDROP — the login reuses the registration card but,
   unlike the register page, isn't guaranteed a themed page background
   behind it. Paint a full-bleed subtle backdrop so the centered card
   has the same "floating on a tinted surface" look as register.
   Scoped to .dimi-affiliate-login-screen → never touches the register
   page or the logged-in dashboard.
   ───────────────────────────────────────────────────────────────── */
.dimi-affiliate-login-screen {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    background:
        radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--di-primary, #2563EB) 10%, transparent), transparent 42%),
        radial-gradient(circle at 100% 100%, color-mix(in srgb, var(--di-primary, #2563EB) 8%, transparent), transparent 42%),
        var(--di-surface-alt, #F1F5F9);
}
/* Grid pattern overlay — faint guide lines, like the register page's
   themed backdrop. Sits above the tint, below the card, masked to fade
   out toward the edges so it never looks like a hard table. */
.dimi-affiliate-login-screen::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-image:
        linear-gradient(to right, color-mix(in srgb, var(--di-primary, #2563EB) 9%, transparent) 1px, transparent 1px),
        linear-gradient(to bottom, color-mix(in srgb, var(--di-primary, #2563EB) 9%, transparent) 1px, transparent 1px);
    background-size: 40px 40px;
    -webkit-mask-image: radial-gradient(circle at 50% 40%, #000 0%, transparent 75%);
    mask-image: radial-gradient(circle at 50% 40%, #000 0%, transparent 75%);
}
.dimi-affiliate-login-screen .dimi-affiliate-register-wrap {
    position: relative;
    z-index: 1;
    margin: clamp(24px, 5vw, 64px) auto;
}

/* Login/forgot submit buttons also carry legacy classes
   (.login-submit-btn / .forgot-password-submit-btn) that the dashboard JS
   needs for loading states. frontend-dashboard.css styles those with a
   higher-specificity selector (.dimi-affiliate-login-form .login-submit-btn,
   white fill) that beats plain .reg-submit. Re-assert the accent fill at
   matching specificity, scoped to the login screen. */
.dimi-affiliate-login-screen .reg-submit,
.dimi-affiliate-login-screen .reg-submit:hover,
.dimi-affiliate-login-screen .reg-submit:focus,
.dimi-affiliate-login-screen .reg-submit:active {
    background: var(--di-primary, #2563EB) !important;
    background-image: none !important;
    background-color: var(--di-primary, #2563EB) !important;
    color: #fff !important;
    border: 0 !important;
    box-shadow: 0 6px 16px -6px color-mix(in srgb, var(--di-primary, #2563EB) 55%, transparent) !important;
    text-shadow: none !important;
    opacity: 1 !important;
    /* Geometry props the theme's [type=submit] rule tries to dictate
       (border-radius:3px, theme padding/min-height). Pin them so the button
       keeps its rounded accent shape. */
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    padding: 13px 20px !important;
    border-radius: 10px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    font-size: 0.9375rem !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    text-transform: none !important;
    letter-spacing: 0.005em !important;
}
.dimi-affiliate-login-screen .reg-submit:hover {
    background: var(--di-primary-hover, color-mix(in srgb, var(--di-primary, #2563EB) 88%, #000)) !important;
    background-color: var(--di-primary-hover, color-mix(in srgb, var(--di-primary, #2563EB) 88%, #000)) !important;
}
.dimi-affiliate-login-screen .reg-submit,
.dimi-affiliate-login-screen .reg-submit * {
    color: #fff !important;
}
.dimi-affiliate-login-screen .reg-submit .di-icon {
    color: #fff !important;
}
