/* ==================================================================================================================
   MARKETING PAGES
   Uses design tokens from base.css
   ================================================================================================================== */

/* ==================================================================================================================
   Layout (outer wrapper & container)
   ================================================================================================================== */

.site-wrapper {
    min-height: 100vh;
    padding: 0 ;
}

.site-container {
    background: linear-gradient(to right, var(--surface-base), var(--color-pale-silver-100), var(--surface-base));
    padding: var(--spacing-20) var(--spacing-6);
    margin: 0 auto;
    min-height: 100vh;
}

/* ==================================================================================================================
   NAVIGATION
   ================================================================================================================== */

/* Header, fixed at top on mobile */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: var(--z-fixed);
    padding: 0 var(--spacing-5);
    pointer-events: none;
}

/* Main navigation bar */
.main-nav {
    max-width: var(--container-xs);
    margin: var(--spacing-3) auto 0;
}

.main-nav__container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--nav-bg);
    border: 1px solid var(--nav-border);
    border-radius: var(--nav-radius);
    box-shadow: var(--nav-shadow);
    padding: var(--nav-padding-y) var(--nav-padding-x);
    pointer-events: auto;
}

/* Logo */
.main-nav__logo {
    display: flex;
    flex-shrink: 0;
    text-decoration: none;
    padding: var(--spacing-1);
    border-radius: var(--radius-md);
    background: var(--nav-bg);
    transition: var(--transition-fast);
}

.main-nav__logo:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.main-nav__logo:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.main-nav__logo-image {
    height: 2rem;
    width: auto;
}

/* Mobile menu button */
.main-nav__menu-button {
    display: flex;
    align-items: center;
    background: var(--nav-bg);
    border: none;
    color: var(--text-primary);
    font-weight: var(--font-bold);
    font-size: var(--text-base);
    cursor: pointer;
    padding: var(--button-padding-y-sm) var(--button-padding-x-sm);
    border-radius: var(--radius-md);
    transition: var(--transition-fast);
}

.main-nav__menu-button:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.main-nav__menu-button:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* Desktop navigation links, hidden on mobile */
.main-nav__links {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* CTA button, hidden on mobile */
.main-nav__cta {
    display: none;
}


/* ==================================================================================================================
   BUTTONS
   ================================================================================================================== */

.btn {
    display: inline-block;
    padding: var(--button-padding-y-sm) var(--button-padding-x-sm);
    font-weight: var(--font-bold);
    font-size: var(--text-sm);
    text-decoration: none;
    border-radius: var(--radius-full);
    border: none;
    cursor: pointer;
    transition: var(--transition-fast);
    text-align: center;
}

.btn--primary {
    background: var(--button-primary-bg);
    color: var(--button-primary-text);
}

.btn--primary:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn--primary:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn--secondary {
    background: var(--button-secondary-bg);
    color: var(--button-secondary-text);
}

.btn--secondary:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.btn--secondary:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* ==================================================================================================================
   REVIEWS (WWW home page)
   ================================================================================================================== */

.reviews {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-2);
}

.review {
    max-width: 100%;
}

.review--hidden-mobile {
    display: none;
}

.review__link {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: var(--spacing-2);
    border-radius: var(--radius-lg);
    transition: var(--transition-fast);
}

.review__link:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.review__link:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.review__stars {
    color: var(--review-star-color);
    font-size: var(--text-sm);
    margin-bottom: var(--spacing-2);
}

.review__text {
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    color: var(--text-secondary);
    font-style: italic;
    margin: 0;
}

/* Show all reviews at tablet size and up */
@media (min-width: 768px) {
    .review--hidden-mobile {
        display: block;
    }
}

/* ==================================================================================================================
   HERO SECTION (WWW home page)
   ================================================================================================================== */

.hero {
    padding: var(--spacing-12) 0 var(--spacing-16);
    text-align: center;
}

.hero__content {
    max-width: var(--container-sm);
    margin: 0 auto;
}

.hero__title {
    font-size: var(--text-5xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
    background: linear-gradient(135deg, var(--color-charcoal-700), var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--text-secondary); /* Fallback */
}

.hero__tagline {
    font-size: var(--text-3xl);
    font-weight: var(--font-extrabold);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
    background: linear-gradient(135deg, var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--text-secondary); /* Fallback */
}


/* ==================================================================================================================
   PRACTICE HERO (Practice home page)
   ================================================================================================================== */

.practice-hero {
    padding: var(--spacing-12) 0 var(--spacing-8);
}

.practice-hero__card {
    max-width: var(--container-xl);
    margin: 0 auto;
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.practice-hero__header {
    padding: var(--spacing-8) var(--spacing-16);
    text-align: center;
}

.practice-hero__title {
    font-size: var(--text-4xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
    background: linear-gradient(135deg, var(--color-charcoal-700), var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--color-charcoal-800);
}

.practice-hero__tagline {
    font-size: var(--text-2xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-3);
    background: linear-gradient(135deg, var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--text-secondary); /* Fallback */
}

.practice-hero__description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-secondary);
    max-width: var(--container-sm);
    margin: 0 auto;
}

.practice-hero__actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-3);
}

