/* ==========================================================================
   Page-Specific Styles
   Extends main.css
   ========================================================================== */

/* --------------------------------------------------------------------------
   Page Header (Interior Pages)
   -------------------------------------------------------------------------- */
.page-header {
    padding-top: calc(80px + var(--space-3xl));
    padding-bottom: var(--space-2xl);
    background-color: var(--color-background-alt);
}

.page-header--centered {
    text-align: center;
}

.page-header__label {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin-bottom: var(--space-sm);
}

.page-header__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    letter-spacing: var(--letter-spacing-tight);
    line-height: var(--line-height-tight);
    margin-bottom: var(--space-md);
}

.page-header__subtitle {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    max-width: 700px;
}

.page-header--centered .page-header__subtitle {
    margin-inline: auto;
}

.section__description {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    max-width: 640px;
    margin-top: var(--space-sm);
}

/* --------------------------------------------------------------------------
   About Page - Identity Bar
   -------------------------------------------------------------------------- */
.about-identity {
    padding-block: var(--section-spacing-sm);
    background-color: var(--color-background-alt);
}

.identity-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.identity-card {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-md) var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.identity-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    color: var(--grey-slate);
}

.identity-card__label {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: var(--letter-spacing-wide);
}

.identity-card__value {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
}

@media (min-width: 640px) {
    .identity-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .identity-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* --------------------------------------------------------------------------
   About Page - Bio Section
   -------------------------------------------------------------------------- */
.about-bio__content {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

.about-bio__image {
    max-width: 300px;
}

.about-bio__image img {
    width: 100%;
    border-radius: var(--radius-lg);
    aspect-ratio: 1;
    object-fit: cover;
}

.about-bio__text h2 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
}

.about-bio__text h2:first-child {
    margin-top: 0;
}

.about-bio__text p {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.about-bio__text p:last-child {
    margin-bottom: 0;
}

.about-bio__text strong {
    color: var(--color-text);
    font-weight: var(--font-weight-semibold);
}

@media (min-width: 768px) {
    .about-bio__content {
        grid-template-columns: 200px 1fr;
        gap: var(--space-2xl);
    }
    
    .about-bio__image {
        position: sticky;
        top: 100px;
        align-self: start;
    }
}

/* --------------------------------------------------------------------------
   Timeline Section
   -------------------------------------------------------------------------- */
.timeline-section {
    background-color: var(--color-background-alt);
}

.timeline {
    position: relative;
    max-width: 800px;
    margin-inline: auto;
}

.timeline::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, var(--grey-slate), var(--color-border));
}

.timeline__item {
    position: relative;
    padding-left: var(--space-xl);
    padding-bottom: var(--space-xl);
}

.timeline__item:last-child {
    padding-bottom: 0;
}

.timeline__marker {
    position: absolute;
    left: -6px;
    top: 0;
    width: 14px;
    height: 14px;
    background-color: var(--grey-slate);
    border-radius: 50%;
    border: 3px solid var(--color-background-alt);
}

.timeline__year {
    position: absolute;
    left: var(--space-xl);
    top: -2px;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-bold);
    color: var(--grey-steel);
    font-family: var(--font-mono);
}

.timeline__content {
    padding-top: var(--space-lg);
}

.timeline__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

.timeline__description {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

.timeline__item--future .timeline__marker {
    background-color: transparent;
    border-color: var(--grey-slate);
}

.timeline__item--future .timeline__title,
.timeline__item--future .timeline__description {
    opacity: 0.7;
}

@media (min-width: 768px) {
    .timeline::before {
        left: 50%;
        transform: translateX(-50%);
    }
    
    .timeline__item {
        padding-left: 0;
        width: 50%;
    }
    
    .timeline__item:nth-child(odd) {
        padding-right: var(--space-xl);
        text-align: right;
    }
    
    .timeline__item:nth-child(even) {
        margin-left: 50%;
        padding-left: var(--space-xl);
    }
    
    .timeline__marker {
        left: auto;
        right: -7px;
    }
    
    .timeline__item:nth-child(even) .timeline__marker {
        left: -7px;
        right: auto;
    }
    
    .timeline__year {
        position: static;
        display: block;
        margin-bottom: var(--space-xs);
    }
    
    .timeline__content {
        padding-top: 0;
    }
}

/* --------------------------------------------------------------------------
   Competencies Section
   -------------------------------------------------------------------------- */
.competencies__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.competency-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

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

.competency-card__list {
    list-style: none;
}

.competency-card__list li {
    padding: var(--space-xs) 0;
    color: var(--color-text-secondary);
    border-bottom: 1px solid var(--color-border-light);
}

.competency-card__list li:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

@media (min-width: 768px) {
    .competencies__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .competencies__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.competency-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    color: var(--grey-steel);
    margin-bottom: var(--space-md);
}

/* --------------------------------------------------------------------------
   About Page - Values & Principles
   -------------------------------------------------------------------------- */
.about-values {
    background-color: var(--color-background-alt);
}

.values-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.value-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    position: relative;
}

.value-card__number {
    display: block;
    font-family: var(--font-mono);
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-extrabold);
    color: var(--grey-cloud);
    opacity: 0.25;
    line-height: 1;
    margin-bottom: var(--space-sm);
}

.value-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-sm);
}

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

@media (min-width: 640px) {
    .values-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .values-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Venture Detail Section
   -------------------------------------------------------------------------- */
.venture-detail {
    overflow: hidden;
}

.venture-detail--alt {
    background-color: var(--color-background-alt);
}

.venture-detail__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
    align-items: center;
}

.venture-detail__badge {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: var(--grey-steel);
    margin-bottom: var(--space-sm);
}

.venture-detail__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    letter-spacing: var(--letter-spacing-tight);
    margin-bottom: var(--space-xs);
}

.venture-detail__tagline {
    font-size: var(--font-size-xl);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-lg);
}

.venture-detail__description p {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.venture-detail__stats {
    display: flex;
    gap: var(--space-xl);
    padding: var(--space-lg) 0;
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
    margin: var(--space-lg) 0;
}

.stat-mini__number {
    display: block;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
}

.stat-mini__label {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.venture-detail__products h3,
.venture-detail__services h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-md);
}

.product-list {
    list-style: none;
}

.product-list li {
    padding: var(--space-sm) 0;
    border-bottom: 1px solid var(--color-border-light);
    color: var(--color-text-secondary);
}

.product-list li:last-child {
    border-bottom: none;
}

.product-list strong {
    color: var(--color-text);
    font-weight: var(--font-weight-medium);
}

.service-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.service-tag {
    padding: var(--space-xs) var(--space-md);
    font-size: var(--font-size-sm);
    background-color: var(--color-background-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
}

.venture-detail__cta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-top: var(--space-xl);
}

.venture-detail__visual {
    display: none;
}

.venture-visual__mockup {
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    padding: var(--space-lg);
    aspect-ratio: 16/10;
    display: flex;
    align-items: center;
    justify-content: center;
}

.venture-visual__mockup img {
    max-width: 100%;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
}

@media (min-width: 1024px) {
    .venture-detail__grid {
        grid-template-columns: 1fr 1fr;
    }
    
    .venture-detail__grid--reverse {
        direction: rtl;
    }
    
    .venture-detail__grid--reverse > * {
        direction: ltr;
    }
    
    .venture-detail__visual {
        display: block;
    }
}

