body.app-shell-public .site-page-public {
    --shell-max-width: var(--shell-max-width-public);
}

body.app-shell-public .public-page-shell,
body.app-shell-public .public-form-shell {
    max-width: min(var(--shell-max-width-public), 100%);
}

body.app-shell-public .login-hero {
    grid-template-columns: minmax(0, 1.15fr) minmax(420px, 0.85fr);
}

body.app-shell-public .login-hero-main {
    max-width: none;
}

body.app-shell-public .guest-access-panel-login {
    max-width: 560px;
}

body.app-shell-public .public-content-card {
    max-width: 100%;
}

body.app-shell-public .public-page-shell {
    display: grid;
    gap: 28px;
}

body.app-shell-public .public-section-eyebrow {
    color: var(--ui-primary);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

body.app-shell-public .public-home-layout {
    grid-template-columns: minmax(0, 1.35fr) minmax(360px, 0.9fr);
    align-items: start;
}

body.app-shell-public .public-home-main,
body.app-shell-public .public-home-aside {
    display: grid;
    gap: 24px;
}

body.app-shell-public .public-home-intro-card,
body.app-shell-public .public-home-panel,
body.app-shell-public .public-signin-card,
body.app-shell-public .public-side-card,
body.app-shell-public .public-feature-card,
body.app-shell-public .public-features-visual-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 249, 255, 0.96) 100%);
    border: 1px solid rgba(198, 216, 236, 0.95);
    border-radius: 26px;
    box-shadow: 0 18px 36px rgba(14, 48, 94, 0.09);
}

body.app-shell-public .public-home-intro-card {
    padding: 32px 34px;
}

body.app-shell-public .public-home-title {
    margin: 10px 0 14px;
    color: var(--ui-primary-strong);
    font-size: clamp(2.2rem, 3.2vw, 3.4rem);
    font-weight: 900;
    line-height: 0.96;
    letter-spacing: -0.05em;
}

body.app-shell-public .public-home-intro {
    max-width: 72ch;
    margin: 0;
    color: var(--ui-text);
    font-size: 1.08rem;
    line-height: 1.7;
}

body.app-shell-public .public-home-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 26px;
}

body.app-shell-public .public-home-summary-card {
    padding: 18px 18px 20px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(236, 244, 252, 0.96) 0%, rgba(255, 255, 255, 0.94) 100%);
    border: 1px solid rgba(206, 220, 238, 0.95);
}

body.app-shell-public .public-home-summary-card h2,
body.app-shell-public .public-service-card h2,
body.app-shell-public .public-feature-card h2,
body.app-shell-public .public-home-panel h2,
body.app-shell-public .public-side-card h2,
body.app-shell-public .public-signin-title,
body.app-shell-public .public-notice-title {
    margin: 0 0 10px;
    color: var(--ui-primary-strong);
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

body.app-shell-public .public-home-summary-card p,
body.app-shell-public .public-service-card p,
body.app-shell-public .public-feature-card p,
body.app-shell-public .public-home-panel p,
body.app-shell-public .public-side-card p,
body.app-shell-public .public-notice-message,
body.app-shell-public .public-details-copy p {
    margin: 0;
    color: var(--ui-text);
    line-height: 1.7;
}

body.app-shell-public .public-home-service-grid,
body.app-shell-public .public-feature-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

body.app-shell-public .public-service-card,
body.app-shell-public .public-feature-card {
    padding: 24px 22px 24px;
}

body.app-shell-public .public-service-icon {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 18px;
    border-radius: 14px;
    background: linear-gradient(135deg, #0d61aa 0%, #2b8bd1 100%);
    color: #fff;
    font-size: 1rem;
    font-weight: 900;
    box-shadow: 0 12px 24px rgba(15, 87, 153, 0.18);
}

body.app-shell-public .public-service-list,
body.app-shell-public .public-process-list {
    margin: 16px 0 0;
    padding-left: 20px;
    color: var(--ui-text);
    line-height: 1.65;
}

body.app-shell-public .public-service-list li,
body.app-shell-public .public-process-list li {
    margin-top: 8px;
}

body.app-shell-public .public-home-panel-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px;
}

body.app-shell-public .public-home-panel {
    padding: 28px 28px 30px;
}

body.app-shell-public .public-home-panel-accent {
    background: linear-gradient(180deg, rgba(10, 47, 94, 0.96) 0%, rgba(11, 58, 111, 0.96) 100%), url('/images/brand-header.png') center/cover no-repeat;
    border-color: rgba(9, 61, 120, 0.6);
}

body.app-shell-public .public-home-panel-accent .public-section-eyebrow,
body.app-shell-public .public-home-panel-accent h2,
body.app-shell-public .public-home-panel-accent p,
body.app-shell-public .public-home-panel-accent li,
body.app-shell-public .public-home-panel-accent .public-secondary-link {
    color: #fff;
}

body.app-shell-public .public-home-panel-accent .public-section-eyebrow {
    color: rgba(255, 255, 255, 0.96) !important;
    text-shadow: 0 2px 10px rgba(3, 16, 38, 0.18);
}

body.app-shell-public .public-home-panel-accent h2 {
    color: #fff !important;
    text-shadow: 0 2px 10px rgba(3, 16, 38, 0.18);
}

body.app-shell-public .public-home-panel-accent p,
body.app-shell-public .public-home-panel-accent .public-process-list,
body.app-shell-public .public-home-panel-accent .public-process-list li {
    color: rgba(255, 255, 255, 0.96) !important;
}

body.app-shell-public .public-process-intro {
    margin: 0 0 10px !important;
    max-width: 56ch;
    font-size: 1rem;
    line-height: 1.72;
}

body.app-shell-public .public-checklist {
    display: grid;
    gap: 18px;
    margin-top: 18px;
}

body.app-shell-public .public-check-item {
    display: grid;
    gap: 6px;
}

body.app-shell-public .public-check-item strong {
    color: var(--ui-primary-strong);
    font-size: 1rem;
}

body.app-shell-public .public-home-panel-accent .public-check-item strong {
    color: #fff;
}

body.app-shell-public .public-home-panel-actions,
body.app-shell-public .public-side-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 22px;
}

