/* Monterey Financial — Consumer Portal · JoinNow (Create account)
   Split-screen wizard. Brand panel left with vertical stepper,
   wizard form right. Chrome of _BaseEmpty.cshtml is hidden so the
   page reads as a focused signup flow. */

/* =====================================================================
   PAGE CHROME OVERRIDES (only apply on this page since this CSS is
   page-scoped via @section PageStyles in JoinNow.cshtml)
   ===================================================================== */
body { background-color: var(--bg-primary) !important; font-family: var(--font-sans); -webkit-font-smoothing: antialiased; }
.page-header.navbar { display: none !important; }
.page-footer { display: none !important; }
.page-container { margin: 0 !important; padding: 0 !important; }
.page-content-wrapper, .page-content { background: var(--bg-primary) !important; padding: 0 !important; margin: 0 !important; min-height: 100vh; }
.scroll-to-top { display: none !important; }

/* =====================================================================
   SPLIT-SCREEN SHELL
   ===================================================================== */
.mf-join {
    display: grid;
    grid-template-columns: 1fr 1.7fr;
    min-height: 100vh;
    width: 100%;
    background: var(--bg-primary);
}

/* =====================================================================
   BRAND PANEL (left)
   ===================================================================== */
.mf-join__brand {
    position: relative;
    overflow: hidden;
    padding: 48px 40px;
    display: flex;
    flex-direction: column;
    gap: 32px;
    background-color: var(--aegean-100);
    color: var(--fg-on-dark);
    min-height: 100vh;
}

.mf-join__brand-photo,
.mf-join__brand-scrim {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.mf-join__brand-photo {
    background-image: url("../images/monterey/hero-building.png");
    background-size: cover;
    background-position: center;
    opacity: 0.45;
}

.mf-join__brand-scrim {
    background: linear-gradient(160deg,
        rgba(6, 48, 77, 0.95) 0%,
        rgba(6, 48, 77, 0.78) 60%,
        rgba(6, 48, 77, 0.55) 100%);
}

.mf-join__brand-inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: 28px;
}

.mf-join__logo {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
}

.mf-join__logo img {
    width: 230px;
    max-width: 100%;
    height: auto;
    filter: brightness(0) invert(1);
}

.mf-join__logo-tag {
    font-weight: 600;
    font-size: 11px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--fg-on-dark-dim);
}

.mf-join__intro h2 {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 32px;
    line-height: 1.1;
    letter-spacing: var(--tracking-tight);
    color: var(--fg-on-dark);
    margin: 0 0 10px;
}

.mf-join__intro p {
    font-size: 14px;
    line-height: 1.55;
    color: var(--fg-on-dark-dim);
    margin: 0;
}

/* Vertical stepper — styled bootstrap nav-pills.
   The ul.nav.nav-pills.steps is required by the wizard JS. */
.mf-join__brand .steps,
.mf-join__brand ul.nav.nav-pills {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    background: transparent;
    border: none;
}

.mf-join__brand .steps > li,
.mf-join__brand ul.nav.nav-pills > li {
    background: transparent;
    margin: 0;
    padding: 0;
    flex: none;
}

.mf-join__brand .steps > li > a {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px;
    border-radius: 12px;
    background: transparent;
    color: var(--fg-on-dark-dim);
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: background 150ms ease, color 150ms ease;
}

.mf-join__brand .steps > li > a:hover,
.mf-join__brand .steps > li > a:focus {
    background: rgba(255, 255, 255, 0.05);
    color: var(--fg-on-dark);
    text-decoration: none;
}

.mf-join__brand .steps > li.active > a {
    background: rgba(255, 255, 255, 0.10);
    color: var(--fg-on-dark);
    font-weight: 700;
}

/* Replace the bootstrap-wizard's number circle */
.mf-join__brand .steps .number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.10);
    color: var(--fg-on-dark-dim);
    font-weight: 700;
    font-size: 14px;
    flex-shrink: 0;
    border: 1px solid transparent;
}

.mf-join__brand .steps > li.active .number {
    background: var(--cerulean-100);
    color: var(--fg-on-dark);
    border-color: var(--cerulean-100);
}

.mf-join__brand .steps > li.done .number {
    background: var(--fg-on-dark);
    color: var(--aegean-100);
}

.mf-join__brand .steps > li.done .number::before {
    content: "\f00c"; /* fa-check */
    font-family: FontAwesome;
    font-weight: normal;
}

.mf-join__brand .steps > li.done .number .step-num-text {
    display: none;
}

.mf-join__brand .steps .desc {
    flex: 1;
    line-height: 1.3;
}

.mf-join__brand .steps .desc i {
    display: none;
}

.mf-join__brand-foot {
    position: relative;
    z-index: 2;
    margin-top: auto;
    padding-top: 24px;
    color: var(--fg-on-dark-dim);
    font-size: 11px;
    line-height: 1.6;
}

