/* ==========================================================================
   Home page â€” page-specific styles (Salix-style redesign)
   ========================================================================== */

/* â”€â”€ Hero â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hero {
    padding-top: var(--space-20);
    padding-bottom: 0;
    text-align: center;
    overflow: hidden;
}

.hero__inner {
    max-width: var(--layout-md);
    margin-inline: auto;
    padding-inline: var(--gutter);
}

.hero__badge {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    font-size: var(--font-size-xs);;
    /* 11px */
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-normal).08em;
    text-transform: uppercase;
    color: var(--text-muted);
    background: var(--color-badge-bg);
    border-radius: var(--radius-full);
    margin-bottom: var(--space-3);
}


.hero__headline {
    font-size: clamp(2.5rem, 5vw, var(--font-size-4xl));
    font-weight: var(--font-weight-medium);
    /* Salix Landing v1 measured: exactly 500 */
    letter-spacing: var(--letter-spacing-tighter);
    line-height: var(--line-height-tight);
    /* Salix measured: 70.4px / 64px = 1.1 */
    color: var(--text-primary);
    margin-bottom: var(--space-4);
}

.hero__subheadline {
    font-size: var(--font-size-md);
    /* 16px â€” matches Salix subheadline */
    font-weight: var(--font-weight-medium);
    color: var(--text-secondary);
    margin-bottom: var(--space-8);
    line-height: var(--line-height-relaxed);
    max-width: 48ch;
    margin-inline: auto;
}

.hero__actions {
    display: flex;
    gap: var(--space-3);
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: var(--space-6);
}

.hero__footnote {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    opacity: var(--opacity-60);
    margin-bottom: var(--space-16);
}

/* Secondary CTA — plain text link, subordinate to the primary button */
.hero__text-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-medium);
    color: var(--text-primary);
    text-decoration: none;
    opacity: var(--opacity-70);
    transition: opacity var(--transition-base);
}

.hero__text-link:hover {
    opacity: 1;
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* â”€â”€ Hero App Mockup Panel â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hero__mockup-wrap {
    max-width: var(--layout-lg);
    margin-inline: auto;
    padding-inline: var(--gutter);
    position: relative;
    /* transform is controlled exclusively by scroll-animations.js.
       transition provides the smooth easing (replaces the old lerp loop). */
    transform-origin: top center;
    transition: transform var(--transition-base)-out;
    will-change: transform;
}

/* Subtle gradient fade at the bottom of the mockup â€” covers bottom ~15-20% only */
.hero__mockup-wrap::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: var(--space-20);
    background: linear-gradient(to bottom, transparent 0%, var(--surface-primary) 100%);
    pointer-events: none;
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

.hero__app {
    background: var(--surface-primary);
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    box-shadow: var(--shadow-modal);
    overflow: hidden;
    border: var(--border-width-base) solid var(--border-subtle);
    border-bottom: none;
}

/* App chrome bar */
.app__chrome {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    background: var(--surface-primary);
    border-bottom: var(--border-width-base) solid var(--border-subtle);
}

.app__dot {
    width: var(--space-3);
    height: var(--space-3);
    border-radius: 50%;
    background: var(--surface-secondary);
}

/* App layout */
.app__body {
    display: flex;
    min-height: 380px;
}

.app__sidebar {
    width: 180px;
    background: var(--surface-inverse);
    padding: var(--space-5) var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    flex-shrink: 0;
}

.app__sidebar-logo {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    color: var(--text-inverse);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    letter-spacing: var(--letter-spacing-tight);
    margin-bottom: var(--space-5);
    padding-inline: var(--space-2);
}

.app__sidebar-logo-icon {
    width: var(--space-6);
    height: var(--space-6);
    background: var(--accent-primary);
    border-radius: var(--radius-base);
    flex-shrink: 0;
}

.app__nav-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2);
    border-radius: var(--radius-base);
    color: var(--text-secondary);
    font-size: var(--font-size-xs);;
}

.app__nav-item--active {
    background: var(--color-badge-bg);
    color: var(--text-primary);
}

.app__nav-icon {
    width: var(--space-3);
    height: var(--space-3);
    background: currentColor;
    border-radius: var(--radius-sm);
    opacity: var(--opacity-60);
    flex-shrink: 0;
}

.app__nav-label {
    height: var(--space-2);
    flex: 1;
    background: currentColor;
    border-radius: var(--radius-sm);
    opacity: var(--opacity-50);
}

.app__main {
    flex: 1;
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    background: var(--surface-secondary);
}

.app__main-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-1);
}

.app__heading-block {
    height: var(--space-4);
    width: 160px;
    background: var(--surface-inverse);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-10);
}

.app__user-block {
    width: var(--space-8);
    height: var(--space-8);
    border-radius: 50%;
    background: var(--accent-primary);
    opacity: var(--opacity-60);
}

.app__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
}

.app__stat {
    background: var(--surface-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-3);
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
}

.app__stat-label {
    height: var(--space-2);
    width: 60%;
    background: var(--color-bg-brand-hovered);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-10);
    margin-bottom: var(--space-2);
}

.app__stat-value {
    height: var(--space-4);
    width: 80%;
    background: var(--surface-inverse);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-10);
    margin-bottom: var(--space-2);
}

.app__stat-trend {
    height: var(--space-2);
    width: 40%;
    border-radius: var(--radius-sm);
    opacity: var(--opacity-50);
}

.app__stat--up .app__stat-trend {
    background: var(--color-bg-success-default);
}

.app__stat--down .app__stat-trend {
    background: var(--feedback-error);
}

.app__sparkline {
    height: var(--space-8);
    width: 100%;
    border-radius: var(--radius-sm);
    background: linear-gradient(to right, var(--color-teal-10), transparent);
    margin-top: var(--space-2);
}

.app__chart {
    background: var(--surface-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    box-shadow: var(--shadow-sm);
}

.app__chart-header {
    height: var(--space-3);
    width: 30%;
    background: var(--surface-inverse);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-10);
    margin-bottom: var(--space-4);
}

.app__chart-bars {
    display: flex;
    align-items: flex-end;
    gap: var(--space-2);
    height: var(--space-16);
}

.app__bar {
    flex: 1;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    background: var(--color-navy-10);
}

.app__bar--active {
    background: var(--accent-primary);
    opacity: var(--opacity-60);
}