body.app-shell-public .public-secondary-link,
body.app-shell-public .public-side-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    color: inherit;
    font-weight: 700;
    text-decoration: none;
}

body.app-shell-public .public-side-action {
    min-height: 46px;
    background: linear-gradient(135deg, #0d61aa 0%, #2b8bd1 100%);
    border: 0;
    color: #fff;
    box-shadow: 0 12px 24px rgba(13, 97, 170, 0.18);
}

body.app-shell-public .public-side-action-secondary {
    background: rgba(236, 244, 252, 0.98);
    border: 1px solid rgba(206, 220, 238, 0.95);
    color: var(--ui-primary-strong);
    box-shadow: none;
}

body.app-shell-public .public-signin-card,
body.app-shell-public .public-side-card {
    padding: 24px;
}

body.app-shell-public .public-signin-card {
    position: static;
}

body.app-shell-public .public-signin-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}

body.app-shell-public .public-signin-title {
    margin-bottom: 0;
    font-size: 1.6rem;
}

body.app-shell-public .public-forgot-password a {
    color: var(--ui-primary-strong) !important;
    font-size: 0.9rem;
    font-weight: 700;
    text-decoration: none;
    border-bottom: 1px solid rgba(22, 79, 142, 0.24);
}

body.app-shell-public .public-signin-form {
    display: grid;
    gap: 16px;
}

body.app-shell-public .public-login-field .loginInputText {
    width: 100%;
}

body.app-shell-public .public-field-label {
    display: block;
    margin-bottom: 8px;
    color: var(--ui-primary-strong);
    font-size: 0.9rem;
    font-weight: 700;
}

body.app-shell-public .public-signin-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

body.app-shell-public .public-signin-button {
    width: 100%;
    min-width: 140px;
}

body.app-shell-public .public-side-card-guest {
    background:
        linear-gradient(180deg, rgba(241, 247, 255, 0.98) 0%, rgba(255, 255, 255, 0.96) 100%);
}

body.app-shell-public .public-side-card-accent {
    background: linear-gradient(180deg, rgba(10, 47, 94, 0.96) 0%, rgba(11, 58, 111, 0.96) 100%), url('/images/brand-header.png') center/cover no-repeat;
    border-color: rgba(9, 61, 120, 0.6);
}

body.app-shell-public .public-side-card-accent .public-section-eyebrow,
body.app-shell-public .public-side-card-accent h2,
body.app-shell-public .public-side-card-accent p,
body.app-shell-public .public-side-card-accent strong,
body.app-shell-public .public-side-card-accent span,
body.app-shell-public .public-side-card-accent a {
    color: #fff !important;
}

body.app-shell-public .public-side-feature-list {
    display: grid;
    gap: 16px;
    margin-top: 20px;
}

body.app-shell-public .public-side-feature-item {
    display: grid;
    gap: 5px;
}

body.app-shell-public .public-side-feature-item strong {
    font-size: 1rem;
}

body.app-shell-public .public-side-contact-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 22px;
}

body.app-shell-public .public-side-contact-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.18);
    color: #fff;
    font-weight: 700;
    text-decoration: none;
    text-align: center;
}

body.app-shell-public .public-guest-access-link {
    display: inline-flex;
    margin-top: 14px;
}

body.app-shell-public .public-guest-access-image {
    width: min(260px, 100%);
    height: auto;
}

body.app-shell-public .public-side-note {
    margin-top: 14px !important;
    font-size: 0.94rem;
}

body.app-shell-public .public-notice-stack {
    display: grid;
    gap: 18px;
}

body.app-shell-public .public-notice-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 249, 255, 0.96) 100%);
    border: 1px solid rgba(198, 216, 236, 0.95);
    border-radius: 26px;
    box-shadow: 0 18px 36px rgba(14, 48, 94, 0.09);
    overflow: hidden;
}

body.app-shell-public .public-notice-table td {
    padding: 24px 28px;
}

body.app-shell-public .public-notice-table-alert {
    border-color: rgba(230, 177, 67, 0.42);
    background: linear-gradient(180deg, rgba(255, 250, 235, 0.98) 0%, rgba(255, 244, 208, 0.94) 100%);
}

