/* Global/base, public site, login, dashboard primitives.
   Extracted from legacy site.css without selector changes. */
* { box-sizing: border-box }

body {
    margin: 0;
    font-family: Inter, Segoe UI, Arial, sans-serif;
    color: var(--text);
    background: #fff
}

a {
    text-decoration: none;
    color: inherit
}

.brand {
    display: flex;
    align-items: center;
    gap: 10px
}

.brand strong {
    display: block;
    font-size: 30px;
    line-height: 24px;
    letter-spacing: -1.5px
}

.brand small {
    display: block;
    color: #2a8cff;
    font-size: 11px;
    font-weight: 700
}

.brand-mark {
    display: flex;
    gap: 6px
}

.brand-mark:before, .brand-mark i {
    content: "";
    display: block;
    width: 7px;
    height: 31px;
    border-radius: 3px;
    background: #1b73df
}

.brand-mark i:first-child { background: #3a99ff }

.brand-mark i:last-child { background: #0f4d94 }

.marketing-nav {
    height: 78px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 58px;
    border-bottom: 1px solid var(--line);
    background: #fff;
    position: sticky;
    top: 0;
    z-index: 10
}

.marketing-nav nav {
    display: flex;
    gap: 38px;
    font-size: 14px;
    font-weight: 700
}

.nav-actions {
    display: flex;
    align-items: center;
    gap: 20px
}

.link-button { font-weight: 700 }

.orange-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 8px;
    background: var(--orange);
    color: white;
    font-weight: 800;
    padding: 16px 28px;
    box-shadow: 0 16px 35px rgba(255, 106, 26, .22);
    cursor: pointer
}

.orange-button.small {
    padding: 11px 18px;
    font-size: 14px
}

.orange-button.full {
    width: 100%;
    font-size: 16px
}

.outline-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, .45);
    color: white;
    border-radius: 8px;
    font-weight: 800;
    padding: 15px 28px
}

.hero {
    min-height: 620px;
    background: radial-gradient(circle at 60% 50%, #0b3d75 0%, #062653 34%, #031838 70%);
    color: white;
    display: grid;
    grid-template-columns: 1.05fr 1fr;
    gap: 40px;
    padding: 82px 58px 70px;
    overflow: hidden
}

.eyebrow {
    font-size: 14px;
    letter-spacing: .05em;
    font-weight: 900;
    color: #4ba4ff
}

.hero h1 {
    font-size: 45px;
    line-height: 1.13;
    letter-spacing: -1.8px;
    max-width: 620px;
    margin: 22px 0 12px
}

.hero h1 span { color: #5daaff }

.hero-subtitle {
    font-size: 19px;
    color: #dbeafe
}

.hero-actions {
    display: flex;
    gap: 18px;
    margin-top: 34px
}

.hero-points {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 26px;
    margin-top: 54px;
    max-width: 620px
}

.hero-points div {
    border-left: 1px solid rgba(255, 255, 255, .15);
    padding-left: 16px
}

.hero-points strong { display: block }

.hero-points small {
    display: block;
    color: #bdd4f4;
    margin-top: 6px;
    line-height: 1.4
}

.hero-visual {
    position: relative;
    min-height: 430px
}

.video-card {
    position: absolute;
    inset: 18px 90px 95px 40px;
    border-radius: 12px;
    background: linear-gradient(135deg, #e9f4ff, #b5d9fb 45%, #08315f);
    box-shadow: 0 30px 70px rgba(0, 0, 0, .35)
}

.video-card:after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 12px;
    background: radial-gradient(circle at 52% 42%, rgba(255, 255, 255, .86) 0 5%, rgba(255, 255, 255, .25) 6% 16%, rgba(6, 27, 58, .25) 17% 100%)
}

.profile-card {
    position: absolute;
    right: 0;
    top: 0;
    width: 255px;
    background: #fff;
    color: var(--text);
    border-radius: 9px;
    padding: 18px;
    box-shadow: 0 20px 45px rgba(0, 0, 0, .26);
    display: flex;
    gap: 14px
}

.avatar, .talent-avatar {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #0c2d57;
    color: #fff;
    font-weight: 900
}

.profile-card small {
    display: block;
    color: var(--muted);
    margin: 4px 0 10px
}

.profile-card span {
    font-size: 12px;
    color: #1d995c;
    background: #dcfce7;
    border-radius: 999px;
    padding: 4px 10px;
    font-weight: 800
}

.config-card {
    position: absolute;
    left: 80px;
    bottom: 40px;
    width: 330px;
    background: rgba(5, 27, 63, .86);
    border: 1px solid rgba(255, 255, 255, .22);
    border-radius: 10px;
    padding: 18px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .25)
}

.config-card p {
    margin: 0 0 12px;
    color: #8ebdff;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em
}

.config-card div {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    color: #cfe5ff;
    font-size: 13px
}

.date-card {
    position: absolute;
    right: 45px;
    bottom: 40px;
    background: #228eff;
    border-radius: 10px;
    padding: 24px;
    color: white;
    width: 160px
}

.date-card small, .date-card strong { display: block }

.date-card strong {
    font-size: 20px;
    margin: 7px 0 18px
}

.trusted {
    text-align: center;
    padding: 28px 60px;
    border-bottom: 1px solid var(--line)
}

.trusted p {
    font-size: 13px;
    color: #5a9ae9;
    font-weight: 900;
    letter-spacing: .06em
}

.trusted div {
    display: flex;
    justify-content: center;
    gap: 70px;
    color: #60718c;
    font-size: 24px;
    font-weight: 900
}

.features { padding: 38px 60px 58px }

.features h2 {
    text-align: center;
    font-size: 31px;
    margin-bottom: 34px
}

.feature-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 18px
}

.feature-grid article {
    text-align: center;
    padding: 20px 12px;
    border-right: 1px solid var(--line)
}

.feature-grid article:last-child { border-right: 0 }

.feature-grid div {
    font-size: 32px;
    background: #eaf4ff;
    width: 70px;
    height: 70px;
    display: grid;
    place-items: center;
    margin: 0 auto 14px;
    border-radius: 10px
}

.feature-grid h3 { font-size: 15px }

.feature-grid p {
    font-size: 13px;
    line-height: 1.45;
    color: #334155
}