/* â”€â”€ Social Proof Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.proof-bar {
    padding-block: var(--space-12);
}

.proof-bar .container {
    display: flex;
    align-items: center;
    gap: var(--space-8);
    justify-content: center;
}

.proof-bar__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--text-secondary);
    opacity: var(--opacity-60);
    white-space: nowrap;
}

.proof-bar__divider {
    width: 1px;
    height: var(--space-5);
    background: var(--surface-secondary);
    flex-shrink: 0;
}

.proof-bar__logos {
    display: flex;
    align-items: center;
    gap: var(--space-8);
    flex-wrap: wrap;
    justify-content: center;
}

.proof-logo {
    width: var(--space-20);
    height: var(--space-5);
    background: var(--color-bg-brand-hovered);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-10);
}

/* â”€â”€ Features Section â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
    margin-bottom: var(--space-6);
}

.feature-card {
    background: var(--card-background);
    border: var(--border-width-base) solid var(--card-border);
    border-radius: var(--card-radius);
    overflow: hidden;
    transition: box-shadow var(--transition-slow), transform var(--transition-slow);
}

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

.feature-card__preview {
    height: 180px;
    background: var(--card-background);
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: var(--border-width-base) solid var(--border-subtle);
    overflow: hidden;
    position: relative;
}

/* Mini UI previews inside feature cards */
.mini-ui {
    width: 80%;
    background: var(--surface-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-3);
    box-shadow: var(--card-shadow);
    border: var(--border-width-base) solid var(--border-subtle);
}

.mini-ui__row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) 0;
    border-bottom: var(--border-width-base) solid var(--border-subtle);
}

.mini-ui__row:last-child {
    border-bottom: none;
}

.mini-ui__avatar {
    width: var(--space-6);
    height: var(--space-6);
    border-radius: 50%;
    background: var(--color-teal-20);
    flex-shrink: 0;
}

.mini-ui__line {
    flex: 1;
    height: var(--space-2);
    background: var(--surface-secondary);
    border-radius: var(--radius-sm);
}

.mini-ui__tag {
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    flex-shrink: 0;
}

.mini-ui__tag--green {
    background: var(--color-success);
    color: var(--color-text-success);
}

.mini-ui__tag--amber {
    background: var(--color-warning);
    color: var(--color-text-warning);
}

/* Token colour swatches mini-UI */
.mini-tokens {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-2);
    width: 70%;
}

.mini-token {
    height: var(--space-8);
    border-radius: var(--radius-base);
}

/* Subdomain mini-UI */
.mini-domains {
    width: 80%;
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.mini-domain {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    background: var(--surface-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-2) var(--space-3);
    border: var(--border-width-base) solid var(--border-subtle);
    box-shadow: var(--shadow-sm);
}

.mini-domain__dot {
    width: var(--space-2);
    height: var(--space-2);
    border-radius: 50%;
    flex-shrink: 0;
}

.mini-domain__line {
    flex: 1;
    height: var(--space-2);
    background: var(--surface-secondary);
    border-radius: var(--radius-sm);
}

.mini-domain__status {
    width: var(--space-10);
    height: var(--space-2);
    border-radius: var(--radius-sm);
    flex-shrink: 0;
}

.feature-card__body {
    padding: var(--space-6);
}

.feature-card__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin-bottom: var(--space-2);
}

.feature-card__text {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
}

/* â”€â”€ Tabbed Feature Detail â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.feature-detail {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: var(--space-12);
    align-items: start;
    margin-top: var(--space-6);
    background: var(--surface-primary);
    border-radius: var(--radius-2xl);
    padding: var(--space-10);
    border: var(--border-width-base) solid var(--border-subtle);
    box-shadow: var(--card-shadow);
}

.feature-tabs {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.feature-tab {
    display: block;
    padding: var(--space-4) var(--space-5);
    border-radius: var(--radius-lg);
    cursor: pointer;
    transition: background-color var(--transition-base);
    border-left: var(--border-width-lg) solid transparent;
}

.feature-tab__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--text-muted);
    margin-bottom: var(--space-1);
    transition: color var(--transition-base);
}

.feature-tab__desc {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    display: none;
}

.feature-tab.is-active {
    border-left-color: var(--border-focus);
    background: var(--surface-primary);
}

.feature-tab.is-active .feature-tab__title {
    color: var(--text-primary);
}

.feature-tab.is-active .feature-tab__desc {
    display: block;
}

.feature-panel {
    background: var(--surface-primary);
    border-radius: var(--radius-xl);
    overflow: hidden;
    aspect-ratio: 4/3;
    border: var(--border-width-base) solid var(--border-subtle);
    display: flex;
    align-items: center;
    justify-content: center;
}

.feature-panel__inner {
    width: 85%;
    background: var(--surface-primary);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-raised);
    border: var(--border-width-base) solid var(--border-subtle);
}

/* Panel variant A â€“ token editor */
.panel-tokens {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.panel-token-row {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.panel-token-swatch {
    width: var(--space-8);
    height: var(--space-8);
    border-radius: var(--radius-base);
    flex-shrink: 0;
}

.panel-token-name {
    flex: 1;
    height: var(--space-2);
    background: var(--surface-secondary);
    border-radius: var(--radius-sm);
}

.panel-token-value {
    width: var(--space-16);
    height: var(--space-2);
    background: var(--surface-primary);
    border-radius: var(--radius-sm);
    border: var(--border-width-base) solid var(--border-subtle);
}

/* Panel variant B â€“ progress */
.panel-progress {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.panel-progress-item {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.panel-progress-label {
    display: flex;
    justify-content: space-between;
}

.panel-progress-label-text {
    height: var(--space-2);
    width: 40%;
    background: var(--surface-secondary);
    border-radius: var(--radius-sm);
}

.panel-progress-label-pct {
    height: var(--space-2);
    width: var(--space-6);
    background: var(--accent-primary);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-50);
}

.panel-progress-track {
    height: var(--space-2);
    background: var(--surface-primary);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.panel-progress-fill {
    height: 100%;
    background: var(--accent-primary);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-60);
}

/* â”€â”€ Bento Stats / Testimonials â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.bento-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto auto;
    gap: var(--space-4);
}

.bento-cell {
    border-radius: var(--radius-xl);
    padding: var(--space-8);
    overflow: hidden;
}

/* Stat cell â€” red */
.bento-cell--stat-red {
    grid-column: span 3;
    background: var(--feedback-error);
    color: var(--text-inverse);
}

/* Quote cell â€” dark */
.bento-cell--quote-dark {
    grid-column: span 5;
    background: var(--surface-inverse);
    color: var(--text-inverse);
}

/* Stat cell â€” white */
.bento-cell--stat-white {
    grid-column: span 4;
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
}

/* Second row: small stat, metric, large quote */
.bento-cell--stat-sm {
    grid-column: span 3;
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
}

.bento-cell--metric {
    grid-column: span 3;
    background: var(--color-bg-info-default);
    color: var(--text-inverse);
}

.bento-cell--quote-light {
    grid-column: span 6;
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-subtle);
}

.bento__stat-number {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-none);
    letter-spacing: var(--letter-spacing-tighter);
    margin-bottom: var(--space-3);
}

.bento__stat-label {
    font-size: var(--font-size-sm);
    opacity: var(--opacity-80);
    line-height: var(--line-height-snug);
}

.bento__quote {
    font-size: var(--font-size-md);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-5);
}