body.app-shell-public .public-notice-table-dark {
    border-color: rgba(11, 40, 87, 0.6);
    background: linear-gradient(180deg, rgba(8, 23, 46, 0.96) 0%, rgba(10, 36, 69, 0.96) 100%);
}

body.app-shell-public .public-notice-table-dark .public-notice-message {
    color: #fff;
}

body.app-shell-public .public-details-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
    gap: 28px;
    align-items: center;
}

body.app-shell-public .public-details-visual-card {
    height: 100%;
    padding: 24px;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(10, 47, 94, 0.95) 0%, rgba(14, 71, 132, 0.95) 100%), url('/images/brand-header.png') center/cover no-repeat;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

body.app-shell-public .public-logo-plate {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    padding: 12px 16px;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.08) 100%);
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

body.app-shell-public .public-details-logo {
    width: min(360px, 100%);
    height: auto;
    margin: 0;
}

body.app-shell-public .public-details-visual-card .public-logo-plate {
    margin-bottom: 26px;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.app-shell-public .public-details-stat {
    display: grid;
    gap: 4px;
    color: #fff;
}

body.app-shell-public .public-details-stat + .public-details-stat {
    margin-top: 20px;
}

body.app-shell-public .public-details-stat-value {
    font-size: 2.4rem;
    font-weight: 900;
    line-height: 1;
}

body.app-shell-public .public-details-stat-label {
    font-size: 0.96rem;
    line-height: 1.55;
}

body.app-shell-public .public-details-bullet-list {
    margin: 0;
    padding-left: 20px;
    color: #fff;
    line-height: 1.7;
}

body.app-shell-public .public-details-bullet-list li + li {
    margin-top: 10px;
}

body.app-shell-public .public-recovery-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
    gap: 24px;
    align-items: start;
}

body.app-shell-public .public-recovery-content {
    display: grid;
    gap: 16px;
}

body.app-shell-public .public-recovery-side {
    display: grid;
    gap: 16px;
    padding: 22px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(245, 250, 255, 0.98) 0%, rgba(236, 244, 252, 0.98) 100%);
    border: 1px solid rgba(206, 220, 238, 0.95);
}

body.app-shell-public .public-recovery-side h2 {
    margin: 0;
}

body.app-shell-public .public-recovery-list {
    margin: 0;
    padding-left: 20px;
    color: var(--ui-text);
    line-height: 1.7;
}

body.app-shell-public .public-recovery-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

body.app-shell-public .public-recovery-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, #0d61aa 0%, #2b8bd1 100%);
    color: #fff;
    font-weight: 700;
    text-decoration: none;
    box-shadow: 0 12px 24px rgba(13, 97, 170, 0.18);
}

body.app-shell-public .public-recovery-action-secondary {
    background: rgba(236, 244, 252, 0.98);
    border: 1px solid rgba(206, 220, 238, 0.95);
    color: var(--ui-primary-strong);
    box-shadow: none;
}

body.app-shell-public .application-notice {
    padding: 1.35rem 1.5rem;
    border-radius: 1.35rem;
    border: 1px solid rgba(183, 206, 238, 0.72);
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.97), rgba(237, 244, 255, 0.97));
    box-shadow: 0 18px 38px rgba(14, 36, 72, 0.08);
}

body.app-shell-public .application-notice ul {
    margin: 0.9rem 0 0;
    padding-left: 1.1rem;
}

body.app-shell-public .application-notice li + li {
    margin-top: 0.55rem;
}

body.app-shell-public .app-notice-emphasis {
    margin: 0.2rem 0 0.65rem;
    color: var(--ui-primary-strong);
    font-size: clamp(1.35rem, 2vw, 1.8rem);
    line-height: 1.1;
}

body.app-shell-public .app-notice-action {
    font-weight: 800;
    text-decoration: underline;
    text-decoration-thickness: 1.5px;
}

body.app-shell-public .public-form-table {
    width: 100%;
}

body.app-shell-public .public-form-table td {
    padding-top: 0.55rem;
    padding-bottom: 0.55rem;
    vertical-align: top;
}

body.app-shell-public .public-form-table .colHeader {
    width: 170px;
    min-width: 170px;
    padding-right: 1rem;
}

body.app-shell-public .public-form-table input[type="text"],
body.app-shell-public .public-form-table input[type="password"],
body.app-shell-public .public-form-table input[type="email"],
body.app-shell-public .public-form-table textarea,
body.app-shell-public .public-form-table select,
body.app-shell-public .public-form-table .inputText,
body.app-shell-public .public-form-table .inputTextLong {
    max-width: 100%;
}

body.app-shell-public .public-form-table .inputText {
    width: min(100%, 20rem) !important;
}

body.app-shell-public .public-form-table .inputTextLong {
    width: min(100%, 42rem) !important;
}

body.app-shell-public .public-form-table textarea {
    width: 100% !important;
    min-height: 7rem;
}

body.app-shell-public .public-features-layout {
    gap: 24px;
}

body.app-shell-public .public-features-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(420px, 0.9fr);
    gap: 22px;
    align-items: stretch;
}

