/**
 * CARE app shell — presentation layer (use of tokens only).
 * Targets html.care-app and data-care-* hooks from UserManagementWebPresentation.
 */

/* —— Document shell —— */
html.care-app {
    font-family: var(--care-app-type-family-body);
    font-size: var(--care-app-type-size-body);
    font-weight: var(--care-app-type-weight-body);
    line-height: var(--care-app-type-leading-body);
    -webkit-text-size-adjust: 100%;
}

html.care-app body {
    margin: 0;
    min-height: 100dvh;
    color: var(--care-app-color-ink-primary);
    background-color: var(--care-app-color-canvas);
    background-image: var(--care-app-color-canvas-tint);
}

/* —— Main landmark (page chrome) —— */
html.care-app main[data-care-page] {
    box-sizing: border-box;
    width: min(100%, var(--care-app-width-shell-max));
    max-width: 100%;
    margin-inline: auto;
    padding-inline: var(--care-app-width-shell-pad-inline);
    padding-block: var(--care-app-width-shell-pad-block);
}

/* —— Auth & public notice pages: centered card —— */
html.care-app main[data-care-page="login"],
html.care-app main[data-care-page="signup"],
html.care-app main[data-care-page="goodbye-signed-out"],
html.care-app main[data-care-page="goodbye-account-closed"],
html.care-app main[data-care-page="forbidden"] {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-block-start: clamp(2rem, 12vh, 5rem);
    padding-block-end: var(--care-app-space-2xl);
}

html.care-app .care-auth-card {
    box-sizing: border-box;
    width: min(100%, 24rem);
    margin-inline: auto;
    padding: var(--care-app-space-xl);
    border-radius: var(--care-app-radius-lg);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-default);
    box-shadow: var(--care-app-shadow-raised);
}

html.care-app main[data-care-page="signup"] .care-auth-card {
    width: min(100%, 26rem);
}

html.care-app .care-auth-card > h1:first-child {
    margin-top: 0;
}

html.care-app .care-auth-card form button[type="submit"] {
    width: 100%;
}

html.care-app .care-auth-card__pricing-row {
    margin-block: var(--care-app-space-md) 0;
    margin-inline: 0;
    text-align: center;
}

html.care-app .care-auth-card__pricing {
    font: inherit;
    font-size: var(--care-app-type-size-body-small);
    color: var(--care-app-color-accent-primary, #2563eb);
    background: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

html.care-app .care-auth-card__pricing:hover {
    color: var(--care-app-color-ink-primary);
}

@media (min-width: 64rem) {
    html.care-app {
        --care-app-width-shell-pad-inline: var(--care-app-space-xl);
    }
}

/* —— Typography roles —— */
html.care-app h1 {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-heading-1);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-tight);
    letter-spacing: var(--care-app-type-tracking-heading);
    color: var(--care-app-color-ink-primary);
}

html.care-app h2 {
    margin: var(--care-app-space-section) 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-heading-2);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-snug);
    letter-spacing: var(--care-app-type-tracking-heading);
    color: var(--care-app-color-ink-primary);
}

html.care-app h3 {
    margin: var(--care-app-space-lg) 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-heading-3);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-ink-secondary);
}

html.care-app main[data-care-page] > h2:first-of-type,
html.care-app section:first-of-type > h2:first-child {
    margin-top: var(--care-app-space-lg);
}

html.care-app p {
    margin: 0 0 var(--care-app-space-md);
    color: var(--care-app-color-ink-secondary);
}

/* Main app pages: paragraphs follow section width (no ultra-narrow “typewriter column”) */
html.care-app main[data-care-page] p {
    max-width: none;
}

html.care-app ul {
    margin: 0 0 var(--care-app-space-md);
    padding-inline-start: var(--care-app-space-lg);
    color: var(--care-app-color-ink-secondary);
}

html.care-app li {
    margin-block: var(--care-app-space-xs);
}

html.care-app strong {
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

/* —— Section (feature regions) —— */
html.care-app section[data-care-feature],
html.care-app section[data-care-dashboard],
html.care-app section[data-care-profile] {
    margin-block-end: var(--care-app-space-xl);
    padding: var(--care-app-space-lg);
    border-radius: var(--care-app-radius-lg);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-default);
    box-shadow: var(--care-app-shadow-raised);
}

html.care-app section[data-care-feature] > h2:first-child,
html.care-app section[data-care-dashboard] > h2:first-child {
    margin-top: 0;
}

/* —— Prose & note callouts —— */
html.care-app .care-profile-note {
    padding: var(--care-app-space-md) var(--care-app-space-lg);
    border-radius: var(--care-app-radius-md);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-info-border);
    background: var(--care-app-color-info-surface);
    color: var(--care-app-color-info-ink);
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-snug);
    max-width: var(--care-app-measure-prose);
}

html.care-app .care-profile-note strong {
    color: inherit;
}

html.care-app .care-dashboard-org {
    font-size: var(--care-app-type-size-lead);
    color: var(--care-app-color-ink-secondary);
}

/* —— Links —— */
html.care-app a {
    color: var(--care-app-color-accent);
    text-decoration: var(--care-app-link-underline-default);
    text-underline-offset: 0.15em;
    transition:
        color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        text-decoration var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

html.care-app a:hover {
    color: var(--care-app-color-accent-hover);
    text-decoration: var(--care-app-link-underline-interaction);
}

html.care-app a:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
    border-radius: var(--care-app-radius-sm);
}

/* —— Forms: field groups —— */
html.care-app form p {
    margin: 0 0 var(--care-app-space-md);
    max-width: var(--care-app-measure-prose);
}

html.care-app main[data-care-page] form p {
    max-width: none;
}

html.care-app label {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--care-app-space-xs);
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-secondary);
}

html.care-app label:has(input[type="checkbox"]) {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--care-app-space-sm);
    font-weight: var(--care-app-type-weight-body);
}

html.care-app input[type="text"],
html.care-app input[type="email"],
html.care-app input[type="password"],
html.care-app input[type="number"],
html.care-app select,
html.care-app textarea {
    box-sizing: border-box;
    width: 100%;
    max-width: min(100%, 28rem);
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    font: inherit;
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-control-text);
    background: var(--care-app-color-control-bg);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-control-border);
    border-radius: var(--care-app-radius-md);
    box-shadow: var(--care-app-shadow-none);
    transition:
        border-color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        box-shadow var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

html.care-app textarea {
    min-height: 8rem;
    resize: vertical;
    max-width: min(100%, 36rem);
}

html.care-app input:disabled,
html.care-app select:disabled,
html.care-app textarea:disabled,
html.care-app button:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

html.care-app input:focus-visible,
html.care-app select:focus-visible,
html.care-app textarea:focus-visible {
    outline: none;
    border-color: var(--care-app-color-accent);
    box-shadow: 0 0 0 1px var(--care-app-color-accent);
}

html.care-app input[type="checkbox"] {
    width: auto;
    max-width: none;
    margin-top: var(--care-app-space-2xs);
    accent-color: var(--care-app-color-accent);
}

/* —— Buttons (primary action) —— */
html.care-app button[type="submit"],
html.care-app button:not([type]) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--care-app-space-sm) var(--care-app-space-lg);
    font: inherit;
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-tight);
    color: var(--care-app-color-ink-on-accent);
    background: var(--care-app-color-accent);
    border: var(--care-app-border-width-hairline) solid transparent;
    border-radius: var(--care-app-radius-md);
    cursor: pointer;
    transition:
        background var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        transform var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

html.care-app button[type="submit"]:hover,
html.care-app button:not([type]):hover {
    background: var(--care-app-color-accent-hover);
}

html.care-app button[type="submit"]:focus-visible,
html.care-app button:not([type]):focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

/* Irreversible / destructive: soft tint at rest; solid red on hover/focus only */
html.care-app button[type="submit"].care-btn.care-btn--danger,
html.care-app button.care-btn.care-btn--danger[type="button"] {
    color: var(--care-app-color-danger-button-label);
    background: var(--care-app-color-danger-button-surface);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-danger-button-border);
    border-radius: var(--care-app-radius-md);
    cursor: pointer;
    transition:
        background var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        border-color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        transform var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

html.care-app button[type="submit"].care-btn.care-btn--danger:hover,
html.care-app button.care-btn.care-btn--danger[type="button"]:hover,
html.care-app button[type="submit"].care-btn.care-btn--danger:focus-visible,
html.care-app button.care-btn.care-btn--danger[type="button"]:focus-visible {
    color: var(--care-app-color-danger-button-ink);
    border-color: transparent;
    background: var(--care-app-color-danger-button-fill);
}

html.care-app button[type="submit"].care-btn.care-btn--danger:hover,
html.care-app button.care-btn.care-btn--danger[type="button"]:hover {
    background: var(--care-app-color-danger-button-fill-hover);
}

html.care-app button[type="submit"].care-btn.care-btn--danger:focus-visible,
html.care-app button.care-btn.care-btn--danger[type="button"]:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn.care-btn--danger {
    color: var(--care-app-color-danger-button-label);
    background: var(--care-app-color-danger-button-surface);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-danger-button-border);
    transition:
        background var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        border-color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn.care-btn--danger:hover,
:is(html.care-app, .care-landing-hero-app-mock) a.care-btn.care-btn--danger:focus-visible {
    border-color: transparent;
    background: var(--care-app-color-danger-button-fill);
    color: var(--care-app-color-danger-button-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn.care-btn--danger:hover {
    background: var(--care-app-color-danger-button-fill-hover);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn.care-btn--danger:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

/* —— Buttons .care-btn[type="button"] (Leave team, dialog cancel, etc.) —— */
html.care-app button.care-btn[type="button"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--care-app-space-sm) var(--care-app-space-lg);
    font: inherit;
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-tight);
    color: var(--care-app-color-ink-primary);
    background: var(--care-app-color-surface-default);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    border-radius: var(--care-app-radius-md);
    cursor: pointer;
    transition:
        background var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        border-color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

html.care-app button.care-btn[type="button"]:hover {
    background: var(--care-app-color-surface-subtle);
    border-color: var(--care-app-color-border-subtle);
}

html.care-app button.care-btn[type="button"]:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app button.care-btn--secondary[type="button"] {
    color: var(--care-app-color-ink-secondary);
}

html.care-app button.care-btn--secondary[type="button"]:hover {
    color: var(--care-app-color-ink-primary);
}

/* Link styled as .care-btn (e.g. Open on agent roster) */
:is(html.care-app, .care-landing-hero-app-mock) a.care-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--care-app-space-sm) var(--care-app-space-lg);
    font: inherit;
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-tight);
    text-decoration: none;
    box-sizing: border-box;
    border-radius: var(--care-app-radius-md);
    cursor: pointer;
    transition:
        background var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        border-color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
    color: var(--care-app-color-ink-primary);
    background: var(--care-app-color-surface-default);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn:hover {
    background: var(--care-app-color-surface-subtle);
    border-color: var(--care-app-color-border-subtle);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn--secondary {
    color: var(--care-app-color-ink-secondary);
    background: transparent;
}

:is(html.care-app, .care-landing-hero-app-mock) a.care-btn--secondary:hover {
    color: var(--care-app-color-ink-primary);
}

/* —— Agent governance: wide tables (ownership / stakeholders) —— */
/*
 * Fieldset is semantic only (disabled state). Visual structure matches /manage-profile: each
 * .care-governance-details is its own card — no extra outer fieldset frame or padding.
 */
html.care-app form[data-care-form="agent-governance"] {
    min-width: 0;
    max-width: 100%;
}

html.care-app form[data-care-form="agent-governance"] fieldset {
    max-width: min(100%, 85rem);
    min-width: 0;
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
    border-radius: 0;
}

/* Identity, Intended role, Process context: 2-column pairs on wide viewports; optional full-width row */
html.care-app .care-agent-governance-dual {
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-md);
}

html.care-app .care-agent-governance-dual > p,
html.care-app .care-agent-governance-dual > .care-agent-location-wrap {
    margin: 0;
    min-width: 0;
}

html.care-app .care-agent-governance-dual .care-agent-location-hint {
    margin-top: 0.35rem;
}

@media (min-width: 48rem) {
    html.care-app .care-agent-governance-dual {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        column-gap: var(--care-app-space-lg);
        row-gap: var(--care-app-space-md);
        align-items: start;
    }

    html.care-app .care-agent-governance-dual > .care-agent-governance-dual__full {
        grid-column: 1 / -1;
    }
}

/* A / D: stacked labels + controls must use full main width on phones (global label is flex-start). */
html.care-app .care-agent-governance-dual label {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    align-items: stretch;
}

/* Agent detail: keep section bodies and tile grids inside the scrollable column (flex min-width:auto). */
html.care-app main[data-care-page="agent-detail"] .care-governance-details,
html.care-app main[data-care-page="agent-detail"] .care-governance-details__body,
html.care-app main[data-care-page="agent-data-import"] .care-governance-details,
html.care-app main[data-care-page="agent-data-import"] .care-governance-details__body {
    min-width: 0;
    max-width: 100%;
}

html.care-app main[data-care-page="agent-detail"] .care-assessment-tiles,
html.care-app main[data-care-page="agent-data-import"] .care-assessment-tiles {
    min-width: 0;
}

html.care-app main[data-care-page="agent-detail"] > h1,
html.care-app main[data-care-page="agent-data-import"] > h1 {
    overflow-wrap: anywhere;
}

html.care-app main[data-care-page="agent-detail"] > .care-app-main-context,
html.care-app main[data-care-page="agent-data-import"] > .care-app-main-context {
    min-width: 0;
    max-width: 100%;
}

html.care-app main[data-care-page="agent-detail"] > .care-app-main-context a,
html.care-app main[data-care-page="agent-data-import"] > .care-app-main-context a {
    overflow-wrap: anywhere;
}

html.care-app #care-agent-location-readonly,
html.care-app #care-process-description-readonly {
    overflow-wrap: anywhere;
    line-height: var(--care-app-type-leading-body);
}

html.care-app .care-agent-governance-status {
    overflow-wrap: anywhere;
}

html.care-app .care-governance-save-actions {
    min-width: 0;
    max-width: 100%;
}

/* Full-width controls inside wide governance form (override global 28rem / 36rem caps) */
html.care-app form[data-care-form="agent-governance"] input[type="text"],
html.care-app form[data-care-form="agent-governance"] input[type="email"],
html.care-app form[data-care-form="agent-governance"] input[type="password"],
html.care-app form[data-care-form="agent-governance"] select,
html.care-app form[data-care-form="agent-governance"] textarea,
html.care-app main[data-care-page="manage-tenant"] form input[type="text"],
html.care-app main[data-care-page="manage-tenant"] form input[type="email"],
html.care-app main[data-care-page="manage-tenant"] form select,
html.care-app main[data-care-page="manage-tenant"] form textarea,
html.care-app main[data-care-page="manage-profile"] form input[type="text"],
html.care-app main[data-care-page="manage-profile"] form select,
html.care-app main[data-care-page="manage-profile"] form textarea {
    max-width: 100%;
}

/* Tabular data in the authenticated app: `care-tabular-view` (+ wrap). `care-person-grid*` is a legacy alias — same rules. */
html.care-app :is(.care-tabular-view-wrap, .care-person-grid-wrap) {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    margin-block-end: var(--care-app-space-md);
    min-width: 0;
    max-width: 100%;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid) {
    width: 100%;
    /* Wide layouts: do not use percentage min-width — it often resolves a few px wider than the scrollport
       (scrollbar gutter, subpixels) and forces a pointless horizontal bar. Narrow viewports: floor below. */
    min-width: 0;
    table-layout: fixed;
}

@media (max-width: 47.99rem) {
    html.care-app :is(table.care-tabular-view, table.care-person-grid) {
        min-width: 42rem;
    }
}

/* UA styles often center `th`; keep ownership / stakeholder role labels left-aligned */
html.care-app :is(table.care-tabular-view, table.care-person-grid) th {
    text-align: start;
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    vertical-align: middle;
}

/* Action / icon columns: extra class on `th`/`td` beats `th { text-align: start }` (0,1,3). */
html.care-app :is(table.care-tabular-view, table.care-person-grid) th.care-agents-roster__th-action,
html.care-app :is(table.care-tabular-view, table.care-person-grid) td.care-agents-roster__action,
html.care-app :is(table.care-tabular-view, table.care-person-grid) :is(th.care-tabular-view__col-actions, th.care-person-grid__col-actions, td.care-tabular-view__col-actions, td.care-person-grid__col-actions),
html.care-app :is(table.care-tabular-view, table.care-person-grid) th.care-col-del,
html.care-app :is(table.care-tabular-view, table.care-person-grid) td.care-col-del {
    text-align: end;
}

/*
 * Global `label { display: flex; flex-direction: column }` breaks fixed table column sizing when the
 * label sits in a `th`/`td` (Chromium computes a huge min-content width and squeezes the field column).
 */
html.care-app :is(table.care-tabular-view, table.care-person-grid) th label:not(.care-sr-only),
html.care-app :is(table.care-tabular-view, table.care-person-grid) td label:not(.care-sr-only) {
    display: inline;
    flex-direction: unset;
    align-items: unset;
    gap: unset;
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid) thead th {
    border-bottom: var(--care-app-border-width-emphasis) solid var(--care-app-color-border-subtle);
}

/* Manage tenant: members roster (person + department + role) */
html.care-app .care-member-person {
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-xs);
    align-items: flex-start;
    max-width: min(100%, 28rem);
}