.how {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 55px;
    padding: 55px 58px 70px;
    background: linear-gradient(90deg, #f5fbff, #fff)
}

.steps h2 {
    font-size: 32px;
    line-height: 1.1
}

.steps ol {
    counter-reset: step;
    list-style: none;
    padding: 0;
    margin: 30px 0
}

.steps li {
    counter-increment: step;
    position: relative;
    padding: 0 0 28px 54px
}

.steps li:before {
    content: counter(step);
    position: absolute;
    left: 0;
    top: 0;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #228eff;
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 900
}

.steps li:after {
    content: "";
    position: absolute;
    left: 15px;
    top: 32px;
    width: 1px;
    height: 46px;
    background: #cfe0f5
}

.steps li:last-child:after { display: none }

.steps strong, .steps span { display: block }

.steps span {
    color: #475569;
    font-size: 14px;
    line-height: 1.4;
    margin-top: 4px
}

.dashboard-shell {
    display: flex;
    min-height: 100vh;
    background: #fbfdff
}

.preview-shell {
    min-height: auto;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 24px 60px rgba(38, 87, 143, .18);
    background: #fff
}

.sidebar {
    width: 240px;
    background: #fff;
    border-right: 1px solid var(--line);
    padding: 30px 20px;
    flex: 0 0 240px
}

.sidebar.compact {
    width: 178px;
    flex-basis: 178px;
    padding: 22px 16px
}

.compact-brand strong { font-size: 22px }

.sidebar nav, .sidebar {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.sidebar nav { margin-top: 38px }

.sidebar a:not(.brand) {
    padding: 12px 14px;
    border-radius: 9px;
    font-weight: 800;
    color: #253653
}

.sidebar a.active, .sidebar a:not(.brand):hover {
    background: #eaf4ff;
    color: #1683f7
}

.dashboard-main {
    flex: 1;
    padding: 36px 42px;
    min-width: 0
}

.preview-main {
    padding: 28px;
    transform: scale(.92);
    transform-origin: top left;
    width: calc(100% / .92)
}

.dash-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 28px
}

.dash-top h1, .dash-top h2 {
    margin: 0;
    font-size: 26px
}

.user-chip {
    display: flex;
    align-items: center;
    gap: 10px
}

.user-chip span {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #eaf4ff;
    color: #115cad;
    font-weight: 900;
    display: grid;
    place-items: center
}

.user-chip small {
    color: #475569;
    font-weight: 800;
    line-height: 1.2
}

.metric-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-bottom: 22px
}

.metric-grid article, .panel {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 11px;
    box-shadow: 0 8px 28px rgba(15, 45, 85, .06)
}

.metric-grid article { padding: 20px }

.metric-grid small {
    display: block;
    color: #64748b;
    font-weight: 800
}

.metric-grid strong {
    display: block;
    font-size: 34px;
    margin-top: 8px
}

.panel {
    padding: 22px;
    margin-bottom: 18px
}

.panel-title {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.panel h2, .panel h3 {
    font-size: 17px;
    margin: 0 0 16px
}

.panel-title a {
    color: #228eff;
    font-weight: 900;
    font-size: 13px
}

table {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px
}

th {
    text-align: left;
    color: #64748b;
    font-size: 12px
}

th, td {
    padding: 14px 10px;
    border-bottom: 1px solid var(--line)
}

tr:last-child td { border-bottom: 0 }

.badge {
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 900
}

.green {
    background: #d9f7e7;
    color: #188450
}

.bottom-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px
}

.donut-row {
    display: flex;
    align-items: center;
    gap: 40px
}

