/* ============================================================
   BespokeLMS — Solutions Pages (overview + detail)
   solutions.css
   ============================================================ */

/* ── Solutions Hero ───────────────────────────────────────── */
.solutions-hero {
    padding: var(--space-8) 0 var(--space-16);
    background: linear-gradient(160deg, var(--surface-primary) 60%, var(--surface-secondary) 100%);
    border-bottom: var(--border-width-base) solid var(--border-subtle);
    text-align: left;
}

.solutions-hero__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
}

.solutions-hero__eyebrow {
    margin-bottom: var(--space-4);
}

.solutions-hero__title {
    font-size: clamp(2rem, 4.5vw, 3rem);
    line-height: var(--line-height-tight);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    margin-bottom: var(--space-5);
}

.solutions-hero__lead {
    font-size: var(--font-size-lg);;
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-8);
    max-width: var(--layout-sm);
}

.solutions-hero__actions {
    display: flex;
    gap: var(--space-3);
    flex-wrap: wrap;
}

.solutions-hero__trust {
    margin-top: var(--space-5);
    max-width: var(--layout-sm);
}

.solutions-hero__trust-text {
    font-size: var(--font-size-md);;
    color: var(--text-secondary);
    line-height: var(--line-height-normal);
    margin: 0;
    opacity: var(--opacity-90);
}

.solutions-hero__visual {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.solutions-hero__cards {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    width: 100%;
    max-width: 400px;
    margin-left: auto;
}

.solutions-hero__mockup {
    width: 100%;
    max-width: var(--layout-sm);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-raised);
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
    overflow: hidden;
    aspect-ratio: 4/3;
    display: flex;
    align-items: center;
    justify-content: center;
}

.solutions-hero__illustration {
    width: 100%;
    max-width: var(--layout-sm);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-raised);
    display: block;
    height: auto;
}

/* ── Who You Are cards ────────────────────────────────────── */
.solutions-who {
    padding: var(--space-16) 0;
}

.solutions-who__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-10);
}

.sol-card {
    background: var(--card-background);
    border: var(--border-width-base) solid var(--card-border);
    border-radius: var(--card-radius);
    padding: var(--space-7);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.sol-card--compact {
    padding: var(--space-5);
}

\.sol-card:hover {
    box-shadow: var(--shadow-raised);
    transform: translateY(-4px);
    border-color: var(--color-border-hovered);
}

.sol-card__icon {
    width: var(--space-10);
    height: var(--space-10);
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, hsl(174 60% 90%), hsl(174 60% 82%));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-link);
    flex-shrink: 0;
}

.sol-card__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-heading);
    margin: 0;
}

.sol-card__body {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
    flex: 1;
}

.sol-card__standout {
    font-size: var(--font-size-xs);;
    font-weight: var(--font-weight-semibold);
    color: var(--text-link);
    background: hsl(174 60% 95%);
    border-radius: var(--radius-base);
    padding: var(--space-2) var(--space-3);
    margin: 0;
}

.sol-card__link {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-link);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    margin-top: var(--space-2);
    transition: gap var(--transition-fast);
}

.sol-card:hover .sol-card__link { gap: var(--space-2); text-decoration: none; }
.sol-card__link::after { display: none !important; }

/* ── What You're Delivering grid (image cards — matches homepage style) ─── */
.solutions-what {
    padding: var(--space-16) 0;
}

.solutions-what__grid--cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-5);
    margin-top: var(--space-8);
}

/* ── Solutions Layout (Left Rail) ─────────────────────────── */
.solutions-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-12);
    padding: var(--space-16) 0;
}

@media (min-width: 900px) {
    .solutions-layout {
        grid-template-columns: 280px 1fr;
        gap: var(--space-16);
    }
}

.solutions-layout__sidebar {
    display: none;
}

@media (min-width: 900px) {
    .solutions-layout__sidebar {
        display: block;
        position: sticky;
        top: 120px; /* Below nav */
        height: max-content;
    }
}