/* --------------------------------------------------------------------------
   Other Projects Grid
   -------------------------------------------------------------------------- */
.projects-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.project-card {
    display: block;
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.project-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--grey-steel);
}

.project-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

.project-card__description {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    margin-bottom: var(--space-sm);
}

.project-card__link {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
}

@media (min-width: 768px) {
    .projects-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .projects-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Coming Next Section
   -------------------------------------------------------------------------- */
.coming-next {
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    text-align: center;
}

.coming-next__content {
    max-width: 600px;
    margin-inline: auto;
}

.coming-next .section__label {
    color: var(--color-text-secondary);
}

.coming-next__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-md);
}

.coming-next__description {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: var(--space-lg);
}

.coming-next .link-arrow {
    color: var(--color-text-inverse);
}

.coming-next .link-arrow:hover {
    color: var(--color-text-secondary);
}

/* --------------------------------------------------------------------------
   Section Description (shared)
   -------------------------------------------------------------------------- */
.section__description {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    max-width: 640px;
}

/* --------------------------------------------------------------------------
   Ventures — By the Numbers
   -------------------------------------------------------------------------- */
.ventures-numbers {
    background-color: var(--color-primary);
    color: var(--color-text-inverse);
    padding-block: var(--space-xl);
}

.ventures-numbers__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg);
    text-align: center;
}

@media (min-width: 768px) {
    .ventures-numbers__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.ventures-num__value {
    display: block;
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    line-height: 1;
    margin-bottom: var(--space-xs);
}

.ventures-num__label {
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.7);
}

/* --------------------------------------------------------------------------
   Ventures — Ecosystem Hub Visual (replaces broken images)
   -------------------------------------------------------------------------- */
.venture-visual--ecosystem,
.venture-visual--stack {
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 360px;
}

.ecosystem-hub {
    position: relative;
    width: 280px;
    height: 280px;
}

.ecosystem-hub__center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90px;
    height: 90px;
    background: var(--color-primary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-inverse);
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-sm);
    z-index: 2;
    box-shadow: 0 0 0 6px rgba(200, 200, 208, 0.2);
}

.ecosystem-hub__ring {
    position: absolute;
    inset: 0;
}

.ecosystem-hub__node {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 64px;
    height: 64px;
    margin: -32px 0 0 -32px;
    background-color: var(--color-surface);
    border: 2px solid var(--color-border-light);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    transform: rotate(calc(var(--i) * 60deg)) translateY(-110px) rotate(calc(var(--i) * -60deg));
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.ecosystem-hub__node:hover {
    border-color: var(--grey-steel);
    box-shadow: var(--shadow-md);
}

/* --------------------------------------------------------------------------
   Ventures — Tech Stack Visual (LVMRE section)
   -------------------------------------------------------------------------- */
.tech-stack-visual {
    width: 100%;
    max-width: 340px;
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.tech-stack-visual__layer {
    padding: var(--space-md) var(--space-lg);
    border-radius: var(--radius-md);
    text-align: center;
    transition: transform var(--transition-fast);
}

.tech-stack-visual__layer:hover {
    transform: translateX(4px);
}

.tech-stack-visual__layer span {
    display: block;
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    margin-bottom: 2px;
}

.tech-stack-visual__layer small {
    font-size: var(--font-size-xs);
    opacity: 0.8;
}

.tech-stack-visual__layer--1 {
    background: linear-gradient(135deg, var(--grey-slate), var(--grey-steel));
    color: var(--color-text-inverse);
}

.tech-stack-visual__layer--2 {
    background: linear-gradient(135deg, var(--grey-iron), var(--grey-ash));
    color: var(--color-text-inverse);
}

.tech-stack-visual__layer--3 {
    background: linear-gradient(135deg, var(--grey-cool), var(--grey-cloud));
    color: var(--color-text-inverse);
}

.tech-stack-visual__layer--4 {
    background: linear-gradient(135deg, var(--grey-warm), var(--grey-cloud));
    color: var(--grey-steel);
}

/* --------------------------------------------------------------------------
   Ventures — SYMS Ecosystem Grid
   -------------------------------------------------------------------------- */
.syms-ecosystem {
    background-color: var(--color-background-alt);
}

.syms-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 640px) {
    .syms-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .syms-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.syms-card {
    position: relative;
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.syms-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--grey-steel);
}

.syms-card__icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-md);
    color: var(--grey-steel);
}

.syms-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

.syms-card__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.syms-card__status {
    display: inline-block;
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    padding: 3px 10px;
    border-radius: var(--radius-full);
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.syms-card__status--live {
    background-color: rgba(90, 101, 112, 0.12);
    color: var(--grey-steel);
}

.syms-card__status--dev {
    background-color: rgba(138, 128, 120, 0.12);
    color: var(--grey-warm);
}

.syms-card__status--planned {
    background-color: rgba(107, 114, 128, 0.12);
    color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   Ventures — Platform Cards (Industry Solutions)
   -------------------------------------------------------------------------- */
.platforms-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 768px) {
    .platforms-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.platform-card {
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.platform-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.platform-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.platform-card__icon {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    color: var(--color-text-inverse);
    flex-shrink: 0;
}

.platform-card__icon--health {
    background: linear-gradient(135deg, var(--grey-warm), var(--grey-cloud));
}

.platform-card__icon--finance {
    background: linear-gradient(135deg, var(--grey-cool), var(--grey-steel));
}

.platform-card__icon--edu {
    background: linear-gradient(135deg, var(--grey-slate), var(--grey-iron));
}

.platform-card__sector {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-text-muted);
}

.platform-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-sm);
}

.platform-card__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.platform-card__modules {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.platform-card__modules span {
    font-size: 11px;
    font-family: var(--font-mono);
    padding: 3px 8px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   Ventures — Solutions Grid (Client Work)
   -------------------------------------------------------------------------- */
.ventures-solutions {
    background-color: var(--color-background-alt);
}

.solutions-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 640px) {
    .solutions-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .solutions-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.solution-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.solution-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.solution-card__icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--grey-steel);
    margin-bottom: var(--space-sm);
}

.solution-card__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

.solution-card__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.solution-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.solution-card__tags span {
    font-size: 11px;
    font-weight: var(--font-weight-medium);
    padding: 2px 8px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   Ventures — Developer Tools Grid
   -------------------------------------------------------------------------- */
.tools-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 640px) {
    .tools-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .tools-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.tool-card {
    display: block;
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
    text-decoration: none;
    color: inherit;
}

.tool-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--grey-steel);
}

.tool-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.tool-card__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
}

.tool-card__lang {
    font-size: 11px;
    font-family: var(--font-mono);
    padding: 2px 8px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--grey-steel);
    white-space: nowrap;
}

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

.section__footer--centered {
    text-align: center;
    margin-top: var(--space-xl);
}

/* --------------------------------------------------------------------------
   Collaborate Page - Collab Types
   -------------------------------------------------------------------------- */
.collab-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.collab-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.collab-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.collab-card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    color: var(--grey-steel);
    margin-bottom: var(--space-md);
}

.collab-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-sm);
}