.mf-join__brand-foot a {
    color: var(--fg-on-dark-dim);
    text-decoration: underline;
}

.mf-join__brand-foot a:hover {
    color: var(--fg-on-dark);
}

/* =====================================================================
   FORM PANEL (right)
   ===================================================================== */
.mf-join__form-panel {
    background: var(--bg-primary);
    padding: 48px 56px 64px;
    overflow-y: auto;
    min-height: 100vh;
}

.mf-join__form-wrap {
    width: 100%;
    max-width: 640px;
    margin: 0 auto;
}

.mf-join__form-header {
    margin-bottom: 24px;
}

.mf-join__form-header .eyebrow {
    font-weight: 700;
    font-size: 13px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fg-brand);
    margin: 0 0 8px;
}

.mf-join__form-header h1 {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 28px;
    line-height: 1.15;
    letter-spacing: var(--tracking-tight);
    color: var(--fg-primary);
    margin: 0 0 8px;
}

.mf-join__form-header p {
    font-size: 15px;
    line-height: 1.55;
    color: var(--fg-secondary);
    margin: 0;
}

/* Hide the original portlet chrome from the bootstrap admin theme */
.mf-join .portlet,
.mf-join .portlet-light,
.mf-join .portlet-bordered { background: transparent !important; box-shadow: none !important; border: none !important; padding: 0 !important; }
.mf-join .portlet-title { display: none !important; }
.mf-join .portlet-body { padding: 0 !important; }

/* The progress bar at the top of the form panel */
.mf-join .form-wizard .progress {
    height: 4px;
    background: var(--border-primary);
    border-radius: 9999px;
    overflow: hidden;
    margin: 0 0 28px;
    box-shadow: none;
}

.mf-join .form-wizard .progress-bar,
.mf-join .form-wizard .progress-bar-success {
    background: var(--cerulean-100);
    box-shadow: none;
    transition: width 250ms ease;
}

/* Alerts */
.mf-join .alert {
    padding: 14px 16px;
    border-radius: var(--radius-md);
    font-size: 14px;
    line-height: 1.45;
    margin-bottom: 18px;
    border: 1px solid transparent;
    text-shadow: none;
    box-shadow: none;
}

.mf-join .alert.alert-danger {
    background: var(--error-10);
    color: #842424;
    border-color: var(--error-100);
}

.mf-join .alert.alert-success {
    background: var(--success-20);
    color: #054f31;
    border-color: var(--success-100);
}

.mf-join .alert .close {
    color: inherit;
    opacity: 0.5;
    background: transparent;
    border: none;
    font-size: 16px;
}

.mf-join .alert .close:hover { opacity: 1; }
.mf-join .alert.display-none { display: none; }

/* =====================================================================
   FORM FIELDS — override bootstrap form-horizontal layout
   ===================================================================== */
.mf-join h3.block {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 20px;
    color: var(--fg-primary);
    letter-spacing: var(--tracking-tight);
    margin: 4px 0 18px;
    line-height: 1.3;
}

.mf-join .tab-pane h3 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 16px;
    color: var(--fg-primary);
    line-height: 1.45;
    margin: 18px 0 12px;
}

.mf-join .form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin: 0 0 18px;
}

.mf-join .form-group .control-label {
    width: 100% !important;
    text-align: left !important;
    padding: 0 !important;
    margin: 0 !important;
    font-weight: 500;
    font-size: 14px;
    color: var(--fg-tertiary);
    line-height: 1.4;
    float: none !important;
}

.mf-join .form-group .col-md-3,
.mf-join .form-group .col-md-4,
.mf-join .form-group .col-md-9,
.mf-join .form-group .col-md-offset-3 {
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    float: none !important;
}

.mf-join .form-control {
    width: 100%;
    height: 44px;
    padding: 10px 14px;
    border: 1px solid var(--border-secondary);
    border-radius: var(--radius-md);
    background: var(--bg-primary);
    color: var(--fg-primary);
    font: 400 16px/24px var(--font-sans);
    box-shadow: var(--shadow-xs);
    transition: border-color 150ms, box-shadow 150ms;
    outline: none;
}

.mf-join .form-control::placeholder { color: #717680; }

.mf-join .form-control:focus {
    border-color: var(--cerulean-100);
    box-shadow: 0 0 0 3px rgba(0, 127, 156, 0.2);
}

.mf-join .has-error .form-control { border-color: var(--error-100); }
.mf-join .has-error .form-control:focus { box-shadow: 0 0 0 3px rgba(240, 68, 55, 0.2); }
.mf-join .has-success .form-control { border-color: var(--success-100); }

.mf-join .help-block {
    font-size: 13px;
    color: var(--fg-secondary);
    margin: 4px 0 0;
    line-height: 1.5;
    display: block;
}

.mf-join .help-block-error {
    color: var(--error-100);
    font-weight: 500;
}

/* Inline image hint (for accountnumber.png) — keep but constrain */
.mf-join .form-group img {
    margin-top: 8px;
    max-width: 100%;
    height: auto;
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
}

/* =====================================================================
   INNER VERIFY-METHOD TABS — styled as radio cards
   Uses a custom class (not .nav-tabs) so Bootstrap's float layout
   never interferes. Bootstrap's tab plugin keys off data-toggle="tab"
   on the <a>, not the <ul> class, so switching panels still works.
   ===================================================================== */
.mf-join .mf-verify-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 8px 0 18px;
    padding: 0;
    list-style: none;
    border: none;
}