.practice-hero__video {
    width: 100%;
    max-width: var(--container-md);
    margin-top: var(--spacing-4);
    line-height: 0;
}


/* ==================================================================================================================
   PRACTICES SECTION
   ================================================================================================================== */

.practices {
    padding-bottom: var(--spacing-16)
}

.practices__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-12);
}


/* ==================================================================================================================
   PRACTICE CARDS
   ================================================================================================================== */

.practice-card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    overflow: hidden;
    transition: all var(--transition-base);
}

.practice-card:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-2px);
    box-shadow: var(--shadow-xl);
}

.practice-card:has(.practice-card__link:focus-visible) {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-xl);
}

.practice-card__link {
    display: block;
    text-decoration: none;
    color: inherit;
    border-radius: var(--card-radius);
}

.practice-card__content {
    padding: var(--spacing-6);
}

.practice-card__title {
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--text-brand);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-3);
}

.practice-card__description {
    font-size: var(--text-base);
    color: var(--text-primary);
    line-height: var(--leading-relaxed);
    margin: 0;
}

.practice-card__image {
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    padding: 0 var(--spacing-6);
    background: var(--card-bg);
}

.practice-practice-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}


/* ==================================================================================================================
   VIDEO TRIGGER
   ================================================================================================================== */

.video-trigger {
    position: relative;
    width: 100%;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    overflow: hidden;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    transition: var(--transition-fast);
}

.video-trigger:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.video-trigger:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.video-trigger__image {
    width: 100%;
    height: auto;
    display: block;
}

.video-trigger__button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    background: var(--surface-base);
    padding: var(--spacing-2);
    padding-right: var(--spacing-4);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-md);
    transition: var(--transition-fast);
}

.video-trigger__icon {
    width: var(--icon-md);
    height: var(--icon-md);
}

.video-trigger__text {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--text-primary);
}


/* ==================================================================================================================
   TESTIMONIALS
   ================================================================================================================== */

.testimonials {
    padding: var(--spacing-12) var(--spacing-6) var(--spacing-16);
    max-width: var(--container-lg);
    margin: 0 auto;
}

.testimonials__header{
    text-align: center;
    margin-bottom: var(--spacing-8);
}

.testimonials__title{
    font-size: var(--text-3xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
}

.testimonials__title em {
    font-style: italic;
}

.testimonials__description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-secondary);
    max-width: var(--container-sm);
    margin: 0 auto;
}

.testimonials__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-8);
}


/* ==================================================================================================================
   TESTIMONIAL CARD
   ================================================================================================================== */

.testimonial {
    position: relative;
    background: linear-gradient(135deg, var(--color-cultured-50), var(--color-charcoal-50), var(--color-cultured-50));
    border: 1px solid var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    padding: var(--spacing-6);
    padding-top: var(--spacing-8);
}

.testimonial__author {
    position: absolute;
    top: calc(var(--spacing-4) * -1);
    left: calc(var(--spacing-4) * -1);
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    background: var(--surface-base);
    padding: var(--spacing-1);
    padding-right: var(--spacing-4);
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-sm);
    text-decoration: none;
    transition: var(--transition-fast);
}

.testimonial__author:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.testimonial__author:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-xl);
}

.testimonial__avatar {
    width: var(--icon-md);
    height: var(--icon-md);
    border-radius: var(--radius-full);
    object-fit: cover;
}

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

.testimonial__content p {
    font-size: var(--text-xs);
    line-height: var(--leading-relaxed);
    color: var(--text-primary);
}


/* ==================================================================================================================
   PATIENT EXPERIENCE
   ================================================================================================================== */

.patient-experience {
    padding: var(--spacing-12) var(--spacing-6) var(--spacing-16);
    max-width: var(--container-lg);
    margin: 0 auto;
}

.experience-step {
    margin-bottom: var(--spacing-12);
}

.experience-step:last-child {
    margin-bottom: 0;
}

.experience-step__header {
    text-align: center;
    margin-bottom: var(--spacing-6);
}

.experience-step__title {
    font-size: var(--text-3xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
    background: linear-gradient(135deg, var(--color-charcoal-700), var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--text-secondary); /* Fallback */
}

.experience-step__description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-secondary);
    max-width: var(--container-md);
    margin: 0 auto;
}

.experience-step__figure {
    margin: 0 var(--spacing-5);
}