.collab-card__description {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

@media (min-width: 768px) {
    .collab-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .collab-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Contact Form Section
   -------------------------------------------------------------------------- */
.contact-form-section {
    background-color: var(--color-background-alt);
}

.contact-form-wrapper {
    background-color: var(--color-surface);
    padding: var(--space-xl);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

.contact-form__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-xs);
}

.contact-form__subtitle {
    color: var(--color-text-secondary);
    margin-bottom: var(--space-xl);
}

.form-group {
    margin-bottom: var(--space-md);
}

.form-label {
    display: block;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    margin-bottom: var(--space-xs);
}

.form-optional {
    font-weight: var(--font-weight-normal);
    color: var(--color-text-muted);
}

.form-input,
.form-select,
.form-textarea {
    width: 100%;
    padding: var(--space-sm) var(--space-md);
    font-family: var(--font-primary);
    font-size: var(--font-size-base);
    color: var(--color-text);
    background-color: var(--color-background);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--grey-steel);
    box-shadow: 0 0 0 3px rgba(200, 200, 208, 0.2);
}

.form-input::placeholder,
.form-textarea::placeholder {
    color: var(--color-text-muted);
}

.form-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--space-sm) center;
    padding-right: var(--space-xl);
}

.form-textarea {
    resize: vertical;
    min-height: 120px;
}

.btn--full {
    width: 100%;
}

/* --------------------------------------------------------------------------
   Direct Contact Section
   -------------------------------------------------------------------------- */
.direct-contact__content {
    text-align: center;
}

.direct-contact__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-xl);
}

.direct-contact__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    margin-bottom: var(--space-xl);
}

.direct-contact__item {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.direct-contact__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-muted);
    margin-bottom: var(--space-xs);
}

.direct-contact__link {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    transition: color var(--transition-fast);
}

.direct-contact__link:hover {
    color: var(--color-text-secondary);
}

.direct-contact__social {
    margin-bottom: var(--space-xl);
}

.social-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-md);
    margin-top: var(--space-md);
}

.social-link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-sm) var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-medium);
    transition: border-color var(--transition-fast), background-color var(--transition-fast);
}

.social-link:hover {
    border-color: var(--grey-steel);
    background-color: var(--color-background-alt);
}

.direct-contact__location {
    color: var(--color-text-secondary);
}

.direct-contact__timezone {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-top: var(--space-xs);
}

@media (min-width: 768px) {
    .direct-contact__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .direct-contact__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Journal Page Styles
   -------------------------------------------------------------------------- */
.journal-header {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    margin-bottom: var(--space-xl);
}

.journal-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.filter-btn {
    padding: var(--space-xs) var(--space-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    background-color: transparent;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    color: var(--color-text-secondary);
    transition: all var(--transition-fast);
}

.filter-btn:hover,
.filter-btn.is-active {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.journal-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.journal-list-item {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.journal-list-item:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.journal-list-item__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-sm);
}

.journal-list-item__date {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    font-family: var(--font-mono);
}

.journal-list-item__category {
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: var(--grey-steel);
    padding: 2px var(--space-xs);
    background-color: rgba(200, 200, 208, 0.12);
    border-radius: var(--radius-sm);
}

.journal-list-item__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-snug);
}

.journal-list-item__title a {
    transition: color var(--transition-fast);
}

.journal-list-item__title a:hover {
    color: var(--color-text-secondary);
}