.solutions-nav {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.solutions-nav__link {
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-base);
    color: var(--text-secondary);
    font-weight: var(--font-weight-medium);
    text-decoration: none;
    transition: background var(--transition-base), color var(--transition-base);
}

.solutions-nav__link:hover, .solutions-nav__link[aria-current="true"] {
    background: var(--surface-secondary);
    color: var(--text-primary);
    text-decoration: none;
}

.solutions-layout__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-20);
}

.solutions-content-section {
    scroll-margin-top: 140px;
}

/* Cross Audience Pill */
.cross-audience-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
    background: var(--surface-secondary);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-full);
    margin-top: var(--space-4);
    width: max-content;
}

/* ── Card (shared with homepage) ──────────────────────────────────────────── */
.solutions-grid__card {
    display: flex;
    flex-direction: column;
    border-radius: var(--card-radius);
    overflow: hidden;
    border: var(--border-width-base) solid var(--border-default);
    background: var(--card-background);
    text-decoration: none;
    color: inherit;
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
    box-shadow: var(--card-shadow);
    height: 100%;
}

\.solutions-grid__card:hover {
    box-shadow: var(--shadow-raised);
    transform: translateY(-4px);
    border-color: var(--color-border-hovered);
}

.solutions-grid__card::after { display: none !important; }

/* Image area */
.solutions-grid__image-wrap {
    aspect-ratio: 3 / 2;
    overflow: hidden;
    background: var(--surface-secondary);
    flex-shrink: 0;
}

.solutions-grid__image-wrap--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--surface-secondary), var(--surface-secondary));
}

.solutions-grid__placeholder-icon {
    color: var(--text-link);
    opacity: var(--opacity-50);
}

.solutions-grid__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--duration-400) ease;
}

.solutions-grid__card:hover .solutions-grid__image {
    transform: scale(1.04);
}

/* Body */
.solutions-grid__body {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    padding: var(--space-5) var(--space-5) var(--space-6);
    flex: 1;
}

.solutions-grid__label {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
    margin: 0;
    letter-spacing: var(--letter-spacing-normal);
}

.solutions-grid__desc {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
    flex: 1;
}

.solutions-grid__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-link);
    margin-top: var(--space-2);
    opacity: 0;
    transform: translateX(-4px);
    transition: opacity var(--transition-base), transform var(--transition-base);
}

.solutions-grid__card:hover .solutions-grid__link {
    opacity: 1;
    transform: translateX(0);
}

.solutions-grid__link--mt-auto {
    margin-top: auto;
}

/* Dark mode */

/* Responsive */
@media (max-width: 900px) {
    .solutions-what__grid--cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .solutions-what__grid--cards {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }

    .solutions-grid__link {
        opacity: 1;
        transform: none;
    }
}


.sol-what-card {
    background: var(--card-background);
    border: var(--border-width-base) solid var(--card-border);
    border-radius: var(--card-radius);
    padding: var(--space-7);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    height: 100%;
}

/* full 5-item row — last two items span to avoid orphan */
.solutions-what__grid .sol-what-card:nth-child(4) {
    grid-column: 1;
}

.sol-what-card__icon {
    width: var(--space-10);
    height: var(--space-10);
    border-radius: var(--radius-lg);
    background: var(--surface-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-link);
}

.sol-what-card__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-heading);
    margin: 0;
}

.sol-what-card__body {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    flex: 1;
    margin: 0;
}

.sol-what-card__feature {
    font-size: var(--font-size-xs);;
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
    border-top: var(--border-width-base) solid var(--border-default);
    padding-top: var(--space-3);
    margin-top: var(--space-2);
}

.sol-what-card__link {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-link);
    text-decoration: none;
}
.sol-what-card__link:hover { text-decoration: none; opacity: var(--opacity-80); }
.sol-what-card__link::after { display: none !important; }

/* ── Stats bar ────────────────────────────────────────────── */
.stats-bar {
    padding: var(--space-12) 0;
}