.bento__author {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.bento__avatar {
    width: var(--space-8);
    height: var(--space-8);
    border-radius: var(--radius-lg);
    background: var(--surface-secondary);
    flex-shrink: 0;
}

.bento__avatar--dark {
    background: var(--surface-secondary);
}

.bento__author-name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    opacity: var(--opacity-90);
}

.bento__author-role {
    font-size: var(--font-size-xs);
    opacity: var(--opacity-60);
    margin-top: 1px;
}

/* Colours for white stat cells */
.bento-cell--stat-white .bento__stat-number,
.bento-cell--stat-sm .bento__stat-number {
    color: var(--text-primary);
}

.bento-cell--stat-white .bento__stat-label,
.bento-cell--stat-sm .bento__stat-label {
    color: var(--text-secondary);
}

.bento-cell--quote-light .bento__quote {
    color: var(--text-primary);
}

.bento-cell--quote-light .bento__author-name,
.bento-cell--quote-light .bento__author-role {
    color: var(--text-secondary);
    opacity: 1;
}

.bento-cell--quote-light .bento__avatar {
    background: var(--surface-primary);
}

/* â”€â”€ Power Pack â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* Section itself is transparent â€” no background bleeds around the rounded box */
.power-pack {
    padding-block: var(--space-6);
    padding-inline: var(--space-6);
}

/* The actual dark rounded box that contains everything */
.power-pack__box {
    background-color: var(--surface-inverse);
    border-radius: var(--radius-2xl);
    padding-block: var(--space-24);
    padding-inline: var(--space-16);
    position: relative;
    overflow: hidden;
}

.power-pack__box .section__header {
    margin-bottom: var(--space-12);
}

.power-pack__box .section__title {
    color: var(--text-inverse);
}

.power-pack__box .section__lead {
    color: rgba(255, 255, 255, 0.55);
    max-width: 44ch;
    margin-inline: auto;
}

/* 3-col grid */
.power-pack-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
}

/* Individual card â€” Salix style */
.power-pack-card {
    background-color: rgba(255, 255, 255, 0.04);
    border: var(--border-width-base) solid var(--border-default);
    border-radius: var(--card-radius);
    padding: var(--space-10) var(--space-8);
    display: flex;
    flex-direction: column;
    transition: background-color var(--transition-slow), border-color var(--transition-slow);
}

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

/* Bare icon â€” no background box, just the coloured SVG directly */
.power-pack-card__icon {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    color: var(--text-link);
    margin-bottom: var(--space-6);
    flex-shrink: 0;
}

.power-pack-card__icon svg {
    width: var(--space-8);
    height: var(--space-8);
    stroke: currentColor;
    fill: none;
    stroke-width: 1.5;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.power-pack-card__title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    color: var(--text-inverse);
    margin-bottom: var(--space-3);
    letter-spacing: var(--letter-spacing-normal);
}

.power-pack-card__body {
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.5);
    line-height: var(--line-height-relaxed);
}

/* â”€â”€ How It Works â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    position: relative;
}

.steps::before {
    content: '';
    position: absolute;
    top: var(--space-6);
    left: calc(16.67% + 27px);
    right: calc(16.67% + 27px);
    height: 1px;
    background: var(--surface-secondary);
}

.step {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
}

.step__number {
    width: var(--space-12);
    height: var(--space-12);
    border-radius: var(--radius-lg);
    background: var(--surface-primary);
    border: var(--border-width-md) solid var(--border-subtle);
    color: var(--text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-bold);
    flex-shrink: 0;
    position: relative;
    z-index: var(--z-index-base);
    box-shadow: var(--shadow-sm);
}

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

.step__body {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
}

/* â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 1024px) {
    .features-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .feature-detail {
        grid-template-columns: 1fr;
    }

    .bento-grid {
        grid-template-columns: repeat(6, 1fr);
    }

    .power-pack-grid {
        grid-template-columns: 1fr;
    }

    .bento-cell--stat-red {
        grid-column: span 3;
    }

    .bento-cell--quote-dark {
        grid-column: span 3;
    }

    .bento-cell--stat-white {
        grid-column: span 6;
    }

    .bento-cell--stat-sm {
        grid-column: span 3;
    }

    .bento-cell--metric {
        grid-column: span 3;
    }

    .bento-cell--quote-light {
        grid-column: span 6;
    }

    .app__sidebar {
        width: 140px;
    }
}

@media (max-width: 768px) {
    .hero__headline {
        font-size: var(--font-size-2xl);
    }

    .features-grid {
        grid-template-columns: 1fr;
    }

    .feature-detail {
        padding: var(--space-6);
    }

    .steps {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }

    .steps::before {
        display: none;
    }

    .step {
        flex-direction: row;
        align-items: flex-start;
    }

    .bento-grid {
        grid-template-columns: 1fr 1fr;
    }

    .power-pack-grid {
        grid-template-columns: 1fr;
    }

    .power-pack {
        margin: 0 var(--space-3) var(--space-3);
        border-radius: var(--radius-xl);
        padding-inline: var(--space-4);
    }

    .bento-cell--stat-red,
    .bento-cell--quote-dark,
    .bento-cell--stat-white,
    .bento-cell--stat-sm,
    .bento-cell--metric {
        grid-column: span 1;
    }

    .bento-cell--quote-light {
        grid-column: span 2;
    }

    .proof-bar .container {
        flex-direction: column;
        gap: var(--space-4);
        text-align: center;
    }

    .proof-bar__divider {
        display: none;
    }

    .app__sidebar {
        display: none;
    }
}

@media (max-width: 640px) {
    .bento-grid {
        grid-template-columns: 1fr;
    }

    .bento-cell--stat-red,
    .bento-cell--quote-dark,
    .bento-cell--stat-white,
    .bento-cell--stat-sm,
    .bento-cell--metric,
    .bento-cell--quote-light {
        grid-column: span 1;
    }

    /* Power pack: full-width, 1-col on mobile */
    .power-pack {
        margin: 0 0 var(--space-4);
        border-radius: var(--radius-xl);
        padding-block: var(--space-12);
    }

    .power-pack-grid {
        grid-template-columns: 1fr;
    }

    .power-pack-card {
        padding: var(--card-padding-block) var(--card-padding-inline) var(--space-6);
    }

    /* Hero buttons: full-width stacked column on small mobile */
    .hero__actions {
        flex-direction: column;
        align-items: stretch;
    }

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

    /* Footer bottom: stack and centre on mobile */
    .site-footer__bottom {
        flex-direction: column;
        gap: var(--space-2);
        text-align: center;
    }
}