html.care-app .care-member-person__primary {
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

html.care-app .care-member-person__secondary {
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
    word-break: break-word;
}

html.care-app .care-member-department-empty {
    color: var(--care-app-color-ink-muted);
}

html.care-app :is(table.care-tabular-view, table.care-person-grid) th.care-col-del,
html.care-app :is(table.care-tabular-view, table.care-person-grid) td.care-col-del {
    width: 2.5rem;
    vertical-align: middle;
    padding-inline: var(--care-app-space-xs);
}

html.care-app :is(table.care-tabular-view, table.care-person-grid) .care-person-name-cell {
    vertical-align: middle;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid) .care-person-email-cell input[type="email"] {
    max-width: 100%;
}

html.care-app .care-person-unassigned {
    color: var(--care-app-color-danger-ink);
    font-weight: var(--care-app-type-weight-heading);
}

html.care-app .care-person-not-member {
    color: var(--care-app-color-danger-ink);
}

html.care-app .care-not-member-x {
    font-weight: var(--care-app-type-weight-heading);
    margin-inline-end: 0.15em;
}

html.care-app .care-inline-demo.care-person-not-member,
html.care-app .care-inline-demo.care-person-unassigned {
    display: inline;
    font-weight: inherit;
}

html.care-app .care-inline-demo.care-person-unassigned {
    color: inherit;
    font-weight: var(--care-app-type-weight-heading);
}

html.care-app button.care-btn-icon[type="submit"],
html.care-app button.care-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2rem;
    min-height: 2rem;
    padding: 0;
    font-size: 1.25rem;
    line-height: 1;
    color: var(--care-app-color-danger-ink);
    background: transparent;
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-danger-border);
    border-radius: var(--care-app-radius-sm);
    cursor: pointer;
}

html.care-app button.care-btn-icon[type="submit"]:hover,
html.care-app button.care-btn-icon:hover {
    background: var(--care-app-color-danger-surface);
}

html.care-app .care-stakeholder-add-row td {
    padding-block: var(--care-app-space-md);
    border-bottom: none;
}

html.care-app .care-empty-roster {
    color: var(--care-app-color-ink-secondary);
    font-style: italic;
}

/* Collapsible admin sections: agent governance + manage-organization */
html.care-app .care-governance-details {
    margin-block-start: var(--care-app-space-md);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    border-radius: var(--care-app-radius-md);
    background: var(--care-app-color-surface-subtle);
}

html.care-app form[data-care-form="agent-governance"] fieldset > .care-governance-details:first-of-type {
    margin-block-start: var(--care-app-space-lg);
}

html.care-app form[data-care-form="agent-governance"] :is(.care-tabular-view-wrap, .care-person-grid-wrap) {
    min-width: 0;
    max-width: 100%;
}

html.care-app form[data-care-form="agent-governance"] :is(table.care-tabular-view, table.care-person-grid) :is(td, th) {
    min-width: 0;
}

html.care-app form[data-care-form="agent-governance"] :is(table.care-tabular-view, table.care-person-grid) tbody tr:nth-child(even) {
    background: transparent;
}

html.care-app main[data-care-page="manage-tenant"] > .care-governance-details:first-of-type,
html.care-app main[data-care-page="manage-profile"] > .care-governance-details:first-of-type {
    margin-block-start: var(--care-app-space-lg);
}

html.care-app .care-governance-details__summary {
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    font-size: var(--care-app-type-size-heading-2);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-snug);
    letter-spacing: var(--care-app-type-tracking-heading);
    color: var(--care-app-color-ink-primary);
    cursor: pointer;
}

html.care-app .care-governance-details__title {
    display: inline-block;
}