.stats-bar__inner {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 0;
}

.stats-bar__item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-4) var(--space-8);
    border-right: var(--border-width-base) solid var(--border-default);
}

.stats-bar__item:last-child { border-right: none; }

.stats-bar__number {
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: var(--font-weight-bold);
    color: var(--text-link);
    line-height: var(--line-height-none);
    display: block;
    margin-bottom: var(--space-2);
}

.stats-bar__label {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-normal);
}

/* ── Pain points & Benefits (detail pages) ───────────────────────────── */
#how-it-works,
.solutions-problem,
.solutions-benefits {
    padding: var(--space-16) 0;
}

.solutions-problem__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(Min(100%, 300px), 1fr));
    gap: var(--space-6);
    margin-top: var(--space-10);
}

.solutions-benefits__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(Min(100%, 300px), 1fr));
    gap: var(--space-6);
}

.pain-card {
    background: var(--card-background);
    border: var(--border-width-base) solid var(--card-border);
    border-radius: var(--card-radius);
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    transition: transform var(--transition-slow), box-shadow var(--transition-slow);
    height: 100%;
}

\.pain-card:hover {
    box-shadow: var(--shadow-raised);
    transform: translateY(-4px);
    border-color: var(--color-border-hovered);
}

.pain-card__icon {
    width: var(--space-10);
    height: var(--space-10);
    border-radius: var(--radius-lg);
    background: var(--surface-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
}


.pain-card__title {
    font-size: var(--font-size-md);;
    font-weight: var(--font-weight-semibold);
    color: var(--color-heading);
    margin: 0;
}

.pain-card__body {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

/* ── Feature rows (detail pages) ─────────────────────────── */
.solutions-features {
    padding: var(--space-16) 0;
}

.solutions-features__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-6);
    margin-top: var(--space-10);
}

.solutions-features__item {
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-default);
    border-radius: var(--radius-xl);
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.solutions-features__item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-raised);
}

.solutions-features__icon {
    width: var(--space-10);
    height: var(--space-10);
    border-radius: var(--radius-lg);
    background: var(--surface-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    flex-shrink: 0;
}

.solutions-features__heading {
    display: block;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-heading);
    margin-bottom: var(--space-2);
}

.solutions-features__body {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

.feature-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
    padding: var(--space-10) 0;
    border-bottom: var(--border-width-base) solid var(--border-subtle);
}

.feature-row:last-child { border-bottom: none; }

.feature-row--reverse { direction: rtl; }
.feature-row--reverse > * { direction: ltr; }

.feature-row__visual {
    background: var(--surface-secondary);
    border: var(--border-width-base) solid var(--border-subtle);
    border-radius: var(--radius-xl);
    aspect-ratio: 4/3;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
    overflow: hidden;
}

/* Ensure placeholder SVG icons render properly */
.feature-row__visual svg {
    width: 40px;
    height: 40px;
    opacity: 0.4;
}


.feature-row__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
    margin: 0 0 var(--space-4);
}

.feature-row__body {
    font-size: var(--font-size-md);;
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--space-5);
}

.feature-row__bullets {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.feature-row__bullets li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    font-size: var(--font-size-sm);
    color: var(--text-primary);
}

.feature-row__bullets li::before {
    content: '✓';
    color: var(--text-secondary);
    font-weight: var(--font-weight-bold);
    flex-shrink: 0;
    margin-top: 1px;
}

/* ── How It Works ─────────────────────────────────────────── */
.solutions-how__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-8);
    margin-top: var(--space-8);
}

/* ── Vertical Timeline Layout ── */
.solutions-how__timeline {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    max-width: var(--layout-md);
    margin: var(--space-10) auto 0;
    position: relative;
    text-align: left;
}

.solutions-how__timeline::before {
    content: '';
    position: absolute;
    top: var(--space-4);
    bottom: var(--space-7);
    left: 19px; /* Centered on the var(--space-10) number disc */
    width: 2px;
    background: var(--surface-secondary);
    z-index: var(--z-index-base);
}