/* ==========================================================================
   Logo marquee (Salix-style)
   ========================================================================== */

.logo-marquee-section {
    padding: var(--space-12) 0 var(--space-10);
    background: transparent;
    overflow: hidden;
}

.logo-marquee__label {
    text-align: center;
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-regular);
    color: var(--text-primary);
    opacity: var(--opacity-70);
    margin-bottom: var(--space-6);
}

/* Centred window â€” logos scroll inside it */
.logo-marquee {
    max-width: var(--layout-lg);
    margin: 0 auto;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 12%, black 88%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, black 12%, black 88%, transparent 100%);
}

.logo-marquee__track {
    display: flex;
    align-items: center;
    gap: var(--space-16);
    width: max-content;
    will-change: transform;
    animation: marquee-scroll 30s linear infinite;
}

.logo-marquee__track:hover {
    animation-play-state: paused;
}

.logo-marquee__item {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    text-decoration: none;
    opacity: var(--opacity-80);
    transition: opacity var(--transition-base);
}

.logo-marquee__item:hover {
    opacity: 1;
}

/* All SVGs the same rendered height */
.logo-marquee__item svg {
    height: var(--space-8);
    width: auto;
    display: block;
}

.logo-marquee__item--placeholder {
    cursor: default;
}

/* ==========================================================================
   Mobile overrides â€” hero spacing + marquee containment
   ========================================================================== */

@media (max-width: 768px) {

    /* Reduce the gap between the navbar and the hero kicker on mobile */
    .hero {
        padding-top: var(--space-10);
    }

    /* Tighten the gap between tagline and the mockup — var(--space-16) → var(--space-6) on mobile */
    .hero__footnote {
        margin-bottom: var(--space-6);
    }

    /* Keep button-to-tagline gap proportional */
    .hero__actions {
        margin-bottom: var(--space-4);
    }

    /* Ensure the marquee can't escape its section on narrow viewports */
    .logo-marquee-section {
        overflow: hidden;
    }

    .logo-marquee {
        max-width: 100%;
    }

    /* Why-us — handled by dedicated breakpoint below the base rule */
}

/* â”€â”€ Why businesses choose BespokeLMS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.why-us__badge {
    font-size: var(--font-size-xs);;
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-normal).08em;
    text-transform: uppercase;
    color: var(--text-link);
    background: var(--color-teal-10);
    border-radius: var(--radius-full);
    padding: var(--space-1) var(--space-3);
    margin-bottom: var(--space-5);
    display: inline-block;
}

.why-us__heading {
    font-size: clamp(1.75rem, 3.5vw, var(--font-size-2xl));
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-tight);
    color: var(--text-primary);
    margin-bottom: var(--space-4);
}

.why-us__sub {
    font-size: var(--font-size-md);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
}

/* Three-column card grid */
.why-us__cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    text-align: left;
}

@media (max-width: 768px) {
    .why-us__cards {
        grid-template-columns: 1fr;
    }
}

.why-us__card {
    background: var(--surface-secondary);
    border-radius: var(--radius-xl, 16px);
    border: var(--border-width-base) solid rgba(0, 0, 0, 0.07);
    box-shadow: var(--card-shadow);
    overflow: hidden;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

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

.why-us__card-mockup {
    background: var(--surface-secondary);
    padding: var(--space-5);
    border-bottom: var(--border-width-base) solid var(--border-default);
}

.why-us__card-title {
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    margin: var(--space-5) var(--space-5) var(--space-2);
}

.why-us__card-desc {
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin: 0 var(--space-5) var(--space-5);
}

/* Stagger the three cards left-to-right */
.why-us__card:nth-child(1) {
    transition-delay: 0ms;
}

.why-us__card:nth-child(2) {
    transition-delay: var(--duration-100);
}

.why-us__card:nth-child(3) {
    transition-delay: var(--duration-base);
}

/* â”€â”€ wmock â€” wireframe browser-chrome mockup â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.wmock {
    background: var(--surface-primary);
    border-radius: var(--radius-lg, 12px);
    border: var(--border-width-base) solid var(--border-default);
    overflow: hidden;
    min-height: 180px;
}

/* Traffic-light title bar */
.wmock__bar {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-3);
    background: var(--surface-secondary);
    border-bottom: var(--border-width-base) solid var(--border-default);
}

.wmock__dot {
    width: var(--space-2);
    height: var(--space-2);
    border-radius: 50%;
}

.wmock__dot--r {
    background: var(--feedback-error);
}

.wmock__dot--y {
    background: var(--color-bg-warning-default);
}

.wmock__dot--g {
    background: var(--color-bg-success-default);
}

/* Brand mockup */
.wmock__body {
    display: flex;
    height: 160px;
}

.wmock__panel--dark {
    width: 40%;
    background: var(--surface-inverse);
    padding: var(--space-3) var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.wmock__panel--light {
    flex: 1;
    background: var(--surface-secondary);
    padding: var(--space-3) var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.wmock__swatch-row {
    display: flex;
    gap: var(--space-1);
    margin-bottom: var(--space-1);
}

.wmock__swatch {
    width: var(--space-4);
    height: var(--space-4);
    border-radius: var(--radius-sm);
}

.wmock__swatch--teal {
    background: var(--accent-primary);
}

.wmock__swatch--ink {
    background: var(--surface-inverse);
    border: var(--border-width-base) solid var(--border-default);
}

.wmock__swatch--accent {
    background: var(--color-bg-info-default);
}

.wmock__label-line {
    height: var(--space-1);
    background: rgba(255, 255, 255, 0.15);
    border-radius: var(--radius-sm);
}

.wmock__label-line--short {
    width: 60%;
}

.wmock__preview-btn {
    height: var(--space-4);
    border-radius: var(--radius-sm);
    background: var(--accent-primary);
    opacity: var(--opacity-70);
    width: 70%;
}

.wmock__preview-card {
    height: var(--space-8);
    border-radius: var(--radius-base);
    background: var(--color-border);
}

/* Tenant mockup */
.wmock__tenant-list {
    padding: var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.wmock__tenant-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-2);
    border-radius: var(--radius-lg);
    background: var(--surface-secondary);
}

.wmock__tenant-row--active {
    background: var(--color-teal-10);
}

.wmock__tenant-icon {
    width: var(--space-6);
    height: var(--space-6);
    border-radius: var(--radius-base);
    flex-shrink: 0;
}

.wmock__tenant-icon--teal {
    background: var(--accent-primary);
}

.wmock__tenant-icon--purple {
    background: var(--color-bg-info-default);
}

.wmock__tenant-icon--orange {
    background: var(--color-bg-warning-default);
}

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

.wmock__meta-line {
    height: var(--space-1);
    background: var(--surface-secondary);
    border-radius: var(--radius-sm);
}

.wmock__meta-line--short {
    width: 50%;
}

.wmock__pill {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    padding: 2px var(--space-2);
    border-radius: var(--radius-full);
    flex-shrink: 0;
}

.wmock__pill--green {
    background: rgba(22, 163, 74, 0.12);
    color: var(--color-text-success);
}

.wmock__pill--grey {
    background: var(--color-border);
    color: var(--text-muted);
}

/* Reporting mockup */
.wmock__stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2);
    padding: var(--space-2);
}