.mf-join .mf-verify-tabs > li {
    margin: 0;
    padding: 0;
    float: none;
    display: block;
    list-style: none;
}

.mf-join .mf-verify-tabs > li > a {
    display: block;
    width: 100%;
    padding: 14px 16px 14px 42px;
    background: var(--bg-primary);
    border: 1px solid var(--border-secondary);
    border-radius: var(--radius-md);
    color: var(--fg-primary);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.3;
    text-align: left;
    text-decoration: none;
    cursor: pointer;
    transition: border-color 150ms, background 150ms, box-shadow 150ms;
    margin: 0;
    position: relative;
}

.mf-join .mf-verify-tabs > li > a::before {
    content: "";
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    width: 16px;
    height: 16px;
    border-radius: 9999px;
    border: 2px solid var(--border-secondary);
    background: var(--bg-primary);
    transition: border-color 150ms, background 150ms, box-shadow 150ms;
}

.mf-join .mf-verify-tabs > li > a:hover {
    background: var(--cerulean-5);
    border-color: var(--cerulean-100);
    text-decoration: none;
}

.mf-join .mf-verify-tabs > li.active > a,
.mf-join .mf-verify-tabs > li.active > a:hover,
.mf-join .mf-verify-tabs > li.active > a:focus {
    background: var(--cerulean-5);
    border-color: var(--cerulean-100);
    color: var(--fg-brand-dark);
    box-shadow: 0 0 0 1px var(--cerulean-100) inset;
    text-decoration: none;
}

.mf-join .mf-verify-tabs > li.active > a::before {
    border-color: var(--cerulean-100);
    background: var(--cerulean-100);
    box-shadow: inset 0 0 0 3px var(--bg-primary);
}

/* =====================================================================
   ACTION BUTTONS
   ===================================================================== */
.mf-join .form-actions {
    margin-top: 28px;
    padding: 24px 0 0;
    border-top: 1px solid var(--border-primary);
    background: transparent;
    box-shadow: none;
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.mf-join .form-actions .row,
.mf-join .form-actions .col-md-9,
.mf-join .form-actions .col-md-offset-3 {
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    display: flex;
    gap: 12px;
    flex: 1;
    justify-content: space-between;
}

.mf-join .form-actions .btn,
.mf-join .form-actions a.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 44px;
    padding: 0 22px;
    border-radius: var(--radius-xl);
    font-family: var(--font-sans);
    font-weight: 700;
    font-size: 15px;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    transition: background 150ms ease, color 150ms ease;
    border: none;
}

.mf-join .form-actions .btn.button-previous,
.mf-join .form-actions .btn.default {
    background: var(--bg-primary);
    color: var(--fg-tertiary);
    border: 1px solid var(--border-secondary);
    box-shadow: var(--shadow-xs);
}

.mf-join .form-actions .btn.button-previous:hover,
.mf-join .form-actions .btn.default:hover {
    background: var(--cerulean-5);
    color: var(--fg-brand-dark);
    border-color: var(--cerulean-100);
    text-decoration: none;
}

.mf-join .form-actions .btn.button-next,
.mf-join .form-actions .btn.button-submit,
.mf-join .form-actions .btn.green,
.mf-join .form-actions .btn.btn-outline.green {
    background: var(--btn-primary-bg);
    color: var(--fg-on-dark);
    box-shadow: var(--btn-shadow);
}

.mf-join .form-actions .btn.button-next:hover,
.mf-join .form-actions .btn.button-submit:hover,
.mf-join .form-actions .btn.green:hover {
    background: var(--btn-primary-bg-hover);
    color: var(--fg-on-dark);
    text-decoration: none;
}

.mf-join .form-actions .btn:active { background: var(--btn-primary-bg-active); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 980px) {
    .mf-join { grid-template-columns: 1fr; grid-template-rows: auto auto; }
    .mf-join__brand { order: 1; min-height: auto; padding: 32px 24px 40px; }
    .mf-join__form-panel { order: 2; min-height: auto; padding: 32px 20px 40px; }
    .mf-join__intro h2 { font-size: 24px; }
    .mf-join__form-header h1 { font-size: 22px; }
    .mf-join .nav-tabs { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .mf-join__brand { padding: 28px 20px 32px; }
    .mf-join__form-panel { padding: 24px 16px 32px; }
    .mf-join .form-actions .btn,
    .mf-join .form-actions a.btn { padding: 0 16px; font-size: 14px; }
}