body.app-shell-public .public-features-copy {
    padding: 32px 34px;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 249, 255, 0.96) 100%);
    border: 1px solid rgba(198, 216, 236, 0.95);
    box-shadow: 0 18px 36px rgba(14, 48, 94, 0.09);
}

body.app-shell-public .public-features-title {
    margin: 10px 0 14px;
    color: var(--ui-primary-strong);
    font-size: clamp(2.2rem, 3.2vw, 3.25rem);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.05em;
}

body.app-shell-public .public-features-intro {
    margin: 0;
    color: var(--ui-text);
    font-size: 1.08rem;
    line-height: 1.7;
}

body.app-shell-public .public-features-highlight-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

body.app-shell-public .public-feature-pill {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(233, 242, 252, 0.98);
    border: 1px solid rgba(206, 220, 238, 0.95);
    color: var(--ui-primary-strong);
    font-weight: 700;
}

body.app-shell-public .public-features-visual-card {
    height: 100%;
    padding: 24px;
    background: linear-gradient(180deg, rgba(10, 47, 94, 0.95) 0%, rgba(9, 34, 72, 0.96) 100%), url('/images/brand-header.png') center/cover no-repeat;
    border-color: rgba(9, 61, 120, 0.6);
}

body.app-shell-public .public-features-visual-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}

body.app-shell-public .public-features-visual-logo {
    width: min(350px, 100%);
    height: auto;
}

body.app-shell-public .public-features-visual-card .public-logo-plate {
    flex: 0 1 auto;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.app-shell-public .public-features-visual-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
    min-width: 158px;
    max-width: 172px;
    padding: 12px 18px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: #fff;
    font-size: 0.9rem;
    font-weight: 800;
    line-height: 1.38;
    text-align: center;
    white-space: normal;
}

body.app-shell-public .public-features-visual-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

body.app-shell-public .public-features-mini-card {
    padding: 18px 16px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

body.app-shell-public .public-features-mini-card strong {
    display: block;
    margin-bottom: 8px;
    font-size: 1rem;
    color: #fff;
}

body.app-shell-public .public-features-mini-card span {
    display: block;
    font-size: 0.94rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.96);
}

body.app-shell-public .public-details-visual-card a,
body.app-shell-public .public-details-visual-card p,
body.app-shell-public .public-details-visual-card li,
body.app-shell-public .public-details-visual-card span,
body.app-shell-public .public-details-visual-card strong,
body.app-shell-public .public-features-visual-card a,
body.app-shell-public .public-features-visual-card p,
body.app-shell-public .public-features-visual-card li,
body.app-shell-public .public-features-visual-card span,
body.app-shell-public .public-features-visual-card strong {
    color: #fff;
}

body.app-shell-public .public-features-panel-grid {
    margin-top: 4px;
}

body.app-shell-public #headerLogin.site-header-panel {
    position: relative;
    min-height: 186px;
    border-radius: var(--ui-radius-lg) var(--ui-radius-lg) 0 0;
    overflow: hidden;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.02) 0%, rgba(255, 255, 255, 0) 24%, rgba(2, 18, 46, 0.04) 100%), url('/images/brand-header.png') center center / cover no-repeat;
    box-shadow: var(--ui-shadow);
}

body.app-shell-public #loginbar.topbar-public {
    position: relative;
    z-index: 1;
    min-height: 126px;
    padding: 18px 28px 58px;
    background: transparent;
}

body.app-shell-public #headerLogin.site-header-panel .public-topbar-shell-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
}

body.app-shell-public #headerLogin.site-header-panel .public-brand-block {
    display: grid;
    align-items: flex-start;
    gap: 18px;
    max-width: 640px;
}

body.app-shell-public #headerLogin.site-header-panel .public-brand-mark-link {
    flex: 0 0 auto;
    text-decoration: none;
}

body.app-shell-public #headerLogin.site-header-panel .public-brand-logo {
    display: block;
    width: auto;
    height: 82px;
    max-width: none;
    object-fit: contain;
    filter: drop-shadow(0 14px 30px rgba(3, 24, 59, 0.1));
}

body.app-shell-public #headerLogin.site-header-panel .public-brand-copy {
    display: grid;
    gap: 8px;
    padding-top: 0;
    justify-items: end;
    margin-left: auto;
}

body.app-shell-public #headerLogin.site-header-panel .public-brand-title {
    max-width: 15ch;
    color: #0b2857;
    font-size: clamp(2.45rem, 4vw, 3.55rem);
    font-weight: 900;
    line-height: 0.96;
    letter-spacing: -0.05em;
    text-wrap: balance;
    text-shadow: 0 8px 22px rgba(255, 255, 255, 0.48);
}