.solutions-how__timeline-item {
    display: flex;
    gap: var(--space-6);
    position: relative;
    z-index: var(--z-index-base);
}

.solutions-how__timeline-marker {
    flex-shrink: 0;
    padding: 0;
}

.solutions-how__timeline-content {
    padding-top: var(--space-2); /* visually align text block natively with the centered disc */
}

@media (max-width: 768px) {
    .solutions-how__timeline {
        gap: var(--space-7);
        margin-top: var(--space-8);
    }
    .solutions-how__timeline::before {
        left: 15px; /* Centered on the natively scaling var(--space-8) mobile disc */
    }
    .solutions-how__timeline-item {
        gap: var(--space-4);
    }
}

.solutions-how__timeline .solutions-how__heading {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
    margin: 0 0 var(--space-2);
}

.solutions-how__timeline .solutions-how__body {
    margin-left: 0; /* Overrides the calc(var(--space-8) + space-3) from the grid layout */
}

.solutions-how__title {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
    margin: 0 0 var(--space-3);
}

.solutions-how__number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--space-8);
    height: var(--space-8);
    background: var(--color-bg-brand-hovered);
    color: var(--text-inverse);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    flex-shrink: 0;
    margin-top: 2px;
}

.solutions-how__heading {
    flex: 1;
}

.solutions-how__body {
    font-size: var(--font-size-md);;
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0 0 0 calc(var(--space-8) + var(--space-3));
}

/* ── Feature icon grid (6-up) ─────────────────────────────── */
.solutions-grid {
    padding: var(--space-16) 0;
}

.solutions-grid__cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(Min(100%, 300px), 1fr));
    gap: var(--space-5);
    margin-top: var(--space-10);
}

.feat-chip {
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
}

.feat-chip__icon {
    width: var(--space-8);
    height: var(--space-8);
    border-radius: var(--radius-base);
    background: var(--surface-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-link);
    flex-shrink: 0;
}

.feat-chip__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
}

/* ── Social proof ─────────────────────────────────────────── */
.solutions-proof {
    padding: var(--space-16) 0;
}

.solutions-proof__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
}

.sol-quote {
    background: var(--surface-secondary);
    border-left: var(--border-width-2xl) solid var(--border-focus);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
}

.sol-quote__text {
    font-size: var(--font-size-lg);
    font-style: italic;
    color: var(--color-heading);
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--space-5);
}

.sol-quote__attribution {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
}

.sol-outcomes {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.sol-outcome {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-5);
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
    border-radius: var(--radius-lg);
}

.sol-outcome__icon {
    color: var(--text-link);
    flex-shrink: 0;
    margin-top: 2px;
}

.sol-outcome__text {
    font-size: var(--font-size-sm);
    color: var(--text-primary);
    line-height: var(--line-height-normal);
}

/* ── Related solutions ────────────────────────────────────── */
.solutions-related {
    padding: var(--space-16) 0;
}

.solutions-related__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-10);
}

.related-card {
    background: var(--card-background);
    border: var(--border-width-base) solid var(--card-border);
    border-radius: var(--card-radius);
    padding: var(--space-6);
    text-decoration: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
    color: inherit;
    height: 100%;
}

\.related-card:hover {
    box-shadow: var(--shadow-raised);
    transform: translateY(-4px);
    border-color: var(--color-border-hovered);
}

.related-card::after { display: none !important; }

.related-card__icon {
    width: var(--space-10);
    height: var(--space-10);
    border-radius: var(--radius-lg);
    background: var(--surface-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-link);
}

.related-card__title {
    font-size: var(--font-size-md);;
    font-weight: var(--font-weight-semibold);
    color: var(--color-heading);
    margin: 0;
}

.related-card__body {
    font-size: var(--font-size-sm);;
    color: var(--text-secondary);
    line-height: var(--line-height-normal);
    flex: 1;
    margin: 0;
}