.wmock__stat-tile {
    background: var(--surface-secondary);
    border-radius: var(--radius-lg);
    padding: var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.wmock__stat-label {
    height: var(--space-1);
    background: var(--color-border);
    border-radius: var(--radius-sm);
    width: 60%;
}

.wmock__stat-value {
    height: var(--space-3);
    background: var(--text-muted);
    border-radius: var(--radius-sm);
    width: 80%;
}

.wmock__trend {
    height: var(--space-4);
    border-radius: var(--radius-sm);
}

.wmock__trend--up {
    background: linear-gradient(90deg, transparent, rgba(22, 163, 74, 0.3));
}

.wmock__chart-area {
    display: flex;
    align-items: flex-end;
    gap: var(--space-1);
    padding: var(--space-2) var(--space-2) var(--space-1);
    height: var(--space-16);
}

.wmock__chart-bar {
    flex: 1;
    background: var(--color-border);
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    transition: background var(--transition-base);
}

.wmock__chart-bar--active {
    background: var(--accent-primary);
}

/* ── Who it's for ─────────────────────────────────────────────────────────── */

#who-its-for {
    contain: layout;
    position: relative;
}

.who-for__header {
    text-align: center;
    margin-bottom: var(--space-10);
}

.who-for__heading {
    font-size: clamp(1.75rem, 3.5vw, 2.5rem);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--letter-spacing-tighter);
    color: var(--text-primary);
    margin-bottom: var(--space-4);
}

.who-for__sub {
    font-size: var(--font-size-md);
    color: var(--text-secondary);
    max-width: 52ch;
    margin-inline: auto;
    line-height: var(--line-height-relaxed);
}

/* Tab bar */
.who-for__tabs {
    display: flex;
    gap: var(--space-2);
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: var(--space-8);
}

.who-for__tab {
    padding: var(--space-2) var(--space-5);
    border-radius: var(--radius-full);
    border: var(--border-width-md) solid var(--border-default);
    background: transparent;
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
    font-family: var(--font-family-body);
    white-space: nowrap;
}

.who-for__tab:hover {
    border-color: var(--border-focus);
    color: var(--text-link);
}

.who-for__tab.is-active {
    background: var(--accent-primary);
    border-color: var(--border-focus);
    color: var(--text-inverse);
}

/* Panel container — fixed height so switching tabs never moves content below */
.who-for__panels {
    position: relative;
    min-height: var(--layout-sm); /* must be >= the tallest panel — all panels are absolute */
}

/* Hidden panels: taken out of flow but occupying no height via absolute */
.who-for__panel {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    pointer-events: none;
    transition: opacity var(--transition-base), visibility var(--transition-base);
}

/* Active panel: fully visible — stays absolute so container height never changes */
.who-for__panel.is-active {
    opacity: 1;
    visibility: visible;
    position: absolute;
    pointer-events: auto;
}

/* 2-col panel grid: content left, visual right */
.who-for__panel-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: flex-start;
    background: var(--color-surface, var(--surface-secondary));
    border: var(--border-width-base) solid var(--border-default);
    border-radius: var(--radius-xl, 20px);
    padding: var(--space-10) var(--space-12);
}

.who-for__panel-headline {
    font-size: clamp(1.25rem, 2.5vw, 1.625rem);
    font-weight: var(--font-weight-medium);
    letter-spacing: var(--letter-spacing-tight);
    color: var(--text-primary);
    margin-bottom: var(--space-4);
    line-height: var(--line-height-snug);
}

.who-for__panel-desc {
    font-size: var(--font-size-md);;
    color: var(--text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-6);
}

/* Checklist */
.who-for__checklist {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--space-8) 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.who-for__checklist-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: var(--font-size-md);;
    color: var(--text-primary);
    font-weight: var(--font-weight-medium);
}

.who-for__checklist-item::before {
    content: '✓';
    flex-shrink: 0;
    width: var(--space-6);
    height: var(--space-6);
    background: var(--color-teal-10);
    color: var(--text-link);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-normal);
    text-align: center;
}

/* Visual side */
.who-for__panel-visual {
    display: flex;
    align-items: center;
    justify-content: center;
}

.who-for__panel-visual .wmock {
    width: 100%;
    max-width: var(--layout-sm);
}

/* Certificate badge overlay */
.who-for__cert-wrap {
    position: relative;
}

.who-for__cert-badge {
    position: absolute;
    bottom: calc(-1 * var(--space-3));
    right: calc(-1 * var(--space-3));
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: var(--accent-primary);
    color: var(--text-inverse);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-raised);
    white-space: nowrap;
}

/* Mini app mockup for Onboarding panel */
.who-for__app-mini {
    width: 100%;
    max-width: var(--layout-sm);
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: var(--border-width-base) solid var(--border-default);
    box-shadow: var(--shadow-float);
    background: var(--surface-primary);
}

.who-for__app-mini .app__body {
    display: flex;
    height: 160px;
}

.who-for__app-mini .app__sidebar {
    width: var(--space-20);
    background: var(--surface-inverse);
    padding: var(--space-3) var(--space-2);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    overflow: hidden;
}

.who-for__app-mini .app__sidebar-logo {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    font-size: var(--font-size-xs);;
    color: rgba(255,255,255,0.7);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-2);
}

.who-for__app-mini .app__sidebar-logo-icon {
    width: var(--space-3);
    height: var(--space-3);
    border-radius: var(--radius-sm);
    background: var(--accent-primary);
    flex-shrink: 0;
}

.who-for__app-mini .app__sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.who-for__app-mini .app__nav-item {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);;
    color: rgba(255,255,255,0.55);
}

.who-for__app-mini .app__nav-item--active {
    background: rgba(255,255,255,0.12);
    color: var(--text-inverse);
}