html.care-app .care-governance-details__body {
    padding: var(--care-app-space-sm) var(--care-app-space-md) var(--care-app-space-md);
    border-block-start: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

/* Manage profile: teams roster + inline create/join */
html.care-app :is(table.care-tabular-view, table.care-person-grid).care-teams-roster {
    min-width: 0;
}

@media (max-width: 47.99rem) {
    html.care-app :is(table.care-tabular-view, table.care-person-grid).care-teams-roster {
        min-width: 22rem;
    }
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-teams-roster tbody td {
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    vertical-align: middle;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-teams-actions td {
    vertical-align: middle;
}

html.care-app .care-teams-action-form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-sm);
}

html.care-app .care-teams-action-form input[type="text"] {
    flex: 1 1 12rem;
    min-width: 0;
}

html.care-app .care-teams-action-form select {
    flex: 1 1 10rem;
    min-width: 0;
    max-width: 100%;
}

/*
 * Key–value tables (`th` label | `td` control): `<colgroup>` sets column shares for `table-layout: fixed`.
 * Without it, intrinsic min-width from `textarea cols=""`, `select`, and nested flex can collapse the
 * field column to a sliver inside fieldset/details.
 */
html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid {
    width: 100%;
    min-width: 0;
    table-layout: fixed;
}

html.care-app col.care-governance-kv-col--label {
    width: 38%;
}

html.care-app col.care-governance-kv-col--field {
    width: 62%;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid th[scope="row"] {
    vertical-align: top;
    padding-block: var(--care-app-space-md);
    word-break: break-word;
    hyphens: auto;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid td {
    vertical-align: top;
    padding-block: var(--care-app-space-md);
    min-width: 0;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid td :is(input, select, textarea) {
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid td textarea {
    width: 100%;
}

html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid td select {
    width: 100%;
    vertical-align: middle;
}

@media (max-width: 47.99rem) {
    html.care-app :is(table.care-tabular-view, table.care-person-grid).care-governance-kv-grid {
        min-width: 40rem;
    }
}

html.care-app .care-agent-blocked-hint {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-governance-save-actions .care-save-agent-hint {
    display: block;
    margin-block-start: var(--care-app-space-xs);
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
}

@media (min-width: 48rem) {
    html.care-app .care-governance-save-actions .care-save-agent-hint {
        display: inline;
        margin-block-start: 0;
        margin-inline-start: var(--care-app-space-sm);
    }
}

@media (min-width: 64rem) {
    html.care-app main[data-care-page="agent-detail"] a.care-assessment-tile,
    html.care-app main[data-care-page="agent-detail"] div.care-assessment-tile.care-assessment-tile--readonly {
        min-height: 5.75rem;
        padding-block-start: var(--care-app-space-sm);
    }
}

/* Manage organization (/manage-tenant): intros, subheadings, privilege list */
html.care-app .care-manage-intro {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-body);
    color: var(--care-app-color-ink-secondary);
    max-width: min(100%, 42rem);
}

html.care-app .care-manage-intro code {
    font-size: 0.95em;
}

html.care-app .care-manage-hint {
    margin: var(--care-app-space-xs) 0 0;
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
    max-width: min(100%, 36rem);
}

html.care-app .care-personal-agent-toggle {
    margin: 0 0 var(--care-app-space-xs);
}

/*
 * Agent governance — ownership + stakeholders: on narrow viewports, card-style rows (email first, name below).
 * Overrides the global `min-width: 42rem` tabular rule for these tables only.
 */
@media (max-width: 47.99rem) {
    html.care-app form[data-care-form="agent-governance"] table.care-tabular-view.care-agent-gov-person-table {
        min-width: 0;
        width: 100%;
        table-layout: auto;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table thead {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table tbody tr {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-areas:
            'role del'
            'email email'
            'name name';
        gap: var(--care-app-space-xs) var(--care-app-space-sm);
        padding-block: var(--care-app-space-md);
        border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
        align-items: start;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table tbody tr:last-child {
        border-bottom: none;
    }

    html.care-app
        form[data-care-form="agent-governance"]
        table.care-agent-gov-person-table:not(.care-stakeholders-grid)
        tbody
        th[scope='row'] {
        grid-area: role;
        margin: 0;
        padding: 0;
        border: none;
        font-weight: var(--care-app-type-weight-heading);
    }

    html.care-app
        form[data-care-form="agent-governance"]
        table.care-agent-gov-person-table:not(.care-stakeholders-grid)
        tbody
        .care-person-email-cell {
        grid-area: email;
        padding: 0;
        border: none;
    }

    html.care-app
        form[data-care-form="agent-governance"]
        table.care-agent-gov-person-table:not(.care-stakeholders-grid)
        tbody
        .care-person-name-cell {
        grid-area: name;
        padding: 0;
        border: none;
    }

    /* Stakeholders: role | remove on first row; email; name */
    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table.care-stakeholders-grid tbody td:nth-child(1) {
        grid-area: role;
        padding: 0;
        border: none;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table.care-stakeholders-grid tbody td.care-col-del {
        grid-area: del;
        justify-self: end;
        padding: 0;
        border: none;
        align-self: start;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table.care-stakeholders-grid tbody td.care-person-email-cell {
        grid-area: email;
        padding: 0;
        border: none;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-agent-gov-person-table.care-stakeholders-grid tbody td.care-person-name-cell {
        grid-area: name;
        padding: 0;
        border: none;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-stakeholders-grid tbody tr.care-stakeholder-add-row {
        display: block;
        padding-block: var(--care-app-space-sm);
    }

    html.care-app form[data-care-form="agent-governance"] table.care-stakeholders-grid tbody tr.care-stakeholder-add-row td {
        display: block;
        width: 100%;
        padding: 0;
        border: none;
    }

    html.care-app form[data-care-form="agent-governance"] table.care-stakeholders-grid tbody tr:has(td.care-empty-roster) {
        display: block;
        padding-block: var(--care-app-space-sm);
    }

    html.care-app form[data-care-form="agent-governance"] table.care-stakeholders-grid tbody tr:has(td.care-empty-roster) td {
        display: block;
        width: 100%;
        padding: 0;
        border: none;
    }
}

/* Manage organization: responsive rosters + key–value rows (no wide table scroll on mobile) */
html.care-app .care-manage-roster-wrap {
    margin-block-end: var(--care-app-space-md);
    min-width: 0;
    max-width: 100%;
}

html.care-app .care-manage-roster {
    min-width: 0;
}

html.care-app .care-manage-roster__head {
    display: none;
}

html.care-app .care-manage-roster__body {
    min-width: 0;
}

/* Manage organization: one encapsulated card per row on narrow viewports */
@media (max-width: 47.99rem) {
    html.care-app main[data-care-page="manage-tenant"] .care-manage-roster__body,
    html.care-app main[data-care-page="manage-profile"] .care-manage-roster__body {
        display: flex;
        flex-direction: column;
        gap: var(--care-app-space-md);
    }

    html.care-app main[data-care-page="manage-tenant"] .care-mt-member-card,
    html.care-app main[data-care-page="manage-tenant"] .care-admin-team-card,
    html.care-app main[data-care-page="manage-tenant"] .care-invitations-card,
    html.care-app main[data-care-page="manage-profile"] .care-profile-team-card {
        margin: 0;
        padding: var(--care-app-space-md);
        background: var(--care-app-color-surface-default);
        border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
        border-radius: var(--care-app-radius-md);
        box-shadow: var(--care-app-shadow-raised);
        border-bottom: none;
    }

    html.care-app main[data-care-page="manage-tenant"] .care-mt-member-card:last-child,
    html.care-app main[data-care-page="manage-tenant"] .care-admin-team-card:last-child,
    html.care-app main[data-care-page="manage-tenant"] .care-invitations-card:last-child,
    html.care-app main[data-care-page="manage-profile"] .care-profile-team-card:last-child {
        border-bottom: none;
    }

    html.care-app main[data-care-page="manage-tenant"] .care-mt-member-card__field:not(:first-child),
    html.care-app main[data-care-page="manage-tenant"] .care-invitations-card__field:not(:first-child) {
        padding-top: var(--care-app-space-sm);
        margin-top: var(--care-app-space-xs);
        border-top: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    }
}

@media (max-width: 35.99rem) {
    html.care-app main[data-care-page="manage-tenant"] .care-admin-team-card__actions,
    html.care-app main[data-care-page="manage-profile"] .care-profile-team-card__actions {
        padding-top: var(--care-app-space-sm);
        margin-top: var(--care-app-space-xs);
        border-top: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    }
}

html.care-app .care-manage-roster__field-label {
    display: block;
    margin: 0 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-governance-kv {
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-lg);
    margin-block-end: var(--care-app-space-md);
    min-width: 0;
    max-width: 100%;
}

html.care-app .care-governance-kv__row {
    display: grid;
    gap: var(--care-app-space-xs) var(--care-app-space-md);
    grid-template-columns: 1fr;
    align-items: start;
    min-width: 0;
}

html.care-app .care-governance-kv__label label {
    display: inline;
    flex-direction: unset;
    align-items: unset;
    gap: unset;
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-governance-kv__field {
    min-width: 0;
}

html.care-app .care-governance-kv__field :is(input, select, textarea) {
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
}

html.care-app .care-governance-kv__field textarea {
    width: 100%;
}

html.care-app .care-governance-kv__field select {
    width: 100%;
}

@media (min-width: 48rem) {
    html.care-app .care-governance-kv__row {
        grid-template-columns: minmax(10rem, 38%) minmax(0, 1fr);
    }
}

/* Teams (admin) roster */
html.care-app .care-admin-team-card {
    display: grid;
    gap: var(--care-app-space-sm);
    align-items: center;
    padding: var(--care-app-space-md) 0;
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-admin-team-card:last-child {
    border-bottom: none;
}

html.care-app .care-admin-team-card__name {
    min-width: 0;
    word-break: break-word;
}

html.care-app .care-admin-team-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-sm);
    justify-content: flex-start;
}

@media (min-width: 36rem) {
    html.care-app .care-admin-team-card {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    html.care-app .care-admin-team-actions {
        justify-content: flex-end;
    }
}

/* Teams (profile) roster — same row layout as admin teams */
html.care-app .care-profile-team-card {
    display: grid;
    gap: var(--care-app-space-sm);
    align-items: center;
    padding: var(--care-app-space-md) 0;
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-profile-team-card:last-child {
    border-bottom: none;
}

html.care-app .care-profile-team-card__name {
    min-width: 0;
    word-break: break-word;
}

html.care-app .care-profile-team-card__actions {
    min-width: 0;
}

@media (min-width: 36rem) {
    html.care-app .care-profile-team-card {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    html.care-app .care-profile-team-card__actions {
        justify-self: end;
        text-align: end;
    }
}

@media (min-width: 48rem) {
    html.care-app main[data-care-page="manage-tenant"] .care-manage-roster__body,
    html.care-app main[data-care-page="manage-profile"] .care-manage-roster__body {
        gap: 0;
    }

    html.care-app .care-admin-team-card {
        background: transparent;
        box-shadow: none;
        border-radius: 0;
        border: none;
        border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
        padding: var(--care-app-space-md) 0;
    }

    html.care-app .care-admin-team-card:last-child {
        border-bottom: none;
    }

    html.care-app .care-admin-team-card__actions {
        padding-top: 0;
        margin-top: 0;
        border-top: none;
    }

    html.care-app .care-manage-roster__head.care-admin-teams-roster__head {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: var(--care-app-space-md);
        align-items: end;
        padding: var(--care-app-space-sm) 0;
        font-size: var(--care-app-type-size-caption);
        font-weight: var(--care-app-type-weight-heading);
        color: var(--care-app-color-ink-primary);
        border-bottom: var(--care-app-border-width-emphasis) solid var(--care-app-color-border-subtle);
    }

    html.care-app .care-profile-team-card {
        background: transparent;
        box-shadow: none;
        border-radius: 0;
        border: none;
        border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
        padding: var(--care-app-space-md) 0;
    }

    html.care-app .care-profile-team-card:last-child {
        border-bottom: none;
    }

    html.care-app .care-profile-team-card__actions {
        padding-top: 0;
        margin-top: 0;
        border-top: none;
    }

    html.care-app .care-manage-roster__head.care-profile-teams-roster__head {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: var(--care-app-space-md);
        align-items: end;
        padding: var(--care-app-space-sm) 0;
        font-size: var(--care-app-type-size-caption);
        font-weight: var(--care-app-type-weight-heading);
        color: var(--care-app-color-ink-primary);
        border-bottom: var(--care-app-border-width-emphasis) solid var(--care-app-color-border-subtle);
    }
}

/* Members + invitations: column headers on wide viewports; stacked labeled fields on narrow */
html.care-app .care-mt-member-card {
    display: grid;
    gap: var(--care-app-space-md);
    padding: var(--care-app-space-md) 0;
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-mt-member-card:last-child {
    border-bottom: none;
}

html.care-app .care-mt-member-card__value {
    min-width: 0;
}

html.care-app .care-mt-member-card__value .care-form-inline select {
    width: 100%;
    max-width: 100%;
}

html.care-app .care-mt-member-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-xs);
    justify-content: flex-start;
}

html.care-app .care-mt-member-actions__self {
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
    font-style: italic;
}

html.care-app .care-member-blocked-badge {
    display: inline-block;
    margin-inline-start: var(--care-app-space-xs);
    padding: 0.1em 0.45em;
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-danger-ink);
    background: var(--care-app-color-danger-surface);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-danger-border);
    border-radius: var(--care-app-radius-sm);
    vertical-align: middle;
}

html.care-app .care-mt-member-action-form {
    margin: 0;
}

html.care-app .care-invitations-card {
    display: grid;
    gap: var(--care-app-space-md);
    padding: var(--care-app-space-md) 0;
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-invitations-card:last-child {
    border-bottom: none;
}

html.care-app .care-invitations-card__value {
    min-width: 0;
    word-break: break-word;
}

html.care-app .care-invitations-card__field--actions .care-invitations-roster__action-cell {
    justify-content: flex-start;
}

@media (min-width: 48rem) {
    html.care-app .care-manage-roster__head.care-members-roster__head {
        display: grid;
        grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.65fr) minmax(0, 12rem) auto;
        gap: var(--care-app-space-md);
        align-items: end;
        padding: var(--care-app-space-sm) 0;
        font-size: var(--care-app-type-size-caption);
        font-weight: var(--care-app-type-weight-heading);
        color: var(--care-app-color-ink-primary);
        border-bottom: var(--care-app-border-width-emphasis) solid var(--care-app-color-border-subtle);
    }

    html.care-app .care-mt-member-card {
        grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.65fr) minmax(0, 12rem) auto;
        gap: var(--care-app-space-md);
        align-items: start;
        padding: var(--care-app-space-sm) 0;
        background: transparent;
        box-shadow: none;
        border-radius: 0;
        border: none;
        border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    }

    html.care-app .care-mt-member-actions {
        justify-content: flex-end;
    }

    html.care-app .care-mt-member-card__field:not(:first-child) {
        padding-top: 0;
        margin-top: 0;
        border-top: none;
    }

    html.care-app .care-mt-member-card .care-manage-roster__field-label {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }

    html.care-app .care-manage-roster__head.care-invitations-roster__head {
        display: grid;
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.85fr) minmax(0, 8rem) auto;
        gap: var(--care-app-space-md);
        align-items: end;
        padding: var(--care-app-space-sm) 0;
        font-size: var(--care-app-type-size-caption);
        font-weight: var(--care-app-type-weight-heading);
        color: var(--care-app-color-ink-primary);
        border-bottom: var(--care-app-border-width-emphasis) solid var(--care-app-color-border-subtle);
    }

    html.care-app .care-manage-roster__head-cell--action {
        text-align: end;
    }

    html.care-app .care-invitations-card {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.85fr) minmax(0, 8rem) auto;
        gap: var(--care-app-space-md);
        align-items: center;
        padding: var(--care-app-space-sm) 0;
        background: transparent;
        box-shadow: none;
        border-radius: 0;
        border: none;
        border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    }

    html.care-app .care-invitations-card__field:not(:first-child) {
        padding-top: 0;
        margin-top: 0;
        border-top: none;
    }

    html.care-app .care-invitations-card .care-manage-roster__field-label {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }

    html.care-app .care-invitations-card__field--actions .care-invitations-roster__action-cell {
        justify-content: flex-end;
    }
}

html.care-app .care-admin-team-delete-warning {
    margin: 0 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-body, 1rem);
    line-height: var(--care-app-type-leading-body, 1.5);
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app .care-admin-members-subheading {
    margin: var(--care-app-space-md) 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-admin-members-subheading:first-child {
    margin-top: 0;
}

html.care-app .care-admin-members-list {
    margin: 0 0 var(--care-app-space-md);
    padding: 0;
    list-style: none;
}

html.care-app .care-admin-members-list__item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--care-app-space-sm);
    padding: var(--care-app-space-sm) 0;
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-admin-members-list__item:last-child {
    border-bottom: none;
}

html.care-app .care-admin-members-list__label {
    min-width: 0;
    font-size: var(--care-app-type-size-caption);
    word-break: break-word;
}

html.care-app .care-admin-team-add-member-form select {
    max-width: 100%;
}

html.care-app .care-manage-actions {
    margin: var(--care-app-space-md) 0 0;
}

html.care-app .care-manage-subheading {
    margin: var(--care-app-space-lg) 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-heading-3);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-manage-fieldset {
    margin: var(--care-app-space-md) 0;
    padding: var(--care-app-space-md);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    border-radius: var(--care-app-radius-sm);
    background: var(--care-app-color-surface-default);
}

html.care-app .care-manage-fieldset legend {
    padding: 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

/* —— Settings boolean: switch (checkbox + track), not assessment tiles —— */
html.care-app label.care-switch {
    position: relative;
    display: inline-block;
    flex-shrink: 0;
    width: 2.75rem;
    height: 1.5rem;
    vertical-align: middle;
    cursor: pointer;
    margin: 0;
}

html.care-app .care-switch input {
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
    position: absolute;
}

html.care-app .care-switch-track {
    position: absolute;
    cursor: pointer;
    inset: 0;
    border-radius: 999px;
    background-color: var(--care-app-color-border-subtle);
    transition: background-color 0.25s ease;
}

html.care-app .care-switch-track::after {
    position: absolute;
    content: "";
    width: 1.125rem;
    height: 1.125rem;
    left: 0.1875rem;
    bottom: 0.1875rem;
    border-radius: 50%;
    background-color: var(--care-app-color-surface-elevated);
    box-shadow: 0 0.06rem 0.2rem rgb(15 23 42 / 0.2);
    transition: transform 0.25s ease;
}

html.care-app .care-switch input:checked + .care-switch-track {
    background-color: var(--care-app-color-accent);
}

html.care-app .care-switch input:focus-visible + .care-switch-track {
    outline: 2px solid var(--care-app-color-focus-ring);
    outline-offset: 2px;
}

html.care-app .care-switch input:checked + .care-switch-track::after {
    transform: translateX(1.125rem);
}

html.care-app .care-switch input:disabled + .care-switch-track {
    cursor: not-allowed;
    opacity: 0.55;
}

html.care-app .care-switch input:disabled + .care-switch-track::after {
    background-color: var(--care-app-color-surface-default);
}

@media (prefers-reduced-motion: reduce) {
    html.care-app .care-switch-track,
    html.care-app .care-switch-track::after {
        transition: none;
    }
}

html.care-app .care-settings-switch-grid {
    display: grid;
    gap: var(--care-app-space-md);
    grid-template-columns: 1fr;
    margin: 0;
    padding: 0;
    list-style: none;
}

@media (min-width: 42rem) {
    html.care-app .care-settings-switch-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

html.care-app .care-settings-switch-item,
html.care-app form.care-settings-switch-item {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--care-app-space-sm);
    min-height: 5.5rem;
    margin: 0;
    padding: var(--care-app-space-md);
    border-radius: var(--care-app-radius-md);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-subtle);
}

html.care-app .care-settings-switch-item--readonly {
    opacity: 1;
}

html.care-app .care-settings-switch-item__label {
    margin: 0;
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-ink-primary);
    max-width: 100%;
    cursor: pointer;
}

html.care-app .care-settings-switch-item__hint {
    margin: 0;
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
}

html.care-app .care-settings-switch-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: var(--care-app-space-md);
    width: 100%;
    max-width: min(100%, 40rem);
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-secondary);
}

html.care-app label.care-settings-switch-row__text {
    flex: 1;
    min-width: 0;
    line-height: var(--care-app-type-leading-snug);
    cursor: pointer;
    font-weight: inherit;
    color: inherit;
}

html.care-app main[data-care-page="manage-tenant"] :is(.care-tabular-view, .care-person-grid) code,
html.care-app main[data-care-page="manage-vouchers"] :is(.care-tabular-view, .care-person-grid) code {
    font-size: var(--care-app-type-size-caption);
}

html.care-app ul.care-company-role-list {
    list-style: none;
    margin: 0 0 var(--care-app-space-md);
    padding: 0;
}

html.care-app ul.care-company-role-list li {
    margin-block: var(--care-app-space-xs);
    padding-block: var(--care-app-space-xs);
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-secondary);
}

html.care-app ul.care-company-role-list li:last-child {
    border-bottom: none;
}

/* —— Agent governance: assessment tiles —— */
html.care-app .care-assessment-tiles-intro {
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-ink-secondary);
    max-width: min(85ch, 100%);
}

html.care-app .care-assessment-tiles-group__heading {
    margin-block: var(--care-app-space-md) var(--care-app-space-sm);
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-assessment-tiles-group__heading:first-child {
    margin-block-start: 0;
}

html.care-app .care-assessment-tiles {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(13.5rem, 1fr));
    gap: var(--care-app-space-md);
    margin-block-end: var(--care-app-space-xl);
    list-style: none;
    padding: 0;
}

html.care-app .care-assessment-tiles.care-assessment-tiles--governance-row {
    margin-block-end: var(--care-app-space-lg);
}

html.care-app .care-assessment-tiles.care-assessment-tiles--governance-row:last-child {
    margin-block-end: var(--care-app-space-xl);
}

/* Same grid for Pre-Build and DevOps: equal-width columns, at most 4 per row by breakpoint */
html.care-app .care-assessment-tiles.care-assessment-tiles--governance-row {
    grid-template-columns: repeat(1, minmax(0, 1fr));
}

@media (min-width: 30rem) {
    html.care-app .care-assessment-tiles.care-assessment-tiles--governance-row {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 48rem) {
    html.care-app .care-assessment-tiles.care-assessment-tiles--governance-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (min-width: 64rem) {
    html.care-app .care-assessment-tiles.care-assessment-tiles--governance-row {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

html.care-app a.care-assessment-tile,
html.care-app div.care-assessment-tile.care-assessment-tile--readonly {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-xs);
    min-height: 5.75rem;
    padding: var(--care-app-space-md) var(--care-app-space-md) var(--care-app-space-sm);
    border-radius: var(--care-app-radius-md);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    text-decoration: none;
    color: inherit;
    box-shadow: var(--care-app-shadow-raised);
    transition: transform 0.14s ease, box-shadow 0.14s ease, border-color 0.14s ease, background-color 0.14s ease;
}

html.care-app a.care-assessment-tile {
    cursor: pointer;
}

html.care-app div.care-assessment-tile.care-assessment-tile--readonly {
    cursor: default;
}

html.care-app a.care-assessment-tile:hover {
    transform: translateY(-3px);
    box-shadow: var(--care-app-shadow-floating);
    border-color: var(--care-app-color-accent);
    background-color: var(--care-app-color-surface-elevated);
}

html.care-app a.care-assessment-tile:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app .care-assessment-tile__title {
    font-size: var(--care-app-type-size-body);
    font-weight: var(--care-app-type-weight-heading);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-ink-primary);
    overflow-wrap: anywhere;
}

html.care-app .care-assessment-tile__req {
    align-self: flex-start;
    font-size: 0.65rem;
    font-weight: var(--care-app-type-weight-heading);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0.15rem 0.35rem;
    border-radius: var(--care-app-radius-sm);
    color: var(--care-app-color-accent);
    background: var(--care-app-color-accent-muted-bg);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-strong);
}

html.care-app .care-assessment-tile__score {
    margin-top: auto;
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-secondary);
    overflow-wrap: anywhere;
}

/* Untaken */
html.care-app .care-assessment-tile--empty {
    background: var(--care-app-color-surface-subtle);
    border-color: var(--care-app-color-border-subtle);
}

html.care-app .care-assessment-tile--empty .care-assessment-tile__title,
html.care-app .care-assessment-tile--empty .care-assessment-tile__score {
    color: var(--care-app-color-ink-muted);
}

/* Saved but no readable score */
html.care-app .care-assessment-tile--unknown {
    background: var(--care-app-color-info-surface);
    border-color: var(--care-app-color-info-border);
}

html.care-app .care-assessment-tile--unknown .care-assessment-tile__score {
    color: var(--care-app-color-info-ink);
}

/* Binary (viability-style) */
html.care-app .care-assessment-tile--binary-pass {
    background: var(--care-app-color-success-surface);
    border-color: var(--care-app-color-success-border);
}

html.care-app .care-assessment-tile--binary-pass .care-assessment-tile__score {
    color: var(--care-app-color-success-ink);
}

html.care-app .care-assessment-tile--binary-fail {
    background: var(--care-app-color-danger-surface);
    border-color: var(--care-app-color-danger-border);
}

html.care-app .care-assessment-tile--binary-fail .care-assessment-tile__score {
    color: var(--care-app-color-danger-ink);
}

/*
 * Maturity tiles: explicit level classes (normal = capability, reversed = risk).
 * Normal: Level 0–1 weak → 5 strong (red → amber → green).
 * Reversed: Level 0–1 low risk → 5 high risk (green → amber → red).
 */
html.care-app .care-assessment-tile--maturity-normal-l0 {
    background: var(--care-app-color-danger-surface);
    border-color: var(--care-app-color-danger-border);
}

html.care-app .care-assessment-tile--maturity-normal-l0 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-normal-l0 .care-assessment-tile__score {
    color: var(--care-app-color-danger-ink);
}

html.care-app .care-assessment-tile--maturity-normal-l1 {
    background: color-mix(in srgb, var(--care-app-color-danger-surface) 72%, var(--care-app-color-surface-default));
    border-color: color-mix(in srgb, var(--care-app-color-danger-border) 65%, var(--care-app-color-border-subtle));
}

html.care-app .care-assessment-tile--maturity-normal-l1 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-normal-l1 .care-assessment-tile__score {
    color: var(--care-app-color-danger-ink);
}

html.care-app .care-assessment-tile--maturity-normal-l2 {
    background: color-mix(in srgb, var(--care-app-color-accent-muted-bg) 50%, var(--care-app-color-danger-surface) 35%);
    border-color: color-mix(in srgb, var(--care-app-color-accent) 22%, var(--care-app-color-border-subtle));
}

html.care-app .care-assessment-tile--maturity-normal-l2 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-normal-l2 .care-assessment-tile__score {
    color: var(--care-app-color-accent-hover);
}

html.care-app .care-assessment-tile--maturity-normal-l3 {
    background: color-mix(in srgb, var(--care-app-color-success-surface) 38%, var(--care-app-color-accent-muted-bg) 45%);
    border-color: color-mix(in srgb, var(--care-app-color-success-border) 25%, var(--care-app-color-accent) 20%);
}

html.care-app .care-assessment-tile--maturity-normal-l3 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-normal-l3 .care-assessment-tile__score {
    color: var(--care-app-color-accent-hover);
}

html.care-app .care-assessment-tile--maturity-normal-l4 {
    background: color-mix(in srgb, var(--care-app-color-success-surface) 78%, var(--care-app-color-surface-default));
    border-color: var(--care-app-color-success-border);
}

html.care-app .care-assessment-tile--maturity-normal-l4 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-normal-l4 .care-assessment-tile__score {
    color: var(--care-app-color-success-ink);
}

html.care-app .care-assessment-tile--maturity-normal-l5 {
    background: var(--care-app-color-success-surface);
    border-color: var(--care-app-color-success-border);
}

html.care-app .care-assessment-tile--maturity-normal-l5 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-normal-l5 .care-assessment-tile__score {
    color: var(--care-app-color-success-ink);
}

/* Reversed (risk): low level = favorable */
html.care-app .care-assessment-tile--maturity-reversed-l0 {
    background: var(--care-app-color-success-surface);
    border-color: var(--care-app-color-success-border);
}

html.care-app .care-assessment-tile--maturity-reversed-l0 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-reversed-l0 .care-assessment-tile__score {
    color: var(--care-app-color-success-ink);
}

html.care-app .care-assessment-tile--maturity-reversed-l1 {
    background: color-mix(in srgb, var(--care-app-color-success-surface) 72%, var(--care-app-color-surface-default));
    border-color: color-mix(in srgb, var(--care-app-color-success-border) 55%, var(--care-app-color-border-subtle));
}

html.care-app .care-assessment-tile--maturity-reversed-l1 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-reversed-l1 .care-assessment-tile__score {
    color: var(--care-app-color-success-ink);
}

html.care-app .care-assessment-tile--maturity-reversed-l2 {
    background: color-mix(in srgb, var(--care-app-color-accent-muted-bg) 48%, var(--care-app-color-success-surface) 32%);
    border-color: color-mix(in srgb, var(--care-app-color-accent) 24%, var(--care-app-color-border-subtle));
}

html.care-app .care-assessment-tile--maturity-reversed-l2 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-reversed-l2 .care-assessment-tile__score {
    color: var(--care-app-color-accent-hover);
}

html.care-app .care-assessment-tile--maturity-reversed-l3 {
    background: color-mix(in srgb, var(--care-app-color-danger-surface) 35%, var(--care-app-color-accent-muted-bg) 42%);
    border-color: color-mix(in srgb, var(--care-app-color-danger-border) 22%, var(--care-app-color-accent) 18%);
}

html.care-app .care-assessment-tile--maturity-reversed-l3 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-reversed-l3 .care-assessment-tile__score {
    color: var(--care-app-color-accent-hover);
}

html.care-app .care-assessment-tile--maturity-reversed-l4 {
    background: color-mix(in srgb, var(--care-app-color-danger-surface) 78%, var(--care-app-color-surface-default));
    border-color: var(--care-app-color-danger-border);
}

html.care-app .care-assessment-tile--maturity-reversed-l4 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-reversed-l4 .care-assessment-tile__score {
    color: var(--care-app-color-danger-ink);
}

html.care-app .care-assessment-tile--maturity-reversed-l5 {
    background: var(--care-app-color-danger-surface);
    border-color: var(--care-app-color-danger-border);
}

html.care-app .care-assessment-tile--maturity-reversed-l5 .care-assessment-tile__title,
html.care-app .care-assessment-tile--maturity-reversed-l5 .care-assessment-tile__score {
    color: var(--care-app-color-danger-ink);
}

/* Visually hidden default submit (Enter key → save via script) */
html.care-app button.care-form-default-submit {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

html.care-app .care-autosave-status {
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-manage-autosave-status {
    min-height: 1.35em;
    margin-block: 0 var(--care-app-space-sm);
}

/* —— Fieldset —— */
html.care-app fieldset {
    margin: var(--care-app-space-md) 0;
    padding: var(--care-app-space-md) var(--care-app-space-lg);
    max-width: min(100%, 44rem);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    border-radius: var(--care-app-radius-md);
    background: var(--care-app-color-surface-subtle);
}

html.care-app fieldset ul {
    list-style: none;
    padding-inline-start: 0;
    margin-block-end: 0;
}

html.care-app legend {
    padding-inline: var(--care-app-space-xs);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

/* —— Inline forms (table row actions) —— */
html.care-app .care-form-inline {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-sm);
    vertical-align: middle;
}

html.care-app .care-form-inline label {
    display: inline;
    font-weight: var(--care-app-type-weight-body);
}

html.care-app .care-form-inline select {
    width: auto;
    max-width: 12rem;
}

/* —— Tables —— */
html.care-app section:has(> table) {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

html.care-app table {
    width: 100%;
    min-width: min(100%, 32rem);
    border-collapse: collapse;
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-secondary);
}

html.care-app thead th {
    text-align: left;
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
    border-bottom: var(--care-app-border-width-emphasis) solid var(--care-app-color-border-subtle);
    white-space: nowrap;
}

html.care-app tbody td {
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    border-bottom: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    vertical-align: middle;
}

html.care-app tbody tr:nth-child(even) {
    background: var(--care-app-table-stripe);
}

/* —— Code —— */
html.care-app code {
    font-family: var(--care-app-type-family-mono);
    font-size: 0.9em;
    padding: var(--care-app-space-2xs) var(--care-app-space-xs);
    border-radius: var(--care-app-radius-sm);
    background: var(--care-app-color-code-surface);
    color: var(--care-app-color-code-ink);
}

/* —— Feedback: flash & field errors —— */
html.care-app .care-flash {
    padding: var(--care-app-space-md) var(--care-app-space-lg);
    margin-block-end: var(--care-app-space-lg);
    max-width: min(100%, 48rem);
    border-radius: var(--care-app-radius-md);
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-snug);
}

html.care-app .care-flash-error,
html.care-app .care-login-error,
html.care-app .care-signup-error {
    color: var(--care-app-color-danger-ink);
    background: var(--care-app-color-danger-surface);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-danger-border);
}

html.care-app .care-flash-ok {
    color: var(--care-app-color-success-ink);
    background: var(--care-app-color-success-surface);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-success-border);
}

/* Quota-blocked primary create (subscription toggles) */
html.care-app button.care-btn--quota-blocked:disabled,
html.care-app button[disabled].care-btn--quota-blocked {
    opacity: 0.45;
    cursor: not-allowed;
}

html.care-app .care-quota-blocked-hint {
    margin-block-start: var(--care-app-space-sm);
    max-width: min(100%, 40rem);
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-muted-ink, #555);
}

html.care-app .care-quota-upgrade-link {
    font-weight: 600;
}

/* Development / test: fixed bottom dev toolbar (plan override + dev page links) */
html.care-app .care-dev-toolbar {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100vw;
    max-width: 100vw;
    box-sizing: border-box;
    min-width: 0;
    z-index: 10050;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-sm) var(--care-app-space-md);
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    font-size: var(--care-app-type-size-caption);
    line-height: 1.3;
    color: #f8f8f0;
    background: linear-gradient(90deg, #1a3a2a, #0f2a22);
    border-top: 2px solid #c9a227;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.35);
    /* Must stay visible: dropdown panels sit above the bar; overflow:auto clips them. */
    overflow: visible;
}

html.care-app .care-dev-toolbar__tag {
    flex-shrink: 0;
    padding: 0.15em 0.45em;
    font-weight: 700;
    font-size: 0.7rem;
    letter-spacing: 0.06em;
    color: #0f2a22;
    background: #c9a227;
    border-radius: var(--care-app-radius-sm);
}

html.care-app .care-dev-toolbar__title {
    flex-shrink: 0;
    font-weight: 600;
    opacity: 0.95;
}

html.care-app .care-dev-toolbar__menus {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-xs) var(--care-app-space-sm);
    min-width: 0;
    flex: 1 1 auto;
    justify-content: flex-end;
    overflow: visible;
}

html.care-app .care-dev-toolbar__details {
    position: relative;
    flex-shrink: 0;
    overflow: visible;
}

/* Anchor targets: summary is the visual control (toolbar is bottom-right; menus open above & align to its right edge). */
html.care-app .care-dev-toolbar__details--subscription > .care-dev-toolbar__summary {
    anchor-name: --care-dev-toolbar-subscription;
}

html.care-app .care-dev-toolbar__details--pages > .care-dev-toolbar__summary {
    anchor-name: --care-dev-toolbar-pages;
}

html.care-app .care-dev-toolbar__summary {
    list-style: none;
    margin: 0;
    padding: 0.35em 0.75em;
    font: inherit;
    font-weight: 600;
    color: #f8f8f0;
    cursor: pointer;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: var(--care-app-radius-sm);
}

html.care-app .care-dev-toolbar__summary::-webkit-details-marker {
    display: none;
}

html.care-app .care-dev-toolbar__summary::after {
    content: " ▾";
    font-size: 0.75em;
    opacity: 0.85;
}

html.care-app .care-dev-toolbar__details[open] > .care-dev-toolbar__summary {
    background: rgba(255, 255, 255, 0.2);
}

/* Fallback when anchor() is unavailable: above the <details> box, right-aligned to the trigger. */
html.care-app .care-dev-toolbar__panel {
    position: absolute;
    bottom: calc(100% + 0.35rem);
    right: 0;
    left: auto;
    top: auto;
    z-index: 10060;
    min-width: 11rem;
    max-width: min(100vw - 2rem, 22rem);
    padding: var(--care-app-space-sm);
    color: #f8f8f0;
    background: #0f2a22;
    border: 1px solid rgba(201, 162, 39, 0.55);
    border-radius: var(--care-app-radius-md);
    box-shadow: 0 -6px 24px rgba(0, 0, 0, 0.4);
}

/*
 * Anchor positioning: explicit anchor(--name <side>) + fixed so menus aren’t clipped by the toolbar
 * (absolute + overflow on any ancestor used to hide panels entirely).
 */
@supports (bottom: anchor(--care-dev-toolbar-pages top)) {
    html.care-app .care-dev-toolbar__details--subscription > .care-dev-toolbar__panel {
        position: fixed;
        bottom: anchor(--care-dev-toolbar-subscription top);
        right: anchor(--care-dev-toolbar-subscription right);
        left: auto;
        top: auto;
        margin-bottom: 0.35rem;
        z-index: 10060;
    }

    html.care-app .care-dev-toolbar__details--pages > .care-dev-toolbar__panel {
        position: fixed;
        bottom: anchor(--care-dev-toolbar-pages top);
        right: anchor(--care-dev-toolbar-pages right);
        left: auto;
        top: auto;
        margin-bottom: 0.35rem;
        z-index: 10060;
    }
}

html.care-app .care-dev-toolbar__subscription-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--care-app-space-xs);
}

