/* ==========================================================================
   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-accent);
    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;
}

/* --------------------------------------------------------------------------
   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(--color-accent), 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(--color-accent);
    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(--color-accent);
    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(--color-accent);
}

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

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

/* --------------------------------------------------------------------------
   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(--color-accent);
    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-accent);
}

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

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

@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-accent);
}

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

/* --------------------------------------------------------------------------
   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(--color-accent);
    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(--color-accent);
    box-shadow: 0 0 0 3px rgba(212, 160, 23, 0.15);
}

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

.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(--color-accent);
    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-accent);
    border-color: var(--color-accent);
    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(--color-accent);
    padding: 2px var(--space-xs);
    background-color: rgba(212, 160, 23, 0.1);
    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-accent);
}

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

@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(--color-accent);
    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-accent);
    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);
    color: var(--color-accent);
}

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

.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
   -------------------------------------------------------------------------- */
.impact-metrics {
    padding-bottom: 0;
}

.impact-card__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-top: var(--space-xs);
}

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

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

.recognition-badge__icon {
    font-size: var(--font-size-2xl);
}

.recognition-badge__content {
    display: flex;
    flex-direction: column;
    gap: var(--space-2xs);
}

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

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

/* --------------------------------------------------------------------------
   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(--color-accent);
}

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

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

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

.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(--color-accent);
    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(--color-accent);
    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(--color-accent);
    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(--color-accent);
    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(--color-accent);
    font-weight: var(--font-weight-semibold);
}

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