.journal-list-item__excerpt {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

.journal-list-item__read-more {
    font-weight: var(--font-weight-medium);
    color: var(--color-text);
    transition: color var(--transition-fast);
}

.journal-list-item__read-more:hover {
    color: var(--color-text-secondary);
}

@media (min-width: 768px) {
    .journal-header {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
}

/* --------------------------------------------------------------------------
   Media Page Styles
   -------------------------------------------------------------------------- */
.speaking-topics {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.topic-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.topic-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-sm);
}

.topic-card__description {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

.media-appearances {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.media-card {
    display: flex;
    gap: var(--space-md);
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.media-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.media-card__type {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    color: var(--grey-slate);
    flex-shrink: 0;
}

.media-card__content {
    flex: 1;
}

.media-card__title {
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

.media-card__outlet {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.media-card__date {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

@media (min-width: 768px) {
    .speaking-topics {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .media-appearances {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Impact Page Styles
   -------------------------------------------------------------------------- */
.case-study {
    padding: var(--space-2xl) 0;
    border-bottom: 1px solid var(--color-border-light);
}

.case-study:last-child {
    border-bottom: none;
}

.case-study__header {
    margin-bottom: var(--space-xl);
}

.case-study__label {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    color: var(--color-text-secondary);
    margin-bottom: var(--space-sm);
}

.case-study__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-md);
}

.case-study__summary {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    max-width: 800px;
}

.case-study__metrics {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
    padding: var(--space-lg);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-xl);
}

.metric {
    text-align: center;
}

.metric__value {
    display: block;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    font-family: var(--font-mono);
    color: var(--grey-slate);
    line-height: 1;
}

.metric__label {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.case-study__content h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-md);
}

.case-study__content p {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.case-study__content ul {
    list-style: disc;
    padding-left: var(--space-lg);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-md);
}

.case-study__content li {
    margin-bottom: var(--space-xs);
    line-height: var(--line-height-relaxed);
}

@media (min-width: 768px) {
    .case-study__metrics {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Expertise Page Styles
   -------------------------------------------------------------------------- */
.expertise-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

.expertise-item {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.expertise-item__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    color: var(--grey-slate);
}

.expertise-item__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-sm);
}

.expertise-item__description {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.expertise-item__skills {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.skill-tag {
    padding: var(--space-xs) var(--space-sm);
    font-size: var(--font-size-xs);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-secondary);
}

@media (min-width: 768px) {
    .expertise-item {
        grid-template-columns: 80px 1fr;
    }
}

/* --------------------------------------------------------------------------
   Impact Page Styles
   -------------------------------------------------------------------------- */

/* 8-stat numbers bar override */
.impact-numbers__grid {
    grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px) {
    .impact-numbers__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 1024px) {
    .impact-numbers__grid {
        grid-template-columns: repeat(8, 1fr);
    }
}

/* Case Study Badges */
.case-study__badge {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    color: var(--color-text-inverse);
    margin-bottom: var(--space-md);
}

.case-study__badge--edu {
    background: linear-gradient(135deg, var(--grey-slate), var(--grey-iron));
}

.case-study__badge--health {
    background: linear-gradient(135deg, var(--grey-warm), var(--grey-cloud));
}

.case-study__badge--fin {
    background: linear-gradient(135deg, var(--grey-cool), var(--grey-steel));
}

.case-studies-section {
    padding-top: var(--space-2xl);
}

/* Client Portfolio Grid */
.impact-portfolio {
    background-color: var(--color-background-alt);
}

.portfolio-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 640px) {
    .portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .portfolio-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.portfolio-item {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.portfolio-item:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.portfolio-item__icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--grey-slate);
    margin-bottom: var(--space-sm);
}

.portfolio-item__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

.portfolio-item__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.portfolio-item__sector {
    display: inline-block;
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    padding: 3px 10px;
    border-radius: var(--radius-full);
    background-color: var(--color-background-alt);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

/* Geographic Reach */
.reach-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 768px) {
    .reach-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.reach-card {
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.reach-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.reach-card__region {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.reach-card__region svg {
    color: var(--grey-slate);
    flex-shrink: 0;
}

.reach-card__region h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
}

.reach-card__desc {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.reach-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.reach-card__tags span {
    font-size: 11px;
    font-family: var(--font-mono);
    padding: 3px 8px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
}

/* Recognition Section */
.recognition-section {
    background-color: var(--color-background-alt);
}

.impact__recognition {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.recognition-badge {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.recognition-badge:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-md);
}

.recognition-badge__icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    color: var(--color-text-inverse);
    flex-shrink: 0;
}

.recognition-badge__icon--award {
    background: linear-gradient(135deg, var(--grey-warm), var(--grey-cloud));
}

.recognition-badge__icon--global {
    background: linear-gradient(135deg, var(--grey-slate), var(--grey-steel));
}

.recognition-badge__icon--cert {
    background: linear-gradient(135deg, var(--grey-iron), var(--grey-ash));
}

.recognition-badge__icon--community {
    background: linear-gradient(135deg, var(--grey-cool), var(--grey-cloud));
}

.recognition-badge__icon--code {
    background: linear-gradient(135deg, var(--grey-stone), var(--grey-ash));
}

.recognition-badge__content {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.recognition-badge__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
}

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

.recognition-badge__year {
    font-size: var(--font-size-xs);
    font-family: var(--font-mono);
    color: var(--grey-slate);
    font-weight: var(--font-weight-medium);
}

/* --------------------------------------------------------------------------
   Impact Page - Radial Progress Dashboard
   -------------------------------------------------------------------------- */
.impact-dashboard {
    background-color: var(--color-background-alt);
}

.radial-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg);
}

@media (min-width: 768px) {
    .radial-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.radial-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.radial-ring {
    position: relative;
    width: 100px;
    height: 100px;
    margin-bottom: var(--space-md);
}

.radial-ring__svg {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}

.radial-ring__track {
    fill: none;
    stroke: var(--color-border-light);
    stroke-width: 6;
}

.radial-ring__fill {
    fill: none;
    stroke: var(--grey-slate);
    stroke-width: 6;
    stroke-linecap: round;
    stroke-dasharray: 326.73;
    stroke-dashoffset: 326.73;
    transition: stroke-dashoffset 1.5s var(--ease-out-expo);
}

.radial-ring__fill--green { stroke: var(--grey-cool); }
.radial-ring__fill--blue { stroke: var(--grey-slate); }

.radial-ring__value {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    font-family: var(--font-mono);
    color: var(--color-text);
}

.radial-card__label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    margin-bottom: 2px;
}

.radial-card__sub {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   Impact Page - Growth Chart
   -------------------------------------------------------------------------- */
.impact-growth__layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
    align-items: center;
}

@media (min-width: 768px) {
    .impact-growth__layout {
        grid-template-columns: 1fr 1.4fr;
    }
}

.growth-stats {
    display: flex;
    gap: var(--space-xl);
    margin-top: var(--space-lg);
}

.growth-stat__value {
    display: block;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-extrabold);
    font-family: var(--font-mono);
    color: var(--grey-slate);
    line-height: 1;
}

.growth-stat__label {
    display: block;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: var(--space-xs);
}

/* Bar Chart */
.bar-chart {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.bar-chart__row {
    display: grid;
    grid-template-columns: 40px 1fr 44px;
    align-items: center;
    gap: var(--space-sm);
}

.bar-chart__label {
    font-size: var(--font-size-xs);
    font-family: var(--font-mono);
    color: var(--color-text-muted);
    text-align: right;
}

.bar-chart__track {
    height: 24px;
    background-color: var(--color-border-light);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.bar-chart__fill {
    height: 100%;
    width: 0;
    background: linear-gradient(90deg, var(--grey-slate), var(--grey-steel));
    border-radius: var(--radius-sm);
    transition: width 1.2s var(--ease-out-expo);
}

.bar-chart__fill--accent {
    background: var(--gradient-accent);
}

.bar-chart__value {
    font-size: var(--font-size-xs);
    font-family: var(--font-mono);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
}

/* --------------------------------------------------------------------------
   Impact Page - Industry Distribution Chart
   -------------------------------------------------------------------------- */
.industry-chart {
    max-width: 700px;
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.industry-chart__row {
    display: grid;
    grid-template-columns: 160px 1fr 44px;
    align-items: center;
    gap: var(--space-md);
}

@media (max-width: 639px) {
    .industry-chart__row {
        grid-template-columns: 1fr;
        gap: var(--space-xs);
    }
    .industry-chart__pct {
        display: none;
    }
}

.industry-chart__info {
    display: flex;
    flex-direction: column;
}

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

.industry-chart__count {
    font-size: 11px;
    color: var(--color-text-muted);
    font-family: var(--font-mono);
}

.industry-chart__bar {
    height: 20px;
    background-color: var(--color-border-light);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.industry-chart__fill {
    height: 100%;
    width: 0;
    border-radius: var(--radius-sm);
    transition: width 1.2s var(--ease-out-expo);
}

.industry-chart__fill[data-color="edu"]    { background: linear-gradient(90deg, var(--grey-slate), var(--grey-steel)); }
.industry-chart__fill[data-color="fin"]    { background: linear-gradient(90deg, var(--grey-cool), var(--grey-cloud)); }
.industry-chart__fill[data-color="health"] { background: linear-gradient(90deg, var(--grey-warm), var(--grey-cloud)); }
.industry-chart__fill[data-color="ecom"]   { background: linear-gradient(90deg, var(--grey-iron), var(--grey-ash)); }
.industry-chart__fill[data-color="agri"]   { background: linear-gradient(90deg, var(--grey-stone), var(--grey-cloud)); }
.industry-chart__fill[data-color="prop"]   { background: linear-gradient(90deg, var(--grey-ash), var(--grey-cloud)); }
.industry-chart__fill[data-color="legal"]  { background: linear-gradient(90deg, var(--color-secondary), var(--grey-iron)); }
.industry-chart__fill[data-color="other"]  { background: linear-gradient(90deg, var(--grey-cloud), var(--grey-slate)); }

.industry-chart__pct {
    font-size: var(--font-size-sm);
    font-family: var(--font-mono);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-secondary);
    text-align: right;
}

/* --------------------------------------------------------------------------
   Impact Page - Comparison Cards
   -------------------------------------------------------------------------- */
.impact-comparison {
    background-color: var(--color-background-alt);
}

.comparison-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 768px) {
    .comparison-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.comparison-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
}

.comparison-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    margin-bottom: var(--space-lg);
    color: var(--grey-slate);
}

.comparison-card__header h3 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
}

.comparison-card__bars {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    margin-bottom: var(--space-md);
}

.comparison-bar {
    display: grid;
    grid-template-columns: 48px 1fr auto;
    align-items: center;
    gap: var(--space-sm);
}

.comparison-bar__label {
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted);
}

.comparison-bar__track {
    height: 16px;
    background-color: var(--color-border-light);
    border-radius: var(--radius-sm);
    overflow: hidden;
}

.comparison-bar__fill {
    height: 100%;
    width: 0;
    border-radius: var(--radius-sm);
    transition: width 1s var(--ease-out-expo);
}

.comparison-bar__fill--before {
    background: linear-gradient(90deg, var(--grey-warm), var(--grey-cloud));
}

.comparison-bar__fill--after {
    background: linear-gradient(90deg, var(--grey-slate), var(--grey-steel));
}

.comparison-bar__value {
    font-size: 11px;
    font-family: var(--font-mono);
    color: var(--color-text-secondary);
    white-space: nowrap;
}

.comparison-card__delta {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    color: var(--grey-slate);
    background-color: rgba(90, 101, 112, 0.12);
    padding: 3px 10px;
    border-radius: var(--radius-full);
}

/* --------------------------------------------------------------------------
   Impact Page - Platform Cards
   -------------------------------------------------------------------------- */
.platform-cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 768px) {
    .platform-cards {
        grid-template-columns: repeat(3, 1fr);
    }
}

.platform-card {
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
}

.platform-card__header {
    margin-bottom: var(--space-lg);
}

.platform-card__badge {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    color: var(--color-text-inverse);
    margin-bottom: var(--space-sm);
}

.platform-card--edu .platform-card__badge { background: linear-gradient(135deg, var(--grey-slate), var(--grey-iron)); }
.platform-card--health .platform-card__badge { background: linear-gradient(135deg, var(--grey-warm), var(--grey-cloud)); }
.platform-card--fin .platform-card__badge { background: linear-gradient(135deg, var(--grey-cool), var(--grey-steel)); }

.platform-card__header h3 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: 4px;
}

.platform-card__tag {
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-muted);
}

.platform-card__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-sm);
    padding: var(--space-md) 0;
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
    margin-bottom: var(--space-md);
}

