/*
 * Soter Grav trial overrides.
 * Loaded after Quark 2 theme.css.
 */

:root {
    --soter-blue: #155bd1;
    --soter-blue-light: #2f7aea;
    --soter-blue-dark: #0f3f9c;
    --soter-blue-deep: #08275f;
    --soter-blue-pale: #e8eeff;
    --soter-navy: #0f1e3c;
    --soter-ink: #142033;
    --soter-muted: #617089;
    --soter-text-mid: #374151;
    --soter-text-muted: #6b7280;
    --soter-line: #dde6f3;
    --soter-border: #e5e4e0;
    --soter-warm-white: #f8f7f4;
    --soter-off-white: #f0eeea;
    --soter-green: #4caf7d;
    --soter-green-dark: #0f6a4a;
    --soter-grad-blue: linear-gradient(135deg, #155bd1 0%, #0f3f9c 55%, #08275f 100%);
    --soter-grad-blue-soft: linear-gradient(135deg, #eef5ff 0%, #dbeafe 52%, #f7fbff 100%);
    --soter-radius: 1.25rem;
    --soter-radius-lg: 1.6rem;
    --soter-shadow-sm: 0 1px 3px rgba(0, 0, 0, .07), 0 1px 2px rgba(0, 0, 0, .05);
    --soter-shadow-md: 0 4px 16px rgba(0, 0, 0, .09), 0 2px 4px rgba(0, 0, 0, .05);
}

body {
    background: #ffffff;
    color: var(--soter-ink);
}

h2::before {
    display: none !important;
}

.container {
    max-width: 1280px;
}

#header {
    background: rgba(255, 255, 255, .96);
    border-bottom: 1px solid var(--soter-line);
}

.navbar-brand {
    padding: .35rem 0;
}

.navbar-brand img {
    max-height: 76px;
    width: auto;
}

.navigation a {
    color: var(--soter-ink);
    font-weight: 800;
}

i[class^="fa-"],
i[class*=" fa-"] {
    color: var(--soter-blue);
}

.dropmenu a:hover,
.dropmenu a.active,
.dropmenu a.active:hover,
.navigation a:hover,
.navigation a.active,
.overlay .overlay-menu a:hover,
.overlay .overlay-menu a.active {
    background: transparent !important;
    box-shadow: none !important;
    color: var(--soter-blue) !important;
    text-decoration: none;
}

.dropmenu a.active,
.navigation a.active,
.overlay .overlay-menu a.active {
    font-weight: 900 !important;
}

.section {
    padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 5rem);
}

.modular-hero {
    background: var(--soter-grad-blue);
    color: #ffffff;
    padding-left: max(clamp(1.25rem, 5vw, 5rem), calc((100vw - 1280px) / 2));
    padding-right: max(clamp(1.25rem, 5vw, 5rem), calc((100vw - 1280px) / 2));
}

.modular-hero .container {
    margin: 0;
    max-width: 1280px;
    text-align: left !important;
}

.hero-layout {
    align-items: center;
    display: grid;
    gap: clamp(2rem, 5vw, 4rem);
    grid-template-columns: minmax(0, 2fr) minmax(260px, 1fr);
}

.hero-copy-panel {
    min-width: 0;
    text-align: left;
}

.hero-copy-panel > * {
    margin-left: 0;
}

.hero-visual-card {
    align-items: center;
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .28);
    border-radius: 2rem;
    box-shadow: 0 24px 70px rgba(0, 0, 0, .18);
    display: flex;
    justify-content: center;
    justify-self: end;
    margin: 0;
    max-width: 420px;
    padding: clamp(1.25rem, 3vw, 2rem);
    width: 100%;
}

.hero-visual-card img {
    display: block;
    max-height: min(62vh, 560px);
    object-fit: contain;
    width: 100%;
}

.modular-hero h1 {
    color: #ffffff;
    font-size: clamp(2.25rem, 6vw, 5rem);
    line-height: .95;
    margin: .3rem 0 1rem;
    max-width: 920px;
}