.experience-step__image {
    width: 100%;
    max-width: var(--container-md);
    height: auto;
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-lg);
    display: block;
    margin: 0 auto;
}


/* ==================================================================================================================
   TEAM
   ================================================================================================================== */

.team {
    padding: var(--spacing-12) var(--spacing-6) var(--spacing-16);
    max-width: var(--container-lg);
    margin: 0 auto;
}

.team__header {
    text-align: center;
    margin-bottom: var(--spacing-8);
}

.team__title {
    font-size: var(--text-3xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
    background: linear-gradient(135deg, var(--color-charcoal-700), var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--text-secondary); /* Fallback */
}

.team__description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-secondary);
    max-width: var(--container-sm);
    margin: 0 auto;
}


/* ==================================================================================================================
   TEAM MEMBER CARD
   ================================================================================================================== */

.team__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-4);
    max-width: var(--container-md);
    margin: 0 auto;
}

.team-member {
    background: var(--card-bg);
    border-radius: var(--radius-xl);
    box-shadow: var(--card-shadow);
    overflow: hidden;
    transition: var(--transition-fast);
}

.team-member:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.team-member__figure {
    position: relative;
    margin: 0;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.team-member__media {
    position: relative;
}

.team-member__image {
    aspect-ratio: 2 / 3;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: center;
    display: block;
}

.team-member__placeholder {
    aspect-ratio: 2 / 3;
    width: 100%;
    background: var(--color-pale-silver-200);
    display: flex;
    align-items: center;
    justify-content: center;
}

.team-member__placeholder-icon {
    width: var(--icon-xl);
    height: var(--icon-xl);
    color: var(--text-tertiary);
}

.team-member__badge {
    position: absolute;
    bottom: var(--spacing-2);
    left: var(--spacing-2);
    display: inline-flex;
    align-items: center;
    background: var(--color-pale-silver-200);
    padding: var(--spacing-1) var(--spacing-2);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    box-shadow: var(--shadow-sm);
}

.team-member__caption {
    padding: var(--spacing-2);
    text-align: center;
}

.team-member__name {
    font-size: var(--text-xs);
    font-weight: var(--font-bold);
    margin-bottom: var(--spacing-1);
}

.team-member__title {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    margin: 0;
}


/* ==================================================================================================================
   CONTACT SECTION
   ================================================================================================================== */

.contact {
    padding: var(--spacing-12) var(--spacing-6) var(--spacing-12);
    max-width: var(--container-lg);
    margin: 0 auto;
    scroll-margin-top: var(--spacing-16);
}

.contact__card {
    background: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: var(--card-radius);
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.contact__header {
    padding: var(--spacing-8) var(--spacing-6) var(--spacing-6);
    text-align: center;
}

.contact__title {
    font-size: var(--text-3xl);
    font-weight: var(--font-black);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-4);
    background: linear-gradient(135deg, var(--color-charcoal-700), var(--color-charcoal-500), var(--color-charcoal-700));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    color: var(--text-secondary);
}

.contact__description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    color: var(--text-secondary);
    max-width: var(--container-sm);
    margin: 0 auto;
}

.contact__body {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    padding: 0 var(--spacing-6) var(--spacing-6);
}

/* Group container */
.contact__group {
    margin: 0;
    padding: var(--spacing-4);
    background: var(--surface-base);
    border-radius: var(--radius-lg);
    border: 1px solid var(--card-border);
}

/* Row within group */
.contact__row {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--spacing-2) var(--spacing-4);
    align-items: center;
    padding: var(--spacing-2) 0;
}

.contact__row--header {
    padding-bottom: var(--spacing-3);
    margin-bottom: var(--spacing-2);
}

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

.contact__value {
    font-size: var(--text-sm);
    color: var(--text-primary);
    text-align: right;
}

/* Hours-specific styling */
.contact__group--hours .contact__row--header .contact__label {
    font-size: var(--text-base);
    font-weight: var(--font-bold);
    color: var(--text-primary);
}

.contact__row--today {
    background: var(--color-pale-silver-100);
    margin: 0 calc(var(--spacing-4) * -1);
    padding-left: var(--spacing-4);
    padding-right: var(--spacing-4);
    border-radius: var(--radius-md);
}

.contact__row--today .contact__label,
.contact__row--today .contact__value {
    font-weight: var(--font-bold);
    color: var(--text-brand);
}

.contact__hours-note {
    font-size: var(--text-xs);
    font-style: italic;
    color: var(--text-tertiary);
    margin: 0;
}

/* Links */
.contact__link {
    color: var(--link-default);
    text-decoration: underline;
    transition: var(--transition-fast);
}

.contact__link:hover {
    color: var(--link-hover);
    filter: var(--interactive-brightness);
}