.platform-stat {
    text-align: center;
}

.platform-stat__num {
    display: block;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    font-family: var(--font-mono);
    color: var(--grey-slate);
    line-height: 1.2;
}

.platform-stat__label {
    display: block;
    font-size: 10px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.platform-card__modules {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    margin-bottom: var(--space-lg);
    flex-grow: 1;
}

.platform-card__modules span {
    font-size: 11px;
    font-family: var(--font-mono);
    padding: 3px 8px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
}

.platform-card__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--grey-slate);
    text-decoration: none;
    transition: gap var(--transition-fast);
}

.platform-card__link:hover {
    gap: var(--space-sm);
}

/* --------------------------------------------------------------------------
   Impact Page - Reach Indicators
   -------------------------------------------------------------------------- */
.reach-card__indicator {
    margin-bottom: var(--space-md);
}

.reach-indicator {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.reach-indicator__label {
    font-size: 11px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.reach-indicator__bar {
    height: 6px;
    background-color: var(--color-border-light);
    border-radius: var(--radius-full);
    overflow: hidden;
}

.reach-indicator__fill {
    height: 100%;
    width: 0;
    background: var(--gradient-accent);
    border-radius: var(--radius-full);
    transition: width 1.2s var(--ease-out-expo);
}

/* --------------------------------------------------------------------------
   Approach Section (used on Expertise)
   -------------------------------------------------------------------------- */
.approach__content {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
}

.approach__description {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.approach__description:last-child {
    margin-bottom: 0;
}

.approach__principles {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.principle {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
}

.principle h3 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-xs);
}

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

@media (min-width: 768px) {
    .approach__content {
        grid-template-columns: 1fr 1fr;
    }
    
    .approach__principles {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .approach__principles {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Expertise — Tech Stack Layers
   -------------------------------------------------------------------------- */
.exp-stack {
    background-color: var(--color-background-alt);
}

.stack-layers {
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
}

.stack-layer__title {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-md);
    color: var(--grey-slate);
}

.stack-layer__title svg {
    color: var(--grey-slate);
    flex-shrink: 0;
}

.stack-layer__items {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.stack-chip {
    padding: 6px 14px;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-full);
    color: var(--color-text-secondary);
    transition: border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);
}

.stack-chip:hover {
    border-color: var(--grey-slate);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.stack-chip--primary {
    background-color: var(--grey-slate);
    border-color: var(--grey-slate);
    color: var(--color-text-inverse);
    font-weight: var(--font-weight-semibold);
}

.stack-chip--primary:hover {
    border-color: var(--grey-slate);
    box-shadow: var(--shadow-md);
}

/* --------------------------------------------------------------------------
   Expertise — Industry Experience Grid
   -------------------------------------------------------------------------- */
.industries-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

@media (min-width: 640px) {
    .industries-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .industries-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

.industry-card {
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.industry-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.industry-card__icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    color: var(--color-text-inverse);
    margin-bottom: var(--space-md);
}

.industry-card__icon--edu {
    background: linear-gradient(135deg, var(--grey-slate), var(--grey-iron));
}

.industry-card__icon--health {
    background: linear-gradient(135deg, var(--grey-warm), var(--grey-cloud));
}

.industry-card__icon--fin {
    background: linear-gradient(135deg, var(--grey-cool), var(--grey-steel));
}

.industry-card__icon--legal {
    background: linear-gradient(135deg, var(--color-secondary), var(--grey-iron));
}

.industry-card__icon--prop {
    background: linear-gradient(135deg, var(--grey-stone), var(--grey-ash));
}

.industry-card__icon--ecom {
    background: linear-gradient(135deg, var(--grey-ash), var(--grey-cloud));
}

.industry-card__icon--community {
    background: linear-gradient(135deg, var(--grey-iron), var(--grey-stone));
}

.industry-card__icon--media {
    background: linear-gradient(135deg, var(--grey-cool), var(--grey-cloud));
}

.industry-card__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: 2px;
}

.industry-card__count {
    display: block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--grey-slate);
    margin-bottom: var(--space-sm);
}

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

/* --------------------------------------------------------------------------
   Expertise — Principle Numbers
   -------------------------------------------------------------------------- */
.principle__number {
    display: block;
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--grey-slate);
    opacity: 0.3;
    line-height: 1;
    margin-bottom: var(--space-sm);
    font-family: var(--font-mono);
}

/* --------------------------------------------------------------------------
   Speaking/Topics Section (Media Page)
   -------------------------------------------------------------------------- */
.speaking-topics {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.topic-card {
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: border-color var(--transition-base);
}

.topic-card:hover {
    border-color: var(--grey-slate);
}

.topic-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-sm);
}

.topic-card__description {
    font-size: var(--font-size-base);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

@media (min-width: 768px) {
    .speaking-topics {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .speaking-topics {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Formats Section (Media Page)
   -------------------------------------------------------------------------- */
.formats-section {
    background-color: var(--color-background-alt);
}

/* --------------------------------------------------------------------------
   Media Appearances Section
   -------------------------------------------------------------------------- */
.media-appearances {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-md);
}

.media-card {
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
    padding: var(--space-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: border-color var(--transition-base);
}

.media-card:hover {
    border-color: var(--grey-slate);
}

.media-card__type {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    flex-shrink: 0;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-md);
    color: var(--grey-slate);
}

.media-card__content {
    flex: 1;
}

.media-card__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-2xs);
}

.media-card__outlet {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-xs);
}

.media-card__date {
    font-size: var(--font-size-xs);
    color: var(--color-text-tertiary);
}

@media (min-width: 768px) {
    .media-appearances {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Article Page Styles
   -------------------------------------------------------------------------- */
.container--narrow {
    max-width: 700px;
}

.article__header {
    padding-top: calc(80px + var(--space-2xl));
    padding-bottom: var(--space-2xl);
    background-color: var(--color-background-alt);
}

.article__back {
    display: inline-flex;
    align-items: center;
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    text-decoration: none;
    margin-bottom: var(--space-xl);
    transition: color var(--transition-base);
}

.article__back:hover {
    color: var(--grey-slate);
}

.article__category {
    display: inline-block;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    letter-spacing: var(--letter-spacing-wider);
    text-transform: uppercase;
    color: var(--grey-slate);
    margin-bottom: var(--space-sm);
}

.article__title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    letter-spacing: var(--letter-spacing-tight);
    line-height: var(--line-height-tight);
    margin-bottom: var(--space-lg);
}

.article__lead {
    font-size: var(--font-size-lg);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-lg);
}

.article__meta {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-tertiary);
}