.modular-hero h1 em {
    color: #fbbf24;
    font-style: normal;
}

.modular-hero p {
    color: rgba(255, 255, 255, .82);
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    max-width: 760px;
}

.modular-hero p:first-child {
    color: #fbbf24;
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.modular-hero a,
.button,
button.button {
    align-items: center;
    border: 0;
    border-radius: 999px;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-weight: 900;
    min-height: 2.9rem;
    padding: .85rem 1.25rem;
    text-decoration: none;
}

.modular-hero p:last-child a:first-child,
.button.primary,
.button.button-primary,
button.button.primary {
    background: var(--soter-blue);
    color: #ffffff;
}

.modular-hero p:last-child a:last-child {
    background: #ffffff;
    border: 1px solid var(--soter-line);
    color: var(--soter-blue);
    margin-left: .75rem;
}

.modular-features.why-section,
.modular-features.features-section {
    background: #ffffff;
}

.modular-features.features-section {
    background:
        linear-gradient(rgba(255, 255, 255, .78), rgba(255, 255, 255, .82)),
        url("/images/Indoor.png") center calc(50% + var(--parallax-y, 0px)) / cover no-repeat;
    will-change: background-position;
}

.modular-features.features-section .column {
    background: rgba(255, 255, 255, .88);
    backdrop-filter: blur(2px);
}

@media (min-width: 900px) and (prefers-reduced-motion: no-preference) {
    .modular-features.features-section {
        background-size: auto 120%;
    }
}

.modular-features.soter-how {
    background: var(--soter-grad-blue-soft);
}

.modular-audiences {
    background: var(--soter-off-white);
}

.modular-pricing {
    background: var(--soter-grad-blue);
    color: #ffffff;
}

.modular-text.contact-section,
.content-item.has-soter-form {
    background: var(--soter-warm-white);
}

.modular-features .frame-box {
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: 0;
}

.modular-features h2,
.modular-audiences h2,
.modular-pricing h2,
.modular-text h2,
.content-item.has-soter-form h1,
.content-item.has-soter-form h2 {
    color: var(--soter-navy);
    font-size: clamp(2rem, 3vw, 2.75rem);
    line-height: 1.08;
    margin: 0 0 .5rem;
}

.section-kicker {
    color: var(--soter-blue);
    font-size: .8rem;
    font-weight: 900;
    letter-spacing: .12em;
    line-height: 1.2;
    margin: 0 0 .3rem;
    text-transform: uppercase;
}

.section-kicker + h2,
.section-kicker + h1 {
    margin-top: 0;
}

.modular-pricing h2,
.modular-pricing .section-kicker {
    color: #ffffff;
}

.modular-pricing .pricing-intro,
.modular-pricing .pricing-note {
    color: rgba(255, 255, 255, .78);
}

.modular-pricing .pricing-cta-row .button,
.modular-pricing .pricing-cta-row .button-primary,
.modular-pricing .pricing-cta-row .button.button-primary {
    background: #ffffff;
    color: var(--soter-blue);
}

.modular-pricing .pricing-cta-row .button:hover,
.modular-pricing .pricing-cta-row .button-primary:hover,
.modular-pricing .pricing-cta-row .button.button-primary:hover {
    background: var(--soter-blue-pale);
    color: var(--soter-blue-dark);
}

.modular-hero p:first-child,
.modular-text.contact-section .section-kicker,
.content-item.has-soter-form .section-kicker {
    color: var(--soter-blue);
}

.modular-hero p:first-child {
    color: #fbbf24;
}

.modular-pricing .section-kicker {
    color: rgba(255, 255, 255, .82);
}

.modular-text.contact-section .contact-copy a,
.content-item.has-soter-form .contact-copy a {
    color: var(--soter-blue);
}

.modular-features .frame-box > p,
.modular-audiences .personas-intro {
    color: var(--soter-text-mid);
    font-size: 1.05rem;
    margin-top: 0;
    margin-bottom: 2.25rem;
    max-width: 680px;
}

.modular-pricing .pricing-intro {
    color: rgba(255, 255, 255, .78);
    font-size: 1.05rem;
    margin-top: 0;
    margin-bottom: 2.25rem;
    max-width: 680px;
}

.modular-features .columns,
.persona-grid,
.pricing-grid,
.reassurance-grid {
    display: grid;
    gap: 1.5rem;
    width: 100%;
}

.modular-features.standard .columns,
.pricing-grid,
.reassurance-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.modular-features.small .columns {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.modular-features .column,
.pricing-card,
.persona-panel,
.partnership-card,
.frame-box,
.contact-form,
.purchase-image-card,
.choice-field,
.families-image-card,
.about-image-card,
.terms-panel,
.faq-list details {
    background: #ffffff;
    border: 1px solid var(--soter-border);
    border-radius: var(--soter-radius);
    box-shadow: var(--soter-shadow-sm);
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.modular-features .column,
.pricing-card {
    padding: 1.5rem;
}

.modular-features .column:hover,
.pricing-card:hover,
.persona-panel:hover,
.partnership-card:hover,
.frame-box:hover,
.contact-form:hover,
.purchase-image-card:hover,
.choice-field:hover,
.families-image-card:hover,
.about-image-card:hover,
.terms-panel:hover,
.faq-list details:hover {
    border-color: rgba(21, 91, 209, .32);
    box-shadow: var(--soter-shadow-md);
    transform: translateY(-2px);
}

.persona-panel:hover {
    transform: translateY(-2px);
}

.hero-copy-panel,
.hero-visual-card {
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.hero-copy-panel:hover,
.hero-visual-card:hover {
    box-shadow: var(--soter-shadow-md);
    transform: translateY(-2px);
}

.modular-features .feature-icon {
    align-items: flex-start;
    color: var(--soter-blue);
    display: grid;
    gap: .75rem;
}

.modular-features .feature-icon i {
    font-size: 1.4rem;
}

.modular-features .feature-icon i,
.feature-icon i,
.card-icon,
.step-icon,
.marker,
.price-marker,
.new-feature-badge i {
    color: var(--soter-blue) !important;
}

.modular-features .feature-icon h6 {
    color: var(--soter-navy);
    font-size: 1rem;
    font-weight: 900;
    line-height: 1.2;
    margin: 0;
}

.modular-features .feature-content p {
    color: var(--soter-text-muted);
    font-size: .95rem;
    margin: .6rem 0 0;
}

.new-feature-badge {
    align-items: center;
    background: #e8f0ff;
    border: 1px solid rgba(21, 91, 209, .18);
    border-radius: 999px;
    color: var(--soter-blue);
    display: inline-flex;
    font-size: .62rem;
    font-weight: 900;
    gap: .25rem;
    letter-spacing: .08em;
    margin-left: .45rem;
    padding: .16rem .42rem;
    text-transform: uppercase;
    vertical-align: middle;
}

.new-feature-badge i {
    font-size: .62rem !important;
}

.modular-features.soter-how .columns {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.75rem;
}

.modular-features.soter-how .column {
    position: relative;
}

.modular-features.soter-how .column:not(:last-child)::after {
    position: absolute;
    top: 50%;
    right: -1.35rem;
    color: var(--soter-blue);
    content: "→";
    font-size: 1.6rem;
    font-weight: 900;
    line-height: 1;
    transform: translateY(-50%);
}

.modular-features .feature-image {
    align-items: center;
    display: flex;
    justify-content: center;
    margin-bottom: .9rem;
    min-height: 170px;
}

.modular-features .feature-image img {
    display: block;
    height: auto;
    max-width: min(100%, 230px);
}

.modular-features.soter-how .feature-image img {
    max-width: min(100%, 240px);
}

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

.persona-panel {
    border-radius: var(--soter-radius-lg);
    box-shadow: var(--soter-shadow-md);
    overflow: hidden;
}

.persona-header {
    padding: 1.75rem 2rem 1.5rem;
}

.persona-header.family {
    background: linear-gradient(135deg, #0f1e3c 0%, #1a3570 100%);
}

.persona-header.care {
    background: linear-gradient(135deg, #064e3b 0%, #065f46 100%);
}

.persona-tag {
    color: rgba(255, 255, 255, .72);
    font-size: .7rem;
    font-weight: 900;
    letter-spacing: .12em;
    margin: 0 0 .65rem;
    text-transform: uppercase;
}

.persona-header h3 {
    color: #ffffff;
    font-size: 1.4rem;
    line-height: 1.12;
    margin: 0 0 .5rem;
}

.persona-header p {
    color: rgba(255, 255, 255, .66);
    font-size: .95rem;
    margin: 0;
}

.persona-body {
    background: #ffffff;
    padding: 1.75rem 2rem;
}

.persona-list,
.pricing-features {
    display: flex;
    flex-direction: column;
    gap: .65rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.persona-list li,
.pricing-features li {
    align-items: flex-start;
    color: var(--soter-text-mid);
    display: flex;
    font-size: .95rem;
    gap: .65rem;
}

.persona-list li::before,
.pricing-features li::before {
    color: var(--soter-blue);
    content: "✓";
    flex-shrink: 0;
    font-size: .9rem;
    font-weight: 900;
}

.persona-cta {
    border-radius: .8rem;
    color: #ffffff;
    display: inline-flex;
    font-weight: 900;
    margin-top: 1.25rem;
    min-height: 2.75rem;
    padding: .65rem 1.1rem;
    text-decoration: none;
}

.persona-cta.family-cta {
    background: var(--soter-blue);
    box-shadow: 0 4px 16px rgba(26, 79, 214, .28);
}

.persona-cta.care-cta {
    background: var(--soter-green);
}

.modular-reassurance,
.reassurance {
    background: var(--soter-blue-pale);
    border-bottom: 1px solid #d1d9f8;
    border-top: 1px solid #d1d9f8;
}

.reassurance {
    padding: clamp(2.75rem, 5vw, 4rem) clamp(1.25rem, 5vw, 5rem);
}

.reassurance-item {
    text-align: center;
}

.reassurance-num {
    color: var(--soter-blue);
    font-size: clamp(2.25rem, 4vw, 2.7rem);
    font-weight: 900;
    letter-spacing: -.08em;
    line-height: 1;
    margin-bottom: .4rem;
}

.reassurance-label {
    color: var(--soter-text-mid);
    font-size: .95rem;
    font-weight: 900;
}

.reassurance-sub {
    color: var(--soter-text-muted);
    font-size: .82rem;
    margin-top: .2rem;
}

.pricing-card {
    display: flex;
    flex-direction: column;
    padding: 2rem 1.75rem;
}

.pricing-name {
    color: var(--soter-text-muted);
    font-size: .85rem;
    font-weight: 900;
    letter-spacing: .08em;
    margin-bottom: .5rem;
    text-transform: uppercase;
}

.pricing-price {
    align-items: baseline;
    display: flex;
    gap: .25rem;
    margin-bottom: .35rem;
    min-height: 3.4rem;
}

.pricing-price .amount,
.pricing-price-text {
    color: var(--soter-navy);
    font-size: 2.65rem;
    font-weight: 900;
    letter-spacing: -.08em;
    line-height: 1.1;
}

.pricing-price .currency {
    color: var(--soter-text-mid);
    font-size: 1.25rem;
    font-weight: 900;
}

.pricing-price .period {
    color: var(--soter-text-muted);
    font-size: .95rem;
}

.pricing-desc {
    color: var(--soter-text-muted);
    font-size: .95rem;
    min-height: 4.5rem;
}

.pricing-divider {
    border: 0;
    border-top: 1px solid var(--soter-border);
    margin: 1.25rem 0;
}

.pricing-features {
    margin-top: auto;
}

.pricing-cta-row {
    display: flex;
    justify-content: center;
    margin-top: 1.75rem;
}

.pricing-note {
    color: var(--soter-text-muted);
    font-size: .85rem;
    margin: 1.5rem auto 0;
    max-width: 760px;
    text-align: center;
}

.soter-contact-grid {
    align-items: start;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, .9fr) minmax(320px, 1.1fr);
}

.contact-copy address {
    font-style: normal;
}

.contact-form {
    background: #ffffff;
    border: 1px solid var(--soter-line);
    border-radius: var(--soter-radius);
    box-shadow: 0 24px 70px rgba(10, 35, 75, .12);
    color: var(--soter-ink);
    display: grid;
    gap: 1rem;
    padding: clamp(1.2rem, 3vw, 2rem);
}

.contact-form h2 {
    color: var(--soter-ink);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    margin: 0;
}

.field-row {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr 1fr;
}

.field-group {
    display: grid;
    gap: .4rem;
}

.field-group label,
.choice-field {
    color: var(--soter-ink);
    font-weight: 900;
}

.field-group input,
.field-group select,
.field-group textarea {
    border: 1px solid var(--soter-line);
    border-radius: .8rem;
    color: var(--soter-ink);
    font: inherit;
    padding: .78rem .9rem;
    width: 100%;
}

.field-group textarea {
    resize: vertical;
}

.choice-field {
    align-items: flex-start;
    border: 1px solid var(--soter-line);
    border-radius: .9rem;
    display: flex;
    gap: .65rem;
    padding: .75rem .85rem;
}

.choice-field input[type="checkbox"] {
    flex: 0 0 1.1rem;
    height: 1.1rem;
    min-height: 1.1rem;
    width: 1.1rem;
}

.choice-field input {
    margin-top: .25rem;
}

.form-note {
    color: var(--soter-muted);
    font-size: .95rem;
    margin: 0;
}

.form-alert {
    border-radius: .9rem;
    font-weight: 900;
    padding: .85rem 1rem;
}

.form-alert-success {
    background: #e8f8ed;
    color: #156b31;
}

.form-alert-error {
    background: #fff0f0;
    color: #a51f1f;
}

.hp-field {
    left: -9999px;
    position: absolute;
    top: auto;
}

html body #footer.soter-footer,
#footer.soter-footer,
.soter-footer {
    background: #000000 !important;
    color: #ffffff;
}

.soter-footer .container {
    align-items: start;
    display: grid;
    gap: 2rem;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 34rem);
}

.soter-footer__brand {
    justify-self: start;
    max-width: 34rem;
    text-align: left;
}

.soter-footer__brand img {
    display: block;
    height: auto;
    margin: 0 0 .75rem;
    max-width: 210px;
}

.soter-footer__brand p {
    color: rgba(255, 255, 255, .72);
    margin: 0;
}

.soter-footer__copyright {
    color: rgba(255, 255, 255, .58) !important;
    font-size: .9rem;
    margin-top: .55rem !important;
}

.soter-footer__address {
    color: rgba(255, 255, 255, .72);
    font-style: normal;
    justify-self: end;
    line-height: 1.6;
    margin: 0;
    text-align: right;
}

.soter-footer__address strong {
    color: #ffffff;
}

.content-item.families-page {
    background: var(--soter-grad-blue-soft);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    max-width: none;
    padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 5rem);
    width: 100vw;
}

.content-item.families-page > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 1280px;
}

.content-item.families-page h1,
.content-item.families-page h2 {
    color: var(--soter-navy);
}

.content-item.about-page,
.content-item.partnerships-page,
.content-item.purchase-page {
    max-width: none;
}

.content-item.about-page > *,
.content-item.partnerships-page > *,
.content-item.purchase-page > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 1280px;
}

.content-item.faq-page {
    background: linear-gradient(135deg, #f7fbff 0%, #ffffff 100%);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    max-width: none;
    padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 5rem);
    width: 100vw;
}

.content-item.faq-page > * {
    margin-left: auto;
    margin-right: auto;
    max-width: 1280px;
}

.faq-layout {
    align-items: start;
    display: grid;
    gap: clamp(2rem, 5vw, 4rem);
    grid-template-columns: minmax(0, 1fr) minmax(280px, .42fr);
    margin-top: 2rem;
}

.faq-list {
    display: grid;
    gap: 1rem;
}

.faq-list details {
    padding: 0;
}

.faq-list summary {
    color: var(--soter-navy);
    cursor: pointer;
    font-weight: 900;
    padding: 1.2rem 1.35rem;
}

.faq-list details > p {
    color: var(--soter-text-mid);
    margin: 0;
    padding: 0 1.35rem 1rem;
}

.faq-aside {
    display: grid;
    gap: 1rem;
    position: sticky;
    top: 7rem;
}

.faq-aside img {
    background: #ffffff;
    border: 1px solid var(--soter-line);
    border-radius: var(--soter-radius-lg);
    box-shadow: var(--soter-shadow-md);
    display: block;
    width: 100%;
}

.content-item.purchase-page {
    background: linear-gradient(135deg, #eef5ff 0%, #ffffff 100%);
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 5rem);
    width: 100vw;
}

.content-item.purchase-page .soter-contact-grid {
    margin-left: auto;
    margin-right: auto;
    max-width: 1280px;
}

.content-item.purchase-page .contact-copy h1 {
    color: var(--soter-navy);
    font-size: clamp(2.25rem, 5vw, 4.75rem);
    line-height: .98;
    margin-bottom: 1rem;
}

.content-item.purchase-page .contact-copy > p:first-of-type {
    color: var(--soter-text-mid);
    font-size: clamp(1.08rem, 2vw, 1.3rem);
    max-width: 720px;
}

.purchase-image-card {
    background: #ffffff;
    border: 1px solid var(--soter-line);
    border-radius: var(--soter-radius-lg);
    box-shadow: var(--soter-shadow-md);
    margin: 1.5rem 0 2rem;
    max-width: 640px;
    overflow: hidden;
    padding: .75rem;
}

.purchase-image-card img {
    border-radius: calc(var(--soter-radius-lg) - .5rem);
    display: block;
    height: auto;
    width: 100%;
}

.terms-panel {
    background: rgba(255, 255, 255, .78);
    border: 1px solid var(--soter-line);
    border-radius: var(--soter-radius);
    display: grid;
    gap: .8rem;
    margin-top: 1.5rem;
    padding: clamp(1.1rem, 3vw, 1.5rem);
}

.terms-panel-wide {
    margin: 2rem auto 0;
    max-width: 1280px;
}

.terms-panel p {
    color: var(--soter-text-muted);
    margin: 0;
}

.content-item.about-page .about-image-card {
    background: #ffffff;
    border: 1px solid var(--soter-line);
    border-radius: var(--soter-radius-lg);
    box-shadow: var(--soter-shadow-md);
    margin: 2rem auto;
    max-width: 980px;
    overflow: hidden;
    padding: .75rem;
}

.content-item.about-page .about-image-card:first-of-type {
    float: right;
    margin: 0 0 1.25rem 2rem;
    max-width: min(42vw, 420px);
}

.about-image-card img {
    border-radius: calc(var(--soter-radius-lg) - .5rem);
    display: block;
    height: auto;
    width: 100%;
}

.content-item.partnerships-page {
    background:
        linear-gradient(rgba(255, 255, 255, .78), rgba(255, 255, 255, .82)),
        url("/images/Care.001.jpeg") center / cover no-repeat;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding: clamp(3rem, 7vw, 6rem) clamp(1.25rem, 5vw, 5rem);
    width: 100vw;
}

.partnership-matrix {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 2rem auto;
}

.partnership-card {
    background: rgba(255, 255, 255, .9);
    border: 1px solid rgba(21, 91, 209, .16);
    border-radius: var(--soter-radius);
    box-shadow: var(--soter-shadow-sm);
    padding: clamp(1.25rem, 3vw, 1.75rem);
}

.partnership-icon {
    align-items: center;
    background: #eef5ff;
    border-radius: 1rem;
    color: var(--soter-blue);
    display: inline-flex;
    font-size: 1.4rem;
    height: 3rem;
    justify-content: center;
    margin-bottom: 1rem;
    width: 3rem;
}

.partnership-card h3 {
    color: var(--soter-navy);
    margin: 0 0 .5rem;
}

.partnership-card p {
    color: var(--soter-text-mid);
    margin: 0;
}

.families-lead-grid {
    align-items: center;
    display: grid;
    gap: clamp(2rem, 5vw, 4rem);
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
    margin: 1.5rem auto 3rem;
    max-width: 1280px;
}

.families-lead-copy p {
    color: var(--soter-text-mid);
    font-size: clamp(1.02rem, 1.6vw, 1.16rem);
}

.families-image-stack {
    display: grid;
    gap: 1rem;
}

.families-image-card {
    background: rgba(255, 255, 255, .78);
    border: 1px solid rgba(21, 91, 209, .16);
    border-radius: var(--soter-radius-lg);
    box-shadow: var(--soter-shadow-md);
    margin: 0;
    overflow: hidden;
    padding: .75rem;
}

.families-image-card img {
    border-radius: calc(var(--soter-radius-lg) - .5rem);
    display: block;
    height: auto;
    width: 100%;
}

.soter-video,
.families-video {
    display: block;
    margin: 1rem auto 2rem;
    max-width: 1280px;
    width: 100%;
}

.families-cta-row {
    margin-top: 1.5rem;
}

body.reveal-enabled .reveal-section {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .65s ease, transform .65s ease;
    will-change: opacity, transform;
}

body.reveal-enabled .reveal-section.is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
    body.reveal-enabled .reveal-section {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

@media (max-width: 980px) {
    .modular-features.standard .columns,
    .modular-features.small .columns,
    .modular-features.soter-how .columns,
    .persona-grid,
    .pricing-grid,
    .reassurance-grid,
    .hero-layout,
    .soter-contact-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .modular-features.soter-how .column:nth-child(2)::after {
        display: none;
    }
}

@media (max-width: 720px) {
    .section,
    .modular-hero,
    .reassurance {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    .navbar-brand img {
        max-height: 60px;
    }

    .soter-footer .container {
        align-items: flex-start;
        grid-template-columns: 1fr;
    }

    .soter-footer__brand {
        justify-self: start;
        text-align: left;
    }

    .soter-footer__brand img {
        margin-left: 0;
    }

    .soter-footer__address {
        justify-self: start;
        text-align: left;
    }

    .families-lead-grid {
        grid-template-columns: 1fr;
    }

    .families-image-card {
        max-width: 520px;
    }

    .partnership-matrix {
        grid-template-columns: 1fr;
    }

    .faq-layout {
        grid-template-columns: 1fr;
    }

    .faq-aside {
        position: static;
    }

    .content-item.about-page .about-image-card:first-of-type {
        float: none;
        margin: 1.5rem auto;
        max-width: 100%;
    }

    .modular-features.standard .columns,
    .modular-features.small .columns,
    .modular-features.soter-how .columns,
    .persona-grid,
    .pricing-grid,
    .reassurance-grid,
    .hero-layout,
    .soter-contact-grid,
    .field-row {
        grid-template-columns: 1fr;
    }

    .hero-visual-card {
        justify-self: start;
        max-width: 360px;
    }

    .modular-hero p:last-child a:last-child {
        margin-left: 0;
        margin-top: .75rem;
    }

    .modular-features.soter-how .columns {
        gap: 2.25rem;
    }

    .modular-features.soter-how .column:not(:last-child)::after {
        top: auto;
        right: 50%;
        bottom: -1.55rem;
        display: block;
        transform: translateX(50%) rotate(90deg);
    }

    .persona-header,
    .persona-body,
    .pricing-card {
        padding: 1.35rem;
    }
}