.who-for__app-mini .app__nav-icon {
    width: var(--space-2);
    height: var(--space-2);
    border-radius: var(--radius-sm);
    background: currentColor;
    flex-shrink: 0;
    opacity: var(--opacity-70);
}

.who-for__app-mini .app__main {
    flex: 1;
    padding: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    overflow: hidden;
}

.who-for__app-mini .app__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.who-for__app-mini .app__toolbar-title {
    height: var(--space-2);
    width: var(--space-16);
    background: var(--color-bg-brand-hovered);
    border-radius: var(--radius-sm);
}

.who-for__app-mini .app__action-btn {
    height: var(--space-3);
    width: var(--space-10);
    background: var(--accent-primary);
    border-radius: var(--radius-sm);
    opacity: var(--opacity-70);
}

.who-for__app-mini .app__card-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--space-2);
    flex: 1;
}

.who-for__app-mini .app__mini-card {
    background: var(--border-subtle);
    border-radius: var(--radius-base);
    border: var(--border-width-base) solid var(--border-default);
}

/* ==========================================================================
   Dark mode — home page specific overrides
   ========================================================================== */

/* Logo marquee: use invert filter in dark mode for better readability */

/* Mockup border: light content panels need a border in dark mode
   to read as "light UI" rather than blending into dark page */

/* Hero badge */

/* Mobile: stack panel grid */
@media (max-width: 768px) {
    .who-for__panels {
        min-height: 0; /* let content define height on mobile */
    }

    /* Revert to simple display-toggle on mobile — absolute stacking doesn't help in single-col */
    .who-for__panel {
        display: none;
        opacity: 1;
        visibility: visible;
        position: static;
        pointer-events: auto;
        transition: none;
    }

    .who-for__panel.is-active {
        display: block;
        position: static;
    }

    .who-for__panel-grid {
        grid-template-columns: 1fr;
        padding: var(--space-8) var(--space-6);
        gap: var(--space-8);
    }

    .who-for__panel-visual {
        order: -1; /* Visual above content on mobile */
    }

    .who-for__panel-visual .wmock,
    .who-for__app-mini {
        max-width: 260px;
        margin-inline: auto;
    }
}

@media (max-width: 480px) {
    .who-for__tabs {
        gap: var(--space-1);
    }

    .who-for__tab {
        padding: var(--space-2) var(--space-3);
        font-size: var(--font-size-sm);;
    }

    .who-for__panel-grid {
        padding: var(--space-6) var(--space-4);
    }
}


/* ==========================================================================
   Value Pillars section
   Three-column benefit row that sits directly below the hero.
   ========================================================================== */

.value-pillars {
    padding-block: var(--space-16);
}

.value-pillars__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
}

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

.value-pillar:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-raised);
}

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

.value-pillar__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
    letter-spacing: var(--letter-spacing-tight);
    margin: 0;
}

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

/* Responsive: 2-col at ≤768, 1-col at ≤480 */
@media (max-width: 768px) {
    .value-pillars__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .value-pillars {
        padding-block: var(--space-12);
    }
    .value-pillars__grid {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }
}


/* ==========================================================================
   Platform Features grid section (.feat-grid-section)
   Six outcome-led feature cards in a 3-col grid.
   ========================================================================== */

/* .feat-grid-section background is set via section--white / section--subtle in HTML */

.feat-grid__header {
    max-width: var(--layout-md);
    margin-bottom: var(--space-12);
    margin-inline: auto;
    text-align: center;
}

.feat-grid__heading {
    font-size: clamp(1.5rem, 3vw, var(--font-size-2xl));
    color: var(--text-primary);
    letter-spacing: var(--letter-spacing-tight);
    line-height: var(--line-height-snug);
    margin: 0;
}

.feat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}

.feat-card {
    background: var(--card-background);
    border: var(--border-width-base) solid var(--border-default);
    border-radius: var(--card-radius);
    padding: var(--card-padding-block) var(--card-padding-inline) var(--space-6);
    box-shadow: var(--card-shadow);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}

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

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

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

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

/* Responsive: 2-col at ≤900px, 1-col at ≤560px */
@media (max-width: 900px) {
    .feat-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .feat-grid {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }
    .feat-grid__header {
        margin-bottom: var(--space-8);
    }
}

/* ==========================================================================
   Dark mode — additional overrides (audit fixes 3–12)
   ========================================================================== */

/* ── Fix 3: How It Works — .section--white uses hard-coded white ─────────── */

/* ── Fix 4: Bento proof — light quote cell uses hard-coded white ─────────── */

/* ── Fix 5: Hero mockup — light content area hard-coded white ───────────── */

/* ── Fix 6: Scrollspy feature mockup — white inner panels ────────────────── */

/* ── Fix 7: Feature icons — ensure teal bg more vivid in dark mode ───────── */

/* ── Fix 8: Scrollspy nav inactive items — increase contrast ─────────────── */

/* ── Fix 10 & 11: Who it's for panel — add border + secondary btn fix ────── */

/* ── Feat-card and value-pillar dark backgrounds ─────────────────────────── */


/* ==========================================================================
   Proof — Founder Credentials Section
   ========================================================================== */

.proof__grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: var(--space-16);
    align-items: start;
}

.proof__narrative {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    margin-bottom: var(--space-6);
}

.proof__narrative p {
    font-size: var(--font-size-md);
    line-height: var(--line-height-loose);
    color: var(--text-secondary);
    margin: 0;
}

.proof__link {
    color: var(--text-link);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.proof__credentials {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding-top: var(--space-6);
    border-top: var(--border-width-base) solid var(--border-default);
}

.proof__credential {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.proof__credential-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--space-8);
    height: var(--space-8);
    flex-shrink: 0;
    color: var(--text-link);
}

.proof__credential strong {
    display: block;
    font-family: var(--font-family-body);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
}

.proof__credential span {
    display: block;
    font-size: calc(var(--font-size-sm) - 1px);
    color: var(--text-secondary);
    line-height: var(--line-height-snug);
}