.article__divider {
    width: 48px;
    height: 2px;
    background-color: var(--grey-slate);
    margin: var(--space-2xl) 0;
}

.article__body {
    padding: var(--space-2xl) 0;
}

.article__body p {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-lg);
}

.article__body h2 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text);
    margin-top: var(--space-2xl);
    margin-bottom: var(--space-md);
}

.article__body h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text);
    margin-top: var(--space-xl);
    margin-bottom: var(--space-sm);
}

.article__body ul,
.article__body ol {
    margin-bottom: var(--space-lg);
    padding-left: var(--space-lg);
}

.article__body li {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-sm);
}

.article__body strong {
    color: var(--color-text);
    font-weight: var(--font-weight-semibold);
}

.article__body a {
    color: var(--grey-steel);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.article__body a:hover {
    text-decoration-color: transparent;
}

.article__body blockquote {
    margin: var(--space-xl) 0;
    padding-left: var(--space-lg);
    border-left: 3px solid var(--grey-slate);
    font-size: var(--font-size-lg);
    font-style: italic;
    color: var(--color-text);
}

.article__body code {
    font-family: var(--font-mono);
    font-size: 0.9em;
    background-color: var(--color-background-alt);
    padding: 0.2em 0.4em;
    border-radius: var(--radius-sm);
}

.article__body pre {
    margin: var(--space-lg) 0;
    padding: var(--space-lg);
    background-color: var(--color-surface-dark);
    border-radius: var(--radius-md);
    overflow-x: auto;
}

.article__body pre code {
    background: none;
    padding: 0;
    font-size: var(--font-size-sm);
}

.article__cta {
    text-align: center;
    padding: var(--space-xl);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    margin-top: var(--space-2xl);
}

.article__cta a {
    color: var(--grey-steel);
    font-weight: var(--font-weight-semibold);
}

/* Related Articles */
.related-articles {
    background-color: var(--color-background-alt);
    border-top: 1px solid var(--color-border-light);
}

/* ==========================================================================
   YouTube / Watch Page Styles
   ========================================================================== */

/* --------------------------------------------------------------------------
   YouTube Hero
   -------------------------------------------------------------------------- */
.yt-hero {
    position: relative;
    padding-top: calc(80px + var(--space-3xl));
    padding-bottom: var(--space-3xl);
    background: linear-gradient(135deg, #111113 0%, #18181B 30%, #1C1C1F 60%, #111113 100%);
    color: var(--color-text-inverse);
    overflow: hidden;
}

.yt-hero__bg {
    position: absolute;
    inset: 0;
    overflow: hidden;
    opacity: 0.15;
}

.yt-hero__wave {
    position: absolute;
    bottom: 0;
    left: -10%;
    width: 120%;
    height: 200px;
    border-radius: 50% 50% 0 0;
}

.yt-hero__wave--1 {
    background: var(--grey-steel);
    opacity: 0.15;
    animation: ytWave 8s ease-in-out infinite;
}

.yt-hero__wave--2 {
    background: var(--color-accent);
    opacity: 0.2;
    animation: ytWave 6s ease-in-out infinite reverse;
    bottom: -20px;
}

@keyframes ytWave {
    0%, 100% { transform: translateY(0) scaleY(1); }
    50% { transform: translateY(-30px) scaleY(1.2); }
}

.yt-hero__equalizer {
    position: absolute;
    bottom: 40px;
    right: 10%;
    display: flex;
    align-items: flex-end;
    gap: 6px;
    height: 120px;
}

.yt-hero__bar {
    display: block;
    width: 8px;
    background: linear-gradient(to top, var(--grey-slate), var(--color-accent));
    border-radius: 4px 4px 0 0;
    animation: eqBounce 1.2s ease-in-out infinite;
}

.yt-hero__bar:nth-child(1) { height: 40%; animation-delay: 0s; }
.yt-hero__bar:nth-child(2) { height: 70%; animation-delay: 0.15s; }
.yt-hero__bar:nth-child(3) { height: 50%; animation-delay: 0.3s; }
.yt-hero__bar:nth-child(4) { height: 90%; animation-delay: 0.45s; }
.yt-hero__bar:nth-child(5) { height: 60%; animation-delay: 0.6s; }
.yt-hero__bar:nth-child(6) { height: 80%; animation-delay: 0.75s; }
.yt-hero__bar:nth-child(7) { height: 45%; animation-delay: 0.9s; }

@keyframes eqBounce {
    0%, 100% { transform: scaleY(1); }
    50% { transform: scaleY(0.4); }
}

.yt-hero__content {
    position: relative;
    z-index: 1;
    max-width: 700px;
}

.yt-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: var(--space-xs) var(--space-md);
    background: rgba(200, 200, 208, 0.1);
    border: 1px solid rgba(200, 200, 208, 0.2);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-accent-light);
    margin-bottom: var(--space-lg);
}

.yt-hero__badge svg {
    width: 18px;
    height: 18px;
}

.yt-hero__title {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-extrabold);
    line-height: var(--line-height-tight);
    letter-spacing: var(--letter-spacing-tight);
    margin-bottom: var(--space-md);
}

.yt-hero__subtitle {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.8);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-xl);
}

.yt-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
    margin-bottom: var(--space-xl);
}

.yt-hero__actions .btn--secondary {
    color: var(--color-text-inverse);
    border-color: rgba(255, 255, 255, 0.3);
}

.yt-hero__actions .btn--secondary:hover {
    border-color: rgba(255, 255, 255, 0.6);
    background-color: rgba(255, 255, 255, 0.1);
}

.yt-hero__stats {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-lg);
}

.yt-hero__stat {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.6);
}

.yt-hero__stat svg {
    color: var(--grey-cloud);
}

/* YouTube Button */
.btn--yt {
    background-color: var(--grey-slate);
    color: var(--color-text-inverse);
}

.btn--yt:hover,
.btn--yt:focus {
    background-color: var(--grey-steel);
    color: var(--color-text-inverse);
    transform: translateY(-1px);
}

.btn--yt svg {
    flex-shrink: 0;
}

/* --------------------------------------------------------------------------
   Content Pillars
   -------------------------------------------------------------------------- */
.yt-pillars {
    background-color: var(--color-background-alt);
}

.yt-pillars__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.yt-pillar {
    padding: var(--space-xl);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    position: relative;
    overflow: hidden;
}

.yt-pillar::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
}

.yt-pillar--music::before {
    background: linear-gradient(90deg, var(--grey-slate), var(--color-accent));
}

.yt-pillar--tech::before {
    background: linear-gradient(90deg, var(--color-accent), var(--grey-cool));
}

.yt-pillar:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.yt-pillar__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    background-color: var(--color-background-alt);
    border-radius: var(--radius-lg);
    color: var(--grey-slate);
    margin-bottom: var(--space-md);
}

.yt-pillar--music .yt-pillar__icon {
    color: var(--grey-slate);
    background-color: rgba(74, 82, 96, 0.1);
}