.donut {
    width: 145px;
    height: 145px;
    border-radius: 50%;
    background: conic-gradient(#1d73d8 0 42%, #3da0ff 42% 70%, #10886f 70% 84%, #a8b3c3 84%);
    position: relative
}

.donut:after {
    content: "";
    position: absolute;
    inset: 36px;
    border-radius: 50%;
    background: #fff
}

.donut-row li {
    list-style: none;
    margin: 12px 0;
    color: #475569
}

.donut-row b {
    float: right;
    margin-left: 50px;
    color: #12213d
}

.spend {
    font-size: 36px;
    font-weight: 900
}

.up {
    color: #16a34a;
    font-weight: 900
}

.spark {
    width: 100%;
    height: 100px;
    margin-top: 20px
}

.login-page {
    min-height: 100vh;
    background: linear-gradient(90deg, #fff 0 74%, #052657 74%);
    display: flex;
    align-items: center;
    padding-left: 0
}

.login-card {
    width: 520px;
    background: white;
    padding: 34px 38px 50px;
    border-radius: 0 0 28px 0
}

.login-brand { margin-bottom: 42px }

.login-card h1 {
    font-size: 36px;
    margin: 0 0 12px
}

.login-card p { color: #51617a }

.login-form {
    display: flex;
    flex-direction: column;
    gap: 12px
}

.login-form label { font-weight: 900 }

.login-form input {
    height: 56px;
    border: 1px solid #cbd8e8;
    border-radius: 14px;
    padding: 0 18px;
    font-size: 16px
}

.form-error {
    background: #feecec;
    color: #bf1717;
    border-radius: 14px;
    padding: 16px;
    font-weight: 900
}

.demo-note {
    font-size: 13px;
    margin-top: 18px
}

.talent-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px
}

.talent-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 16px;
    padding: 22px;
    box-shadow: 0 8px 28px rgba(15, 45, 85, .06)
}

.talent-card h2 {
    font-size: 18px;
    margin: 16px 0 6px
}

.talent-card p { color: #64748b }

.skill-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin: 18px 0
}

.skill-row span {
    background: #eef6ff;
    color: #1767bf;
    border-radius: 999px;
    padding: 7px 10px;
    font-weight: 800;
    font-size: 12px
}

.outline-light {
    display: block;
    text-align: center;
    border: 1px solid #c7defa;
    color: #1674d8;
    border-radius: 10px;
    padding: 12px;
    font-weight: 900
}

@media (max-width: 980px) {
    .marketing-nav nav { display: none }

    .hero, .how { grid-template-columns: 1fr }

    .hero-visual { display: none }

    .feature-grid { grid-template-columns: repeat(2, 1fr) }

    .dashboard-shell { display: block }

    .sidebar {
        width: 100%;
        flex-basis: auto
    }

    .metric-grid, .bottom-grid, .talent-grid { grid-template-columns: 1fr }

    .trusted div {
        gap: 18px;
        flex-wrap: wrap
    }

    .login-page { background: white }

    .login-card {
        width: 100%;
        border-radius: 0
    }
}

.config-form p { color: #64748b }

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin: 24px 0
}

.form-grid label {
    font-weight: 900;
    color: #12213d
}

.form-grid select {
    display: block;
    width: 100%;
    margin-top: 8px;
    height: 50px;
    border: 1px solid #cbd8e8;
    border-radius: 12px;
    padding: 0 14px;
    background: white;
    color: #12213d
}

@media (max-width: 980px) {
    .form-grid { grid-template-columns: 1fr }
}

.app-sidebar {
    width: 240px;
    background: #fff;
    border-right: 1px solid var(--line);
    padding: 30px 20px;
    flex: 0 0 240px;
    display: flex;
    flex-direction: column;
    gap: 12px
}

.app-sidebar .brand { margin-bottom: 28px }

.app-sidebar a:not(.brand) {
    padding: 12px 14px;
    border-radius: 9px;
    font-weight: 800;
    color: #253653
}

.app-sidebar a.active, .app-sidebar a:not(.brand):hover {
    background: #eaf4ff;
    color: #1683f7
}

.dashboard-preview {
    display: grid;
    grid-template-columns: 190px 1fr;
    gap: 0;
    padding: 0;
    overflow: hidden
}

.mini-sidebar {
    border-right: 1px solid var(--line);
    padding: 24px 18px;
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 10px
}

.mini-sidebar .brand strong { font-size: 22px }

.mini-sidebar span:not(.brand-mark) {
    border-radius: 9px;
    padding: 10px 12px;
    font-size: 13px;
    font-weight: 800;
    color: #334155
}

.mini-sidebar span.active {
    background: #eaf4ff;
    color: #1683f7
}

.mini-main {
    padding: 28px;
    min-width: 0
}

.metric-grid.mini { grid-template-columns: repeat(4, 1fr) }

.metric-grid.mini article { padding: 14px }

.metric-grid.mini strong { font-size: 24px }

.badge.blue {
    display: inline-flex;
    background: #eaf4ff;
    color: #1767bf;
    margin-top: 10px
}

.compliance-panel p {
    color: #475569;
    line-height: 1.5
}

.contract-provider {
    display: block;
    font-weight: 900;
    margin: 18px 0
}

.contract-provider select {
    display: block;
    width: 260px;
    margin-top: 8px;
    height: 50px;
    border: 1px solid #cbd8e8;
    border-radius: 12px;
    padding: 0 14px;
    background: white;
    color: #12213d
}

.button-row {
    display: flex;
    gap: 14px;
    flex-wrap: wrap
}

.outline-button.light {
    color: #1767bf;
    border-color: #bcd8fb;
    background: white;
    box-shadow: none
}

.info-box {
    margin-top: 18px;
    background: #eef6ff;
    border: 1px solid #c7defa;
    color: #1767bf;
    border-radius: 12px;
    padding: 14px;
    font-weight: 800
}

@media (max-width: 980px) {
    .app-sidebar {
        width: 100%;
        flex-basis: auto
    }

    .dashboard-preview { grid-template-columns: 1fr }

    .mini-sidebar { display: none }

    .metric-grid.mini { grid-template-columns: 1fr 1fr }
}

/* Public talent microsite and audience switcher */

.audience-bar {
    min-height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 8px 20px;
    background: #eef6ff;
    border-bottom: 1px solid #cfe1f7;
    color: #15345f;
    font-size: 14px
}

.audience-bar span { color: #49657f }

.audience-bar strong { font-weight: 900 }

.audience-bar a {
    color: #116bdc;
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 3px
}

.marketing-nav nav a.active { color: #116bdc }

.talent-site {
    background: #f7fbff;
    color: #071733
}

.talent-hero {
    min-height: 590px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 460px;
    gap: 60px;
    align-items: center;
    padding: 82px 58px;
    background: linear-gradient(135deg, #061f45 0%, #0a3264 64%, #f7fbff 64%, #f7fbff 100%);
    color: #fff
}

.talent-hero-copy { max-width: 690px }

.talent-hero h1 {
    margin: 18px 0 18px;
    font-size: 58px;
    line-height: 1.02;
    letter-spacing: -1.7px;
    color: #fff
}

.talent-hero-copy > p:not(.eyebrow) {
    max-width: 610px;
    color: #dcecff;
    font-size: 19px;
    line-height: 1.6
}

.talent-trust-note {
    max-width: 660px;
    margin-top: 26px;
    padding: 14px 16px;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .07);
    color: #d9eaff;
    font-size: 14px;
    font-weight: 800
}

.talent-hero-panel { align-self: center }

.talent-profile-preview {
    background: #fff;
    color: #071733;
    border: 1px solid #dce8f6;
    border-radius: 8px;
    padding: 24px;
    box-shadow: 0 24px 65px rgba(5, 31, 72, .18)
}

.talent-profile-preview-header {
    display: flex;
    gap: 14px;
    align-items: center;
    margin-bottom: 24px
}

.talent-profile-preview-header > span {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #0b5ed7;
    color: #fff;
    font-weight: 950
}

.talent-profile-preview-header strong, .talent-profile-preview-header small { display: block }

.talent-profile-preview-header small {
    margin-top: 3px;
    color: #64748b
}

.talent-profile-preview ol {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 12px
}

.talent-profile-preview li {
    display: grid;
    grid-template-columns: 34px 1fr;
    align-items: center;
    gap: 12px;
    padding: 13px;
    border: 1px solid #e5edf6;
    border-radius: 8px;
    background: #fbfdff
}

.talent-profile-preview b {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #eaf4ff;
    color: #1767bf
}

.talent-profile-preview li.complete b {
    background: #d9f7e7;
    color: #188450
}

.talent-section { padding: 66px 58px }

.section-heading {
    max-width: 780px;
    margin: 0 auto 32px;
    text-align: center
}

.section-heading h2, .talent-two-column h2, .talent-final-cta h2 {
    margin: 0;
    color: #071d49;
    font-size: 34px;
    line-height: 1.14;
    letter-spacing: -.8px
}

.talent-step-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    max-width: 1180px;
    margin: 0 auto
}

.talent-step-grid article, .talent-card-list article {
    background: #fff;
    border: 1px solid #dfe8f4;
    border-radius: 8px;
    padding: 24px;
    box-shadow: 0 12px 32px rgba(15, 45, 85, .06)
}

.talent-step-grid span {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #eaf4ff;
    color: #1767bf;
    font-weight: 950
}

.talent-step-grid h3, .talent-card-list h3 {
    margin: 18px 0 8px;
    color: #0a1e3f
}

.talent-step-grid p, .talent-card-list p, .talent-final-cta p {
    margin: 0;
    color: #4c5f78;
    line-height: 1.55
}

.talent-two-column {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 520px;
    gap: 54px;
    align-items: start;
    background: #fff
}

.talent-chip-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px
}

.talent-chip-grid span {
    display: inline-flex;
    border-radius: 999px;
    background: #eef6ff;
    color: #1767bf;
    padding: 10px 14px;
    font-weight: 900
}

.talent-card-list {
    display: grid;
    gap: 14px
}

.talent-card-list article { box-shadow: none }

.talent-final-cta {
    text-align: center;
    padding: 66px 20px 76px;
    background: #061f45;
    color: #fff
}

.talent-final-cta h2 { color: #fff }

.talent-final-cta p {
    max-width: 620px;
    margin: 14px auto 28px;
    color: #dcecff
}

.talent-signup-page {
    min-height: calc(100vh - 78px);
    display: grid;
    grid-template-columns: minmax(360px, .78fr) minmax(560px, 1.22fr);
    gap: 46px;
    padding: 58px;
    background: linear-gradient(90deg, #061f45 0 38%, #f7fbff 38% 100%)
}

.talent-signup-intro {
    color: #fff;
    padding-top: 26px
}

.talent-signup-intro h1 {
    max-width: 520px;
    margin: 18px 0 18px;
    color: #fff;
    font-size: 48px;
    line-height: 1.05;
    letter-spacing: -1.3px
}

.talent-signup-intro > p:not(.eyebrow) {
    max-width: 500px;
    color: #dcecff;
    font-size: 18px;
    line-height: 1.6
}

.review-note {
    max-width: 470px;
    margin-top: 28px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 8px;
    background: rgba(255, 255, 255, .07)
}

.review-note strong, .review-note span { display: block }

.review-note span {
    margin-top: 6px;
    color: #d4e8ff;
    line-height: 1.45
}

.talent-signup-card {
    width: 100%;
    max-width: 860px;
    justify-self: end;
    background: #fff;
    border: 1px solid #dfe8f4;
    border-radius: 8px;
    padding: 30px;
    box-shadow: 0 22px 55px rgba(6, 31, 69, .14)
}

.talent-signup-card.success {
    align-self: start;
    text-align: left;
    max-width: 640px
}

.success-mark {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #d9f7e7;
    color: #188450;
    font-weight: 950
}

.talent-signup-card.success h2 {
    margin: 18px 0 10px;
    font-size: 30px;
    color: #071d49
}

.talent-signup-card.success p {
    color: #4c5f78;
    line-height: 1.55
}

.signup-section-title { margin: 0 0 18px }

.signup-section-title:not(:first-child) {
    margin-top: 28px;
    padding-top: 26px;
    border-top: 1px solid #e6edf6
}

.signup-section-title h2 {
    margin: 0;
    color: #071d49;
    font-size: 22px
}

.signup-section-title p {
    margin: 6px 0 0;
    color: #667890;
    line-height: 1.45
}

.talent-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px
}

.talent-signup-card .field {
    display: grid;
    gap: 8px;
    color: #15233d;
    font-weight: 900
}

.talent-signup-card .field.wide { margin-top: 16px }

.talent-signup-card input, .talent-signup-card select, .talent-signup-card textarea {
    width: 100%;
    border: 1px solid #cbd8e8;
    border-radius: 8px;
    background: #fff;
    color: #071733;
    font: inherit;
    padding: 0 14px
}

.talent-signup-card input, .talent-signup-card select { height: 48px }

.talent-signup-card textarea {
    min-height: 104px;
    padding-top: 12px;
    resize: vertical
}

.talent-signup-card .field small {
    color: #697a91;
    font-weight: 700;
    line-height: 1.35
}

.profile-privacy-copy {
    margin: 20px 0 0;
    padding: 14px 16px;
    border: 1px solid #cfe1f7;
    border-radius: 8px;
    background: #eef6ff;
    color: #15345f;
    font-weight: 800;
    line-height: 1.45
}

.talent-signup-card .form-error { margin-top: 18px }

.talent-signup-card button.full { margin-top: 20px }

.talent-signup-card .outline-light {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    padding: 14px 20px;
    background: #fff
}

@media (max-width: 1100px) {
    .talent-hero, .talent-two-column, .talent-signup-page { grid-template-columns: 1fr }

    .talent-hero { background: #061f45 }

    .talent-step-grid { grid-template-columns: repeat(2, minmax(0, 1fr)) }

    .talent-signup-page {
        background: #061f45;
        padding: 40px 24px
    }

    .talent-signup-card {
        justify-self: stretch;
        max-width: none
    }
}

@media (max-width: 700px) {
    .audience-bar {
        align-items: flex-start;
        flex-direction: column;
        gap: 2px
    }

    .talent-hero, .talent-section { padding: 42px 20px }

    .talent-hero h1, .talent-signup-intro h1 { font-size: 38px }

    .talent-step-grid, .talent-form-grid { grid-template-columns: 1fr }

    .talent-signup-page { padding: 32px 18px }

    .talent-signup-card { padding: 22px }

    .talent-two-column { padding: 42px 20px }

    .talent-hero-panel { display: none }
}

.dash-user-actions {
    display: flex;
    align-items: center;
    gap: 16px
}

.logout-link {
    font-size: 13px;
    font-weight: 900;
    color: #226fd8;
    background: #eaf4ff;
    border-radius: 999px;
    padding: 9px 13px
}

.logout-link:hover { background: #dbeeff }

/* Login demo account buttons restored after scoped CSS split. */

.demo-note {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap
}

.demo-note strong { margin-right: 2px }

.demo-note button {
    border: 1px solid #c7defa;
    background: #eef6ff;
    color: #1767bf;
    border-radius: 999px;
    padding: 8px 11px;
    font-size: 12px;
    font-weight: 900;
    cursor: pointer
}

.demo-note button:hover {
    background: #e1f0ff;
    border-color: #91c7ff
}

.form-success {
    background: #ecfdf3;
    color: #167044;
    border-radius: 14px;
    padding: 16px;
    font-weight: 900;
    margin: 16px 0
}

/* MVP operational queue component fallback
   This belongs in global.css during the static/Vite transition because global.css is always loaded
   on portal shells. Keep this until all portal CSS is emitted through Vite chunks. */

.ops-workqueue-panel,
.deliverable-list-panel { min-height: 420px; }

.ops-workqueue-item,
.deliverable-list-item {
    appearance: none;
    -webkit-appearance: none;
    box-sizing: border-box;
    width: 100%;
    min-height: 82px;
    border: 1px solid var(--tf-color-border, var(--tf-border, #dfe8f7));
    border-radius: var(--tf-radius-lg, 18px);
    background: var(--tf-color-surface, #ffffff);
    color: var(--tf-color-text, var(--tf-text, #071431));
    cursor: default;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: 0;
    padding: 18px;
    text-align: left;
    font: inherit;
    line-height: 1.35;
    box-shadow: none;
    outline: 0;
    transition: border-color .15s ease, background .15s ease, box-shadow .15s ease, transform .15s ease;
}

.ops-workqueue-item + .ops-workqueue-item,
.deliverable-list-item + .deliverable-list-item { margin-top: 14px; }

.ops-workqueue-item.is-interactive,
.deliverable-list-item { cursor: pointer; }

.ops-workqueue-item:hover,
.ops-workqueue-item.active,
.ops-workqueue-item:focus-visible,
.deliverable-list-item:hover,
.deliverable-list-item.active,
.deliverable-list-item:focus-visible {
    border-color: #4f8ff7;
    background: #f8fbff;
    box-shadow: 0 14px 34px rgba(9, 29, 75, .08);
    transform: translateY(-1px);
}

.ops-workqueue-main,
.ops-workqueue-meta,
.deliverable-list-item > span:first-child,
.deliverable-list-item > span:last-child {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
}

.ops-workqueue-main,
.deliverable-list-item > span:first-child {
    flex: 1 1 auto;
    align-items: flex-start;
}

.ops-workqueue-meta,
.deliverable-list-item > span:last-child {
    align-items: flex-end;
    flex: 0 0 auto;
    text-align: right;
    white-space: nowrap;
}

.ops-workqueue-item strong,
.deliverable-list-item strong {
    color: var(--tf-color-text, var(--tf-text, #071431));
    display: block;
    font-size: 15px;
    font-weight: 850;
    letter-spacing: -.015em;
    line-height: 1.3;
    margin: 0;
}

.ops-workqueue-item small,
.deliverable-list-item small {
    color: var(--tf-color-text-muted, var(--tf-muted, #64708a));
    display: block;
    font-size: 12px;
    font-weight: 650;
    line-height: 1.35;
    margin: 0;
}

.ops-workqueue-item .ops-badge,
.ops-workqueue-item .badge,
.deliverable-list-item .badge { margin: 0; }

@media (max-width: 760px) {
    .ops-workqueue-item,
    .deliverable-list-item {
        align-items: flex-start;
        flex-direction: column;
    }

    .ops-workqueue-meta,
    .deliverable-list-item > span:last-child {
        align-items: flex-start;
        text-align: left;
        white-space: normal;
    }
}

/* TeamForge login redesign */

.login-page-modern {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(480px, 1.05fr) minmax(420px, .95fr);
    align-items: stretch;
    padding: 0;
    background: #f6f9fd;
    color: var(--tf-color-text, #071633);
    overflow: hidden;
}

.login-page-modern .brand {
    color: #fff;
    text-decoration: none
}

.login-page-modern .brand strong { color: #fff }

.login-page-modern .brand small { color: #79b9ff }

.login-hero-panel {
    position: relative;
    min-height: 100vh;
    padding: 56px 64px;
    display: flex;
    align-items: center;
    background:
              radial-gradient(circle at 18% 18%, rgba(58, 153, 255, .34), transparent 29%),
              radial-gradient(circle at 84% 72%, rgba(255, 106, 26, .18), transparent 30%),
              linear-gradient(135deg, #031936 0%, #062b5f 52%, #041a38 100%);
    color: #fff;
    isolation: isolate;
}

.login-hero-panel:before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
                    linear-gradient(rgba(255, 255, 255, .055) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255, 255, 255, .055) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: linear-gradient(90deg, rgba(0, 0, 0, .82), rgba(0, 0, 0, .16));
    z-index: -2;
}

.login-hero-glow {
    position: absolute;
    width: 520px;
    height: 520px;
    right: -180px;
    top: 14%;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(35, 133, 255, .32), transparent 62%);
    filter: blur(4px);
    z-index: -1;
}

.login-hero-content {
    max-width: 660px;
    width: 100%
}

.login-hero-brand { margin-bottom: 86px }

.login-hero-panel .eyebrow {
    margin: 0 0 18px;
    color: #72b8ff;
    letter-spacing: .1em;
    font-size: 13px;
    font-weight: 900
}

.login-hero-panel h1 {
    margin: 0;
    max-width: 620px;
    font-size: 56px;
    line-height: 1.03;
    letter-spacing: -2.4px;
    color: #fff
}

.login-hero-copy {
    max-width: 590px;
    margin: 22px 0 0;
    color: #d7e9ff;
    font-size: 18px;
    line-height: 1.6
}

.login-hero-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 42px;
    max-width: 620px
}

.login-hero-metrics article {
    padding: 18px 18px 16px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 18px;
    background: rgba(255, 255, 255, .08);
    box-shadow: 0 20px 60px rgba(0, 0, 0, .18);
    backdrop-filter: blur(14px);
}

.login-hero-metrics span {
    display: block;
    font-size: 28px;
    line-height: 1;
    font-weight: 950;
    letter-spacing: -.8px;
    color: #fff
}

.login-hero-metrics small {
    display: block;
    margin-top: 8px;
    color: #bed9f8;
    font-weight: 800;
    line-height: 1.35
}

.login-security-card {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    max-width: 620px;
    margin-top: 18px;
    padding: 18px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 18px;
    background: rgba(3, 20, 45, .54);
    box-shadow: 0 24px 70px rgba(0, 0, 0, .2);
}

.login-security-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(39, 168, 102, .22);
    color: #8ff0bd;
    font-weight: 950;
    flex: 0 0 auto
}

.login-security-card strong {
    display: block;
    color: #fff;
    font-weight: 950
}

.login-security-card small {
    display: block;
    margin-top: 5px;
    color: #bdd4f4;
    line-height: 1.45;
    font-weight: 700
}

.login-auth-panel {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px;
    background: linear-gradient(135deg, #f8fbff 0%, #eef5ff 100%)
}

.login-auth-card {
    width: min(100%, 500px);
    padding: 38px;
    border: 1px solid rgba(196, 213, 235, .92);
    border-radius: 28px;
    background: rgba(255, 255, 255, .92);
    box-shadow: 0 30px 80px rgba(23, 67, 122, .16);
    backdrop-filter: blur(18px);
}

.login-mobile-brand {
    display: none;
    margin-bottom: 30px
}

.login-mobile-brand .brand { color: var(--tf-color-text, #071633) }

.login-mobile-brand .brand strong { color: var(--tf-color-text, #071633) }

.login-card-header { margin-bottom: 24px }

.login-auth-kicker {
    display: inline-flex;
    margin-bottom: 10px;
    color: #1b73df;
    font-size: 13px;
    font-weight: 950;
    letter-spacing: .08em;
    text-transform: uppercase
}

.login-card-header h2 {
    margin: 0;
    color: #061733;
    font-size: 36px;
    line-height: 1.06;
    letter-spacing: -1.3px
}

.login-card-header p {
    margin: 12px 0 0;
    color: #52627a;
    line-height: 1.5;
    font-weight: 650
}

.login-message {
    margin: 0 0 22px;
    border: 1px solid #b7efd0;
    background: #ecfdf4;
    color: #11633b;
    box-shadow: 0 12px 26px rgba(22, 112, 68, .08)
}

.login-message strong { font-weight: 950 }

.login-message span { font-weight: 750 }

.login-form-modern { gap: 10px }

.login-form-modern label {
    margin-top: 8px;
    color: #0b1d3b;
    font-size: 14px;
    font-weight: 950
}

.login-input-shell { position: relative }

.login-input-shell input {
    width: 100%;
    height: 58px;
    border: 1px solid #c9d8ea;
    border-radius: 16px;
    background: #fff;
    padding: 0 18px;
    color: #071633;
    font-size: 16px;
    font-weight: 700;
    outline: none;
    box-shadow: 0 8px 20px rgba(15, 45, 85, .04);
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.login-input-shell input:focus {
    border-color: #2385ff;
    box-shadow: 0 0 0 4px rgba(35, 133, 255, .13), 0 10px 24px rgba(15, 45, 85, .08)
}

.login-submit {
    height: 58px;
    margin-top: 12px;
    border-radius: 16px;
    font-size: 16px;
    box-shadow: 0 18px 42px rgba(255, 106, 26, .24)
}

.login-submit:disabled {
    opacity: .72;
    cursor: not-allowed
}

.demo-access-card {
    margin-top: 22px;
    padding: 18px;
    border: 1px solid #dce8f7;
    border-radius: 18px;
    background: linear-gradient(180deg, #fbfdff, #f3f8ff)
}

.demo-access-header {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: flex-start;
    margin-bottom: 14px
}

.demo-access-header strong {
    color: #0b1d3b;
    font-weight: 950
}

.demo-access-header span {
    color: #64748b;
    font-size: 12px;
    font-weight: 800;
    text-align: right
}

.demo-account-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px
}

.demo-account-grid button {
    min-height: 40px;
    border: 1px solid #c9def8;
    border-radius: 12px;
    background: #fff;
    color: #1767bf;
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 6px 14px rgba(15, 45, 85, .04);
}

.demo-account-grid button:hover, .demo-account-grid button.active {
    border-color: #2385ff;
    background: #eaf4ff;
    color: #0757aa
}

.login-page-modern .form-error {
    margin-top: 8px;
    border: 1px solid #fecaca;
    background: #fff1f1;
    color: #b91c1c
}

@media (max-width: 1100px) {
    .login-page-modern { grid-template-columns: 1fr }

    .login-hero-panel { display: none }

    .login-auth-panel {
        padding: 30px;
        min-height: 100vh
    }

    .login-auth-card { max-width: 520px }

    .login-mobile-brand { display: block }

    .login-mobile-brand .brand-mark:before, .login-mobile-brand .brand-mark i { background: #1b73df }

    .login-mobile-brand .brand-mark i:first-child { background: #3a99ff }

    .login-mobile-brand .brand-mark i:last-child { background: #0f4d94 }
}

@media (max-width: 560px) {
    .login-auth-panel { padding: 18px }

    .login-auth-card {
        padding: 26px 22px;
        border-radius: 22px
    }

    .login-card-header h2 { font-size: 30px }

    .demo-access-header { display: block }

    .demo-access-header span {
        display: block;
        margin-top: 5px;
        text-align: left
    }

    .demo-account-grid { grid-template-columns: 1fr }
}

/* Public Talent page: account-first conversion experience. */

.talent-site {
    background: #fff;
    overflow: hidden
}

.talent-hero {
    position: relative;
    min-height: 628px;
    grid-template-columns: minmax(0, 1.02fr) minmax(410px, .86fr);
    gap: 56px;
    padding: 92px 58px 76px;
    background: linear-gradient(135deg, #061f45 0%, #0a3264 58%, #0f4789 100%);
    color: #fff
}

.talent-hero:after {
    content: "";
    position: absolute;
    right: -210px;
    bottom: -245px;
    width: 660px;
    height: 430px;
    background: rgba(255, 255, 255, .94);
    transform: rotate(-36deg);
    border-radius: 42px;
    box-shadow: 0 18px 55px rgba(6, 41, 90, .14)
}

.talent-hero-copy, .talent-hero-panel {
    position: relative;
    z-index: 1
}

.talent-hero h1 {
    max-width: 760px;
    margin: 18px 0 22px;
    font-size: 62px;
    line-height: 1.02;
    letter-spacing: -2px
}

.talent-hero-copy > p:not(.eyebrow) {
    max-width: 720px;
    margin-bottom: 30px;
    color: #d8e8fb;
    font-size: 20px
}

.talent-trust-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    max-width: 720px;
    margin-top: 24px
}

.talent-trust-note {
    min-height: 72px;
    margin: 0;
    padding: 15px 16px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 16px;
    background: rgba(255, 255, 255, .105)
}

.talent-trust-note strong {
    display: block;
    color: #fff;
    font-size: 15px
}

.talent-trust-note span {
    display: block;
    margin-top: 4px;
    color: #c7daf0;
    font-size: 13px;
    font-weight: 650
}

.talent-hero-panel { align-self: center }

.talent-profile-preview {
    max-width: 520px;
    margin-left: auto;
    border-radius: 24px;
    padding: 26px;
    box-shadow: 0 25px 80px rgba(0, 0, 0, .25)
}

.talent-profile-preview-header {
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 20px
}

.talent-profile-preview-header > span { border-radius: 17px }

.talent-profile-preview-header strong { font-size: 19px }

.talent-status-pill {
    flex: 0 0 auto;
    border-radius: 999px;
    background: #e8f5ed;
    color: #157347;
    padding: 9px 13px;
    font-style: normal;
    font-size: 13px;
    font-weight: 900
}

.talent-progress-card {
    margin: 18px 0;
    padding: 18px;
    border: 1px solid #dceafb;
    border-radius: 20px;
    background: #f5f9ff
}

.talent-progress-card > div:first-child {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 11px;
    font-weight: 900
}

.talent-progress-bar {
    height: 12px;
    overflow: hidden;
    border-radius: 999px;
    background: #dce8f7
}

.talent-progress-bar span {
    display: block;
    width: 38%;
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #1f7ad6, #6bb7fb)
}

.talent-profile-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 12px
}

.talent-profile-steps li {
    display: grid;
    grid-template-columns: 34px 1fr;
    gap: 12px;
    align-items: start;
    padding: 14px;
    border: 1px solid #e2eaf4;
    border-radius: 16px;
    background: #fff
}

.talent-profile-steps b {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: #eaf4ff;
    color: #1767bf
}

.talent-profile-steps li.complete b {
    background: #ff6b2c;
    color: #fff
}

.talent-profile-steps strong {
    display: block;
    color: #071733;
    font-size: 15px
}

.talent-profile-steps small {
    display: block;
    margin-top: 2px;
    color: #64748b;
    font-size: 13px;
    line-height: 1.4
}

.talent-role-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-top: 18px
}

.talent-role-preview span {
    border-radius: 999px;
    background: #edf6ff;
    color: #136bbd;
    padding: 8px 11px;
    font-size: 12px;
    font-weight: 900
}

.section-heading p:not(.eyebrow) {
    max-width: 760px;
    margin: 12px auto 0;
    color: #5d6b82;
    font-size: 18px;
    line-height: 1.55
}

.talent-how { background: #f5f8fc }

.talent-step-grid article {
    min-height: 190px;
    border-radius: 20px
}

.talent-step-grid article.featured {
    border: 2px solid #ff8a55;
    box-shadow: 0 18px 46px rgba(255, 107, 44, .18)
}

.talent-step-grid article.featured span {
    background: #ff6b2c;
    color: #fff
}

.talent-two-column {
    grid-template-columns: .92fr 1.08fr;
    background: #fff
}

.talent-two-column > div:first-child > p:not(.eyebrow) {
    max-width: 610px;
    margin-top: 15px;
    color: #5d6b82;
    font-size: 18px;
    line-height: 1.6
}

.talent-card-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px
}

.talent-card-list article {
    border-radius: 20px;
    box-shadow: 0 10px 28px rgba(8, 42, 88, .055)
}

.talent-roles { background: #f5f8fc }

.talent-roles .talent-chip-grid {
    justify-content: center;
    max-width: 980px;
    margin: 0 auto
}

.talent-chip-grid span {
    background: #eaf4ff;
    color: #126fc7
}

.talent-final-cta {
    padding: 72px 20px;
    background: #061f45
}

.talent-final-cta small {
    display: block;
    max-width: 720px;
    margin: 20px auto 0;
    color: #a9c3e2;
    font-size: 13px;
    font-weight: 800;
    line-height: 1.45
}

.talent-site a:focus-visible, .talent-site button:focus-visible {
    outline: 3px solid #67b8ff;
    outline-offset: 4px
}

@media (max-width: 1100px) {
    .talent-hero {
        grid-template-columns: 1fr;
        background: #061f45
    }

    .talent-hero:after { display: none }

    .talent-profile-preview {
        max-width: none;
        margin: 0
    }

    .talent-trust-grid { grid-template-columns: 1fr }

    .talent-two-column { grid-template-columns: 1fr }

    .talent-card-list { grid-template-columns: 1fr }
}

@media (max-width: 700px) {
    .talent-hero { padding: 44px 20px }

    .talent-hero h1 {
        font-size: 40px;
        letter-spacing: -1px
    }

    .talent-hero-copy > p:not(.eyebrow) { font-size: 17px }

    .talent-hero-panel { display: block }

    .talent-profile-preview {
        padding: 20px;
        border-radius: 18px
    }

    .talent-profile-preview-header { align-items: flex-start }

    .talent-status-pill { font-size: 12px }

    .talent-step-grid { grid-template-columns: 1fr }

    .talent-card-list { grid-template-columns: 1fr }

    .talent-final-cta { padding: 54px 20px }
}

.feature-grid .feature-icon {
    font-family: "Segoe UI Symbol", "Apple Symbols", "Noto Sans Symbols", Inter, Segoe UI, Arial, sans-serif;
    font-size: 34px;
    line-height: 1;
    color: #0f4d94;
    font-weight: 900
}

/* Talent page hero image and step-flow refinements. */

.talent-hero {
    grid-template-columns: minmax(0, .92fr) minmax(460px, 1.08fr);
    align-items: center;
}

.talent-hero-image-panel { min-width: 0; }

.talent-hero-image-card {
    position: relative;
    overflow: hidden;
    width: min(100%, 660px);
    margin: 0 0 0 auto;
    border: 1px solid rgba(255, 255, 255, .2);
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 28px 80px rgba(0, 0, 0, .28);
}

.talent-hero-image-card img {
    display: block;
    width: 100%;
    height: clamp(360px, 42vw, 520px);
    object-fit: cover;
    object-position: center;
}

.talent-hero-image-card figcaption {
    position: absolute;
    right: 18px;
    bottom: 18px;
    left: 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 16px 18px;
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 16px;
    background: rgba(6, 31, 69, .86);
    color: #ffffff;
    box-shadow: 0 18px 48px rgba(0, 0, 0, .22);
    backdrop-filter: blur(12px);
}

.talent-hero-image-card figcaption strong,
.talent-hero-image-card figcaption span {
    display: block;
    min-width: 0;
}

.talent-hero-image-card figcaption strong {
    font-size: 16px;
    font-weight: 950;
}

.talent-hero-image-card figcaption span {
    max-width: 310px;
    color: #cfe2fa;
    font-size: 13px;
    font-weight: 750;
    line-height: 1.4;
}

.talent-step-flow {
    grid-template-columns:
                         minmax(0, 1fr) 42px
                         minmax(0, 1fr) 42px
                         minmax(0, 1fr) 42px
                         minmax(0, 1fr);
    align-items: stretch;
    gap: 14px;
}

.talent-step-arrow {
    align-self: center;
    justify-self: center;
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid #c7defa;
    border-radius: 999px;
    background: #eaf4ff;
    color: #1767bf;
    box-shadow: 0 12px 26px rgba(23, 103, 191, .1);
}

.talent-step-arrow:before {
    content: "";
    width: 10px;
    height: 10px;
    border-top: 3px solid currentColor;
    border-right: 3px solid currentColor;
    transform: translateX(-2px) rotate(45deg);
}

@media (max-width: 1100px) {
    .talent-hero { grid-template-columns: 1fr; }

    .talent-hero-image-card {
        width: 100%;
        margin: 0;
    }

    .talent-step-flow {
        grid-template-columns: 1fr;
        max-width: 720px;
        margin-right: auto;
        margin-left: auto;
    }

    .talent-step-arrow {
        margin: -2px auto;
        transform: rotate(90deg);
    }
}

@media (max-width: 700px) {
    .talent-hero-image-card { border-radius: 18px; }

    .talent-hero-image-card img {
        height: 330px;
        object-position: 42% center;
    }

    .talent-hero-image-card figcaption {
        position: static;
        display: block;
        border: 0;
        border-radius: 0;
        background: #061f45;
        box-shadow: none;
    }

    .talent-hero-image-card figcaption span {
        max-width: none;
        margin-top: 5px;
    }
}

/* Talent signup wizard. */

.talent-signup-wizard {
    grid-template-columns: minmax(360px, .76fr) minmax(560px, 1.24fr);
    align-items: start;
}

.talent-signup-steps {
    display: grid;
    gap: 12px;
    max-width: 500px;
    margin: 32px 0 0;
    padding: 0;
    list-style: none;
}

.talent-signup-steps li {
    display: grid;
    grid-template-columns: 40px 1fr;
    gap: 12px;
    align-items: center;
    padding: 14px;
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 16px;
    background: rgba(255, 255, 255, .075);
    color: #dcecff;
}

.talent-signup-steps li.active {
    border-color: rgba(103, 184, 255, .58);
    background: rgba(35, 133, 255, .18);
    color: #ffffff;
}

.talent-signup-steps li.done {
    border-color: rgba(126, 226, 170, .42);
    background: rgba(39, 168, 102, .18);
}

.talent-signup-steps li > span {
    display: grid;
    place-items: center;
    width: 40px;
    height: 40px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .14);
    color: #ffffff;
    font-weight: 950;
}

.talent-signup-steps li.done > span:before {
    content: "";
    width: 11px;
    height: 7px;
    border-bottom: 3px solid #ffffff;
    border-left: 3px solid #ffffff;
    transform: translateY(-1px) rotate(-45deg);
}

.talent-signup-steps strong,
.talent-signup-steps small { display: block; }

.talent-signup-steps small {
    margin-top: 2px;
    color: #bfd8f7;
    font-weight: 750;
}

.talent-signup-card {
    border-radius: 20px;
    padding: 34px;
}

.talent-signup-card .eyebrow { margin-bottom: 10px; }

.talent-signup-card input:focus {
    border-color: #2385ff;
    box-shadow: 0 0 0 4px rgba(35, 133, 255, .13);
    outline: 0;
}

.talent-signup-card input:disabled,
.talent-signup-card button:disabled {
    cursor: not-allowed;
    opacity: .62;
}

.password-checklist {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 14px;
    margin-top: 18px;
    padding: 16px;
    border: 1px solid #dce8f7;
    border-radius: 16px;
    background: #f7fbff;
}

.password-checklist strong {
    grid-column: 1/-1;
    color: #071d49;
    font-size: 14px;
    font-weight: 950;
}

.password-checklist span {
    display: flex;
    gap: 8px;
    align-items: center;
    color: #687991;
    font-size: 13px;
    font-weight: 800;
}

.password-checklist span:before {
    content: "";
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
    border: 1px solid #c8d8ea;
    border-radius: 999px;
    background: #ffffff;
}

.password-checklist span.valid { color: #116a3a; }

.password-checklist span.valid:before {
    border-color: #27a866;
    background: radial-gradient(circle at center, #27a866 0 42%, #ffffff 45% 100%);
}

.talent-signup-confirmation {
    align-self: start;
    max-width: 760px;
}

.talent-signup-confirmation .success-mark:before {
    content: "";
    width: 14px;
    height: 9px;
    border-bottom: 3px solid currentColor;
    border-left: 3px solid currentColor;
    transform: translateY(-1px) rotate(-45deg);
}

.talent-next-path {
    display: grid;
    gap: 12px;
    margin: 22px 0;
}

.talent-next-path article {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 16px;
    border: 1px solid #dce8f7;
    border-radius: 14px;
    background: #f7fbff;
}

.talent-next-path strong,
.talent-next-path span { display: block; }

.talent-next-path strong {
    color: #1767bf;
    font-weight: 950;
}

.talent-next-path span {
    color: #4c5f78;
    font-weight: 750;
    text-align: right;
}

.talent-signup-card .outline-button.full {
    display: inline-flex;
    justify-content: center;
    width: 100%;
    margin-top: 12px;
    border-color: #bfd5ef;
    color: #0a3264;
}

.talent-signup-fineprint {
    margin: 14px 0 0;
    color: #667890;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.45;
    text-align: center;
}

@media (max-width: 1100px) {
    .talent-signup-wizard { grid-template-columns: 1fr; }

    .talent-signup-steps { max-width: none; }
}

@media (max-width: 700px) {
    .talent-signup-card { padding: 24px 20px; }

    .password-checklist { grid-template-columns: 1fr; }

    .talent-next-path article { display: block; }

    .talent-next-path span {
        margin-top: 4px;
        text-align: left;
    }
}