.proof__stats {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.proof__stat {
    background: var(--surface-primary);
    border: var(--border-width-base) solid var(--border-default);
    border-radius: var(--radius-xl);
    padding: var(--space-6) var(--space-7);
    text-align: center;
    transition: box-shadow var(--transition-base);
}

.proof__stat:hover { box-shadow: var(--shadow-raised); }

.proof__stat-number {
    display: block;
    font-family: var(--font-family-body-heading);
    font-size: clamp(2rem, 4vw, 2.75rem);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    line-height: var(--line-height-none);
    margin-bottom: var(--space-2);
}

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

@media (max-width: 768px) {
    .proof__grid { grid-template-columns: 1fr; }
    .proof__stats { flex-direction: row; flex-wrap: wrap; }
    .proof__stat { flex: 1 1 45%; }
}


/* ==========================================================================
   Credibility Section — Founder portrait + two-column layout
   ========================================================================== */

.credibility__grid {
    display: grid;
    grid-template-columns: 2fr 3fr;
    gap: var(--space-16);
    align-items: start;
}

/* ── Portrait column ─────────────────────────────────────────────────────── */

.credibility__portrait {
    position: sticky;
    top: calc(var(--space-16) + var(--space-8));
}

.credibility__portrait img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: top center;
    border-radius: var(--radius-lg);
    border-left: var(--border-width-xl) solid var(--border-subtle);
    display: block;
}

.credibility__nameplate {
    margin-top: var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

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

.credibility__role {
    font-size: calc(var(--font-size-sm) - 1px);
    color: var(--text-secondary);
}

/* ── Content column ──────────────────────────────────────────────────────── */

.credibility__content {
    padding-top: var(--space-2);
}

.credibility__content .section__header {
    margin-bottom: var(--space-6);
}

.credibility__content p {
    font-size: var(--font-size-md);
    color: var(--text-secondary);
    line-height: var(--line-height-loose);
    margin-bottom: var(--space-4);
}

.credibility__divider {
    border: none;
    border-top: var(--border-width-base) solid var(--border-default);
    margin: var(--space-8) 0;
}

/* Brand chips */
.credibility__brands {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-bottom: var(--space-8);
}

.credibility__brand-chip {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: var(--text-secondary); /* chips inherit this — keep all greyscale */
}

.credibility__brand-chip-icon {
    width: var(--space-8);
    height: var(--space-8);
    border-radius: var(--radius-base);
    border: var(--border-width-base) solid var(--border-default);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--text-primary);
    background: var(--surface-secondary);
}

.credibility__brand-name {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
}

.credibility__brand-desc {
    display: block;
    font-size: calc(var(--font-size-sm) - 1px);
    color: var(--text-secondary);
    line-height: var(--line-height-snug);
}

/* Stat row */
.credibility__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
    border-top: var(--border-width-base) solid var(--border-default);
    padding-top: var(--space-6);
}

.credibility__stat-value {
    display: block;
    font-family: var(--font-family-body-heading);
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
    line-height: var(--line-height-none);
    margin-bottom: var(--space-2);
}

.credibility__stat-label {
    display: block;
    font-size: calc(var(--font-size-sm) - 1px);
    color: var(--text-secondary);
    line-height: var(--line-height-normal);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */

@media (max-width: 900px) {
    .credibility__grid {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }

    .credibility__portrait {
        position: static;
        max-width: 280px;
        margin-inline: auto; /* center on mobile */
    }

    .credibility__stats {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--space-6);
    }
}

@media (max-width: 640px) {
    .credibility__stats {
        grid-template-columns: 1fr;
        gap: var(--space-8);
        text-align: center;
    }

    .credibility__content .section__header {
        text-align: center;
    }
    
    .credibility__stats > div {
        padding-bottom: var(--space-4);
        border-bottom: var(--border-width-base) solid var(--border-subtle);
    }
    
    .credibility__stats > div:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }
}

/* ── Dark mode ──────────────────────────────────────────────────────────── */


/* ==========================================================================
   Build vs. Buy — Comparison Table (desktop)
   ========================================================================== */

/* ==========================================================================
   Build vs Buy — Two-card comparison (replaces table)
   ========================================================================== */

/* Two-column grid */
.bvb__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-6);
    align-items: stretch;
    margin-top: var(--space-10);
}

/* Base card */
.bvb__card {
    border-radius: var(--radius-lg);
    padding: var(--card-padding-block) var(--card-padding-inline);
    border: var(--border-width-base) solid var(--border-default);
    height: 100%;
}

/* Negative card — custom build: deliberately dimmed */
.bvb__card--negative {
    background: var(--surface-secondary);
    opacity: var(--opacity-80);
}

/* Positive card — BespokeLMS: clean, confident */
.bvb__card--positive {
    background: var(--card-background);
    border-color: var(--border-default);
    box-shadow: var(--shadow-raised);
}

/* Card header */
.bvb__card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-4);
    border-bottom: var(--border-width-base) solid var(--border-default);
}

.bvb__card-label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-normal).05em;
    text-transform: uppercase;
    color: var(--text-secondary);
}

/* SMARTER CHOICE badge — greyscale, not teal */
.bvb__badge {
    font-size: calc(var(--font-size-sm) - 2px);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-normal).06em;
    text-transform: uppercase;
    background: var(--surface-inverse);
    color: var(--text-inverse);
    padding: 0.2rem 0.6rem;
    border-radius: var(--radius-full);
    white-space: nowrap;
}

/* List */
.bvb__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

/* List item */
.bvb__item {
    display: flex;
    gap: var(--space-3);
    align-items: flex-start;
}

.bvb__icon {
    flex-shrink: 0;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    margin-top: 2px;
    width: var(--space-4);
    line-height: var(--line-height-snug);
}

/* Negative items — icon and text muted */
.bvb__item--negative .bvb__icon {
    color: var(--text-secondary);
    opacity: var(--opacity-60);
}

.bvb__item--negative strong {
    color: var(--text-secondary);
    font-size: var(--font-size-sm);
    display: block;
    margin-bottom: 2px;
}

.bvb__item--negative span {
    color: var(--text-secondary);
    font-size: calc(var(--font-size-sm) - 1px);
    line-height: var(--line-height-normal);
    opacity: var(--opacity-80);
}

/* Positive items — full ink weight */
.bvb__item--positive .bvb__icon {
    color: var(--text-primary);
}

.bvb__item--positive strong {
    color: var(--text-primary);
    font-size: var(--font-size-sm);
    display: block;
    margin-bottom: 2px;
}

.bvb__item--positive span {
    color: var(--text-secondary);
    font-size: calc(var(--font-size-sm) - 1px);
    line-height: var(--line-height-normal);
}

/* Responsive */
@media (max-width: 768px) {
    .bvb__grid {
        grid-template-columns: 1fr;
    }

    /* Show BespokeLMS (positive) card first on mobile */
    .bvb__card--positive {
        order: -1;
    }
}

/* Dark mode overrides */

/* ==========================================================================
   Build vs Buy — Table (legacy, kept for reference)
   ========================================================================== */

.bvb__table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-xl);
    border: var(--border-width-base) solid var(--border-default);
    background: var(--surface-primary);
    margin-top: var(--space-10);
}

.bvb__table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-size-sm);
}