.yt-pillar__title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-sm);
}

.yt-pillar__description {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-md);
}

.yt-pillar__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
}

.yt-tag {
    padding: 4px var(--space-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    font-family: var(--font-mono);
    background-color: var(--color-background-alt);
    border-radius: var(--radius-sm);
    color: var(--color-text-muted);
}

@media (min-width: 768px) {
    .yt-pillars__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --------------------------------------------------------------------------
   YouTube Embeds (Responsive 16:9)
   -------------------------------------------------------------------------- */
.yt-embed {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background-color: var(--color-surface-dark);
    box-shadow: var(--shadow-lg);
}

.yt-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}

/* --------------------------------------------------------------------------
   Featured Video Section
   -------------------------------------------------------------------------- */
.yt-featured__player {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.yt-subscribe-card {
    padding: var(--space-xl);
    background: linear-gradient(135deg, #18181B 0%, #1C1C1F 100%);
    border-radius: var(--radius-lg);
    text-align: center;
    color: var(--color-text-inverse);
}

[data-theme="light"] .yt-subscribe-card,
:root:not([data-theme="dark"]) .yt-subscribe-card {
    background: linear-gradient(135deg, #18181B 0%, #1C1C1F 100%);
}

.yt-subscribe-card__icon {
    color: var(--grey-cloud);
    margin-bottom: var(--space-md);
}

.yt-subscribe-card__icon svg {
    margin-inline: auto;
}

.yt-subscribe-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-sm);
}

.yt-subscribe-card__text {
    font-size: var(--font-size-sm);
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: var(--space-lg);
    line-height: var(--line-height-relaxed);
}

.yt-quick-links {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.yt-quick-link {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    transition: border-color var(--transition-fast), background-color var(--transition-fast);
}

.yt-quick-link:hover {
    border-color: var(--grey-steel);
    background-color: var(--color-background-alt);
}

.yt-quick-link svg {
    color: var(--grey-slate);
    flex-shrink: 0;
}

@media (min-width: 1024px) {
    .yt-featured__player {
        grid-template-columns: 2fr 1fr;
    }
}

/* --------------------------------------------------------------------------
   Playlists Section
   -------------------------------------------------------------------------- */
.yt-playlists {
    background-color: var(--color-background-alt);
}

.yt-playlists__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

.yt-playlist-card {
    display: flex;
    flex-direction: column;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.yt-playlist-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.yt-playlist-card__visual {
    position: relative;
    height: 180px;
    background: linear-gradient(135deg, var(--grey-slate) 0%, var(--grey-steel) 50%, var(--color-accent) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.yt-playlist-card__visual--deep {
    background: linear-gradient(135deg, #1C1C1F 0%, var(--grey-iron) 50%, var(--color-accent) 100%);
}

.yt-playlist-card__visual--tech {
    background: linear-gradient(135deg, #18181B 0%, var(--grey-cool) 50%, var(--color-accent) 100%);
}

.yt-playlist-card__overlay {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: rgba(255, 255, 255, 0.15);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    border-radius: 50%;
    color: var(--color-text-inverse);
    transition: transform var(--transition-base);
}

.yt-playlist-card:hover .yt-playlist-card__overlay {
    transform: scale(1.1);
}

.yt-playlist-card__content {
    padding: var(--space-lg);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.yt-playlist-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-sm);
}

.yt-playlist-card__description {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    line-height: var(--line-height-relaxed);
    flex: 1;
    margin-bottom: var(--space-md);
}

.yt-playlist-card__link {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    color: var(--color-text);
    transition: gap var(--transition-fast), color var(--transition-fast);
}

.yt-playlist-card__link:hover {
    gap: var(--space-sm);
    color: var(--color-text-secondary);
}

@media (min-width: 768px) {
    .yt-playlists__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Latest Videos Grid
   -------------------------------------------------------------------------- */
.yt-latest__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
    margin-bottom: var(--space-xl);
}

@media (min-width: 768px) {
    .yt-latest__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* --------------------------------------------------------------------------
   YouTube Subscribe CTA
   -------------------------------------------------------------------------- */
.yt-cta {
    background: linear-gradient(135deg, #111113 0%, #18181B 30%, #1C1C1F 60%, #111113 100%);
    color: var(--color-text-inverse);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.yt-cta__content {
    position: relative;
    z-index: 1;
    max-width: 640px;
    margin-inline: auto;
}

.yt-cta__equalizer {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: 4px;
    height: 40px;
    margin-bottom: var(--space-lg);
}

.yt-cta__bar {
    display: block;
    width: 6px;
    background: linear-gradient(to top, var(--grey-slate), var(--color-accent));
    border-radius: 3px 3px 0 0;
    animation: eqBounce 1.2s ease-in-out infinite;
}

.yt-cta__bar:nth-child(1) { height: 50%; animation-delay: 0s; }
.yt-cta__bar:nth-child(2) { height: 80%; animation-delay: 0.2s; }
.yt-cta__bar:nth-child(3) { height: 60%; animation-delay: 0.4s; }
.yt-cta__bar:nth-child(4) { height: 100%; animation-delay: 0.6s; }
.yt-cta__bar:nth-child(5) { height: 70%; animation-delay: 0.8s; }

.yt-cta__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-md);
}

.yt-cta__title em {
    color: var(--grey-cloud);
    font-style: normal;
}

.yt-cta__description {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.8);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--space-xl);
}

.yt-cta__actions {
    margin-bottom: var(--space-xl);
}

.yt-cta__hashtags {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-sm);
    font-family: var(--font-mono);
    font-size: var(--font-size-xs);
    color: rgba(255, 255, 255, 0.4);
}

/* --------------------------------------------------------------------------
   Video Library
   -------------------------------------------------------------------------- */
.yt-library {
    background-color: var(--color-background);
}

.yt-library__filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-xs);
    margin-bottom: var(--space-xl);
}

.yt-filter {
    padding: var(--space-xs) var(--space-md);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-full);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    font-family: var(--font-primary);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.yt-filter:hover {
    border-color: var(--grey-steel);
    color: var(--color-text);
}

.yt-filter--active {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-text-inverse);
}

.yt-library__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 640px) {
    .yt-library__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .yt-library__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* --------------------------------------------------------------------------
   Video Card
   -------------------------------------------------------------------------- */
.yt-video-card {
    display: flex;
    flex-direction: column;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    text-decoration: none;
    color: inherit;
}

.yt-video-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.yt-video-card__thumb {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background-color: var(--color-primary);
}

.yt-video-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.yt-video-card:hover .yt-video-card__thumb img {
    transform: scale(1.05);
}

.yt-video-card__play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(17, 17, 19, 0.85);
    border-radius: 50%;
    color: var(--color-text-inverse);
    opacity: 0;
    transition: opacity var(--transition-fast), transform var(--transition-fast);
}

.yt-video-card:hover .yt-video-card__play {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.1);
}

.yt-video-card__views {
    position: absolute;
    bottom: var(--space-xs);
    right: var(--space-xs);
    padding: 2px var(--space-xs);
    background: rgba(0, 0, 0, 0.8);
    border-radius: var(--radius-sm);
    font-size: 11px;
    font-weight: var(--font-weight-medium);
    color: var(--color-text-inverse);
}