html.care-app .care-dev-toolbar__form {
    display: inline;
    margin: 0;
    padding: 0;
}

html.care-app .care-dev-toolbar__btn {
    margin: 0;
    padding: 0.35em 0.75em;
    font: inherit;
    font-weight: 600;
    color: #f8f8f0;
    cursor: pointer;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: var(--care-app-radius-sm);
}

html.care-app .care-dev-toolbar__btn:hover {
    background: rgba(255, 255, 255, 0.2);
}

html.care-app .care-dev-toolbar__btn--current {
    color: #0f2a22;
    background: #c9a227;
    border-color: #e6c04a;
}

html.care-app .care-dev-toolbar__panel--pages {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    padding: var(--care-app-space-xs);
}

html.care-app .care-dev-toolbar__link {
    display: block;
    padding: 0.45em 0.65em;
    font-weight: 600;
    color: #f8f8f0;
    text-decoration: none;
    border-radius: var(--care-app-radius-sm);
}

html.care-app .care-dev-toolbar__link:hover {
    background: rgba(255, 255, 255, 0.12);
}

html.care-app:has(.care-dev-toolbar) body {
    padding-bottom: 3.5rem;
}

/* —— Screen reader utility —— */
html.care-app .care-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* —— Back link prominence —— */
html.care-app main[data-care-page="manage-tenant"] > p:first-of-type,
html.care-app main[data-care-page="manage-profile"] > p:first-of-type {
    margin-block-end: var(--care-app-space-lg);
}

/* —— Authenticated shell: full-width top bar + sidebar row —— */
html.care-app .care-app-shell {
    --care-app-topbar-height: 3.5rem;

    display: flex;
    flex-direction: column;
    align-items: stretch;
    min-height: 100dvh;
    width: 100%;
}

html.care-app.care-app-shell--scroll-lock,
html.care-app.care-app-shell--scroll-lock body {
    overflow: hidden;
}

html.care-app .care-app-shell__main-row {
    display: flex;
    flex: 1;
    min-height: 0;
    align-items: stretch;
    width: 100%;
}

html.care-app .care-app-sidebar {
    box-sizing: border-box;
    flex: 0 0 15rem;
    max-width: 100%;
    padding: var(--care-app-space-md) var(--care-app-space-lg);
    border-inline-end: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-default);
    box-shadow: var(--care-app-shadow-raised);
}

html.care-app .care-app-sidebar__section {
    margin-block-end: var(--care-app-space-xl);
}

html.care-app .care-app-sidebar__group {
    border-radius: var(--care-app-radius-md);
}

html.care-app .care-app-sidebar__group[open] {
    background: color-mix(in srgb, var(--care-app-color-surface-default) 86%, var(--care-app-color-accent-muted-bg));
}

html.care-app .care-app-sidebar__group-summary {
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--care-app-space-sm);
    padding: var(--care-app-space-xs) var(--care-app-space-sm);
    margin-inline: calc(-1 * var(--care-app-space-sm));
    border-radius: var(--care-app-radius-sm);
    cursor: pointer;
    user-select: none;
}

html.care-app .care-app-sidebar__group-summary::-webkit-details-marker {
    display: none;
}

html.care-app .care-app-sidebar__group-summary::after {
    content: "";
    inline-size: 0.45rem;
    block-size: 0.45rem;
    border-inline-end: var(--care-app-border-width-hairline) solid currentColor;
    border-block-end: var(--care-app-border-width-hairline) solid currentColor;
    transform: rotate(45deg);
    transition: transform var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
    opacity: 0.8;
}

html.care-app .care-app-sidebar__group[open] > .care-app-sidebar__group-summary::after {
    transform: rotate(225deg);
}

html.care-app .care-app-sidebar__group-summary:hover {
    color: var(--care-app-color-ink-secondary);
    background: color-mix(in srgb, var(--care-app-color-surface-default) 74%, var(--care-app-color-accent-muted-bg));
}

html.care-app .care-app-sidebar__group-summary:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app .care-app-sidebar__group-body {
    padding-block-start: var(--care-app-space-xs);
}

html.care-app .care-app-sidebar__heading {
    margin: 0 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--care-app-color-ink-muted);
}

html.care-app .care-app-sidebar__group-summary.care-app-sidebar__heading {
    margin: 0;
}

html.care-app .care-app-sidebar__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

html.care-app .care-app-sidebar__list li {
    margin-block: var(--care-app-space-xs);
}

html.care-app .care-app-sidebar__link,
html.care-app .care-app-sidebar__agent-link {
    display: block;
    padding: var(--care-app-space-xs) 0;
    font-size: var(--care-app-type-size-caption);
    text-decoration: none;
    color: var(--care-app-color-ink-secondary);
    border-radius: var(--care-app-radius-sm);
}

html.care-app .care-app-sidebar__link:hover,
html.care-app .care-app-sidebar__agent-link:hover {
    color: var(--care-app-color-accent-hover);
}

html.care-app .care-app-sidebar__link--current {
    color: var(--care-app-color-accent);
    font-weight: var(--care-app-type-weight-heading);
    background: var(--care-app-color-accent-muted-bg);
    padding-inline: var(--care-app-space-sm);
    margin-inline: calc(-1 * var(--care-app-space-sm));
}

html.care-app .care-app-sidebar__empty {
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
    font-style: italic;
}

html.care-app .care-app-sidebar__add {
    margin: var(--care-app-space-sm) 0 0;
}

html.care-app .care-app-sidebar__add-link {
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
}

/* Primary actions below page/section title (agents create, vouchers, tenant invites, …) */
html.care-app .care-app-page-actions {
    margin: 0 0 var(--care-app-space-md);
}

/* —— Agent roster (/agents): sortable headers, actions —— */
html.care-app table.care-agents-roster-table col.care-agents-roster__col-name {
    width: 22%;
}

html.care-app table.care-agents-roster-table col.care-agents-roster__col-team {
    width: 24%;
}

html.care-app table.care-agents-roster-table col.care-agents-roster__col-lifecycle {
    width: 14%;
}

html.care-app table.care-agents-roster-table col.care-agents-roster__col-updated {
    width: 22%;
}

html.care-app table.care-agents-roster-table col.care-agents-roster__col-action {
    width: 18%;
}

html.care-app .care-agents-roster__title {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-heading-3);
    font-weight: var(--care-app-type-weight-heading);
}

html.care-app .care-agents-roster__cap-create .care-quota-blocked-hint,
html.care-app .care-agents-roster__cap-create .care-agent-blocked-hint {
    margin-block-start: var(--care-app-space-sm);
    margin-block-end: 0;
    text-align: start;
}

/* Manage organization: pending invitations (same table shell as agent roster; non-sort header row) */
html.care-app .care-invitations-roster-section {
    margin: 0;
}

html.care-app .care-invitations-roster__action-cell {
    display: flex;
    flex-wrap: wrap;
    gap: var(--care-app-space-xs);
    justify-content: flex-end;
    align-items: center;
}

html.care-app .care-invitations-roster__inline {
    margin: 0;
}

/* Invitations cap: primary (accent) “Invite”; row actions stay outline despite type="submit" */
html.care-app button.care-btn.care-invitations-cap-invite[type="button"] {
    color: var(--care-app-color-ink-on-accent);
    background: var(--care-app-color-accent);
    border: var(--care-app-border-width-hairline) solid transparent;
}

html.care-app button.care-btn.care-invitations-cap-invite[type="button"]:hover {
    background: var(--care-app-color-accent-hover);
    color: var(--care-app-color-ink-on-accent);
}

html.care-app button.care-btn.care-invitations-cap-invite[type="button"]:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app .care-invitations-roster__inline button[type="submit"].care-btn.care-btn--secondary {
    color: var(--care-app-color-ink-secondary);
    background: var(--care-app-color-surface-default);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-invitations-roster__inline button[type="submit"].care-btn.care-btn--secondary:hover {
    background: var(--care-app-color-surface-subtle);
    border-color: var(--care-app-color-border-subtle);
    color: var(--care-app-color-ink-primary);
}

html.care-app .care-invitations-roster__inline button[type="submit"].care-btn.care-btn--secondary:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app .care-agents-roster__th-sort {
    padding: 0;
    vertical-align: bottom;
    /* Fixed-layout columns can starve flex headers; allow shrinking below label min-content. */
    min-width: 0;
}

html.care-app .care-agents-roster__th-sort .care-th-sort {
    display: flex;
    align-items: center;
    /* Tight label + sort affordance — not `space-between`, which stretches them across the full column. */
    justify-content: flex-start;
    gap: var(--care-app-space-xs);
    width: 100%;
    min-width: 0;
    margin: 0;
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    font: inherit;
    font-weight: var(--care-app-type-weight-heading);
    text-align: start;
    color: var(--care-app-color-ink-primary);
    background: transparent;
    border: none;
    border-radius: var(--care-app-radius-sm);
    cursor: pointer;
    box-sizing: border-box;
}

html.care-app .care-agents-roster__th-sort .care-th-sort:hover {
    background: var(--care-app-color-surface-subtle);
}

html.care-app .care-agents-roster__th-sort .care-th-sort:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app .care-agents-roster__th-sort .care-th-sort::after {
    content: '';
    flex-shrink: 0;
    width: 0.65rem;
    height: 0.65rem;
    opacity: 0.35;
    border-inline-end: 2px solid currentColor;
    border-block-end: 2px solid currentColor;
    transform: rotate(45deg);
    margin-block-end: 0.15rem;
}

html.care-app .care-agents-roster__th-sort--asc .care-th-sort::after {
    opacity: 1;
    transform: rotate(-135deg);
    margin-block-end: -0.1rem;
}

html.care-app .care-agents-roster__th-sort--desc .care-th-sort::after {
    opacity: 1;
    transform: rotate(45deg);
    margin-block-end: 0.2rem;
}

html.care-app .care-agents-roster__th-sort--end .care-th-sort {
    justify-content: flex-end;
    gap: var(--care-app-space-xs);
    text-align: end;
}

html.care-app .care-agents-roster__cell-end {
    text-align: end;
}

html.care-app .care-agents-roster__th-action {
    width: 1%;
    white-space: nowrap;
    vertical-align: bottom;
    padding: var(--care-app-space-sm) var(--care-app-space-md);
}

/* Beats generic `th { … }` if that block ever sets `white-space` again; reserves space in fixed layout. */
html.care-app :is(table.care-tabular-view, table.care-person-grid).care-agents-roster-table th.care-agents-roster__th-action,
html.care-app :is(table.care-tabular-view, table.care-person-grid).care-agents-roster-table td.care-agents-roster__action {
    white-space: nowrap;
    min-width: 6.5rem;
}

html.care-app .care-agents-roster__action {
    vertical-align: middle;
}

html.care-app .care-agents-roster__name-link {
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-accent-primary);
    text-decoration: none;
}

html.care-app .care-agents-roster__name-link:hover {
    text-decoration: underline;
}

html.care-app .care-agents-roster__name-link:focus-visible {
    outline: 2px solid var(--care-app-color-accent-primary);
    outline-offset: 2px;
    border-radius: 2px;
}

html.care-app .care-agents-roster__updated {
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

html.care-app .care-audit-row--lifecycle td {
    background: color-mix(in srgb, var(--care-app-color-accent-primary) 18%, transparent);
}

html.care-app .care-audit-row--lifecycle td:first-child {
    border-left: 4px solid var(--care-app-color-accent-primary);
}

html.care-app .care-audit-row--lifecycle td:nth-child(5) code {
    background: color-mix(in srgb, var(--care-app-color-accent-primary) 28%, var(--care-app-color-surface));
    border: 1px solid color-mix(in srgb, var(--care-app-color-accent-primary) 60%, transparent);
    border-radius: 999px;
    padding: 0.15rem 0.5rem;
    font-weight: 700;
}

html.care-app .care-app-sidebar__placeholder {
    margin: 0;
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-ink-muted);
}