.related-card__cta {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-interactive-default);
    display: flex;
    align-items: center;
    gap: var(--space-1);
    transition: gap var(--transition-fast);
}

.related-card:hover .related-card__cta {
    gap: var(--space-2);
}

/* ── Bottom CTA (teal panel variant) ─────────────────────── */
.solutions-cta {
    padding: var(--space-16) 0;
    background: linear-gradient(135deg, hsl(174 60% 28%), hsl(174 60% 20%));
    text-align: center;
}

.solutions-cta__title {
    font-size: clamp(1.5rem, 3vw, 2rem);
    font-weight: var(--font-weight-bold);
    color: var(--text-inverse);
    margin: 0 0 var(--space-4);
}

.solutions-cta__body {
    font-size: var(--font-size-md);
    color: var(--text-inverse);
    line-height: var(--line-height-relaxed);
    margin: 0 auto var(--space-8);
    max-width: var(--layout-sm);
}

.solutions-cta__actions {
    display: flex;
    gap: var(--space-3);
    justify-content: center;
    flex-wrap: wrap;
}

.btn--white {
    background: var(--surface-primary);
    color: hsl(174 60% 22%);
    border: none;
}

.btn--white:hover {
    background: var(--surface-primary);
    color: hsl(174 60% 18%);
}

.btn--outline-white {
    background: transparent;
    color: var(--text-inverse);
    border: var(--border-width-lg) solid var(--border-subtle);
}

.btn--outline-white:hover {
    background: var(--surface-secondary);
    border-color: var(--border-subtle);
    color: var(--text-inverse);
}

/* ── FAQ (reuse homepage pattern) ────────────────────────── */
.solutions-faq {
    padding: var(--space-16) 0;
}

/* ── Solutions hero breadcrumb ───────────────────────────── */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--font-size-sm);;
    color: var(--text-secondary);
    margin-bottom: var(--space-6);
}

.breadcrumb a {
    color: var(--text-secondary);
    text-decoration: none;
}
.breadcrumb a:hover { color: var(--text-link); text-decoration: none; }
.breadcrumb a::after { display: none !important; }
.breadcrumb__sep { opacity: var(--opacity-40); }
.breadcrumb__current { color: var(--text-primary); }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
    .solutions-who__grid { grid-template-columns: repeat(2, 1fr); }
    .solutions-what__grid { grid-template-columns: repeat(2, 1fr); }
    .solutions-hero__inner { 
        grid-template-columns: 1fr; 
        gap: var(--space-10);
    }
    .solutions-hero__visual { 
        justify-content: center; 
        margin-top: var(--space-4);
    }
    .solutions-hero__mockup {
        max-width: var(--layout-md);
    }
    .solutions-proof__inner { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .solutions-who__grid { grid-template-columns: 1fr; }
    .solutions-what__grid { grid-template-columns: 1fr; }
    .solutions-grid__cards { grid-template-columns: repeat(2, 1fr); }
    .solutions-related__grid { grid-template-columns: 1fr; }
    .solutions-problem__grid { grid-template-columns: 1fr; }
    .solutions-benefits__grid { grid-template-columns: 1fr; }
    .feature-row { grid-template-columns: 1fr; gap: var(--space-6); }
    .feature-row--reverse { direction: ltr; }
    .feature-row__visual { display: none; }
    .stats-bar__inner { flex-direction: column; }
    .stats-bar__item { border-right: none; border-bottom: var(--border-width-base) solid var(--border-subtle); padding: var(--space-6); }
    .stats-bar__item:last-child { border-bottom: none; }
}

@media (max-width: 480px) {
    .solutions-grid__cards { grid-template-columns: 1fr; }
}

/* —— Hero image (replaces placeholder mockup) ———————————————————————————— */
.solutions-hero__mockup img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* —— Testimonial ————————————————————————————————————————————————————————— */
.testimonial-section {
    padding-block: var(--space-16);
}