.yt-video-card__info {
    padding: var(--space-md);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.yt-video-card__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-snug);
    margin-bottom: var(--space-xs);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.yt-video-card__meta {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    margin-top: auto;
}

.yt-video-card[hidden] {
    display: none;
}

/* --------------------------------------------------------------------------
   Individual Video Watch Page
   -------------------------------------------------------------------------- */
.watch-page {
    padding-top: calc(80px + var(--space-xl));
    padding-bottom: var(--space-2xl);
}

.watch-page__back {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
    margin-bottom: var(--space-lg);
    transition: color var(--transition-fast);
}

.watch-page__back:hover {
    color: var(--color-text);
}

.watch-page__player {
    margin-bottom: var(--space-xl);
}

.watch-page__details {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
}

@media (min-width: 1024px) {
    .watch-page__details {
        grid-template-columns: 2fr 1fr;
    }
}

.watch-page__info {
    max-width: 800px;
}

.watch-page__category {
    display: inline-block;
    padding: 2px var(--space-sm);
    background-color: rgba(200, 200, 208, 0.12);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-semibold);
    color: var(--color-accent-dark);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--space-sm);
}

.watch-page__title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-snug);
    margin-bottom: var(--space-sm);
}

.watch-page__meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-lg);
}

.watch-page__description {
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    white-space: pre-line;
}

.watch-page__sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.watch-page__actions {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.watch-page__yt-link {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-md);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-md);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    transition: border-color var(--transition-fast);
}

.watch-page__yt-link:hover {
    border-color: var(--grey-steel);
}

.watch-page__yt-link svg {
    color: var(--grey-slate);
    flex-shrink: 0;
}

/* Related Videos on Watch Page */
.watch-related {
    background-color: var(--color-background-alt);
}

.watch-related__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-lg);
}

@media (min-width: 640px) {
    .watch-related__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .watch-related__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* --------------------------------------------------------------------------
   YouTube Shorts Section
   -------------------------------------------------------------------------- */
.yt-shorts {
    background-color: var(--color-background-alt);
}

.yt-shorts__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-md);
}

@media (min-width: 640px) {
    .yt-shorts__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .yt-shorts__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 1024px) {
    .yt-shorts__grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

.yt-short-card {
    display: flex;
    flex-direction: column;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    text-decoration: none;
    color: inherit;
}

.yt-short-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.yt-short-card__thumb {
    position: relative;
    aspect-ratio: 9 / 16;
    overflow: hidden;
    background-color: var(--color-primary);
}

.yt-short-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.yt-short-card:hover .yt-short-card__thumb img {
    transform: scale(1.05);
}

.yt-short-card__play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(17, 17, 19, 0.85);
    border-radius: 50%;
    color: var(--color-text-inverse);
    opacity: 0;
    transition: opacity var(--transition-fast), transform var(--transition-fast);
}

.yt-short-card:hover .yt-short-card__play {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.1);
}

.yt-short-card__badge {
    position: absolute;
    bottom: var(--space-sm);
    left: var(--space-sm);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: rgba(0, 0, 0, 0.75);
    color: var(--color-text-inverse);
    font-size: 11px;
    font-weight: var(--font-weight-semibold);
    border-radius: var(--radius-sm);
    letter-spacing: 0.02em;
}

.yt-short-card__info {
    padding: var(--space-sm) var(--space-md) var(--space-md);
}

.yt-short-card__title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-snug);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Shorts Coming Soon State */
.yt-shorts__coming-soon {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--space-2xl) var(--space-lg);
    background-color: var(--color-surface);
    border: 2px dashed var(--color-border-light);
    border-radius: var(--radius-lg);
}

.yt-shorts__coming-soon-icon {
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--grey-slate), var(--grey-steel));
    border-radius: 50%;
    color: var(--color-text-inverse);
    margin-bottom: var(--space-md);
}

.yt-shorts__coming-soon h3 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    margin-bottom: var(--space-xs);
}

.yt-shorts__coming-soon p {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    max-width: 400px;
    line-height: var(--line-height-relaxed);
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .yt-hero__wave,
    .yt-hero__bar,
    .yt-cta__bar {
        animation: none;
    }
}

/* --------------------------------------------------------------------------
   Legal Pages (Privacy Policy, Terms, Cookies)
   -------------------------------------------------------------------------- */
.legal-content {
    padding-top: var(--space-xl);
    padding-bottom: var(--space-3xl);
}

.legal-body {
    font-size: var(--font-size-base);
    line-height: var(--line-height-relaxed);
    color: var(--color-text-primary);
}

.legal-effective {
    font-family: var(--font-mono);
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    padding: var(--space-md) var(--space-lg);
    background: var(--color-background-alt);
    border-radius: var(--radius-md);
    border-left: 3px solid var(--grey-slate);
    margin-bottom: var(--space-2xl);
}

.legal-section {
    margin-bottom: var(--space-2xl);
    padding-bottom: var(--space-xl);
    border-bottom: 1px solid var(--color-border);
}

.legal-section:last-of-type {
    border-bottom: none;
}

.legal-section h2 {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-text-primary);
    margin-bottom: var(--space-md);
}

.legal-section h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-top: var(--space-lg);
    margin-bottom: var(--space-sm);
}

.legal-section p {
    margin-bottom: var(--space-md);
    color: var(--color-text-secondary);
}

.legal-section ul {
    list-style: none;
    padding: 0;
    margin-bottom: var(--space-md);
}

.legal-section ul li {
    position: relative;
    padding-left: var(--space-lg);
    margin-bottom: var(--space-sm);
    color: var(--color-text-secondary);
}

.legal-section ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.65em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--grey-slate);
}

.legal-section a {
    color: var(--grey-steel);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.legal-section a:hover {
    opacity: 0.8;
}

.legal-contact-box {
    background: var(--color-background-alt);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-lg);
    margin: var(--space-md) 0;
}

.legal-contact-box p {
    margin-bottom: var(--space-xs);
    color: var(--color-text-secondary);
}

.legal-contact-box p:last-child {
    margin-bottom: 0;
}

.legal-table-wrap {
    overflow-x: auto;
    margin: var(--space-lg) 0;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

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

.legal-table thead {
    background: var(--color-background-alt);
}

.legal-table th {
    text-align: left;
    padding: var(--space-sm) var(--space-md);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    border-bottom: 2px solid var(--color-border);
    white-space: nowrap;
}

.legal-table td {
    padding: var(--space-sm) var(--space-md);
    color: var(--color-text-secondary);
    border-bottom: 1px solid var(--color-border);
    vertical-align: top;
}

.legal-table tr:last-child td {
    border-bottom: none;
}

.legal-table code {
    font-family: var(--font-mono);
    font-size: var(--font-size-sm);
    background: var(--color-background-alt);
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    color: var(--grey-steel);
}

.legal-nav {
    display: flex;
    gap: var(--space-xl);
    flex-wrap: wrap;
    padding-top: var(--space-xl);
    margin-top: var(--space-xl);
    border-top: 2px solid var(--color-border);
}

.section__footer--centered {
    text-align: center;
    display: flex;
    justify-content: center;
}

@media (max-width: 600px) {
    .legal-table {
        font-size: var(--font-size-xs);
    }

    .legal-table th,
    .legal-table td {
        padding: var(--space-xs) var(--space-sm);
    }

    .legal-nav {
        flex-direction: column;
        gap: var(--space-md);
    }
}