html.care-app .care-app-shell__column {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    background: var(--care-app-color-canvas);
}

html.care-app .care-app-topbar__end {
    display: flex;
    align-items: center;
    gap: var(--care-app-space-md);
    margin-inline-start: auto;
    flex-shrink: 0;
}

html.care-app .care-app-topbar__locale {
    position: relative;
    z-index: 35;
    color: var(--care-app-color-ink-primary);
}

/* care-lang-switch.css: panel is absolutely positioned; keep above topbar chrome */
html.care-app .care-app-topbar__locale .care-lang-switch__panel {
    z-index: 50;
    background: var(--care-app-color-surface-default);
    border-color: var(--care-app-color-border-subtle);
    box-shadow: var(--care-app-shadow-raised);
}

html.care-app .care-app-topbar__locale .care-lang-switch__summary {
    color: var(--care-app-color-ink-secondary);
    border-color: transparent;
}

html.care-app .care-app-topbar__locale .care-lang-switch__summary:hover {
    background: var(--care-app-color-surface-subtle);
    border-color: var(--care-app-color-border-subtle);
    color: var(--care-app-color-accent);
}

html.care-app .care-app-topbar__locale .care-lang-switch[open] > .care-lang-switch__summary {
    background: var(--care-app-color-surface-subtle);
    border-color: var(--care-app-color-border-subtle);
    color: var(--care-app-color-ink-primary);
}

html.care-app .care-app-topbar__locale .care-lang-switch__opt {
    color: var(--care-app-color-ink-secondary);
}

html.care-app .care-app-topbar__locale a.care-lang-switch__opt:hover {
    background: var(--care-app-color-accent-muted-bg);
    color: var(--care-app-color-accent);
}

html.care-app .care-app-topbar {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--care-app-space-md) var(--care-app-space-lg);
    box-sizing: border-box;
    width: 100%;
    min-height: var(--care-app-topbar-height);
    padding: var(--care-app-space-sm) var(--care-app-space-lg);
    border-block-end: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-default);
    flex-shrink: 0;
    /* Scrolling is confined to .care-app-shell__body; no sticky needed — avoids subpixel gaps vs. the sidebar row */
    z-index: 30;
}

html.care-app .care-app-nav-toggle {
    display: none;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin: 0;
    padding: 0;
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    border-radius: var(--care-app-radius-md);
    background: var(--care-app-color-surface-subtle);
    color: var(--care-app-color-ink-primary);
    cursor: pointer;
    transition:
        background var(--care-app-motion-duration-interaction) var(--care-app-motion-ease),
        border-color var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
}

html.care-app .care-app-nav-toggle:hover {
    background: var(--care-app-color-surface-default);
    border-color: var(--care-app-color-accent);
}

html.care-app .care-app-nav-toggle:focus-visible {
    outline: var(--care-app-focus-ring-width) solid var(--care-app-color-focus-ring);
    outline-offset: var(--care-app-focus-ring-offset);
}

html.care-app .care-app-nav-toggle__bars {
    display: block;
    width: 1.125rem;
    height: 0.1rem;
    background: currentColor;
    border-radius: var(--care-app-radius-pill);
    box-shadow:
        0 0.35rem 0 currentColor,
        0 -0.35rem 0 currentColor;
}

html.care-app .care-app-brand {
    display: inline-flex;
    align-items: center;
    gap: var(--care-app-space-sm);
    text-decoration: none;
    color: inherit;
    min-width: 0;
}

html.care-app .care-app-brand__mark {
    display: inline-flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

html.care-app .care-app-brand__logo {
    display: block;
    height: 2.25rem;
    width: auto;
    max-width: 2.6rem;
    object-fit: contain;
}

html.care-app .care-app-brand__text {
    display: flex;
    flex-direction: column;
    line-height: var(--care-app-type-leading-tight);
}

html.care-app .care-app-brand__title {
    font-size: var(--care-app-type-size-heading-3);
    font-weight: var(--care-app-type-weight-heading);
    letter-spacing: var(--care-app-type-tracking-heading);
    color: var(--care-app-color-ink-primary);
}

html.care-app .care-app-brand__tagline {
    font-size: 0.65rem;
    font-weight: var(--care-app-type-weight-body);
    letter-spacing: 0.02em;
    color: var(--care-app-color-ink-muted);
    max-width: 14rem;
}

/*
 * Intelygence-only topbar account disclosure (renamed from care-app-user-menu so bundled
 * assessment CSS cannot style it via generic `details` / `summary` selectors).
 * Scoped under .care-app-topbar for specificity over third-party stylesheets.
 */
html.care-app .care-app-topbar .care-inty-topbar-account {
    position: relative;
    margin-inline-start: auto;
    border: none;
    padding: 0;
    background: transparent;
    border-radius: 0;
}

html.care-app .care-app-topbar .care-inty-topbar-account__summary {
    list-style: none;
    cursor: pointer;
    font-size: var(--care-app-type-size-caption);
    font-weight: var(--care-app-type-weight-heading);
    padding: var(--care-app-space-xs) var(--care-app-space-md);
    border-radius: var(--care-app-radius-pill);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-subtle);
    color: var(--care-app-color-ink-primary);
}

html.care-app .care-app-topbar .care-inty-topbar-account__summary::-webkit-details-marker {
    display: none;
}

html.care-app .care-app-topbar .care-inty-topbar-account__panel {
    position: absolute;
    inset-inline-end: 0;
    margin-block-start: var(--care-app-space-xs);
    min-width: 12rem;
    padding: var(--care-app-space-sm);
    border-radius: var(--care-app-radius-md);
    border: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
    background: var(--care-app-color-surface-default);
    box-shadow: var(--care-app-shadow-floating);
    z-index: 20;
}

html.care-app .care-app-topbar .care-inty-topbar-account__list {
    list-style: none;
    margin: 0;
    padding: 0;
}

html.care-app .care-app-topbar .care-inty-topbar-account__list a {
    display: block;
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    border-radius: var(--care-app-radius-sm);
    font-size: var(--care-app-type-size-caption);
    text-decoration: none;
}

html.care-app .care-app-topbar .care-inty-topbar-account__list a:hover {
    background: var(--care-app-color-surface-subtle);
}

html.care-app .care-app-shell__body {
    flex: 1;
    min-height: 0;
    /* Allow column to shrink below wide tables so overflow stays inside this scroller (resize / devtools). */
    min-width: 0;
    overflow: auto;
    /* Reserve vertical scrollbar width so `width: 100%` descendants match the visible column (avoids 1px+ horizontal overflow). */
    scrollbar-gutter: stable;
}

/* Main column inside shell: full width of content area */
html.care-app .care-app-shell__body main.care-app-shell__main[data-care-page],
html.care-app main.care-app-shell__main[data-care-page] {
    box-sizing: border-box;
    width: 100%;
    max-width: var(--care-app-width-shell-max);
    min-width: 0;
    margin-inline: 0;
    padding-inline: var(--care-app-width-shell-pad-inline);
    padding-block: var(--care-app-width-shell-pad-block);
}

html.care-app .care-app-main-context {
    margin-block: 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-caption);
}

/* Agent embedded assessment: context above runner + sidebar assessment index */
html.care-app .care-assessment-agent-context__name {
    margin: 0 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-heading-2);
    line-height: 1.25;
    font-weight: 600;
}

html.care-app .care-assessment-agent-context__team {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-body);
    color: var(--care-app-color-text-muted, #64748b);
}

html.care-app .care-assessment-agent-context__label {
    font-weight: 600;
    margin-inline-end: 0.35em;
}

html.care-app .care-assessment-runner-wrap {
    margin-block-start: var(--care-app-space-sm);
}

/* Runner still targets #title (was h1 in standalone page); keep visual weight */
html.care-app .care-assessment-runner-wrap h2#title.care-assessment-runner-title {
    margin: 0;
    font-size: 1.25rem;
    letter-spacing: 0.0125em;
    font-weight: 600;
    line-height: 1.3;
}

html.care-app .care-app-sidebar__intro {
    margin-block: 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-caption);
    color: var(--care-app-color-text-muted, #64748b);
}

html.care-app .care-app-sidebar__inline-link {
    color: inherit;
}

html.care-app .care-app-sidebar__assess-group {
    display: block;
    font-size: var(--care-app-type-size-caption);
    font-weight: 600;
    color: var(--care-app-color-text-muted, #64748b);
    margin-block: var(--care-app-space-sm) var(--care-app-space-2xs, 0.25rem);
}

html.care-app li.care-app-sidebar__subheading {
    list-style: none;
    margin-inline: 0;
    padding: 0;
}

html.care-app .care-app-sidebar__list--assessments .care-app-sidebar__assess-link {
    font-size: var(--care-app-type-size-caption);
    padding-block: 0.2rem;
}

html.care-app .care-app-sidebar__assess-req {
    font-weight: 700;
    opacity: 0.85;
}

html.care-app .care-app-shell__backdrop {
    display: none;
}

html.care-app .care-app-shell__backdrop:not([hidden]) {
    display: block;
    position: fixed;
    inset: 0;
    top: var(--care-app-topbar-height, 3.5rem);
    z-index: 25;
    background: rgb(15 23 42 / 0.4);
    border: 0;
    padding: 0;
    margin: 0;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

@media (max-width: 48rem) {
    html.care-app .care-app-nav-toggle {
        display: inline-flex;
    }

    html.care-app .care-app-brand__tagline {
        display: none;
    }

    html.care-app .care-app-sidebar {
        position: fixed;
        top: var(--care-app-topbar-height, 3.5rem);
        left: 0;
        bottom: 0;
        width: min(17.5rem, 88vw);
        max-width: 100%;
        z-index: 26;
        transform: translateX(-100%);
        transition: transform var(--care-app-motion-duration-interaction) var(--care-app-motion-ease);
        border-inline-end: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
        border-block-end: none;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        box-shadow: var(--care-app-shadow-floating);
    }

    html.care-app .care-app-shell--nav-open .care-app-sidebar {
        transform: translateX(0);
    }

    html.care-app .care-app-shell__main-row {
        flex: 1;
        min-height: 0;
    }

    html.care-app .care-app-shell__column {
        width: 100%;
    }
}

/* Very narrow viewports: stack language above account in the topbar end cluster (saves horizontal space). */
@media (max-width: 26rem) {
    html.care-app .care-app-shell {
        --care-app-topbar-height: 5.75rem;
    }

    html.care-app .care-app-topbar {
        align-items: flex-start;
    }

    html.care-app .care-app-topbar__end {
        flex-direction: column;
        align-items: flex-end;
        gap: var(--care-app-space-xs);
    }

    html.care-app .care-app-topbar .care-inty-topbar-account {
        margin-inline-start: 0;
    }
}

@media (prefers-reduced-motion: reduce) {
    html.care-app .care-app-sidebar {
        transition: none;
    }
}

html.care-app form[data-care-form="agent-governance"] #care-process-description {
    overflow-y: hidden;
    resize: none;
}

html.care-app .care-evidence-link {
    color: var(--care-app-color-accent);
    text-decoration: underline;
    text-underline-offset: 2px;
    cursor: pointer;
}

html.care-app .care-evidence-link:hover {
    color: var(--care-app-color-accent-hover);
}

/* —— Subscription tier badge (header, manage payments, …) —— */
html.care-app .care-app-topbar .care-inty-topbar-account__identity {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    text-align: right;
}

html.care-app .care-inty-topbar-account__name-row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.35rem;
    max-width: min(100%, 15rem);
}

html.care-app .care-app-topbar .care-inty-topbar-account__name {
    font-weight: 600;
    line-height: 1.25;
}

.care-subscription-badge {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    vertical-align: middle;
    line-height: 0;
    border-radius: 5px;
}

.care-subscription-badge__bg {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    z-index: 0;
}

.care-subscription-badge__svg {
    position: relative;
    z-index: 1;
    display: block;
    width: 11px;
    height: 11px;
    filter: drop-shadow(0 0.5px 0.5px rgba(0, 0, 0, 0.12));
}

.care-subscription-badge--header {
    width: 1.28rem;
    height: 1.06rem;
}

.care-subscription-badge--header .care-subscription-badge__svg {
    width: 10px;
    height: 10px;
}

.care-subscription-badge--lg {
    width: 2.35rem;
    height: 1.85rem;
    border-radius: 7px;
}

.care-subscription-badge--lg .care-subscription-badge__svg {
    width: 18px;
    height: 18px;
}