.contact__address-link {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--spacing-0_5);
    padding: var(--spacing-2) var(--spacing-4);
    background: var(--color-pale-silver-100);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: var(--text-primary);
    font-size: var(--text-sm);
    transition: var(--transition-fast);
}

.contact__address-link:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* Social links */
.contact__social {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-2);
}

.contact__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--color-pale-silver-200);
    padding: var(--spacing-2);
    border-radius: var(--radius-full);
    color: var(--text-primary);
    transition: var(--transition-fast);
}

.contact__social-link:hover {
    background: var(--color-pale-silver-300);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
}

.contact__social-icon {
    width: var(--icon-md);
    height: var(--icon-md);
}


/* ==================================================================================================================
   VIDEO MODAL
   ================================================================================================================== */

.video-modal {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    margin: 0;
    padding: 0;
    border: none;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    z-index: var(--z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
}

.video-modal::backdrop {
    background: transparent;
}

.video-modal:not([open]) {
    display: none;
}

.video-modal__close {
    position: absolute;
    top: var(--spacing-6);
    right: var(--spacing-6);
    background: transparent;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: var(--spacing-2);
    border-radius: var(--radius-md);
    transition: var(--transition-fast);
}

.video-modal__close:hover {
    color: var(--text-primary);
}

.video-modal__close:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-xl);
}

.video-modal__close svg {
    width: var(--spacing-8);
    height: var(--spacing-8);
    display: block;
}

.video-modal__content {
    width: 100%;
    max-width: var(--container-lg);
    padding: var(--spacing-4);
}

.video-modal__player {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: var(--color-charcoal-900);
    border-radius: var(--radius-lg);
}


/* ==================================================================================================================
   FOOTER
   ================================================================================================================== */

.footer {
    padding: var(--spacing-8) 0 var(--spacing-16);
    text-align: center;
}

.footer__nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-8);
    padding: 0;
}

.footer__nav-link {
    display: inline-block;
    padding: var(--button-padding-y-sm) var(--button-padding-x-sm);
    background: var(--button-primary-bg);
    color: var(--button-primary-text);
    text-decoration: none;
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    transition: var(--transition-fast);
}

.footer__nav-link:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

.footer__nav-link:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}

/* Current page indicator */
.footer__nav-link--current {
    background: var(--color-pale-silver-300);
    color: var(--text-tertiary);
    cursor: default;
}

.footer__nav-link--current:hover {
    filter: none;
    transform: none;
    box-shadow: none;
}

.footer__copyright {
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
    color: var(--text-secondary);
    line-height: var(--leading-relaxed);
    max-width: var(--container-sm);
    margin: 0 auto;
}

.footer__copyright-link {
    color: var(--link-default);
    text-decoration: underline;
    transition: var(--transition-fast);
    display: inline-block;
    border-radius: var(--radius-full);
}

.footer__copyright-link:hover {
    color: var(--link-hover);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
}

.footer__copyright-link:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-1px);
}

/* ==================================================================================================================
   FLOATING CTA BUTTON
   ================================================================================================================== */

.floating-cta {
    position: fixed;
    bottom: var(--spacing-5);
    left: 50%;
    transform: translateX(-50%) translateY(5rem);
    z-index: var(--z-floating);
    opacity: 0;
    pointer-events: none;
    transition: var(--transition-slow);
}

/* When visible (controlled by JS) */
.floating-cta--visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}

.floating-cta__link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--button-padding-y-sm) var(--button-padding-x-sm);
    background: var(--button-primary-bg);
    color: var(--button-primary-text);
    font-weight: var(--font-bold);
    font-size: var(--text-lg);
    text-decoration: none;
    border-radius: var(--radius-full);
    box-shadow: var(--shadow-lg);
    transition: var(--transition-fast);
}


.floating-cta__link:hover {
    filter: var(--interactive-brightness);
    transform: translateY(-2px);
    box-shadow: var(--shadow-xl);
}

.floating-cta__link:focus-visible {
    outline: var(--button-focus-ring-width) solid var(--button-focus-ring);
    outline-offset: var(--button-focus-ring-offset);
    filter: var(--interactive-brightness);
    transform: translateY(-2px);
    box-shadow: var(--shadow-xl);
}

/* Responsive padding on body */
/*@media (min-width: 1024px) {*/
/*    .site-wrapper {*/
/*        padding: var(--spacing-14) var(--spacing-6);*/
/*    }*/

/*    .site-container {*/
/*        border-radius: var(--radius-3xl);*/
/*    }*/
/*}*/

/*@media (min-width: 1536px) {*/
/*    .site-wrapper {*/
/*        padding: var(--spacing-18) var(--spacing-10);*/
/*    }*/

/*    .site-container {*/
/*        padding: var(--spacing-16) var(--spacing-16);*/
/*    }*/
/*}*/