body.app-shell-public #headerLogin.site-header-panel .public-brand-subtitle {
    max-width: 42ch;
    color: rgba(11, 40, 87, 0.92);
    font-size: clamp(0.98rem, 1.25vw, 1.08rem);
    font-weight: 600;
    line-height: 1.45;
    text-shadow: 0 4px 18px rgba(255, 255, 255, 0.45);
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav {
    position: absolute;
    right: 26px;
    bottom: 46px;
    z-index: 1;
    width: max-content;
    max-width: calc(100% - 56px);
    padding: 5px 12px 4px;
    background: linear-gradient(180deg, rgba(8, 34, 78, 0.42) 0%, rgba(8, 34, 78, 0.3) 100%);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 18px;
    box-shadow: 0 8px 18px rgba(8, 29, 66, 0.14);
    backdrop-filter: blur(4px);
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .container-fluid {
    width: auto;
    padding-left: 0;
    padding-right: 0;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-nav-list,
body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .navbar-nav {
    gap: 14px;
    flex-wrap: nowrap;
    align-items: center;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-item {
    margin-top: 0;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link {
    min-height: 28px;
    padding: 3px 2px 6px !important;
    margin: 0 !important;
    border-radius: 0;
    background: transparent !important;
    color: #fff !important;
    font-size: 0.84rem;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-shadow: 0 1px 3px rgba(6, 24, 49, 0.32);
    white-space: nowrap;
    position: relative;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    border-radius: 999px;
    background: transparent;
    transition: background-color 120ms ease;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link:hover,
body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link:focus-visible {
    color: #fff !important;
    text-shadow: 0 1px 8px rgba(255, 255, 255, 0.28);
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link:hover::before,
body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link:focus-visible::before {
    background: rgba(255, 255, 255, 0.95);
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-item {
    margin-left: 6px;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-link {
    padding: 8px 16px !important;
    border-radius: 14px !important;
    background: linear-gradient(135deg, #1174bf 0%, #0c5ea2 100%) !important;
    color: #fff !important;
    box-shadow: 0 12px 24px rgba(11, 92, 171, 0.2);
    text-shadow: none;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-link::before {
    display: none;
}

body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-link:hover,
body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-link:focus-visible {
    background: linear-gradient(135deg, #0c5ea2 0%, #094f88 100%) !important;
}

body.app-shell-public .open-account-page {
    gap: 22px;
}

body.app-shell-public .open-account-shell {
    display: block;
    padding: clamp(1rem, 2vw, 1.75rem);
    border: 1px solid rgba(198, 216, 236, 0.95);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 18px 40px rgba(14, 48, 94, 0.1);
}

body.app-shell-public .open-account-panel {
    display: grid;
    gap: 1.35rem;
}

body.app-shell-public .open-account-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.82fr);
    gap: 1.1rem;
    align-items: stretch;
}

body.app-shell-public .open-account-hero-copy,
body.app-shell-public .open-account-notice,
body.app-shell-public .open-account-shell .public-form-card,
body.app-shell-public .open-account-complete-card {
    border: 1px solid rgba(198, 216, 236, 0.95);
    border-radius: 18px;
    box-shadow: 0 14px 30px rgba(14, 48, 94, 0.08);
}

body.app-shell-public .open-account-hero-copy {
    padding: clamp(1.25rem, 2.4vw, 2rem);
    background: linear-gradient(180deg, #f8fbff 0%, #edf5fc 100%);
}

body.app-shell-public .open-account-title {
    margin: 0.35rem 0 0.65rem !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #0f315d !important;
    font-size: clamp(2rem, 4vw, 3.75rem) !important;
    font-style: normal !important;
    font-weight: 900 !important;
    line-height: 0.98 !important;
    letter-spacing: 0 !important;
}

body.app-shell-public .open-account-lede {
    max-width: 58ch;
    margin: 0;
    color: #2f4d69;
    font-size: 1.05rem;
    line-height: 1.65;
}

body.app-shell-public .open-account-notice {
    margin: 0;
    padding: clamp(1.1rem, 2vw, 1.55rem);
    background: #ffffff !important;
    color: #17324d;
}

body.app-shell-public .open-account-notice .public-section-eyebrow {
    color: #0f6d4f;
}

body.app-shell-public .open-account-notice .app-notice-emphasis {
    margin: 0.25rem 0 0.7rem;
    color: #0f315d;
    font-size: clamp(1.25rem, 2vw, 1.65rem);
}

body.app-shell-public .open-account-notice p {
    margin: 0;
    color: #334f69;
    line-height: 1.6;
}

body.app-shell-public .open-account-notice ul {
    margin: 0.85rem 0 0;
    padding-left: 1.15rem;
}

body.app-shell-public .open-account-notice li {
    color: #2f4d69;
    line-height: 1.55;
}

body.app-shell-public .open-account-notice li + li {
    margin-top: 0.45rem;
}

body.app-shell-public .open-account-notice .app-notice-action {
    color: #0b5cab;
    font-weight: 800;
}

body.app-shell-public .open-account-section-heading {
    display: grid;
    gap: 0.25rem;
    padding: 0.15rem 0.15rem 0;
}

body.app-shell-public .open-account-section-heading h2 {
    margin: 0;
    color: #0f315d;
    font-size: clamp(1.55rem, 2.5vw, 2.15rem);
    font-weight: 850;
    line-height: 1.1;
}

body.app-shell-public .open-account-section-heading p {
    margin: 0;
    color: #536d88;
    line-height: 1.55;
}

body.app-shell-public .open-account-shell .public-form-card {
    width: 100%;
    margin: 0;
    padding: clamp(1rem, 2vw, 1.35rem);
    border-collapse: separate;
    border-spacing: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 250, 254, 0.96));
}

body.app-shell-public .open-account-shell .public-form-card h2 {
    margin: 0 0 0.35rem;
    color: #0f315d;
    font-size: 1.18rem;
    font-weight: 850;
    letter-spacing: 0;
}

body.app-shell-public .open-account-shell .public-form-table td {
    padding: 0.58rem 0.75rem;
    vertical-align: middle;
}

body.app-shell-public .open-account-shell .public-form-table tr:first-child td {
    padding-top: 0.2rem;
}

body.app-shell-public .open-account-shell .public-form-table .colHeader {
    width: 250px;
    min-width: 250px;
    color: #173f66;
    font-weight: 800;
    line-height: 1.25;
}

body.app-shell-public .open-account-shell .public-form-table input[type="text"],
body.app-shell-public .open-account-shell .public-form-table input[type="password"],
body.app-shell-public .open-account-shell .public-form-table textarea,
body.app-shell-public .open-account-shell .public-form-table select,
body.app-shell-public .open-account-shell .public-form-table .inputText,
body.app-shell-public .open-account-shell .public-form-table .inputTextLong {
    width: min(100%, 34rem) !important;
    max-width: 100%;
    min-height: 2.35rem;
    border-color: #b7c9dd;
    border-radius: 10px;
}

body.app-shell-public .open-account-shell .public-form-table .inputText {
    width: min(100%, 22rem) !important;
}

body.app-shell-public .open-account-shell .public-form-table input::placeholder {
    color: #7b92aa;
    opacity: 0.78;
}

body.app-shell-public .open-account-shell .public-form-table input[id$='txtCreditRequired'] {
    width: min(100%, 12rem) !important;
}

body.app-shell-public .open-account-password-help {
    width: 450px;
    color: #653f08;
    font-size: 0.92rem;
    line-height: 1.45;
}

body.app-shell-public .open-account-password-help strong {
    display: block;
    margin-bottom: 0.4rem;
    color: #4d3108;
}

body.app-shell-public .open-account-password-help ul {
    margin: 0;
    padding: 0.7rem 0.9rem 0.7rem 1.6rem;
    border: 1px solid rgba(235, 190, 107, 0.55);
    border-radius: 12px;
    background: #fff8e9;
}

body.app-shell-public .open-account-validation-summary {
    margin: 0;
    padding: 0.9rem 1.1rem;
    border: 1px solid rgba(194, 69, 49, 0.32);
    border-radius: 14px;
    background: #fff4f1;
    color: #9b2d1e;
    font-weight: 800;
}

body.app-shell-public .open-account-validation-summary:empty {
    display: none;
}

body.app-shell-public .open-account-terms-card {
    background: linear-gradient(180deg, #fffdf8 0%, #f8fbff 100%) !important;
}

body.app-shell-public .open-account-terms-copy {
    color: #2f4d69;
    font-size: 0.95rem;
    line-height: 1.65;
}

body.app-shell-public .open-account-check-row {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    color: #143b61;
    font-size: 1rem;
    font-weight: 800;
    line-height: 1.45;
}

body.app-shell-public .open-account-check-row input[type="checkbox"] {
    flex: 0 0 auto;
    margin-top: 0.25rem;
}

body.app-shell-public .open-account-check-row strong {
    color: #9b2d1e;
    font-style: italic;
}

body.app-shell-public .open-account-submit-cell {
    padding-top: 1rem !important;
}

body.app-shell-public .open-account-submit-cell .button {
    min-width: 11rem;
    min-height: 2.8rem;
    border-radius: 999px;
    background: linear-gradient(135deg, #0f6d4f 0%, #0b5cab 100%) !important;
    font-size: 1rem;
    font-weight: 850;
}

body.app-shell-public .open-account-complete-card {
    padding: 1.35rem;
    background: #f5fbf7;
    color: #0f5132;
}

@media (max-width: 1280px) {
    body.app-shell-public .public-home-layout,
    body.app-shell-public .public-features-hero,
    body.app-shell-public .public-home-panel-grid,
    body.app-shell-public .public-details-grid {
        grid-template-columns: 1fr;
    }

    body.app-shell-public .public-home-main {
        order: 2;
    }

    body.app-shell-public .public-home-aside {
        order: 1;
    }

    body.app-shell-public .public-home-summary-grid,
    body.app-shell-public .public-home-service-grid,
    body.app-shell-public .public-feature-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    body.app-shell-public #headerLogin.site-header-panel {
        min-height: 176px;
    }

    body.app-shell-public #loginbar.topbar-public {
        min-height: 118px;
        padding: 16px 22px 54px;
    }

    body.app-shell-public #headerLogin.site-header-panel .public-brand-logo {
        height: 72px;
    }

    body.app-shell-public .public-brand-title {
        font-size: clamp(2rem, 3.5vw, 3rem);
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav {
        right: 20px;
        bottom: 38px;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-nav-list,
    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .navbar-nav {
        gap: 10px;
    }

    body.app-shell-public .login-hero {
        grid-template-columns: 1fr;
    }

    body.app-shell-public .open-account-hero {
        grid-template-columns: 1fr;
    }

    body.app-shell-public .public-recovery-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 1024px) {
    body.app-shell-public .public-home-summary-grid,
    body.app-shell-public .public-home-service-grid,
    body.app-shell-public .public-feature-card-grid,
    body.app-shell-public .public-home-panel-grid,
    body.app-shell-public .public-features-visual-grid {
        grid-template-columns: 1fr;
    }

    body.app-shell-public .public-home-intro-card,
    body.app-shell-public .public-home-panel,
    body.app-shell-public .public-signin-card,
    body.app-shell-public .public-side-card,
    body.app-shell-public .public-feature-card,
    body.app-shell-public .public-features-copy,
    body.app-shell-public .public-features-visual-card {
        padding: 22px 20px;
    }

    body.app-shell-public #headerLogin.site-header-panel {
        min-height: 166px;
    }

    body.app-shell-public #loginbar.topbar-public {
        min-height: 110px;
        padding: 14px 18px 50px;
    }

    body.app-shell-public #headerLogin.site-header-panel .public-brand-block {
        gap: 14px;
        max-width: 560px;
    }

    body.app-shell-public #headerLogin.site-header-panel .public-brand-logo {
        height: 62px;
    }

    body.app-shell-public #headerLogin.site-header-panel .public-brand-subtitle {
        justify-self: end;
        color: #fff;
        text-shadow: 0 1px 3px rgba(6, 24, 49, 0.32);
        text-align: center;
    }

    body.app-shell-public #headerLogin.site-header-panel .public-brand-subtitle span {
        display: inline;
        padding: 0.2rem 0.55rem;
        border-radius: 10px;
        background: linear-gradient(180deg, rgba(8, 34, 78, 0.54) 0%, rgba(8, 34, 78, 0.38) 100%);
        -webkit-box-decoration-break: clone;
        box-decoration-break: clone;
        line-height: 1.8;
    }

    body.app-shell-public .public-brand-title {
        max-width: 15ch;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav {
        max-width: calc(100% - 40px);
        bottom: 34px;
        padding: 5px 10px 4px;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link {
        font-size: 0.78rem;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-link {
        padding: 7px 12px !important;
    }

    body.app-shell-public .public-signin-actions,
    body.app-shell-public .public-side-actions,
    body.app-shell-public .public-features-visual-top {
        flex-direction: column;
        align-items: stretch;
    }

    body.app-shell-public .public-form-table td {
        display: block;
        width: 100%;
        min-width: 0;
    }

    body.app-shell-public .public-form-table .colHeader {
        width: 100%;
        min-width: 0;
        padding-bottom: 0.2rem;
    }

    body.app-shell-public .open-account-shell {
        padding: 0.85rem;
        border-radius: 18px;
    }

    body.app-shell-public .open-account-password-help {
        width: 100%;
    }

    body.app-shell-public .open-account-check-row {
        display: flex;
    }
}

@media (max-width: 850px) {
    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav {
        width: 182px;
        max-width: calc(100% - 40px);
        padding: 10px;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-nav-list,
    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .navbar-nav {
        flex-direction: column !important;
        align-items: stretch;
        gap: 8px;
        width: 100%;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-item,
    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link {
        width: 100%;
        text-align: center;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .nav-link {
        min-height: 38px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0.45rem 0.7rem !important;
    }

    body.app-shell-public #headerLogin.site-header-panel > nav.public-nav .public-login-nav-item {
        margin-left: 0;
    }
}

@media (min-width: 700px) and (max-width: 1280px) {
    body.app-shell-public .public-signin-card {
        padding: 20px 22px;
    }

    body.app-shell-public .public-signin-card-header {
        align-items: center;
        margin-bottom: 14px;
    }

    body.app-shell-public .public-signin-title {
        font-size: 1.35rem;
    }

    body.app-shell-public .public-signin-form {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(140px, 0.48fr);
        align-items: end;
        gap: 12px;
    }

    body.app-shell-public .public-field-label {
        margin-bottom: 6px;
    }

    body.app-shell-public .public-login-field .loginInputText {
        width: 100%;
        min-height: 42px;
        padding: 8px 10px;
    }

    body.app-shell-public .public-signin-actions {
        flex-direction: row;
        align-items: end;
        justify-content: flex-start;
        gap: 10px;
    }

    body.app-shell-public .public-signin-button {
        width: 100%;
        min-width: 0;
        min-height: 42px;
    }
}

@media (max-width: 699px) {
    body.app-shell-public .public-signin-card {
        padding: 18px;
        border-radius: 20px;
    }

    body.app-shell-public .public-signin-card-header {
        gap: 10px;
        margin-bottom: 14px;
    }

    body.app-shell-public .public-signin-title {
        font-size: 1.3rem;
    }

    body.app-shell-public .public-signin-form {
        gap: 12px;
    }

    body.app-shell-public .public-login-field .loginInputText,
    body.app-shell-public .public-signin-button {
        width: 100%;
        min-height: 42px;
    }
}

body.app-shell-public .public-form-title {
    margin: 0;
    color: var(--ui-primary-strong);
    font-size: clamp(1.7rem, 2.4vw, 2.45rem);
    font-weight: 850;
    line-height: 1.1;
}

body.app-shell-public .public-form-card {
    padding: clamp(1.25rem, 2.4vw, 1.8rem);
}

body.app-shell-public .public-form-intro + .public-form-intro {
    margin-top: 0.35rem;
}

body.app-shell-public .password-reset-card,
body.app-shell-public .password-update-card,
body.app-shell-public .error-card {
    border: 1px solid rgba(198, 216, 236, 0.95);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 250, 254, 0.96));
    box-shadow: 0 14px 30px rgba(14, 48, 94, 0.08);
}

body.app-shell-public .password-panel {
    display: grid;
    gap: 1rem;
}

body.app-shell-public .password-alert {
    min-height: 0;
    color: var(--ui-danger);
    font-weight: 800;
}

body.app-shell-public .password-alert:empty {
    display: none;
}

body.app-shell-public .password-form-table .colHeader {
    color: #173f66;
    font-weight: 800;
}

body.app-shell-public .password-form-table input[type="text"],
body.app-shell-public .password-form-table input[type="password"],
body.app-shell-public .password-form-table .inputText,
body.app-shell-public .password-form-table .inputTextSmall {
    width: min(100%, 22rem) !important;
    min-height: 2.4rem;
    border-color: #b7c9dd;
    border-radius: 10px;
}

body.app-shell-public .public-form-separator {
    color: var(--ui-text-muted);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

body.app-shell-public .password-validation-cell,
body.app-shell-public .public-validation-summary,
body.app-shell-public .password-validation-cell ul {
    color: var(--ui-danger);
    font-weight: 700;
}

body.app-shell-public .password-validation-cell ul,
body.app-shell-public .public-validation-summary ul {
    margin: 0 0 0.5rem;
    padding-left: 1.1rem;
}

body.app-shell-public .password-rules-cell {
    width: 42%;
}

body.app-shell-public .public-password-rules {
    color: #653f08;
    font-size: 0.94rem;
    line-height: 1.45;
}

body.app-shell-public .public-password-rules strong {
    display: block;
    margin-bottom: 0.45rem;
    color: #4d3108;
    font-weight: 850;
}

body.app-shell-public .public-password-rules ul {
    margin: 0;
    padding: 0.75rem 0.9rem 0.75rem 1.6rem;
    border: 1px solid rgba(235, 190, 107, 0.55);
    border-radius: 12px;
    background: #fff8e9;
}

body.app-shell-public .public-password-rules li + li {
    margin-top: 0.4rem;
}

body.app-shell-public .password-message-panel {
    padding: 1rem 1.1rem;
    border: 1px solid rgba(183, 206, 238, 0.72);
    border-radius: 14px;
    background: rgba(244, 249, 255, 0.98);
    color: var(--ui-text);
    line-height: 1.65;
}

body.app-shell-public .password-update-layout {
    grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1.2fr);
}

body.app-shell-public .password-policy-panel p {
    margin: 0;
    color: var(--ui-text);
    line-height: 1.65;
}

body.app-shell-public .password-update-form-panel {
    align-self: start;
}

body.app-shell-public .error-page {
    max-width: 920px;
}

body.app-shell-public .error-page-header {
    display: flex;
    align-items: center;
    min-height: 118px;
    padding: 24px 28px;
    background: linear-gradient(135deg, rgba(10, 47, 94, 0.96) 0%, rgba(14, 71, 132, 0.94) 100%), url('/images/brand-header.png') center/cover no-repeat;
}

body.app-shell-public .error-brand-link {
    display: inline-flex;
    align-items: center;
}

body.app-shell-public .error-brand-logo {
    width: min(240px, 54vw);
    height: auto;
}

body.app-shell-public .error-page-content {
    padding: clamp(1.25rem, 3vw, 2rem);
}

body.app-shell-public .error-page-shell {
    max-width: 760px;
    margin: 0 auto;
}

body.app-shell-public .error-card {
    display: grid;
    gap: 0.9rem;
}

body.app-shell-public .error-card h1 {
    margin: 0;
    color: var(--ui-primary-strong);
    font-size: clamp(1.85rem, 3vw, 2.65rem);
    font-weight: 850;
    line-height: 1.08;
}

body.app-shell-public .error-card p {
    margin: 0;
    color: var(--ui-text);
    font-size: 1rem;
    line-height: 1.65;
}

body.app-shell-public .error-card-warning {
    border-color: rgba(230, 177, 67, 0.48);
}

body.app-shell-public .error-page-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 0.35rem;
}

body.app-shell-public .error-action,
body.app-shell-public .error-action-secondary {
    min-height: 2.7rem;
    text-decoration: none;
}

body.app-shell-public .error-technical-message {
    color: var(--ui-text-muted);
    font-size: 0.9rem;
    line-height: 1.5;
}

body.app-shell-public .error-technical-message:empty {
    display: none;
}

@media (max-width: 1024px) {
    body.app-shell-public .password-update-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    body.app-shell-public .password-rules-cell {
        width: 100%;
    }

    body.app-shell-public .password-create-table td[rowspan] {
        display: block;
    }

    body.app-shell-public .error-page-actions {
        flex-direction: column;
        align-items: stretch;
    }
}
