/**
 * Pricing modal + tier cards (uses care-app-shell-tokens.css variables).
 * Works on marketing (landing) and html.care-app routes.
 */

/* —— Modal shell —— */
.care-pricing-lightbox {
    position: fixed;
    inset: 0;
    z-index: 12000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--care-app-space-md, 1rem);
    box-sizing: border-box;
}

.care-pricing-lightbox[hidden] {
    display: none !important;
}

.care-pricing-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(4px);
}

.care-pricing-lightbox__sheet {
    position: relative;
    z-index: 1;
    box-sizing: border-box;
    width: min(100%, 72rem);
    max-height: min(92dvh, 56rem);
    overflow: auto;
    padding: var(--care-app-space-xl, 1.5rem);
    border-radius: var(--care-app-radius-lg, 12px);
    border: var(--care-app-border-width-hairline, 1px) solid var(--care-app-color-border-subtle, #e2e8f0);
    background: var(--care-app-color-surface-default, #fff);
    box-shadow: var(--care-app-shadow-raised, 0 20px 50px rgba(0, 0, 0, 0.18));
}

.care-pricing-lightbox__toolbar {
    display: flex;
    justify-content: flex-end;
    margin: calc(-1 * var(--care-app-space-xs, 0.25rem)) 0 var(--care-app-space-sm, 0.5rem);
    position: sticky;
    top: 0;
    z-index: 2;
    background: linear-gradient(
        to bottom,
        var(--care-app-color-surface-default, #fff) 70%,
        transparent
    );
}

.care-pricing-lightbox__close {
    flex-shrink: 0;
    width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: none;
    border-radius: var(--care-app-radius-md, 8px);
    font-size: 1.35rem;
    line-height: 1;
    color: var(--care-app-color-ink-secondary, #64748b);
    background: var(--care-app-color-surface-muted, #f1f5f9);
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.care-pricing-lightbox__close:hover {
    color: var(--care-app-color-ink-primary, #0f172a);
    background: var(--care-app-color-border-subtle, #e2e8f0);
}

.care-pricing-lightbox__close:focus-visible {
    outline: var(--care-app-focus-ring-width, 2px) solid var(--care-app-color-focus-ring, #2563eb);
    outline-offset: 2px;
}

.care-pricing-lightbox__content {
    min-height: 2rem;
}

.care-pricing-loading {
    margin: 0;
    padding: var(--care-app-space-xl, 1.5rem);
    text-align: center;
    color: var(--care-app-color-ink-secondary, #64748b);
}

/* —— Fragment header (inside modal) —— */
.care-pricing-fragment__header {
    margin-bottom: var(--care-app-space-lg, 1.25rem);
    padding-right: 0;
}

.care-pricing-fragment__title {
    margin: 0 0 var(--care-app-space-sm, 0.5rem);
    font-size: var(--care-app-type-size-heading-1, 1.5rem);
    font-weight: var(--care-app-type-weight-heading, 600);
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-pricing-fragment__intro {
    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);
}

.care-pricing-fragment__intro p {
    margin: 0 0 var(--care-app-space-sm, 0.5rem);
}

.care-pricing-fragment__intro p:last-child {
    margin-bottom: 0;
}

.care-pricing-fragment__intro p:first-child {
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-pricing-fragment__intro .slightly-reduced-opacity {
    opacity: 0.82;
}

/* —— Tier grid + Enterprise stack —— */
.care-pricing-offerings-root {
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-2xl, 2.5rem);
}

/* —— Tier grid (auth-card–style panels) —— */
.care-pricing-offerings {
    display: grid;
    gap: var(--care-app-space-lg, 1.25rem);
    grid-template-columns: 1fr;
}

@media (min-width: 40rem) {
    .care-pricing-offerings {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Compact Enterprise row (sales-led; below Free / Starter / Pro) */
.care-pricing-enterprise-compact {
    box-sizing: border-box;
    width: 100%;
}

.care-pricing-enterprise-compact__inner {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--care-app-space-lg, 1.25rem);
    padding: var(--care-app-space-xl, 1.5rem);
    border-radius: var(--care-app-radius-lg, 12px);
    border: 1px solid var(--care-app-color-border-subtle, #e2e8f0);
    border-left: 3px solid var(--care-app-color-accent, #2563eb);
    background: var(--care-app-color-surface-default, #fff);
    box-shadow:
        0 1px 2px rgba(15, 23, 42, 0.04),
        0 8px 24px rgba(15, 23, 42, 0.06);
}

.care-pricing-enterprise-compact__copy {
    min-width: 0;
}

.care-pricing-enterprise-compact__title {
    margin: 0 0 var(--care-app-space-xs, 0.25rem);
    font-size: var(--care-app-type-size-heading-2, 1.15rem);
    font-weight: var(--care-app-type-weight-heading, 600);
    letter-spacing: 0.02em;
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-pricing-enterprise-compact__lead {
    margin: 0 0 var(--care-app-space-md, 1rem);
    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);
    max-width: 42rem;
}

.care-pricing-enterprise-compact__extras {
    margin: 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: var(--care-app-space-xs, 0.35rem);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    line-height: 1.5;
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-pricing-enterprise-compact__plus {
    display: flex;
    align-items: baseline;
    gap: 0.35rem;
}

.care-pricing-enterprise-compact__plus::before {
    content: '+';
    flex-shrink: 0;
    font-weight: 700;
    font-size: 0.95em;
    color: var(--care-app-color-accent, #2563eb);
}

.care-pricing-enterprise-compact__actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: var(--care-app-space-sm, 0.5rem);
}

.care-pricing-enterprise-compact__actions .care-pricing-cta {
    width: 100%;
}

.care-pricing-tier__inner {
    box-sizing: border-box;
    height: 100%;
    display: flex;
    flex-direction: column;
    padding: var(--care-app-space-xl, 1.5rem);
    border-radius: var(--care-app-radius-lg, 12px);
    border: var(--care-app-border-width-hairline, 1px) solid var(--care-app-color-border-subtle, #e2e8f0);
    background: var(--care-app-color-surface-default, #fff);
    box-shadow: var(--care-app-shadow-raised, 0 1px 3px rgba(0, 0, 0, 0.08));
}

.care-pricing-tier--highlight .care-pricing-tier__inner {
    border-color: var(--care-app-color-accent, #2563eb);
    box-shadow:
        0 0 0 1px var(--care-app-color-accent, #2563eb),
        var(--care-app-shadow-raised, 0 8px 24px rgba(37, 99, 235, 0.12));
}

.care-pricing-tier__head {
    margin-bottom: var(--care-app-space-md, 1rem);
}

.care-pricing-tier__title {
    margin: 0 0 var(--care-app-space-xs, 0.25rem);
    font-size: var(--care-app-type-size-heading-3, 1.05rem);
    font-weight: var(--care-app-type-weight-heading, 600);
    letter-spacing: 0.04em;
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-pricing-tier__subtitle {
    margin: 0 0 var(--care-app-space-sm, 0.5rem);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    font-weight: 500;
    line-height: 1.4;
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-pricing-tier__price {
    margin: 0;
    font-size: var(--care-app-type-size-body, 1rem);
    font-weight: var(--care-app-type-weight-heading, 600);
    color: var(--care-app-color-ink-primary, #0f172a);
}

.care-pricing-tier__price--muted {
    font-weight: 500;
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-pricing-tier__features {
    flex: 1 1 auto;
    margin: 0 0 var(--care-app-space-lg, 1.25rem);
    padding-left: var(--care-app-space-lg, 1.25rem);
    font-size: var(--care-app-type-size-body-small, 0.875rem);
    line-height: 1.45;
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-pricing-tier__feature {
    margin-bottom: var(--care-app-space-2xs, 0.25rem);
}

.care-pricing-tier__actions {
    display: flex;
    flex-direction: column;
    gap: var(--care-app-space-sm, 0.5rem);
    margin-top: auto;
    padding-top: var(--care-app-space-md, 1rem);
    border-top: var(--care-app-border-width-hairline, 1px) solid var(--care-app-color-border-subtle, #e2e8f0);
}

/* CTAs: mirror html.care-app primary / ghost buttons */
.care-pricing-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    box-sizing: border-box;
    padding: var(--care-app-space-sm, 0.5rem) var(--care-app-space-lg, 1rem);
    font: inherit;
    font-weight: var(--care-app-type-weight-heading, 600);
    line-height: var(--care-app-type-leading-tight, 1.25);
    text-align: center;
    text-decoration: none;
    border-radius: var(--care-app-radius-md, 8px);
    cursor: pointer;
    transition:
        background 0.15s ease,
        color 0.15s ease,
        border-color 0.15s ease;
}

.care-pricing-cta--primary {
    color: var(--care-app-color-ink-on-accent, #fff);
    background: var(--care-app-color-accent, #2563eb);
    border: var(--care-app-border-width-hairline, 1px) solid transparent;
}

.care-pricing-cta--primary:hover {
    background: var(--care-app-color-accent-hover, #1d4ed8);
    color: var(--care-app-color-ink-on-accent, #fff);
}

/* Global `html.care-app a { color: accent }` must not turn primary CTAs into blue-on-blue */
html.care-app a.care-pricing-cta--primary,
html.care-app a.care-pricing-cta--primary:hover {
    color: var(--care-app-color-ink-on-accent, #fff);
    text-decoration: none;
}

html.care-app a.care-pricing-cta--secondary,
html.care-app a.care-pricing-cta--secondary:hover {
    color: var(--care-app-color-ink-primary, #0f172a);
    text-decoration: none;
}

.care-pricing-cta--secondary {
    color: var(--care-app-color-ink-primary, #0f172a);
    background: transparent;
    border: var(--care-app-border-width-hairline, 1px) solid var(--care-app-color-border-subtle, #cbd5e1);
}

.care-pricing-cta--secondary:hover {
    border-color: var(--care-app-color-ink-secondary, #64748b);
    background: var(--care-app-color-surface-muted, #f8fafc);
}

.care-pricing-cta:focus-visible {
    outline: var(--care-app-focus-ring-width, 2px) solid var(--care-app-color-focus-ring, #2563eb);
    outline-offset: var(--care-app-focus-ring-offset, 2px);
}

/* Full-page pricing gate (same tier styles) */
.care-pricing-gate-layout {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-block-start: clamp(2rem, 10vh, 4rem);
    padding-block-end: var(--care-app-space-2xl, 2.5rem);
    padding-inline: var(--care-app-width-shell-pad-inline, 1rem);
    min-height: 100dvh;
    box-sizing: border-box;
}

.care-pricing-gate-card.care-auth-card {
    width: min(100%, 72rem);
    max-width: 100%;
}

.care-pricing-gate__explain {
    margin-top: 0;
    line-height: var(--care-app-type-leading-body, 1.5);
    color: var(--care-app-color-ink-secondary, #64748b);
}

.care-pricing-gate__explain a {
    color: var(--care-app-color-accent, #2563eb);
}

.care-pricing-gate__form {
    margin-block-start: var(--care-app-space-xl, 1.5rem);
}

.care-pricing-gate__form button[type="submit"] {
    width: 100%;
}

/* Manage payments: full-width plan comparison */
.care-manage-payments-plans {
    margin-block-start: var(--care-app-space-lg, 1.25rem);
}

.care-manage-payments-plans .care-pricing-offerings {
    grid-template-columns: 1fr;
}

@media (min-width: 40rem) {
    .care-manage-payments-plans .care-pricing-offerings {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* /pricing fallback route (modal opens over empty main) */
.care-pricing-route-fallback {
    min-height: 0;
}