.testimonial {
    max-width: var(--max-width-prose);
    margin-inline: auto;
    text-align: center;
    padding: var(--space-12) var(--space-8);
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
    border-radius: var(--radius-xl);
    box-shadow: var(--card-shadow);
}

.testimonial__mark {
    color: var(--text-link);
    opacity: var(--opacity-30);
    margin-inline: auto;
    margin-bottom: var(--space-6);
    display: block;
}

.testimonial__quote {
    margin: 0 0 var(--space-6);
}

.testimonial__quote p {
    font-size: clamp(1.1rem, 2.5vw, 1.25rem);
    font-style: italic;
    line-height: var(--line-height-relaxed);
    color: var(--text-primary);
}

.testimonial__attribution {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.testimonial__name {
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    color: var(--text-primary);
}

.testimonial__role {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}


/* ==========================================================================
   Responsive — Solutions Pages
   ========================================================================== */

/* ── Solutions hero: stack to 1-col at ≤768px ──────────────────────────── */
@media (max-width: 768px) {
    .solutions-hero__inner {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    /* Stack the visual gracefully instead of hiding it */
    .solutions-hero__visual {
        margin-top: var(--space-2);
    }

    .solutions-hero {
        padding: var(--space-6) 0 var(--space-12);
    }

    .solutions-who__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .solutions-delivering__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Compress vertical rhythm on mobile to avoid massive empty gaps between sections */
    .solutions-who,
    .solutions-what,
    #how-it-works,
    .solutions-problem,
    .solutions-benefits,
    .solutions-features,
    .solutions-grid,
    .solutions-proof,
    .solutions-related,
    .solutions-faq,
    .testimonial-section {
        padding: var(--space-10) 0;
    }
}

@media (max-width: 480px) {
    .solutions-hero__title {
        font-size: var(--font-size-2xl);
    }

    .solutions-who__grid,
    .solutions-delivering__grid {
        grid-template-columns: 1fr;
    }

    .solutions-hero__actions {
        flex-direction: column;
    }

    .solutions-hero__actions .btn {
        width: 100%;
        text-align: center;
        justify-content: center;
    }
}

/* ── Benefits Quote ─────────────────────────────────────────── */
.benefits-quote {
    font-size: var(--font-size-lg);
    font-style: italic;
    color: var(--text-secondary);
    max-width: var(--layout-md);
    margin: var(--space-12) auto 0;
    padding: var(--space-6);
    border-left: var(--border-width-2xl) solid var(--border-focus);
    background: var(--surface-primary);
    border-radius: var(--radius-xl);
    text-align: center;
}

/* ── Testimonial Carousel Enhancements ────────────────────── */
.testimonial-carousel {
    display: flex;
    gap: var(--space-6);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    padding-bottom: var(--space-6); /* Room for shadows */
    padding-inline: max(var(--space-4), calc(50% - 340px)); /* Centers the 680px card dynamically inside the container */
    scrollbar-width: none; 
    -ms-overflow-style: none;
}
.testimonial-carousel::-webkit-scrollbar {
    display: none;
}
.testimonial--card {
    flex: 0 0 85%;
    max-width: var(--max-width-prose);
    scroll-snap-align: center;
    margin-inline: 0;
    transition: opacity var(--duration-500) ease, filter 0.5s ease, transform 0.5s ease;
}

@media (min-width: 768px) {
    .testimonial--card {
        flex: 0 0 70%;
    }
    .testimonial-carousel .testimonial--card:not(.is-active) {
        opacity: var(--opacity-40);
        filter: grayscale(100%);
        transform: scale(0.96);
        pointer-events: none; /* Prevent interacting with background cards */
    }
    .testimonial-carousel .testimonial--card.is-active {
        opacity: 1;
        filter: grayscale(0);
        transform: scale(1);
        pointer-events: auto;
    }
}
@media (min-width: 1024px) {
    .testimonial--card {
        flex: 0 0 680px;
    }
}