.care-subscription-badge--free .care-subscription-badge__bg {
    background: linear-gradient(145deg, #4b5563 0%, #9ca3af 50%, #d1d5db 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.22),
        0 0 0 1px rgba(55, 65, 81, 0.35);
}

.care-subscription-badge--starter .care-subscription-badge__bg {
    background: linear-gradient(135deg, #065f46 0%, #059669 40%, #34d399 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.3),
        0 0 0 1px rgba(6, 78, 59, 0.4);
}

.care-subscription-badge--pro .care-subscription-badge__bg {
    background: linear-gradient(135deg, #1e3a8a 0%, #2563eb 42%, #93c5fd 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.28),
        0 0 0 1px rgba(30, 58, 138, 0.4);
}

.care-subscription-badge--control .care-subscription-badge__bg {
    background: linear-gradient(135deg, #312e81 0%, #5b21b6 38%, #a78bfa 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.26),
        0 0 0 1px rgba(49, 46, 129, 0.45);
}

.care-subscription-badge--enterprise .care-subscription-badge__bg {
    background: linear-gradient(135deg, #451a03 0%, #b45309 36%, #fcd34d 100%);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.35),
        0 0 0 1px rgba(69, 26, 3, 0.5);
}

/* Legacy hooks (tier class also on badge span) */
.care-header-tier {
    border: none;
    padding: 0;
    font-size: 0;
}

.care-manage-payments .care-mp-your-plan__name--badge {
    margin: 0 0 var(--care-app-space-sm);
    min-height: 1.85rem;
    display: flex;
    align-items: center;
}

/* —— Paddle /checkout (authenticated shell) —— */
.care-checkout .care-checkout__lead {
    margin-block-end: var(--care-app-space-md);
    max-width: 42rem;
}

.care-checkout .care-checkout__status,
.care-checkout .care-checkout__notice {
    margin-block: var(--care-app-space-md);
    max-width: 42rem;
    padding: var(--care-app-space-md);
    border-radius: var(--care-app-radius-md);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-muted, #f8fafc);
}

.care-checkout .care-checkout__notice--error {
    border-color: var(--care-app-color-danger-border, #fecaca);
    background: var(--care-app-color-danger-surface, #fef2f2);
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-checkout .care-checkout__actions {
    margin-block-start: var(--care-app-space-lg);
}

.care-checkout .care-checkout__back {
    color: var(--care-app-color-link, #2563eb);
    text-decoration: underline;
    text-underline-offset: 0.12em;
}

/* —— Manage payments: summary, voucher panel —— */
.care-manage-payments .care-mp-summary {
    margin-block-end: var(--care-app-space-lg);
    padding: var(--care-app-space-lg);
    border-radius: var(--care-app-radius-md);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-muted, #f8fafc);
}

.care-manage-payments .care-mp-summary p {
    margin: 0 0 var(--care-app-space-sm);
    max-width: none;
}

.care-manage-payments .care-mp-summary p:last-child {
    margin-bottom: 0;
}

.care-manage-payments .care-mp-your-plan__title {
    margin: 0 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-heading-2, 1.25rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-your-plan__name {
    margin: 0 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-body, 1rem);
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-your-plan__action {
    margin: 0;
}

.care-manage-payments .care-mp-your-plan__action .care-pricing-cta {
    display: inline-flex;
    width: fit-content;
}

/* Change-plan picker: single “current plan” card (no duplicate subscription sub-section) */
.care-manage-payments .care-mp-current-plan--picker {
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
}

.care-manage-payments .care-mp-current-plan__title {
    margin: 0 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-heading-2, 1.25rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-current-plan__identity {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-sm) var(--care-app-space-md);
    margin: 0 0 var(--care-app-space-sm);
}

.care-manage-payments .care-mp-current-plan__name {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.5rem;
    font-size: var(--care-app-type-size-body, 1rem);
    line-height: 1.35;
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-current-plan__complimentary {
    font-size: var(--care-app-type-size-heading-3, 1.125rem);
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--care-app-color-ink-primary);
    opacity: 0.5;
}

.care-manage-payments .care-mp-current-plan__label {
    font-weight: 600;
    font-size: var(--care-app-type-size-heading-3, 1.125rem);
    letter-spacing: -0.01em;
}

.care-manage-payments .care-mp-current-plan__badge {
    display: flex;
    align-items: center;
    line-height: 0;
}

.care-manage-payments .care-mp-current-plan__meta {
    margin: 0 0 var(--care-app-space-xs);
    max-width: 40rem;
    color: var(--care-app-color-ink-secondary, #475569);
    line-height: 1.5;
}

.care-manage-payments .care-mp-current-plan__hint {
    margin: 0 0 var(--care-app-space-xs);
    max-width: 40rem;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    color: var(--care-app-color-ink-secondary, #64748b);
    line-height: 1.45;
}

.care-manage-payments .care-mp-current-plan__action {
    margin: var(--care-app-space-sm) 0 0;
}

.care-manage-payments .care-mp-current-plan__action .care-pricing-cta {
    display: inline-flex;
    width: fit-content;
}

.care-manage-payments .care-mp-current-plan:not(.care-mp-current-plan--picker) {
    margin-block-end: 0;
}

.care-manage-payments .care-mp-billing-extras {
    margin-block-start: var(--care-app-space-md);
    padding-block-start: var(--care-app-space-md);
    border-top: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
}

.care-manage-payments .care-mp-billing-extras__line {
    margin: 0 0 var(--care-app-space-xs);
    max-width: 40rem;
    color: var(--care-app-color-ink-secondary, #475569);
    line-height: 1.5;
}

.care-manage-payments .care-mp-billing-extras__line:last-child {
    margin-bottom: 0;
}

.care-manage-payments .care-mp-change-plan__title {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-heading-2, 1.25rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-plan-picker__enterprise-banner {
    margin: 0 0 var(--care-app-space-md);
    padding: var(--care-app-space-sm) var(--care-app-space-md);
    border-radius: var(--care-app-radius-sm, 0.375rem);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-muted, #f8fafc);
    color: var(--care-app-color-ink-secondary, #475569);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    line-height: 1.5;
}

.care-manage-payments .care-mp-plan-picker__muted {
    display: inline-block;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    line-height: 1.45;
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-manage-payments .care-mp-plan-picker__status {
    margin: 0;
    max-width: 100%;
    text-align: inherit;
}

.care-manage-payments .care-mp-plan-picker__current {
    cursor: default;
    pointer-events: none;
}

.care-manage-payments .care-mp-plan-picker__actions form.care-mp-switch-plan-form {
    margin: 0;
    display: inline;
}

.care-manage-payments .care-mp-plan-picker__actions .care-pricing-cta {
    display: inline-flex;
    width: 100%;
    justify-content: center;
    box-sizing: border-box;
    border: none;
    font: inherit;
    cursor: pointer;
    text-align: center;
}

.care-manage-payments .care-mp-subscription {
    margin-block-start: var(--care-app-space-md);
    padding-block-start: var(--care-app-space-md);
    border-top: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
}

.care-manage-payments .care-mp-subscription__title {
    margin: 0 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-heading-3, 1.125rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-subscription__line {
    margin: 0 0 var(--care-app-space-xs);
    max-width: 40rem;
    color: var(--care-app-color-ink-secondary, #475569);
    line-height: 1.5;
}

.care-manage-payments .care-mp-subscription__line:last-of-type {
    margin-bottom: 0;
}

.care-manage-payments .care-mp-cancel-form {
    margin-block-start: var(--care-app-space-md);
}

.care-manage-payments .care-mp-cancel-form__btn {
    padding: 0.45rem 0.9rem;
    border-radius: var(--care-app-radius-sm, 0.375rem);
    border: 1px solid var(--care-app-color-border-strong, #cbd5e1);
    background: var(--care-app-color-surface-default, #fff);
    color: var(--care-app-color-ink-primary);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    cursor: pointer;
}

.care-manage-payments .care-mp-cancel-form__btn:hover {
    border-color: var(--care-app-color-ink-secondary, #64748b);
    background: var(--care-app-color-surface-muted, #f8fafc);
}

.care-manage-payments .care-mp-auto-renew {
    margin-block-start: var(--care-app-space-sm);
    max-width: 36rem;
}

.care-manage-payments .care-mp-auto-renew__form {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
        'label switch'
        'status status'
        'hint hint';
    align-items: center;
    gap: var(--care-app-space-sm) var(--care-app-space-md);
}

.care-manage-payments .care-mp-auto-renew .care-settings-switch-item__label {
    grid-area: label;
    margin: 0;
}

.care-manage-payments .care-mp-auto-renew .care-switch {
    grid-area: switch;
    justify-self: end;
}

.care-manage-payments .care-mp-auto-renew__status {
    grid-area: status;
    margin: 0;
    min-height: 1.25em;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-manage-payments .care-mp-auto-renew__hint {
    grid-area: hint;
    margin: 0;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    color: var(--care-app-color-ink-secondary, #64748b);
    line-height: 1.45;
}

.care-manage-payments .care-mp-panels {
    display: grid;
    gap: var(--care-app-space-lg);
    margin-block-end: var(--care-app-space-xl);
}

@media (min-width: 52rem) {
    .care-manage-payments .care-mp-panels {
        grid-template-columns: minmax(0, 36rem);
        align-items: start;
    }
}

.care-manage-payments .care-mp-panel {
    padding: var(--care-app-space-lg);
    border-radius: var(--care-app-radius-md);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-default, #fff);
    box-shadow: var(--care-app-shadow-none, none);
}

.care-manage-payments .care-mp-panel__title {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-heading-2);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary);
}

.care-manage-payments .care-mp-voucher-form__row {
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-md);
}

@media (min-width: 36rem) {
    .care-manage-payments .care-mp-voucher-form__row {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: flex-end;
    }

    .care-manage-payments .care-mp-voucher-form__field {
        flex: 1 1 12rem;
        min-width: 0;
    }

    .care-manage-payments .care-mp-voucher-form__submit {
        flex: 0 0 auto;
    }
}

.care-manage-payments .care-mp-voucher-form__field input[type='text'] {
    max-width: none;
}

.care-manage-payments .care-mp-voucher-form__hint {
    margin: 0.35rem 0 0;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    color: var(--care-app-color-ink-secondary, #64748b);
    line-height: 1.45;
}

.care-manage-payments .care-mp-history-title {
    margin-block: var(--care-app-space-xl) var(--care-app-space-sm);
}

/* —— Billing: cross-tenant payment transactions —— */
.care-billing-tx-intro {
    max-width: 48rem;
    margin-block: 0 1rem;
    color: var(--care-app-color-ink-secondary, #475569);
}

.care-billing-tx-staff-badge {
    margin: 0 0 1rem;
}

.care-billing-tx-staff-badge__inner {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    font-size: var(--care-app-type-size-body-small, 0.75rem);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    border-radius: var(--care-app-radius-sm, 4px);
    background: var(--care-app-color-surface-muted, #f1f5f9);
    border: 1px solid var(--care-app-color-border-subtle, #e2e8f0);
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-billing-tx-filter {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
    margin-block: 0 1rem;
    padding: var(--care-app-space-md);
    border-radius: var(--care-app-radius-md);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-muted, #f8fafc);
}

.care-billing-tx-filter__select {
    min-width: 14rem;
    padding: 0.35rem 0.5rem;
}

.care-billing-tx-filter__btn {
    padding: 0.35rem 0.85rem;
    cursor: pointer;
}

.care-billing-tx-org-id {
    color: var(--care-app-color-text-muted, #64748b);
    font-size: var(--care-app-type-size-body-small, 0.8125rem);
}

.care-billing-tx-manage {
    color: var(--care-app-color-link, #2563eb);
    text-decoration: underline;
    text-underline-offset: 0.12em;
    white-space: nowrap;
}

.care-billing-tx-pagination {
    margin-block: 1rem 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.care-billing-tx-pagination__info {
    margin: 0;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-billing-tx-page--disabled {
    pointer-events: none;
    opacity: 0.45;
    cursor: default;
}

.care-manage-payments .care-payment-charges-scroll {
    overflow-x: auto;
    margin-block: 0.75rem;
    -webkit-overflow-scrolling: touch;
}

.care-manage-payments .care-payment-charges__ref {
    font-size: var(--care-app-type-size-body-small, 0.8125rem);
    word-break: break-all;
    color: var(--care-app-color-text-muted, #64748b);
}

.care-manage-payments .care-payment-charges {
    width: 100%;
    border-collapse: collapse;
    margin-block: 0.75rem;
}

.care-manage-payments .care-payment-charges th,
.care-manage-payments .care-payment-charges td {
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    padding: 0.5rem 0.75rem;
    text-align: left;
}

/* Post-signup notice: paid tier chosen before billing is live */
/* Closed <dialog> must not use vw-based min/max width — flex ancestors treat it as min-content and layout breaks on resize/devtools. */
html.care-app dialog.care-billing-signup-notice,
html.care-app dialog.care-mp-checkout-success,
html.care-app dialog.care-mp-downgrade-dialog,
/* Unified CRUD modal lightboxes: profile teams, org team admin, agent create */
html.care-app dialog.care-crud-lightbox {
    border: none;
    padding: 0;
    background: transparent;
}

html.care-app dialog.care-billing-signup-notice[open],
html.care-app dialog.care-mp-checkout-success[open],
html.care-app dialog.care-mp-downgrade-dialog[open],
html.care-app dialog.care-crud-lightbox[open] {
    /*
     * Center with translate(-50%,-50%). Use vw/dvh for the anchor, not %: with a transformed ancestor,
     * fixed-position % resolves to that subtree’s box — width was already vw-clamped but left:50% still
     * centered on the wide column, so the modal sat off-screen and caused horizontal scroll.
     * (inset+margin:auto still fights native <dialog> layout in Chromium.)
     */
    position: fixed;
    top: 50vh;
    top: 50dvh;
    left: 50vw;
    right: auto;
    bottom: auto;
    transform: translate(-50%, -50%);
    margin: 0;
    /*
     * Width cap: use both % and vw. When an ancestor uses transform/filter, fixed-position % can resolve to that
     * subtree (wider than the phone viewport) and the modal blows past the screen; vw stays viewport-relative.
     * On desktop, min(% , vw) also avoids 100vw-only scrollbar gutter overflow vs a narrower layout CB.
     */
    width: min(26rem, calc(100% - 2rem), calc(100vw - 2rem));
    max-width: min(calc(100% - 2rem), calc(100vw - 2rem));
    min-width: 0;
    max-height: calc(100vh - 2rem);
    max-height: calc(100dvh - 2rem);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

html.care-app dialog.care-crud-lightbox--wide[open] {
    width: min(32rem, calc(100% - 2rem), calc(100vw - 2rem));
}

html.care-app dialog.care-crud-lightbox--extra-wide[open] {
    width: min(34rem, calc(100% - 2rem), calc(100vw - 2rem));
}

html.care-app dialog.care-mp-checkout-success[open] {
    width: min(34rem, calc(100% - 2rem), calc(100vw - 2rem));
}

/* Billing-style modals: one card child scrolls inside the clamped dialog */
html.care-app dialog.care-billing-signup-notice[open] > .care-billing-signup-notice__card,
html.care-app dialog.care-mp-checkout-success[open] > .care-billing-signup-notice__card,
html.care-app dialog.care-mp-downgrade-dialog[open] > .care-mp-downgrade-dialog__card {
    flex: 1 1 auto;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    box-sizing: border-box;
}

/* CRUD lightbox: form wraps card; body scrolls when content is tall */
html.care-app dialog.care-crud-lightbox[open] > form {
    display: flex;
    flex-direction: column;
    flex: 1 1 auto;
    min-width: 0;
    min-height: 0;
    margin: 0;
    width: 100%;
    max-width: 100%;
    max-height: 100%;
}

html.care-app dialog.care-crud-lightbox[open] > form .care-crud-lightbox__card,
html.care-app dialog.care-crud-lightbox[open] > .care-crud-lightbox__card {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    width: 100%;
    max-height: 100%;
}

html.care-app dialog.care-crud-lightbox[open] .care-crud-lightbox__body {
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

html.care-app dialog.care-billing-signup-notice::backdrop,
html.care-app dialog.care-mp-checkout-success::backdrop,
html.care-app dialog.care-mp-downgrade-dialog::backdrop,
html.care-app dialog.care-crud-lightbox::backdrop {
    background: rgb(15 23 42 / 0.48);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

/* Dark UI: dark-on-dark scrim needs heavy blur so the page behind reads as “back” not “through”. */
@media (prefers-color-scheme: dark) {
    html.care-app:not([data-care-theme="light"]) dialog.care-billing-signup-notice::backdrop,
    html.care-app:not([data-care-theme="light"]) dialog.care-mp-checkout-success::backdrop,
    html.care-app:not([data-care-theme="light"]) dialog.care-mp-downgrade-dialog::backdrop,
    html.care-app:not([data-care-theme="light"]) dialog.care-crud-lightbox::backdrop {
        background: rgb(0 0 0 / 0.62);
        backdrop-filter: blur(40px);
        -webkit-backdrop-filter: blur(40px);
    }
}

html.care-app[data-care-theme="dark"] dialog.care-billing-signup-notice::backdrop,
html.care-app[data-care-theme="dark"] dialog.care-mp-checkout-success::backdrop,
html.care-app[data-care-theme="dark"] dialog.care-mp-downgrade-dialog::backdrop,
html.care-app[data-care-theme="dark"] dialog.care-crud-lightbox::backdrop {
    background: rgb(0 0 0 / 0.62);
    backdrop-filter: blur(40px);
    -webkit-backdrop-filter: blur(40px);
}

html.care-app[data-care-theme="light"] dialog.care-billing-signup-notice::backdrop,
html.care-app[data-care-theme="light"] dialog.care-mp-checkout-success::backdrop,
html.care-app[data-care-theme="light"] dialog.care-mp-downgrade-dialog::backdrop,
html.care-app[data-care-theme="light"] dialog.care-crud-lightbox::backdrop {
    background: rgb(15 23 42 / 0.48);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

html.care-app .care-mp-downgrade-dialog__card {
    margin: 0;
    padding: var(--care-app-space-lg);
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
}

html.care-app .care-mp-downgrade-dialog__title {
    margin: 0 0 var(--care-app-space-sm);
    font-size: var(--care-app-type-size-heading-3, 1.125rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app .care-mp-downgrade-dialog__msg {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-body, 1rem);
    line-height: var(--care-app-type-leading-body, 1.5);
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-mp-downgrade-dialog__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--care-app-space-sm);
    justify-content: flex-end;
}

html.care-app .care-crud-lightbox__card {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
    min-width: 0;
    overflow: hidden;
    border-radius: var(--care-app-radius-lg, 12px);
    background: var(--care-app-color-surface-default, #fff);
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
}

html.care-app .care-crud-lightbox__header {
    flex-shrink: 0;
    min-width: 0;
    padding: var(--care-app-space-lg);
    border-block-end: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-crud-lightbox__title {
    margin: 0;
    font-size: var(--care-app-type-size-heading-3, 1.125rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary, #0f172a);
    overflow-wrap: anywhere;
}

html.care-app .care-crud-lightbox__body {
    flex: 1 1 auto;
    padding: var(--care-app-space-lg);
    min-width: 0;
    min-height: 0;
}

html.care-app .care-crud-lightbox__body > p {
    margin: 0 0 var(--care-app-space-md);
}

html.care-app .care-crud-lightbox__body > p:last-child {
    margin-block-end: 0;
}

html.care-app .care-crud-lightbox__body .care-crud-lightbox__leave-message {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-body, 1rem);
    line-height: var(--care-app-type-leading-body, 1.5);
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-crud-lightbox__footer {
    flex-shrink: 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--care-app-space-md);
    justify-content: flex-end;
    align-items: center;
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
    padding: var(--care-app-space-lg);
    border-block-start: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-profile-teams-new {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--care-app-space-sm);
    margin-block-start: var(--care-app-space-xl);
    padding-block-start: var(--care-app-space-lg);
    border-top: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app .care-new-team-form {
    margin: 0;
}

html.care-app .care-new-team-form__row {
    margin: 0 0 var(--care-app-space-md);
}

html.care-app .care-new-team-form__row label {
    display: block;
    margin-block-end: var(--care-app-space-xs);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app .care-new-team-form__row input,
html.care-app .care-new-team-form__row select,
html.care-app .care-new-team-form__row textarea {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

/* Stacked multi-field CRUD bodies (invite, voucher create, …): § standard-ui-components.md */
html.care-app dialog.care-crud-lightbox .care-invite-lightbox-fields {
    margin: 0;
    min-width: 0;
    max-width: 100%;
}

/* Long unbroken placeholder / labels / values must not widen the dialog past the viewport (flex min-width:auto). */
html.care-app dialog.care-crud-lightbox .care-new-team-form__row {
    min-width: 0;
    max-width: 100%;
}

html.care-app dialog.care-crud-lightbox .care-new-team-form__row label {
    overflow-wrap: anywhere;
}

html.care-app dialog.care-crud-lightbox .care-new-team-form__row :is(input, select, textarea) {
    overflow-x: auto;
}

html.care-app #care-invite-dialog .care-invite-lightbox-external {
    margin-block-start: var(--care-app-space-sm);
    padding-block-start: var(--care-app-space-md);
    border-block-start: var(--care-app-border-width-hairline) solid var(--care-app-color-border-subtle);
}

html.care-app #care-invite-dialog .care-invite-lightbox-external__title {
    margin: 0 0 var(--care-app-space-xs);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app #care-invite-dialog .care-invite-lightbox-external__confirm {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--care-app-space-sm);
}

html.care-app #care-invite-dialog .care-invite-lightbox-external__label {
    margin: 0;
    max-width: 42em;
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-snug);
    color: var(--care-app-color-ink-secondary);
    cursor: pointer;
}

html.care-app #care-invite-delete-dialog .care-invite-delete-dialog__email {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-body, 1rem);
    font-weight: var(--care-app-type-weight-heading);
    word-break: break-word;
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app #care-agent-delete-dialog .care-agent-delete-dialog__name {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-body, 1rem);
    font-weight: var(--care-app-type-weight-heading);
    word-break: break-word;
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app #care-team-report-delete-dialog .care-manage-intro strong {
    font-weight: var(--care-app-type-weight-heading);
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app .care-agents-roster__action-cell {
    display: flex;
    flex-wrap: wrap;
    gap: var(--care-app-space-xs);
    justify-content: flex-end;
    align-items: center;
}

html.care-app .care-billing-signup-notice__card {
    margin: 0;
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.18);
}

html.care-app .care-billing-signup-notice__card h2 {
    margin-top: 0;
}

html.care-app .care-billing-signup-notice__actions {
    margin-bottom: 0;
    text-align: right;
}

html.care-app .care-billing-signup-notice__primary {
    padding: 0.5rem 1rem;
    border-radius: var(--care-app-radius-sm, 4px);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-accent-primary, #2563eb);
    color: #fff;
    font: inherit;
    cursor: pointer;
}

html.care-app .care-billing-signup-notice__primary:hover {
    filter: brightness(1.05);
}

html.care-app .care-mp-checkout-success__block {
    margin-block: 0 1rem;
}

html.care-app .care-mp-checkout-success__block:last-of-type {
    margin-bottom: 0;
}

html.care-app .care-mp-checkout-success__sub {
    margin: 0 0 0.35rem;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    font-weight: 600;
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app .care-mp-checkout-success__p {
    margin: 0;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    line-height: var(--care-app-type-leading-body, 1.5);
    color: var(--care-app-color-ink-secondary, #64748b);
}

/* —— Agent portfolio dashboard (/agents-dashboard) — executive hierarchy + semantic signal —— */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard {
    --dash-danger-bg: var(--care-app-color-danger-surface);
    --dash-danger-border: var(--care-app-color-danger-border);
    --dash-danger-ink: var(--care-app-color-danger-ink);
    --dash-danger-ink-soft: var(--care-app-color-danger-button-fill);
    --dash-caution-bg: var(--care-app-color-caution-surface);
    --dash-caution-border: var(--care-app-color-caution-border);
    --dash-caution-ink: var(--care-app-color-caution-ink);
    --dash-ok-bg: var(--care-app-color-success-surface);
    --dash-ok-border: var(--care-app-color-success-border);
    --dash-ok-ink: var(--care-app-color-success-ink);
    --dash-ok-muted: var(--care-app-color-success-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__page-head {
    margin-bottom: 1.75rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__page-head-row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem 1.5rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__h1 {
    margin: 0;
    font-size: clamp(1.35rem, 2.5vw, 1.75rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--care-app-color-ink-primary, #0f172a);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__filter {
    margin: 0;
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__filter select {
    margin-left: 0.35rem;
    font: inherit;
    padding: 0.35rem 0.6rem;
    border-radius: var(--care-app-radius-sm, 4px);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-control-bg);
    color: var(--care-app-color-control-text);
}

/* Situation band — focal point */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation {
    margin: 0 0 1.75rem;
    padding: 1rem 1.25rem 1.1rem;
    border-radius: var(--care-app-radius-md, 10px);
    border: 1px solid transparent;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation-kicker {
    margin: 0 0 0.35rem;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation-headline {
    margin: 0;
    font-size: clamp(1.05rem, 2vw, 1.35rem);
    font-weight: 700;
    line-height: 1.3;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation-headline--ok {
    font-weight: 650;
    font-size: 1.05rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation-sub {
    margin: 0.5rem 0 0;
    font-size: 0.9rem;
    line-height: 1.45;
    opacity: 0.95;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation-insight {
    margin: 0.65rem 0 0;
    padding-top: 0.65rem;
    border-top: 1px solid var(--care-app-color-border-subtle);
    font-size: 0.88rem;
    font-weight: 600;
    line-height: 1.45;
    opacity: 0.98;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--alert .care-agent-dashboard__situation-insight {
    border-top-color: var(--care-app-color-danger-border);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--alert {
    background: var(--dash-danger-bg);
    border-color: var(--dash-danger-border);
    color: var(--dash-danger-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--alert .care-agent-dashboard__situation-kicker {
    color: var(--dash-danger-ink-soft);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--caution {
    background: var(--dash-caution-bg);
    border-color: var(--dash-caution-border);
    color: var(--dash-caution-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--ok {
    background: var(--dash-ok-bg);
    border-color: var(--dash-ok-border);
    color: var(--dash-ok-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--ok .care-agent-dashboard__situation-sub {
    color: var(--dash-ok-muted);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__situation--ok .care-agent-dashboard__situation-insight {
    border-top-color: var(--care-app-color-success-border);
    color: var(--dash-ok-ink);
    opacity: 0.95;
}

/* Primary KPI + secondaries */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__kpi-stack {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-bottom: 2.5rem;
}

@media (min-width: 768px) {
    :is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__kpi-stack {
        grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr);
        align-items: stretch;
        gap: 1.25rem;
    }
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__kpi-primary {
    padding: 1.35rem 1.5rem 1.5rem;
    border-radius: var(--care-app-radius-md, 12px);
    border: 2px solid var(--care-app-color-border-subtle, #e2e8f0);
    background: linear-gradient(
        165deg,
        var(--care-app-color-surface-default) 0%,
        var(--care-app-color-surface-raised) 100%
    );
    box-shadow: var(--care-app-shadow-raised);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__kpi-primary-label {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--care-app-color-ink-muted, #94a3b8);
    margin-bottom: 0.5rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-value {
    font-size: clamp(2.5rem, 6vw, 3.25rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.03em;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-headline {
    margin: 0.5rem 0 0;
    font-size: 1rem;
    font-weight: 650;
    line-height: 1.35;
    color: var(--care-app-color-ink-primary, #0f172a);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-headline--kpi-lead {
    margin: 0 0 0.35rem;
    font-size: 1.125rem;
    font-weight: 800;
    line-height: 1.3;
    letter-spacing: 0.01em;
    color: var(--care-app-color-ink-primary, #0f172a);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-meta {
    margin: 0.4rem 0 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__signal--ok {
    color: var(--dash-ok-muted);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__signal--caution {
    color: var(--care-app-color-caution-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__signal--alert {
    color: var(--dash-danger-ink-soft);
}

/* Maturity % demoted when headline carries the judgment (alert / caution bands) */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-value--demoted {
    font-size: clamp(1.55rem, 4.2vw, 2.05rem);
    font-weight: 750;
    letter-spacing: -0.02em;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-value--demoted.care-agent-dashboard__signal--alert {
    color: var(--care-app-color-danger-button-fill);
    opacity: 0.9;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__primary-value--demoted.care-agent-dashboard__signal--caution {
    color: var(--care-app-color-caution-ink);
    opacity: 0.92;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__signal--unknown {
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__kpi-secondaries {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.75rem;
    min-height: 100%;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__secondary {
    padding: 0.9rem 1rem;
    border-radius: var(--care-app-radius-md, 8px);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-raised, #f8fafc);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__secondary--hot {
    border-color: var(--dash-danger-border);
    background: var(--dash-danger-bg);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__secondary-label {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--care-app-color-ink-muted, #94a3b8);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__secondary-value {
    margin-top: 0.25rem;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--care-app-color-ink-primary, #0f172a);
    line-height: 1.1;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__secondary-hint {
    margin-top: 0.35rem;
    font-size: 0.75rem;
    line-height: 1.35;
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__secondary--hot .care-agent-dashboard__secondary-hint {
    color: var(--dash-danger-ink);
}

/* Sections */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__section {
    margin-bottom: 2.75rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__section--priority {
    margin-bottom: 2.25rem;
    padding-bottom: 0.25rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__section--compact {
    margin-bottom: 2.25rem;
}

/* Optional detail fold — keeps urgency narrative above */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold {
    margin: 0 0 1.75rem;
    padding: 0;
    border-radius: var(--care-app-radius-md, 10px);
    border: 1px dashed var(--care-app-color-border-subtle, #e2e8f0);
    background: var(--care-app-color-surface-raised, #f8fafc);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold-summary {
    list-style: none;
    cursor: pointer;
    padding: 0.85rem 1.1rem;
    font-size: 0.8rem;
    font-weight: 750;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold-summary::-webkit-details-marker {
    display: none;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold-summary::before {
    content: "▸";
    display: inline-block;
    margin-right: 0.45rem;
    transition: transform 0.15s ease;
    opacity: 0.65;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold[open] > .care-agent-dashboard__fold-summary::before {
    transform: rotate(90deg);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold-body {
    padding: 0 1rem 1.15rem;
    border-top: 1px solid var(--care-app-color-border-subtle, #e2e8f0);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__fold-body .care-agent-dashboard__section:first-child {
    margin-top: 1rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__section-head {
    margin-bottom: 1rem;
    max-width: 40rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__h2 {
    margin: 0 0 0.35rem;
    font-size: 0.95rem;
    font-weight: 650;
    letter-spacing: 0.02em;
    color: var(--care-app-color-ink-primary, #0f172a);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__h2--priority {
    font-size: 1.15rem;
    font-weight: 700;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__section-lead {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.5;
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__muted-inline {
    margin: 0;
    font-size: 0.875rem;
    color: var(--care-app-color-ink-secondary, #64748b);
}

/* Spotlight cards */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 640px) {
    :is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (min-width: 1100px) {
    :is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight {
    padding: 1.1rem 1.2rem 1.15rem;
    border-radius: var(--care-app-radius-md, 10px);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-default);
    box-shadow: var(--care-app-shadow-raised);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight--alert {
    border-color: var(--dash-danger-border);
    border-left-width: 4px;
    border-left-color: var(--dash-danger-ink-soft);
    background: var(--dash-danger-bg);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight--caution {
    border-color: var(--dash-caution-border);
    border-left-width: 4px;
    border-left-color: var(--care-app-color-caution-ink);
    background: var(--dash-caution-bg);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-badge {
    display: inline-block;
    margin-bottom: 0.5rem;
    padding: 0.2rem 0.5rem;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border-radius: 4px;
    background: var(--care-app-color-surface-subtle);
    color: var(--dash-danger-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight--caution .care-agent-dashboard__spotlight-badge {
    color: var(--dash-caution-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-title {
    margin: 0 0 0.5rem;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.25;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-title a {
    color: inherit;
    text-decoration: none;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-title a:hover {
    text-decoration: underline;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-facts {
    margin: 0;
    padding-left: 1.1rem;
    font-size: 0.8125rem;
    line-height: 1.5;
    color: var(--care-app-color-ink-primary, #334155);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-facts li + li {
    margin-top: 0.25rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__spotlight-cta {
    margin: 0.75rem 0 0;
}

/* Lifecycle chips */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.4rem 0.65rem;
    border-radius: 999px;
    font-size: 0.8125rem;
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-default);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chip-count {
    font-weight: 700;
    min-width: 1.25rem;
    text-align: center;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chip--active {
    border-color: var(--care-app-color-success-border);
    background: var(--dash-ok-bg);
    color: var(--dash-ok-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chip--draft {
    background: var(--care-app-color-surface-raised);
    color: var(--care-app-color-ink-secondary, #64748b);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chip--retired {
    opacity: 0.85;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__lc-chip--stopped {
    border-color: var(--care-app-color-caution-border);
    background: var(--care-app-color-caution-surface);
}

/* Process cards + collapsible table */
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

@media (min-width: 720px) {
    :is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-card {
    padding: 1rem 1.1rem;
    border-radius: var(--care-app-radius-md, 10px);
    border: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    background: var(--care-app-color-surface-muted);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-card-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.65rem;
    margin-bottom: 0.5rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-badge {
    display: inline-block;
    padding: 0.15rem 0.45rem;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border-radius: 4px;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-badge--neutral {
    background: var(--care-app-color-surface-subtle);
    color: var(--care-app-color-ink-secondary);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-badge--ok {
    background: var(--care-app-color-success-surface);
    color: var(--care-app-color-success-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-badge--watch {
    background: var(--care-app-color-caution-surface);
    color: var(--care-app-color-caution-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-badge--high {
    background: var(--care-app-color-danger-surface);
    color: var(--care-app-color-danger-button-fill);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-badge--danger {
    background: var(--care-app-color-danger-button-surface);
    color: var(--care-app-color-danger-ink);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 700;
    flex: 1 1 auto;
    min-width: 0;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__process-lead {
    margin: 0 0 0.35rem;
    font-size: 0.875rem;
    line-height: 1.45;
    color: var(--care-app-color-ink-primary, #334155);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__details {
    margin-top: 0.65rem;
    font-size: 0.8125rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__details > summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--care-app-color-accent-primary, #2563eb);
    list-style-position: outside;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__details > summary:hover {
    text-decoration: underline;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__details-table-wrap {
    margin-top: 0.5rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__table th,
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__table td {
    font-size: var(--care-app-type-size-body-small, 0.8125rem);
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__table--compact th,
:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__table--compact td {
    padding: 0.35rem 0.5rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__roster-link {
    margin: 0.5rem 0 1rem;
}

:is(html.care-app, .care-landing-hero-app-mock) .care-agent-dashboard__tagline {
    margin: 2rem 0 0;
    max-width: none;
    width: 100%;
    box-sizing: border-box;
    padding-top: 1.5rem;
    border-top: 1px solid var(--care-app-color-border-subtle, #e5e7eb);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    line-height: 1.55;
    color: var(--care-app-color-ink-secondary, #64748b);
}

/* —— Team reports (/team-reports) —— */
html.care-app .care-team-report__head {
    margin-bottom: 1.25rem;
}

html.care-app .care-team-report__h1 {
    margin: 0 0 0.35rem;
    font-size: clamp(1.35rem, 3vw, 1.75rem);
    font-weight: 700;
    color: var(--care-app-color-ink-primary, #0f172a);
}

html.care-app .care-team-report__lead {
    margin: 0;
    max-width: 42rem;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-team-report__muted {
    margin: 0.5rem 0;
    font-size: 0.9rem;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-team-report__team-form {
    margin-bottom: 1.25rem;
}

html.care-app .care-team-report__dashboard {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

html.care-app .care-team-report__widgets-board {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 0.15rem 0.35rem 0.15rem 0;
    align-content: start;
}

@media (min-width: 52rem) {
    html.care-app .care-team-report__widgets-board {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

html.care-app .care-team-report__widgets-empty {
    grid-column: 1 / -1;
    margin: 0;
}

html.care-app .care-team-report__widget--new {
    border: 2px dashed var(--care-app-color-border-subtle, #cbd5e1);
    border-radius: var(--care-app-radius-md, 8px);
    background: var(--care-app-color-surface-raised, #f8fafc);
    box-shadow: none;
}

html.care-app .care-team-report__widget-body--new {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 5.5rem;
    padding: 1rem;
}

html.care-app .care-team-report__new-tile-link {
    display: inline-block;
    font-weight: 650;
    font-size: 0.95rem;
    text-decoration: none;
    color: var(--care-app-color-accent-primary, #2563eb);
}

html.care-app .care-team-report__new-tile-link:hover,
html.care-app .care-team-report__new-tile-link:focus-visible {
    text-decoration: underline;
}

html.care-app .care-team-report__nf-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 1rem;
}

html.care-app .care-team-report__nf-row input[type="number"] {
    width: auto;
    min-width: 5.5rem;
    max-width: min(100%, 10rem);
    text-align: right;
}

/* Gap between the value and the steppers while steppers stay on the field’s trailing edge (Chromium/Safari). */
html.care-app .care-team-report__nf-row input[type="number"]::-webkit-inner-spin-button,
html.care-app .care-team-report__nf-row input[type="number"]::-webkit-outer-spin-button {
    margin-inline-start: 0.5rem;
    opacity: 1;
}

html.care-app .care-team-report__widget {
    display: flex;
    flex-direction: column;
    min-width: 0;
    position: relative;
    z-index: 0;
    border: 1px solid var(--care-app-color-border-subtle);
    border-radius: 6px 6px 8px 8px;
    overflow: visible;
    background: var(--care-app-color-surface-default);
    box-shadow: var(--care-app-shadow-raised);
}

html.care-app .care-team-report__widget:has(.care-team-report__widget-menu[open]) {
    z-index: 8;
}

html.care-app .care-team-report__widget.is-dragging {
    opacity: 0.55;
}

html.care-app .care-team-report__widget.is-drop-target--before {
    box-shadow:
        0 -3px 0 0 var(--care-app-color-accent),
        var(--care-app-shadow-raised);
}

html.care-app .care-team-report__widget.is-drop-target--after {
    box-shadow:
        0 3px 0 0 var(--care-app-color-accent),
        var(--care-app-shadow-raised);
}

html.care-app .care-team-report__widget-titlebar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    min-height: 2.25rem;
    padding: 0.2rem 0.15rem 0.2rem 0.65rem;
    background: var(--care-app-color-surface-subtle);
    border-bottom: 1px solid var(--care-app-color-border-subtle);
    border-radius: 5px 5px 0 0;
    font-size: 0.8125rem;
}

html.care-app .care-team-report__widget-titlebar--draggable {
    cursor: grab;
}

html.care-app .care-team-report__widget-titlebar--draggable:active {
    cursor: grabbing;
}

html.care-app .care-team-report__widget-titlebar-start {
    display: flex;
    align-items: center;
    gap: 0.15rem;
    min-width: 0;
    flex: 1;
}

html.care-app .care-team-report__widget-title {
    flex: 1;
    min-width: 0;
    margin: 0;
    padding: 0.15rem 0;
    font-size: 0.8125rem;
    font-weight: 650;
    line-height: 1.25;
    color: var(--care-app-color-ink-primary, #0f172a);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

html.care-app .care-team-report__widget-menu {
    position: relative;
    flex-shrink: 0;
}

html.care-app .care-team-report__widget-menu-trigger {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    margin: 0;
    padding: 0;
    list-style: none;
    cursor: pointer;
    border-radius: 4px;
    color: var(--care-app-color-ink-primary, #1e293b);
}

html.care-app .care-team-report__widget-menu-trigger::-webkit-details-marker {
    display: none;
}

html.care-app .care-team-report__widget-menu-trigger::marker {
    content: "";
}

html.care-app .care-team-report__widget-menu-trigger:hover {
    background: var(--care-app-color-accent-muted-bg);
}

html.care-app .care-team-report__widget-menu[open] > .care-team-report__widget-menu-trigger {
    background: var(--care-app-color-accent-muted-bg);
}

html.care-app .care-team-report__widget-menu-icon {
    display: block;
    width: 1.1rem;
    height: 1rem;
    background: repeating-linear-gradient(
        180deg,
        currentColor 0 2px,
        transparent 2px 5px
    );
    opacity: 0.72;
}

html.care-app .care-team-report__widget-menu-list {
    position: absolute;
    z-index: 50;
    top: calc(100% + 1px);
    left: 0;
    min-width: 12.5rem;
    margin: 0;
    padding: 0.25rem 0;
    list-style: none;
    background: var(--care-app-color-surface-elevated);
    border: 1px solid var(--care-app-color-border-subtle);
    border-radius: var(--care-app-radius-sm);
    box-shadow: var(--care-app-shadow-floating);
}

html.care-app .care-team-report__widget-menu-li {
    margin: 0;
    padding: 0;
    display: block;
    width: 100%;
}

html.care-app .care-team-report__widget-menu-item {
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 0.5rem 1rem 0.5rem 1.5rem;
    border: none;
    border-radius: 0;
    background: transparent;
    font: inherit;
    font-size: 0.8125rem;
    line-height: 1.35;
    text-align: left;
    text-decoration: none;
    color: var(--care-app-color-ink-primary);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

html.care-app a.care-team-report__widget-menu-item,
html.care-app a.care-team-report__widget-menu-item:visited,
html.care-app a.care-team-report__widget-menu-item:hover,
html.care-app a.care-team-report__widget-menu-item:focus,
html.care-app a.care-team-report__widget-menu-item:active {
    text-decoration: none;
}

/* Default row: same hover and keyboard focus (danger excluded — higher-specificity rules below) */
html.care-app a.care-team-report__widget-menu-item:hover:not(.care-team-report__widget-menu-item--danger),
html.care-app a.care-team-report__widget-menu-item:focus-visible:not(.care-team-report__widget-menu-item--danger),
html.care-app button.care-team-report__widget-menu-item:hover:not(.care-team-report__widget-menu-item--danger),
html.care-app button.care-team-report__widget-menu-item:focus-visible:not(.care-team-report__widget-menu-item--danger) {
    background: var(--care-app-color-accent);
    color: var(--care-app-color-ink-on-accent);
    text-decoration: none;
    outline: none;
}

html.care-app a.care-team-report__widget-menu-item--danger,
html.care-app a.care-team-report__widget-menu-item--danger:visited {
    color: var(--care-app-color-ink-primary);
    text-decoration: none;
}

html.care-app a.care-team-report__widget-menu-item--danger:hover,
html.care-app a.care-team-report__widget-menu-item--danger:focus-visible,
html.care-app button.care-team-report__widget-menu-item--danger:hover,
html.care-app button.care-team-report__widget-menu-item--danger:focus-visible {
    background: var(--care-app-color-danger-button-fill);
    color: var(--care-app-color-danger-button-ink);
    text-decoration: none;
    outline: none;
}

html.care-app .care-team-report__delete-form--widget-menu {
    display: block;
    margin: 0;
    width: 100%;
    max-width: 100%;
}

html.care-app .care-team-report__widget-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 1.85rem;
    margin: 0;
    padding: 0;
    flex-shrink: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    font-size: 1.35rem;
    line-height: 1;
    font-weight: 400;
    color: var(--care-app-color-ink-primary, #0f172a);
    cursor: pointer;
}

html.care-app .care-team-report__widget-close:hover {
    background: var(--care-app-color-danger-button-fill);
    color: var(--care-app-color-danger-button-ink);
}

html.care-app .care-team-report__widget-close:focus-visible {
    outline: 2px solid var(--care-app-color-accent-primary, #2563eb);
    outline-offset: -2px;
}

html.care-app .care-team-report__widget-client {
    padding: 0.65rem 0.75rem 0.75rem;
    border-top: 1px solid var(--care-app-color-border-subtle);
    border-radius: 0 0 7px 7px;
    background: var(--care-app-color-surface-default);
    overflow: hidden;
}

html.care-app .care-team-report__widget.is-collapsed .care-team-report__widget-client {
    display: none;
}

html.care-app .care-team-report__widget-desc {
    margin: 0 0 0.5rem;
    font-size: 0.8rem;
    line-height: 1.4;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-team-report__widget-body {
    max-height: 26rem;
    overflow: auto;
}

html.care-app .care-btn--small {
    padding: 0.35rem 0.65rem;
    font-size: 0.8125rem;
}

html.care-app .care-team-report__team-label {
    font-size: 0.875rem;
    font-weight: 600;
}

html.care-app .care-team-report__actions {
    margin: 0 0 1rem;
}

html.care-app .care-team-report__h2 {
    margin: 0 0 0.5rem;
    font-size: 1.15rem;
    font-weight: 700;
}

html.care-app .care-team-report__desc {
    margin: 0 0 1rem;
    font-size: 0.875rem;
    line-height: 1.45;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-team-report__row-actions {
    margin: 0 0 0.75rem;
}

html.care-app .care-team-report__delete-form {
    display: inline-block;
    margin: 0 0 1.25rem;
}

html.care-app .care-tr-viz-tiles,
html.care-app .care-tr-pie-entity-tiles {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.25rem;
    justify-content: flex-start;
    align-items: stretch;
    margin: 0.35rem 0 0.25rem;
    box-sizing: border-box;
}

html.care-app .care-tr-viz-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    flex: 0 0 auto;
    width: min(9.375rem, 100%);
    max-width: 9.375rem;
    min-width: 0;
    box-sizing: border-box;
    cursor: pointer;
}

html.care-app .care-tr-viz-tile__input {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    margin: 0;
    pointer-events: none;
}

html.care-app .care-tr-viz-tile__card {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    min-height: 9.375rem;
    height: 100%;
    padding: 0.65rem 0.45rem;
    border: 1px solid var(--care-app-color-border-subtle, #e2e8f0);
    border-radius: var(--care-app-radius-md, 8px);
    background: var(--care-app-color-surface-default);
    color: var(--care-app-color-ink-secondary, #64748b);
    transition: border-color 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
}

html.care-app .care-tr-viz-tile--compact .care-tr-viz-tile__card {
    min-height: 5.25rem;
    padding-block: 0.5rem;
}

html.care-app .care-tr-viz-tile__input:focus-visible + .care-tr-viz-tile__card {
    outline: 2px solid var(--care-app-color-accent-primary, #2563eb);
    outline-offset: 2px;
}

html.care-app .care-tr-viz-tile__input:checked + .care-tr-viz-tile__card {
    border-color: var(--care-app-color-accent-primary, #2563eb);
    color: var(--care-app-color-ink-primary, #0f172a);
    box-shadow: 0 0 0 1px var(--care-app-color-accent-primary, #2563eb);
    background: var(--care-app-color-surface-raised, #f8fafc);
}

html.care-app .care-tr-viz-tile:hover .care-tr-viz-tile__card {
    border-color: var(--care-app-color-border-strong, #cbd5e1);
}

html.care-app .care-tr-viz-tile__icon {
    flex-shrink: 0;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-tr-viz-tile__input:checked + .care-tr-viz-tile__card .care-tr-viz-tile__icon {
    color: var(--care-app-color-accent-primary, #2563eb);
}

html.care-app .care-tr-viz-tile__label {
    font-size: var(--care-app-type-size-caption, 0.8125rem);
    font-weight: 600;
    text-align: center;
    line-height: 1.25;
    max-width: 100%;
    overflow-wrap: anywhere;
    hyphens: auto;
}

html.care-app .care-tr-pie-step {
    margin-top: 0.75rem;
    padding-top: 0.5rem;
    border-top: 1px dashed var(--care-app-color-border-subtle, #e2e8f0);
}

/* Bar / stacked chart editor: match table panel — block sublegends + list radios */
html.care-app .care-tr-chart-bar-stack-body .care-team-report__sublegend {
    display: block;
    margin: 0.65rem 0 0.2rem;
}

html.care-app .care-tr-chart-bar-stack-body .care-team-report__check-list {
    margin-top: 0.25rem;
    margin-bottom: 0.35rem;
}

html.care-app .care-tr-chart-stack-dim {
    margin-top: 0.65rem;
    padding-top: 0.65rem;
    border-top: 1px dashed var(--care-app-color-border-subtle, #e2e8f0);
}

html.care-app .care-tr-pie-search {
    min-width: min(100%, 18rem);
    padding: 0.35rem 0.5rem;
    font-size: 0.875rem;
}

html.care-app .care-team-report__fieldset {
    margin: 1rem 0;
    padding: 0.75rem 1rem;
    border: 1px solid var(--care-app-color-border-subtle, #e2e8f0);
    border-radius: var(--care-app-radius-md, 8px);
    background: var(--care-app-color-surface-raised, #f8fafc);
    /* Fieldsets default to min-inline-size: min-content, which breaks equal grid tracks. */
    min-width: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

html.care-app .care-team-report__fieldset legend {
    font-weight: 650;
    padding: 0 0.35rem;
}

html.care-app .care-team-report__check-list {
    margin: 0.35rem 0 0;
    padding-left: 1.2rem;
}

html.care-app .care-team-report__hint {
    margin: 0 0 0.5rem;
    font-size: 0.8rem;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-team-report__sublegend {
    display: inline-block;
    margin-right: 0.35rem;
    font-weight: 600;
    font-size: 0.85rem;
}

html.care-app .care-team-report__form-actions {
    margin-top: 1.25rem;
}

html.care-app .care-team-report__data th,
html.care-app .care-team-report__data td {
    font-size: var(--care-app-type-size-body-small, 0.8125rem);
    max-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    vertical-align: middle;
}

html.care-app .care-team-report__data td a {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

html.care-app .care-team-report-chart {
    max-width: 42rem;
    margin: 0.5rem 0 0;
    padding: 0;
}

html.care-app .care-team-report-chart__meta {
    margin: 0 0 0.75rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--care-app-color-ink-secondary, #64748b);
}

html.care-app .care-team-report-chart__canvas-wrap {
    position: relative;
    width: 100%;
    min-height: 11rem;
}

html.care-app .care-team-report-chart__canvas {
    display: block;
    width: 100%;
    height: 100%;
}

/* Agent detail: Connect webhook + Manual import below governance form (collapsed by default) */
html.care-app main[data-care-page="agent-detail"] .care-governance-details[data-care-feature="agent-ingestion-webhook"] {
    margin-block-start: var(--care-app-space-lg);
}

html.care-app main[data-care-page="agent-detail"] .care-governance-details[data-care-feature="agent-ingestion"] {
    margin-block-start: var(--care-app-space-md);
}

html.care-app .care-ingestion-webhook__nest {
    margin-block-start: 0.65rem;
    border: 1px solid var(--care-app-color-border, #e2e8f0);
    border-radius: 6px;
    background: var(--care-app-color-surface-muted, #f8fafc);
}

html.care-app .care-ingestion-webhook__nest-summary {
    padding: 0.45rem 0.65rem;
    cursor: pointer;
    font-weight: 600;
    font-size: var(--care-app-type-size-caption, 0.8125rem);
    list-style-position: outside;
}

html.care-app .care-ingestion-webhook__nest-body {
    padding: 0 0.65rem 0.65rem;
    font-size: var(--care-app-type-size-caption, 0.8125rem);
    line-height: 1.45;
}

html.care-app .care-ingestion-webhook__nest-body p {
    margin: 0.35rem 0 0;
}

html.care-app .care-ingestion-webhook__nest-body p:first-child {
    margin-top: 0;
}

html.care-app .care-ingestion-webhook__ul {
    margin: 0.35rem 0 0;
    padding-left: 1.15rem;
}

html.care-app .care-ingestion-webhook__path {
    font-size: 0.92em;
    word-break: break-all;
}

html.care-app .care-ingestion-pending-top {
    margin: 0 0 0.65rem;
    padding: 0.5rem 0.75rem;
    border-radius: 6px;
    border: 1px solid var(--care-app-color-border, #e2e8f0);
    border-left: 4px solid var(--care-app-color-accent-info, #0ea5e9);
    background: var(--care-app-color-surface-muted, #f8fafc);
    font-size: var(--care-app-type-size-caption, 0.8125rem);
}

html.care-app .care-ingestion-pending-top__text {
    margin: 0;
}

html.care-app .care-ingestion-pending-inline {
    margin: 0 0 0.75rem;
    padding: 0.65rem 0.85rem;
    border: 1px solid var(--care-app-color-border, #e2e8f0);
    border-radius: 6px;
    background: var(--care-app-color-surface-muted, #f8fafc);
    font-size: var(--care-app-type-size-caption, 0.8125rem);
}

html.care-app .care-ingestion-pending-inline__actions {
    margin-top: 0.5rem;
}

html.care-app .care-ingestion-pending-form {
    width: 100%;
}

html.care-app .care-ingestion-pending-inline__button-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

html.care-app .care-ingestion-diff__auto-lead {
    margin: 0.35rem 0 0.15rem;
}

html.care-app .care-ingestion-diff__auto-list {
    margin: 0 0 0.5rem 1.1rem;
    padding: 0;
}

html.care-app .care-ingestion-diff__inline-code {
    font-size: 0.75em;
    word-break: break-word;
}

html.care-app .care-ingestion-diff__conflict-lead {
    margin: 0.5rem 0 0.35rem;
}

html.care-app .care-ingestion-diff__table-wrap {
    overflow-x: auto;
    margin: 0.35rem 0 0.65rem;
    max-width: 100%;
}

html.care-app .care-ingestion-diff__table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}

html.care-app .care-ingestion-diff__table th,
html.care-app .care-ingestion-diff__table td {
    border: 1px solid var(--care-app-color-border, #e2e8f0);
    padding: 0.35rem 0.45rem;
    vertical-align: top;
    text-align: start;
}

html.care-app .care-ingestion-diff__table thead th {
    background: var(--care-app-color-surface-elevated, #f1f5f9);
    font-weight: 600;
}

html.care-app .care-ingestion-diff__pre {
    margin: 0;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: ui-monospace, monospace;
    font-size: 0.75rem;
    max-height: 10rem;
    overflow: auto;
}

html.care-app .care-ingestion-diff__choices {
    min-width: 11rem;
}

html.care-app .care-ingestion-diff__choice {
    display: block;
    margin: 0.2rem 0;
    cursor: pointer;
}

/* Picked “keep current”: Current column bold; Import column muted + strike. */
html.care-app .care-ingestion-diff__row:has(input[value="old"]:checked) .care-ingestion-diff__cell--current .care-ingestion-diff__pre {
    font-weight: 700;
}

html.care-app .care-ingestion-diff__row:has(input[value="old"]:checked) .care-ingestion-diff__cell--import .care-ingestion-diff__pre {
    opacity: 0.5;
    text-decoration: line-through;
}

/* Picked “use import”: Import column bold; Current column muted + strike. */
html.care-app .care-ingestion-diff__row:has(input[value="new"]:checked) .care-ingestion-diff__cell--import .care-ingestion-diff__pre {
    font-weight: 700;
}

html.care-app .care-ingestion-diff__row:has(input[value="new"]:checked) .care-ingestion-diff__cell--current .care-ingestion-diff__pre {
    opacity: 0.5;
    text-decoration: line-through;
}

html.care-app .care-ingestion-dialog-schema-pre {
    max-height: 12rem;
    overflow: auto;
    font-size: 0.75rem;
    margin: 0.35rem 0 0.5rem;
    padding: 0.5rem;
    border-radius: 4px;
    background: var(--care-app-color-surface-muted, #f1f5f9);
}

html.care-app .care-ingestion-token-reveal-pre {
    max-height: 10rem;
    overflow: auto;
    word-break: break-all;
    font-size: 0.75rem;
    margin: 0.35rem 0 0.5rem;
    padding: 0.5rem;
    border-radius: 4px;
    background: var(--care-app-color-surface-muted, #f1f5f9);
    font-family: ui-monospace, monospace;
}

html.care-app .care-ingestion-token-status {
    margin: 0.35rem 0 0.5rem;
    padding: 0.45rem 0.55rem;
    border-radius: 6px;
    border: 1px solid var(--care-app-color-border, #e2e8f0);
    font-size: var(--care-app-type-size-caption, 0.8125rem);
    line-height: 1.45;
}

html.care-app .care-ingestion-token-status--none {
    background: var(--care-app-color-surface-muted, #f8fafc);
    color: var(--care-app-color-text-muted, #64748b);
}

html.care-app .care-ingestion-token-status--active {
    background: var(--care-app-color-surface-elevated, #f1f5f9);
}

html.care-app .care-ingestion-dialog-textarea {
    width: 100%;
    min-height: 8rem;
    box-sizing: border-box;
    font-family: ui-monospace, monospace;
    font-size: 0.8125rem;
}

html.care-app .care-ingestion-dialog-divider {
    border: 0;
    border-top: 1px solid var(--care-app-color-border, #e2e8f0);
    margin: 1rem 0;
}

/* Dev: ingestion simulator — same section/heading/fieldset patterns as Agents + Manage */
html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-roster-section {
    margin-block-start: var(--care-app-space-xl);
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-roster-section:first-of-type {
    margin-block-start: var(--care-app-space-sm);
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__mono {
    min-width: 0;
    max-width: 100%;
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__copy-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--care-app-space-sm);
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__copy-hint {
    min-height: 1.2em;
    font-size: var(--care-app-type-size-caption);
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__auth-hint {
    margin: 0 0 var(--care-app-space-md);
    font-size: var(--care-app-type-size-caption);
    line-height: var(--care-app-type-leading-snug, 1.45);
    max-width: 52rem;
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__field + .care-agents-tool-page__field {
    margin-block-start: var(--care-app-space-md);
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__control {
    width: 100%;
    max-width: 52rem;
    box-sizing: border-box;
}

html.care-app main[data-care-page="dev-ingestion-simulator"].care-agents-tool-page .care-agents-tool-page__out {
    min-height: 4rem;
}