.bvb__th {
    padding: var(--space-4) var(--space-5);
    text-align: left;
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    border-bottom: var(--border-width-base) solid var(--border-default);
}

.bvb__th--dimension { width: 18%; color: var(--text-muted); }
.bvb__th--custom { width: 38%; color: var(--text-secondary); }
.bvb__th--bespoke {
    width: 44%;
    background: var(--surface-secondary);
    border-left: var(--border-width-lg) solid var(--border-default);
}

.bvb__badge {
    display: inline-flex;
    align-items: center;
    background: var(--surface-inverse);
    color: var(--text-inverse);
    font-size: var(--font-size-xs);;
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-normal).05em;
    text-transform: uppercase;
    padding: 3px var(--space-3);
    border-radius: var(--radius-base);
}

/* Allows mixed-case text inside the badge (e.g. "BespokeLMS") */
.bvb__badge-name {
    text-transform: none;
    letter-spacing: var(--letter-spacing-normal);
}

.bvb__td {
    padding: var(--space-4) var(--space-5);
    vertical-align: top;
    line-height: var(--line-height-relaxed);
    border-bottom: var(--border-width-base) solid var(--border-subtle);
}

tr:last-child .bvb__td { border-bottom: none; }

.bvb__td--label {
    font-weight: var(--font-weight-semibold);
    color: var(--text-primary);
}

.bvb__td--custom { color: var(--text-secondary); }

.bvb__td--bespoke {
    color: var(--text-primary);
    background: var(--surface-secondary);
    border-left: var(--border-width-lg) solid var(--border-default);
    font-weight: 450;
}

.bvb__footnote {
    margin-top: var(--space-6);
    text-align: center;
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
    font-style: italic;
}



/* ==========================================================================
   Responsive — Build vs Buy table → card stack on mobile
   ========================================================================== */

/* Hide the table on narrow screens, show card stack instead */
@media (max-width: 640px) {
    .bvb__table-wrap {
        display: none;
    }

    .bvb__cards {
        display: flex;
        flex-direction: column;
        gap: var(--space-4);
        margin-top: var(--space-10);
    }

    .bvb__card {
        border-radius: var(--card-radius);
        border: var(--border-width-base) solid var(--border-default);
        overflow: hidden;
        background: var(--card-background);
    }

    .bvb__card-dimension {
        font-size: var(--font-size-sm);
        font-weight: var(--font-weight-bold);
        color: var(--text-primary);
        padding: var(--space-3) var(--space-5);
        background: var(--surface-secondary);
        border-bottom: var(--border-width-base) solid var(--border-default);
        text-transform: uppercase;
        letter-spacing: var(--letter-spacing-normal).04em;
        font-size: var(--font-size-xs);
        color: var(--text-secondary);
    }

    .bvb__card-value {
        display: flex;
        gap: var(--space-3);
        padding: var(--space-4) var(--space-5);
        border-bottom: var(--border-width-base) solid var(--border-subtle);
        font-size: var(--font-size-sm);
        line-height: var(--line-height-relaxed);
    }

    .bvb__card-value:last-child {
        border-bottom: none;
    }

    .bvb__card-value-label {
        flex-shrink: 0;
        font-size: var(--font-size-xs);
        font-weight: var(--font-weight-bold);
        letter-spacing: var(--letter-spacing-normal).06em;
        text-transform: uppercase;
        padding: 2px var(--space-2);
        border-radius: var(--radius-base);
        align-self: flex-start;
        margin-top: 2px;
        white-space: nowrap;
    }

    .bvb__card-value--custom .bvb__card-value-label {
        background: var(--surface-secondary);
        color: var(--text-secondary);
    }

    .bvb__card-value--bespoke .bvb__card-value-label {
        background: var(--color-teal-10);
        color: var(--text-link);
    }

    .bvb__card-value p {
        color: var(--text-secondary);
        margin: 0;
    }

    .bvb__card-value--bespoke p {
        color: var(--text-primary);
    }
}

/* On desktop, card stack is hidden — table is shown */
.bvb__cards {
    display: none;
}


/* ==========================================================================
   Solutions Grid — homepage "Every training model. One platform."
   ========================================================================== */

.solutions-grid-section {
    padding: var(--space-20) 0;
    background: var(--surface-primary);
}

/* ── Audience Tabs ────────────────────────────────────────────────────────── */
.audience-tabs-container {
    display: flex;
    justify-content: center;
    margin-bottom: var(--space-8);
}

.audience-tabs {
    display: flex;
    gap: var(--space-2);
    list-style: none;
    padding: var(--space-1);
    margin: 0;
    background: var(--surface-secondary);
    border-radius: var(--radius-full);
}

.audience-tab {
    background: transparent;
    border: none;
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all var(--transition-base);
    font-family: var(--font-family-body);
}

.audience-tab:hover {
    color: var(--text-primary);
}

.audience-tab.active,
.audience-tab[aria-selected="true"] {
    background: var(--surface-primary);
    color: var(--text-link);
    box-shadow: var(--shadow-sm);
}

.audience-panel {
    animation: fadeIn var(--duration-400) ease forwards;
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 768px) {
    .audience-tabs {
        flex-direction: column;
        border-radius: var(--radius-lg);
        width: 100%;
        max-width: 400px;
    }
    .audience-tab {
        border-radius: var(--radius-base);
        text-align: center;
    }
}

.solutions-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
    margin-top: var(--space-6); /* Reduced from 12 because of tabs */
}

/* ── Card ─────────────────────────────────────────────────────────────────── */
.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);
}

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

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

.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);
}

/* ── Section CTA ──────────────────────────────────────────────────────────── */
.solutions-grid__cta {
    display: flex;
    justify-content: center;
    margin-top: var(--space-10);
}

/* ── Dark mode ────────────────────────────────────────────────────────────── */

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

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

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


/* ==========================================================================
   Pricing Teaser — homepage "Transparent pricing. No surprises."
   ========================================================================== */

.pricing-teaser__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-bottom: var(--space-10);
}

.pricing-teaser__card {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    padding: var(--card-padding-block) var(--card-padding-inline) var(--space-6);
    background: var(--card-background);
    border: var(--border-width-base) solid var(--border-default);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}

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

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

.pricing-teaser__card-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    line-height: var(--line-height-snug);
    letter-spacing: var(--letter-spacing-tight);
    margin: 0;
}

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

.pricing-teaser__ctas {
    display: flex;
    justify-content: center;
    gap: var(--space-4);
    flex-wrap: wrap;
}

@media (max-width: 768px) {
    .pricing-teaser__grid {
        grid-template-columns: 1fr;
        gap: var(--space-4);
    }
}

