/* ========================================
   QFlow - Premium Queue Management System
   Tokens: css/tokens.css | Fonts: css/fonts.css
   ======================================== */

/* ========================================
   Base Styles
   ======================================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: var(--text-body-weight);
    line-height: var(--text-body-line);
    color: var(--color-text);
    background: var(--color-bg-primary);
    overflow-x: hidden;
    font-synthesis: none;
}

p {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
}

.btn,
.navbar,
.nav-link,
.form-control,
.form-label,
.form-check-label {
    font-family: var(--font-body);
}

h1, h2, h3, h4, h5, h6,
.display-3, .display-5 {
    font-family: var(--font-heading);
    color: var(--color-title);
}

h1, .display-3 {
    font-size: var(--text-h1-size);
    line-height: var(--text-h1-line);
    font-weight: var(--text-h1-weight);
}

h2, .display-5 {
    font-size: var(--text-h2-size);
    line-height: var(--text-h2-line);
    font-weight: var(--text-h2-weight);
}

h3 { font-size: var(--text-h3-size); line-height: var(--text-h3-line); font-weight: var(--text-h3-weight); }
h4 { font-size: var(--text-h4-size); line-height: var(--text-h4-line); font-weight: var(--text-h4-weight); }
h5 { font-size: var(--text-h5-size); line-height: var(--text-h5-line); font-weight: var(--text-h5-weight); }

.lead {
    font-size: var(--text-body-lg-size);
    line-height: var(--text-body-lg-line);
    color: var(--color-text);
}

.text-muted {
    color: var(--color-text-muted) !important;
}

/* ========================================
   Page Shell (CRITICAL REQUIREMENT)
   ======================================== */
.page-shell {
    position: relative;
    width: 100%;
    min-height: 100vh;
    background: var(--color-white);
    overflow-x: hidden;
    padding: var(--shell-padding);
}

.page-shell__dots {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

.page-shell__dot {
    position: absolute;
    width: 20px;
    height: 20px;
    max-width: 20px;
    max-height: 20px;
    border-radius: 50%;
    background: rgba(var(--accent-color-rgb), 0.5);
    animation-name: page-dot-float;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
    will-change: transform;
}

.page-shell__dot--muted {
    background: rgba(120, 105, 85, 0.35);
}

@keyframes page-dot-float {
    0% {
        transform: translate3d(0, 0, 0) rotate(0deg);
    }

    25% {
        transform: translate3d(var(--dot-x1, 0), var(--dot-y1, 0), 0) rotate(var(--dot-r1, 0deg));
    }

    50% {
        transform: translate3d(var(--dot-x2, 0), var(--dot-y2, 0), 0) rotate(var(--dot-r2, 0deg));
    }

    75% {
        transform: translate3d(var(--dot-x3, 0), var(--dot-y3, 0), 0) rotate(var(--dot-r3, 0deg));
    }

    100% {
        transform: translate3d(0, 0, 0) rotate(0deg);
    }
}

@media (prefers-reduced-motion: reduce) {
    .page-shell__dots {
        display: none;
    }
}

@media (max-width: 768px) {
    .page-shell {
        padding: var(--shell-padding-mobile);
    }
}

.page-inner {
    position: relative;
    z-index: 1;
    border-radius: var(--page-inner-radius);
    overflow: hidden;
    background: var(--color-white);
}

@media (max-width: 768px) {
    .page-inner {
        border-radius: 0;
    }
}

/* ========================================
   Container horizontal padding (site-wide)
   ======================================== */
.container-fluid.qf-container,
.qf-container {
    --bs-gutter-x: 0;
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding-left: var(--section-padding-x);
    padding-right: var(--section-padding-x);
}

/* Restore Bootstrap row gutters inside our containers */
.container-fluid.qf-container .row,
.qf-container .row {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    margin-inline: calc(var(--bs-gutter-x) * -0.5);
}

/* Shared vertical inset for all page sections */
[class$="-section"]:not(.hero-section):not(.about-section):not(.value-section):not(.story-timeline-section):not(.video-section):not(.transformation-timeline-section) {
    padding-top: var(--section-padding-y);
    padding-bottom: var(--section-padding-y);
}

/* ========================================
   Header with Logo Notch (CRITICAL)
   ======================================== */
.site-header {
    position: relative;
    background: transparent;
    min-height: calc(var(--logo-notch-height) + 1.56rem + var(--section-padding-x));
    padding-top: var(--section-padding-x);
    padding-bottom: 0;
    isolation: isolate;
}

/*
 * Workaround A — true die-cut on a background layer only (nav + logo stay unmasked).
 * The hole reveals page-inner white behind the header.
 */
.site-header__bg {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: -1px;
    z-index: 0;
    background: var(--color-bg-header);
    pointer-events: none;
    -webkit-mask-image: linear-gradient(#fff 0 0), var(--logo-notch-mask);
    mask-image: linear-gradient(#fff 0 0), var(--logo-notch-mask);
    -webkit-mask-size: 100% 100%, var(--logo-notch-width) var(--logo-notch-height);
    mask-size: 100% 100%, var(--logo-notch-width) var(--logo-notch-height);
    -webkit-mask-position: 0 0, center 0;
    mask-position: 0 0, center 0;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-composite: xor;
    mask-composite: exclude;
}

.site-header__inner {
    position: relative;
    z-index: 3;
    margin-top: calc(-1 * var(--section-padding-x));
    padding-top: 0.78rem;
}

.site-header__bar {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
    width: 100%;
    padding-top: 0.5rem;
}

@media (min-width: 1400px) {
    .site-header__bar {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding-top: 1rem;
    }
}

.site-header__nav {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 0.75rem;
}

@media (min-width: 1400px) {
    .site-header__nav {
        flex-wrap: nowrap;
        gap: 0.75rem;
    }
}

.site-header__nav .btn {
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: calc(var(--text-body-sm-size) + 2px);
    white-space: nowrap;
}

.site-header__actions {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 0.75rem;
}

.site-header__actions .navbar-tagline {
    white-space: nowrap;
    font-size: 0.8125rem;
}

.site-header .navbar {
    padding: 0;
    border: none;
    box-shadow: none;
    display: flex;
    justify-content: flex-end;
}

.site-header .navbar-toggler {
    border: none;
    padding: 0.5rem 0.75rem;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    margin-left: auto;
}

.site-header .navbar-toggler:focus {
    box-shadow: none;
    background: rgba(255, 255, 255, 0.2);
}

.site-header .navbar-toggler-icon {
    width: 1.5rem;
    height: 1.5rem;
}

.site-header .navbar-collapse {
    border: none;
}

@media (max-width: 1399px) {
    .site-header .navbar-collapse {
        background: rgba(0, 0, 0, 0.95);
        margin-top: 1rem;
        padding: 1.5rem;
        border-radius: 12px;
    }
    
    .site-header__bar {
        gap: 1.5rem;
    }
    
    .site-header__nav {
        flex-direction: column;
        gap: 1rem;
    }
    
    .site-header__nav .btn {
        width: 100%;
    }
    
    .site-header__actions {
        flex-direction: column;
        gap: 0.75rem;
        width: 100%;
    }
    
    .site-header__actions .btn {
        width: 100%;
    }
}

.site-header .nav-link {
    color: var(--color-text-on-dark);
    font-family: var(--font-body);
    font-weight: 400;
    font-size: calc(var(--text-body-sm-size) + 2px);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0.5rem 0;
    position: relative;
    transition: color 0.3s ease, transform 0.2s ease;
}

.site-header .nav-link::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--accent-color);
    transition: width 0.3s ease;
}

.site-header .nav-link:hover,
.site-header .nav-link:focus {
    color: var(--color-text-inverse);
    transform: translateY(-2px);
}

.site-header .nav-link:hover::after,
.site-header .nav-link:focus::after {
    width: 100%;
}

.navbar-tagline {
    color: var(--color-text-on-dark);
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: 700;
    text-decoration: underline;
    text-underline-offset: 3px;
    margin-bottom: 0;
    transition: color 0.3s ease, text-underline-offset 0.2s ease;
}

.navbar-tagline:hover,
.navbar-tagline:focus {
    color: var(--accent-color);
    text-decoration: underline;
    text-underline-offset: 5px;
}

.btn-accent {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    color: var(--color-text-on-dark);
    font-family: var(--font-body);
    font-size: var(--text-button-size);
    font-weight: var(--text-button-weight);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border-radius: 10px;
    padding: 0.625rem 1.75rem;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}

.site-header .btn-accent {
    border-radius: 10px;
}

.btn-accent:hover,
.btn-accent:focus {
    background-color: var(--accent-color-hover);
    border-color: var(--accent-color-hover);
    color: var(--color-text-on-dark);
}

/* Logo Notch - Trapezium die-cut */
.logo-notch {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%) translateZ(0);
    width: var(--logo-notch-width);
    height: var(--logo-notch-height);
    z-index: 100;
    pointer-events: none;
}

.logo-notch__shape {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
}

/* Hide overlay SVG when mask cutout is active */
@supports (mask-composite: exclude) or (-webkit-mask-composite: xor) {
    .logo-notch__shape {
        display: none;
    }
}

.logo-notch__path {
    fill: var(--color-white);
}

.logo-notch__content {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: var(--logo-notch-logo-offset-y) 0.78rem 0.55rem;
    pointer-events: auto;
}

.logo-notch__img {
    max-width: min(96%, calc(16.88rem - var(--logo-notch-logo-shrink)));
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    object-position: top center;
    display: block;
}

.footer-brand__logo {
    max-width: 160px;
    height: auto;
    display: block;
}

/* ========================================
   Hero Section
   ======================================== */
.hero-section {
    position: relative !important;
    display: flex !important;
    align-items: flex-start !important;
    background-color: var(--color-bg-header) !important;
    background-image: url('../images/hero_image.webp') !important;
    background-repeat: no-repeat !important;
    background-position: 60% center !important;
    background-size: cover !important;
    background-attachment: scroll !important;
    color: var(--color-text-on-dark) !important;
    min-height: 35vh !important;
    max-height: 40vh !important;
    margin-top: -1px !important;
    padding: 1.5rem 0 2rem !important;
    overflow: hidden !important;
}

/* Add gradient overlay for better text readability on mobile */
.hero-section::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to right, rgba(28, 28, 28, 0.85) 0%, rgba(28, 28, 28, 0.5) 60%, transparent 100%) !important;
    z-index: 0 !important;
    pointer-events: none !important;
}

/* Desktop only - full height without parallax for better responsiveness */
@media (min-width: 992px) {
    .hero-section {
        background-attachment: scroll !important;
        background-position: center center !important;
        background-size: cover !important;
        min-height: 100vh !important;
        min-height: 100svh !important;
        max-height: none !important;
        padding: 2rem 0 3rem !important;
    }
    
    .hero-section::before {
        display: none !important;
    }
}

.hero-section .container-fluid {
    position: relative;
    z-index: 2;
    width: 100%;
}

.hero-section__copy {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 100%;
    padding-top: 0.5rem;
    text-align: center;
}

@media (min-width: 992px) {
    .hero-section__copy {
        text-align: left;
        padding-top: 0.5rem;
    }
}

.hero-section__title,
.hero-section__tagline {
    font-family: var(--font-heading);
    font-size: var(--hero-title-size);
    line-height: var(--hero-title-line);
    font-weight: var(--text-display-weight);
    letter-spacing: -0.02em;
    text-transform: uppercase;
    width: 100%;
    max-width: 100%;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}

@media (min-width: 992px) {
    .hero-section__title,
    .hero-section__tagline {
        text-shadow: none;
    }
}

.hero-section__title {
    color: var(--color-text-inverse);
    margin-bottom: 0.5rem;
}

@media (min-width: 768px) {
    .hero-section__title {
        margin-bottom: 0.75rem;
    }
}

.hero-section__tagline {
    color: var(--accent-color);
    margin-bottom: 1rem;
    white-space: normal;
    overflow: visible;
}

@media (min-width: 768px) {
    .hero-section__tagline {
        margin-bottom: 1.5rem;
    }
}

/* Keep tagline on one line on larger screens */
@media (min-width: 992px) {
    .hero-section__tagline {
        white-space: nowrap;
    }
}

.hero-section__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 700;
    line-height: var(--text-body-line);
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: var(--color-text-on-dark);
    margin-bottom: 0;
    max-width: 52rem;
    margin-left: auto;
    margin-right: auto;
    text-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

@media (min-width: 992px) {
    .hero-section__body {
        margin-left: 0;
        margin-right: 0;
        text-shadow: none;
    }
}

/* ========================================
   Icons
   ======================================== */
.qf-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.qf-icon__img {
    display: block;
    width: 1.5rem;
    height: 1.5rem;
    object-fit: contain;
}

/* Fluent SVGs — tinted via CSS mask so accent color can change at runtime */
.qf-svg-accent {
    display: inline-block;
    flex-shrink: 0;
    background-color: var(--accent-color);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
}

.qf-icon--solution {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: #18181c;
}

.qf-icon--feature {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--accent-color-light);
    font-size: 1.375rem;
}

.qf-icon--value {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--color-bg-cream);
    font-size: 1.75rem;
}

.qf-icon--contact {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--color-bg-cream);
    color: var(--color-title);
    font-size: 1.25rem;
}

.qf-icon--dark {
    color: var(--color-text-on-dark);
}

.qf-icon--inline {
    width: auto;
    height: auto;
    background: transparent;
    font-size: 1.125rem;
    vertical-align: middle;
}

/* ========================================
   Solution Section
   ======================================== */
.solution-section {
    background: var(--color-solution-section-bg);
}

.solution-section__grid.row {
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 1.5rem;
    margin-left: calc(var(--bs-gutter-x) * -0.5) !important;
    margin-right: calc(var(--bs-gutter-x) * -0.5) !important;
}

/* Tablet - 2x2 grid */
@media (min-width: 768px) and (max-width: 1199px) {
    .solution-section__grid.row {
        --bs-gutter-x: 1.5rem;
        --bs-gutter-y: 2rem;
        row-gap: 2rem !important;
    }
}

@media (max-width: 991px) {
    .solution-section__grid.row {
        --bs-gutter-x: 1.5rem;
        --bs-gutter-y: 2rem;
        row-gap: 2rem !important;
    }
}

@media (max-width: 576px) {
    .solution-section__grid.row {
        --bs-gutter-x: 1rem;
        --bs-gutter-y: 1rem;
    }
}

.solution-section__header {
    text-align: center;
    margin-bottom: 1rem !important;
    max-width: 52rem;
    margin-left: auto;
    margin-right: auto;
}

.solution-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.solution-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h2-line);
    letter-spacing: 0.02em;
    color: var(--color-title);
    margin: 0;
}

.solution-card {
    display: flex;
    flex-direction: column;
    background: var(--color-white);
    border-radius: var(--solution-card-radius);
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
    overflow: hidden;
}

.solution-card__content {
    padding: 1rem 1rem 0.5rem;
    flex: 0 0 auto;
}

.solution-card__head {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.solution-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-coffee);
    margin: 0;
}

.solution-card__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
}

/* Full-bleed illustration — ignores card text padding, fills remaining height */
.solution-card__media {
    flex: 1 1 auto;
    min-height: 11rem;
    margin: 0;
    padding: 0;
    width: 100%;
    display: flex;
    align-items: flex-end;
    line-height: 0;
}

.solution-card__img {
    display: block;
    width: 100%;
    height: 100%;
    max-height: 22rem;
    object-fit: contain;
    object-position: bottom center;
}

@media (min-width: 1200px) {
    .solution-card {
        min-height: 35rem;
    }

    .solution-card__media {
        min-height: 15.5rem;
    }

    .solution-card__img {
        max-height: none;
    }
}

@media (max-width: 576px) {
    .solution-card__head {
        gap: 0.75rem;
    }

    .solution-card__title {
        font-size: var(--text-h5-size);
    }
}

/* ========================================
   Features Section
   ======================================== */
.features-section {
    position: relative;
    background-color: var(--color-features-section-bg);
}

.features-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--features-section-overlay);
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 100% auto;
    opacity: var(--features-section-overlay-opacity);
    pointer-events: none;
}

.features-section .qf-container {
    position: relative;
    z-index: 1;
}

.features-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1rem !important;
}

.features-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.features-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h3-line);
    letter-spacing: 0.02em;
    color: var(--color-title);
    margin: 0 0 0.75rem;
}

.features-section__subtitle {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 600;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
}

/* Carousel */
.features-carousel {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: clamp(0.75rem, 0.5rem + 1vw, 1.5rem);
    align-items: stretch;
    margin-bottom: 1rem !important;
}

.features-carousel__nav {
    align-self: center;
    width: 2.5rem;
    min-height: 18rem;
    padding: 0;
    border: none;
    border-radius: 10px;
    background: var(--accent-color);
    color: var(--color-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    line-height: var(--line-height-none);
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.features-carousel__nav:hover,
.features-carousel__nav:focus-visible {
    background: var(--accent-color-hover);
}

.features-carousel__nav:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.features-carousel__viewport {
    overflow: hidden;
    min-width: 0;
    /* Room for card box-shadow inside the clip region */
    padding: 0.625rem 0.5rem;
    margin: -0.625rem -0.5rem;
}

.features-carousel__track {
    display: flex;
    gap: 1.5rem;
    transition: transform 0.45s ease;
    will-change: transform;
}

.feature-card {
    flex: 0 0 calc((100% - 3rem) / 3);
    min-height: 18rem;
    padding: 1rem 1rem 1.25rem;
    background: var(--color-feature-card-bg);
    border-radius: 10px;
    box-shadow: 0 4px 4px rgba(120, 105, 85, 0.3);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.feature-card__icon {
    margin-bottom: 1.5rem;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.feature-card__icon img,
.feature-card__icon .qf-svg-accent {
    width: 2rem;
    height: 2rem;
    object-fit: contain;
}

/* Shared card titles — Features carousel */
.feature-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-title);
    margin: 0 0 0.75rem;
}

.feature-card__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
    max-width: 14rem;
}

/* Voice calling card */
.features-audio-card {
    display: grid;
    grid-template-columns: 6rem 1fr;
    gap: 1.25rem 1.5rem;
    align-items: center;
    padding: 1rem 1.25rem;
    background: var(--color-feature-card-bg);
    border-radius: 10px;
    box-shadow: 0 4px 4px rgba(120, 105, 85, 0.3);
}

.features-audio-card__icon {
    width: 6rem;
    align-self: stretch;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.features-audio-card__icon img,
.features-audio-card__icon .qf-svg-accent {
    width: 3rem;
    height: 3rem;
    object-fit: contain;
}

.features-audio-card__content {
    min-width: 0;
}

.features-audio-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-title);
    margin: 0 0 0.35rem;
}

.features-audio-card__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0 0 1rem;
}

.features-audio-player {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 0.75rem 1rem;
    align-items: center;
}

.features-audio-player__toggle {
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
    color: var(--color-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: var(--line-height-none);
    cursor: pointer;
    transition: background-color 0.2s ease;
}

.features-audio-player__toggle:hover,
.features-audio-player__toggle:focus-visible {
    background: var(--accent-color-hover);
}

.features-audio-player__progress {
    position: relative;
    height: 0.875rem;
    background: #e5e1de;
    border: 5px solid #e5e1de;
    border-radius: 999px;
    cursor: pointer;
    overflow: hidden;
}

.features-audio-player__progress-fill {
    height: 100%;
    width: 0%;
    background: var(--accent-color);
    border-radius: 999px;
    pointer-events: none;
    transition: width 0.1s linear;
}

.features-audio-player__volume {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
}

.features-audio-player__volume-toggle {
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--accent-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    line-height: var(--line-height-none);
    cursor: pointer;
    flex-shrink: 0;
}

.features-audio-player__volume-toggle:hover,
.features-audio-player__volume-toggle:focus-visible {
    color: var(--accent-color-hover);
}

.features-audio-player__volume-slider {
    width: clamp(3rem, 2rem + 4vw, 5rem);
    height: 0.875rem;
    margin: 0;
    padding: 0;
    appearance: none;
    background: transparent;
    cursor: pointer;
}

.features-audio-player__volume-slider:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
    border-radius: 999px;
}

.features-audio-player__volume-slider::-webkit-slider-runnable-track {
    height: 0.25rem;
    background: linear-gradient(to right, var(--accent-color) 0%, var(--accent-color) var(--volume-percent, 100%), rgba(229, 225, 222, 0.3) var(--volume-percent, 100%), rgba(229, 225, 222, 0.3) 100%);
    border-radius: 999px;
}

.features-audio-player__volume-slider::-webkit-slider-thumb {
    appearance: none;
    width: 0.625rem;
    height: 0.625rem;
    margin-top: -0.1875rem;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
}

.features-audio-player__volume-slider::-moz-range-track {
    height: 0.25rem;
    background: rgba(229, 225, 222, 0.3);
    border-radius: 999px;
}

.features-audio-player__volume-slider::-moz-range-progress {
    height: 0.25rem;
    background: var(--accent-color);
    border-radius: 999px;
}

.features-audio-player__volume-slider::-moz-range-thumb {
    width: 0.625rem;
    height: 0.625rem;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
}

.features-audio-player__time {
    font-family: var(--font-body);
    font-size: 0.625rem;
    font-weight: 600;
    line-height: var(--line-height-none);
    color: var(--color-text-on-dark);
    background: var(--accent-color);
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    white-space: nowrap;
}

.features-audio-player__audio {
    display: none;
}

@media (max-width: 1199px) {
    .feature-card {
        flex: 0 0 calc((100% - 1.5rem) / 2);
    }
}

@media (max-width: 767px) {
    .features-carousel {
        grid-template-columns: auto minmax(0, 1fr) auto;
        gap: 0.5rem;
    }

    .features-carousel__nav {
        width: 2rem;
        min-height: 16rem;
        font-size: 1rem;
    }

    .feature-card {
        flex: 0 0 100%;
        min-height: 16rem;
    }

    .features-audio-card {
        grid-template-columns: 1fr;
        justify-items: center;
        text-align: center;
    }

    .features-audio-card__icon {
        width: auto;
        align-self: auto;
    }

    .features-audio-card__content {
        width: 100%;
    }

    .features-audio-player {
        grid-template-columns: auto 1fr auto;
        grid-template-rows: auto auto;
    }

    .features-audio-player__volume {
        grid-column: 1 / -1;
        justify-self: center;
    }

    .features-audio-player__time {
        grid-column: 1 / -1;
        justify-self: center;
    }
}


/* ========================================
   Preview Section
   ======================================== */
.preview-section {
    background: var(--color-preview-section-bg);
    color: var(--color-text-on-dark);
}

.preview-section__top {
    position: relative;
    margin-bottom: 1rem !important;
}

.preview-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto;
    padding-top: 0.5rem;
}

.preview-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.preview-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h3-line);
    letter-spacing: 0.02em;
    color: var(--color-text-on-dark);
    margin: 0 0 0.75rem;
}

.preview-section__subtitle {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 600;
    line-height: var(--text-body-line);
    color: var(--color-text-on-dark);
    margin: 0;
}

.preview-section__badge {
    position: absolute;
    top: 0;
    right: 0;
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: 400;
    line-height: var(--line-height-none);
    color: var(--color-text-on-dark);
    background: var(--color-coffee);
    padding: 0.65rem 1rem;
    border-radius: var(--border-radius-pill);
    white-space: nowrap;
}

.preview-section__grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(0.75rem, 0.5rem + 1vw, 1.5rem);
}

.preview-section__thumb {
    display: block;
    width: 100%;
    padding: 0;
    border: 2px solid var(--accent-color);
    border-radius: var(--preview-thumb-radius);
    overflow: hidden;
    background: transparent;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.preview-section__thumb:hover,
.preview-section__thumb:focus-visible {
    transform: translateY(-2px);
    border-color: var(--accent-color-hover);
}

.preview-section__thumb img {
    width: 100%;
    aspect-ratio: 216 / 121;
    object-fit: cover;
    display: block;
}

/* Preview modal */
body:has(#previewModal.show) > .modal-backdrop {
    background-color: #000;
    opacity: 0.3;
}

.preview-modal .modal-dialog {
    max-width: min(92vw, 72rem);
}

.preview-modal__content {
    position: relative;
    background: transparent;
    border: none;
    box-shadow: none;
}

.preview-modal__body {
    padding: 0;
}

.preview-modal__image {
    width: 100%;
    height: auto;
    display: block;
    border-radius: var(--preview-thumb-radius);
}

.preview-modal__close {
    position: absolute;
    top: -2.75rem;
    right: 0;
    z-index: 2;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--color-bg-header);
    color: var(--accent-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    line-height: var(--line-height-none);
    cursor: pointer;
    transition: color 0.2s ease, background-color 0.2s ease;
}

.preview-modal__close:hover,
.preview-modal__close:focus-visible {
    color: var(--accent-color-hover);
    background: var(--color-title);
}

/* Success Modal Component */
.success-modal .modal-dialog {
    max-width: 90vw;
    width: auto;
}

.success-modal__content {
    background: transparent;
    border: none;
    box-shadow: none;
}

.success-modal__body {
    padding: 0;
    background-image: url('../loading_images_and_popups/Message%20sent%20modal%20-%20laptop%20desktop.png');
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    aspect-ratio: 1400 / 788;
    width: 100%;
    height: 60vh;
    max-width: 1400px;
    margin: 0 auto;
}

.success-modal__close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    z-index: 1060;
    width: 3rem;
    height: 3rem;
    border: none;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.9);
    color: #000;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.success-modal__close:hover,
.success-modal__close:focus-visible {
    background: #fff;
    transform: scale(1.1);
}

@media (max-width: 768px) {
    .success-modal__body {
        background-image: url('../loading_images_and_popups/Message%20sent%20modal%20-%20mobile.png');
        aspect-ratio: 430 / 932;
        max-width: 430px;
        height: 95vh;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .success-modal__body {
        background-image: url('../loading_images_and_popups/Message%20sent%20modal%20-%20tablet.png');
        aspect-ratio: 820 / 1180;
        max-width: 820px;
        height: 80vh;
    }
}

@media (max-width: 991px) {
    .preview-section__grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .preview-section__badge {
        position: static;
        display: table;
        margin: 1.25rem auto 0;
    }

    .preview-section__header {
        padding-top: 0;
    }
}

@media (max-width: 576px) {
    .preview-section__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }

    .preview-modal__close {
        top: -2.25rem;
        right: 0.25rem;
    }
}

/* ========================================
   About Section
   ======================================== */
.about-section {
    padding-top: 0;
    padding-bottom: 0;
    background: transparent;
}

.about-section__block {
    padding-top: var(--section-padding-y);
    padding-bottom: var(--section-padding-y);
}

.about-section__block--challenge {
    background: var(--color-about-challenge-bg);
}

.about-section__block--fails {
    background: var(--color-about-fails-bg);
    padding-bottom: 0;
}

.about-section__block--fails .qf-container {
    padding-bottom: var(--section-padding-y);
}

.about-section__block + .about-section__block {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

.about-section__block + .about-section__block--fails {
    padding-top: var(--section-padding-y);
}

.about-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1rem !important;
}

.about-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.about-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 0.85rem + 1.6vw, var(--text-h3-size));
    font-weight: var(--text-h3-weight);
    line-height: var(--text-h3-line);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-title);
    margin: 0;
}

.about-section__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(1.25rem, 1rem + 1vw, 2rem);
}

.about-card {
    background: var(--color-white);
    border-radius: 10px;
    padding: 1.5rem 1.25rem;
    box-shadow: 0 4px 4px rgba(120, 105, 85, 0.15);
}

.about-card__head {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.about-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--color-bg-header);
    color: var(--accent-color);
    font-size: 1.125rem;
    line-height: var(--line-height-none);
    flex-shrink: 0;
}

.about-card__icon img,
.about-card__icon .qf-svg-accent {
    width: 1.5rem;
    height: 1.5rem;
}

.about-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-h5-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-coffee);
    margin: 0;
}

.about-card__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
}

@media (max-width: 991px) {
    .about-section__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 576px) {
    .about-section__grid {
        grid-template-columns: 1fr;
    }
}

/* Full-width queue silhouettes — section footers */
.section-silhouette {
    width: 100%;
    margin: 0;
    padding-top: 3.75rem;
    line-height: var(--line-height-none);
    position: relative;
    bottom: 0;
}

.section-silhouette img {
    width: 100%;
    height: auto;
    display: block;
    vertical-align: bottom;
}

.section-silhouette--flip img {
    transform: scaleX(-1);
}

@media (max-width: 768px) {
    .section-silhouette {
        margin-top: 0;
    }
}

/* ========================================
   Value Section
   ======================================== */
.value-section {
    padding-top: 0;
    padding-bottom: 0;
    background: transparent;
}

.value-section__block {
    padding-top: var(--section-padding-y);
    padding-bottom: var(--section-padding-y);
}

.value-section__block--package {
    background: var(--color-value-package-bg);
}

.value-section__block--outcomes {
    background: var(--color-value-outcomes-bg);
}

.value-section__block--audience {
    background: var(--color-value-audience-bg);
    padding-bottom: 0;
}

.value-section__block--audience .qf-container {
    padding-bottom: var(--section-padding-y);
}

.value-section__block + .value-section__block {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
}

.value-section__block + .value-section__block--outcomes,
.value-section__block + .value-section__block--audience {
    padding-top: var(--section-padding-y);
}

.value-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1rem !important;
}

.value-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.value-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 0.85rem + 1.6vw, var(--text-h3-size));
    font-weight: var(--text-h3-weight);
    line-height: var(--text-h3-line);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-title);
    margin: 0;
}

.value-section__block--outcomes .value-section__title,
.value-section__block--audience .value-section__title {
    font-size: clamp(1.125rem, 0.75rem + 1.2vw, var(--text-h4-size));
    font-weight: var(--text-h4-weight);
    line-height: var(--text-h4-line);
}

.value-section__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    width: 100%;
}

.value-section__grid--outcomes {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(1rem, 0.75rem + 1vw, 1.5rem);
}

.value-card {
    padding: 0 1rem;
    text-align: left;
}

.value-section__grid--outcomes .value-card {
    background: var(--color-white);
    border-radius: 10px;
    padding: 1.25rem 1rem;
    box-shadow: 0 4px 4px rgba(120, 105, 85, 0.12);
    text-align: center;
}

.value-section__grid--outcomes .value-card + .value-card {
    border-left: none;
}

.value-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--color-bg-header);
    color: var(--accent-color);
    font-size: 0.9375rem;
    line-height: var(--line-height-none);
    margin-bottom: 0.625rem;
}

.value-card__icon img,
.value-card__icon .qf-svg-accent {
    width: 1.5rem;
    height: 1.5rem;
}

.value-package {
    display: grid;
    gap: clamp(1.5rem, 1rem + 2vw, 2.5rem);
}

.value-package__label {
    font-family: var(--font-heading);
    font-size: var(--text-h5-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--color-coffee);
    margin: 0 0 1.25rem;
    text-align: center;
}

.value-package__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1rem, 0.75rem + 1vw, 1.5rem);
}

.value-package__grid--addons {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    max-width: none;
    margin-inline: 0;
}

.value-package__addons-panel {
    background: var(--color-bg-header);
    border-radius: 10px;
    padding: clamp(1.5rem, 1rem + 2vw, 2.5rem);
}

.value-package__label--addons {
    color: var(--color-text-on-dark);
}

.value-package__item {
    background: var(--color-white);
    border-radius: 10px;
    padding: 1.5rem 1.25rem;
    box-shadow: 0 4px 4px rgba(120, 105, 85, 0.15);
    text-align: center;
}

.value-package__item--addon {
    --addon-icon-size: 3rem;
    --addon-plus-col-width: var(--addon-icon-size);
    display: flex;
    align-items: stretch;
    gap: 0;
    padding: 0;
    overflow: hidden;
    text-align: center;
    border-bottom: 3px solid var(--accent-color);
}

.value-package__plus-col {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: stretch;
    width: var(--addon-plus-col-width);
    min-width: var(--addon-plus-col-width);
    background: rgba(var(--accent-color-rgb), 0.2);
    border-radius: 0;
}

.value-package__plus {
    font-family: var(--font-heading);
    font-size: calc(var(--addon-icon-size) - 2px);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-none);
    color: var(--accent-color);
}

.value-package__item--addon .value-package__content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1.5rem 1.25rem;
    text-align: center;
}

.value-package__item--addon .value-package__icon {
    width: var(--addon-icon-size);
    height: var(--addon-icon-size);
    margin-bottom: 0.75rem;
    margin-inline: auto;
}

.value-package__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--color-bg-header);
    color: var(--accent-color);
    font-size: 1.125rem;
    line-height: var(--line-height-none);
    margin-bottom: 1rem;
}

.value-package__icon img,
.value-package__icon .qf-svg-accent {
    width: 1.5rem;
    height: 1.5rem;
}

.value-package__title {
    font-family: var(--font-heading);
    font-size: var(--text-h5-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-coffee);
    margin: 0 0 0.5rem;
}

.value-package__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
}

.value-audience__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1rem, 0.75rem + 1vw, 1.5rem);
}

.value-audience__item {
    background: var(--color-white);
    border-radius: 10px;
    padding: 1.5rem 1.25rem;
    box-shadow: 0 4px 4px rgba(120, 105, 85, 0.12);
    text-align: center;
}

.value-audience__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--color-bg-header);
    color: var(--accent-color);
    font-size: 0.9375rem;
    line-height: var(--line-height-none);
    margin-bottom: 0.625rem;
}

.value-audience__icon img,
.value-audience__icon .qf-svg-accent {
    width: 1.5rem;
    height: 1.5rem;
}

.value-card__title,
.value-audience__title {
    font-family: var(--font-heading);
    font-size: var(--text-h5-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-title);
    margin: 0 0 0.5rem;
}

.value-audience__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
}

.value-card + .value-card {
    border-left: 1px solid var(--color-value-divider);
}

.value-card__body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
}

@media (max-width: 991px) {
    .value-section__grid--outcomes {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .value-package__grid {
        grid-template-columns: 1fr;
    }

    .value-package__grid--addons {
        grid-template-columns: 1fr;
    }

    .value-audience__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .value-section__grid {
        grid-template-columns: 1fr;
        gap: 1.75rem;
    }

    .value-card {
        padding: 0;
        text-align: center;
    }

    .value-card + .value-card {
        border-left: none;
        padding-top: 1.75rem;
        border-top: 1px solid var(--color-value-divider);
    }

    .value-section__grid--outcomes .value-card + .value-card {
        border-top: none;
        padding-top: 1.25rem;
    }

    .value-card__body {
        margin-inline: auto;
    }
}

@media (max-width: 576px) {
    .feature-card__title {
        font-size: var(--text-h5-size);
    }

    .value-card__title,
    .value-audience__title {
        font-size: var(--text-label-size);
    }

    .value-section__grid--outcomes,
    .value-audience__grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   People Section
   ======================================== */
.people-section {
    background: var(--color-people-section-bg);
    padding-top: 0;
}

.people-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1rem !important;
}

.people-section__header .people-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.people-section__header .people-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h2-line);
    letter-spacing: 0.02em;
    color: var(--color-title);
    margin: 0;
}

.people-section__figure {
    margin: 0;
    width: 100%;
}

.people-section__figure img {
    width: 100%;
    height: auto;
    display: block;
}

/* ========================================
   Proudly Namibian Section
   ======================================== */
.proudly-namibian-section {
    position: relative;
    background: var(--color-proudly-namibian-section-bg);
    overflow: hidden;
}

.proudly-namibian-section__overlay {
    position: absolute;
    right: 0;
    bottom: 0;
    width: min(28rem, 55vw);
    height: auto;
    opacity: var(--proudly-namibian-section-overlay-opacity);
    pointer-events: none;
    z-index: 0;
}

.proudly-namibian-section .qf-container {
    position: relative;
    z-index: 1;
}

.proudly-namibian-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1rem !important;
}

.proudly-namibian-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.proudly-namibian-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.25rem, 0.85rem + 1.6vw, var(--text-h3-size));
    font-weight: var(--text-h3-weight);
    line-height: var(--text-h3-line);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-title);
    margin: 0;
}

.proudly-namibian-section__body {
    max-width: 52rem;
    margin: 0 auto clamp(1.5rem, 1rem + 1.5vw, 2.5rem);
}

.proudly-namibian-section__body p {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0 0 1rem;
}

.proudly-namibian-section__body p:last-child {
    margin-bottom: 0;
}

.proudly-namibian-section__footer {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--text-h4-line);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    text-align: center;
    color: var(--color-title);
    margin: 0;
}

@media (max-width: 576px) {
    .proudly-namibian-section__overlay {
        width: min(16rem, 70vw);
    }

    .proudly-namibian-section__footer {
        font-size: var(--text-h5-size);
    }
}

/* ========================================
   Contact Section
   ======================================== */
.contact-section {
    position: relative;
    background: var(--color-contact-section-bg);
}

.contact-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--features-section-overlay);
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 100% auto;
    opacity: var(--features-section-overlay-opacity);
    pointer-events: none;
}

.contact-section .qf-container {
    position: relative;
    z-index: 1;
}

.contact-section__header {
    text-align: center;
    max-width: 52rem;
    margin: 0 auto 1rem !important;
}

.contact-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.contact-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h3-line);
    letter-spacing: 0.02em;
    color: var(--color-title);
    margin: 0;
    white-space: nowrap;
}

.contact-section__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1rem, 0.75rem + 1vw, 1.5rem);
    align-items: stretch;
    width: 100%;
}

.contact-info-card,
.contact-form-card {
    border-radius: var(--contact-card-radius);
    box-shadow: 0 4px 4px rgba(0, 0, 0, 0.2);
}

.contact-info-card {
    background: var(--color-white);
    padding: 2.5rem;
}

.contact-info-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: clamp(1.25rem, 1rem + 1vw, 2rem);
}

.contact-info-item {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.contact-info-item__icon {
    flex-shrink: 0;
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    background: var(--accent-color);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: var(--line-height-none);
}

.contact-info-item__icon img {
    width: 1.5rem;
    height: 1.5rem;
    object-fit: contain;
}

.contact-info-item__label {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--accent-color);
    margin: 0 0 0.35rem;
}

.contact-info-item__value {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-title);
    margin: 0;
    text-decoration: none;
}

.contact-info-item__value--link {
    text-decoration: underline;
    text-underline-offset: 0.15em;
}

.contact-info-item__value--link:hover,
.contact-info-item__value--link:focus-visible {
    color: var(--accent-color-hover);
}

.contact-form-card {
    background: var(--accent-color);
    padding: 2.5rem;
    display: flex;
    flex-direction: column;
}

.contact-form-card__header {
    margin-bottom: 1.25rem;
}

.contact-form-card__title {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-text-on-dark);
    margin: 0 0 0.5rem;
}

.contact-form-card__subtitle {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: var(--text-body-weight);
    line-height: var(--text-body-line);
    letter-spacing: 0.02em;
    color: var(--color-text-on-dark);
    margin: 0;
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    flex: 1;
}

.contact-form__row {
    display: grid;
    gap: 0.75rem;
}

.contact-form__row--split {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-form__input {
    width: 100%;
    padding: 0.5rem 1rem;
    border: 1px solid var(--accent-color);
    border-radius: 10px;
    background: var(--color-white);
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    line-height: var(--line-height-relaxed);
    color: var(--color-title);
}

.contact-form__input::placeholder {
    color: #202020;
    opacity: 0.55;
}

.contact-form__input:focus {
    outline: 2px solid var(--color-bg-header);
    outline-offset: 1px;
}

.contact-form__input--textarea {
    min-height: 7.5rem;
    resize: vertical;
}

.contact-form__submit {
    width: 100%;
    margin-top: auto;
    padding: 0.75rem 1.5rem;
    border: none;
    border-radius: 10px;
    background: var(--color-bg-header);
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-button-weight);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-text-on-dark);
    cursor: pointer;
    transition: background-color 0.2s ease;
    position: relative;
}

.contact-form__submit:hover,
.contact-form__submit:focus-visible {
    background: var(--color-title);
}

.contact-form__submit:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

.contact-form__submit-loader {
    display: none;
    align-items: center;
    justify-content: center;
}

.contact-form__submit.is-loading .contact-form__submit-text {
    display: none;
}

.contact-form__submit.is-loading .contact-form__submit-loader {
    display: flex;
}

@media (max-width: 991px) {
    .contact-section__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 576px) {
    .contact-form__row--split {
        grid-template-columns: 1fr;
    }

    .contact-info-item__label {
        font-size: var(--text-h5-size);
    }
}

/* ========================================
   Footer
   ======================================== */
.site-footer {
    position: relative;
    background: var(--color-site-footer-bg);
    color: var(--color-text-on-dark);
    border-bottom-left-radius: var(--page-inner-radius);
    border-bottom-right-radius: var(--page-inner-radius);
    overflow: hidden;
}

.site-footer__silhouette {
    position: relative;
    background-color: var(--color-site-footer-silhouette-underlay);
}

.site-footer__silhouette::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--color-site-footer-silhouette-overlay);
    pointer-events: none;
    z-index: 1;
}

.site-footer__silhouette img {
    position: relative;
    z-index: 2;
    width: 100%;
    height: auto;
    display: block;
    filter: brightness(0);
}

.site-footer__main {
    padding: var(--section-padding-y) 0;
}

.site-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1.1fr;
    gap: clamp(1.5rem, 1rem + 2vw, 3rem);
    align-items: start;
}

.site-footer__logo {
    width: min(100%, 19.75rem);
    height: auto;
    display: block;
    margin-bottom: 1rem;
}

.site-footer__tagline,
.site-footer__cta-text,
.site-footer__contact-text {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-text-on-dark);
    margin: 0;
}

.site-footer__heading {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: var(--text-h4-weight);
    line-height: var(--line-height-snug);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--color-text-on-dark);
    margin: 0 0 1rem;
}

.site-footer__link-list,
.site-footer__contact-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.site-footer__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-text-on-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}

.site-footer__link i {
    flex-shrink: 0;
    color: var(--accent-color);
    font-size: 0.875rem;
    line-height: var(--line-height-none);
}

.site-footer__link:hover,
.site-footer__link:focus-visible,
.site-footer__contact-link:hover,
.site-footer__contact-link:focus-visible {
    color: var(--accent-color-light);
}

.site-footer__contact-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-text-on-dark);
    text-decoration: none;
    transition: color 0.2s ease;
}

.site-footer__contact-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.site-footer__contact-icon,
.site-footer__contact-icon.qf-svg-accent {
    flex-shrink: 0;
    font-size: 1rem;
}

.site-footer__cta-text {
    margin-bottom: 1.5rem;
}

.site-footer__cta-button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 0.65rem 1.75rem;
    border: 1px solid var(--accent-color);
    border-radius: 10px;
    background: var(--accent-color);
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: 400;
    line-height: var(--line-height-none);
    color: var(--color-text-on-dark);
    text-decoration: none;
    transition: background-color 0.2s ease, border-color 0.2s ease;
}

.site-footer__cta-button:hover,
.site-footer__cta-button:focus-visible {
    background: var(--accent-color-hover);
    border-color: var(--accent-color-hover);
    color: var(--color-text-on-dark);
}

.site-footer__bar {
    padding-bottom: var(--section-padding-y);
    background: var(--color-site-footer-bg);
}

.site-footer__bar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    border-top: 1px solid var(--color-divider-on-dark);
    padding-top: var(--section-padding-y);
}

.site-footer__copyright,
.site-footer__slogan {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 400;
    line-height: var(--text-body-line);
    color: var(--color-text-on-dark);
    margin: 0;
}

@media (max-width: 991px) {
    .site-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 576px) {
    .site-footer__grid {
        grid-template-columns: 1fr;
    }

    .site-footer__bar-inner {
        flex-direction: column;
        align-items: flex-start;
    }
}

/* ========================================
   Buttons
   ======================================== */
.btn {
    font-family: var(--font-body);
    border-radius: 10px;
    font-weight: 600;
    padding: 0.5rem 1.5rem;
    transition: all 0.3s ease;
}

.btn-dark {
    background: var(--color-black);
    border-color: var(--color-black);
}

.btn-dark:hover {
    background: var(--color-dark-grey);
    border-color: var(--color-dark-grey);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.btn-light {
    background: var(--color-white);
    border-color: var(--color-white);
    color: var(--color-black);
}

.btn-light:hover {
    background: var(--color-soft-cream);
    border-color: var(--color-soft-cream);
    color: var(--color-black);
}

.btn-outline-dark {
    border: 2px solid var(--color-black);
    color: var(--color-black);
}

.btn-outline-dark:hover {
    background: var(--color-black);
    color: var(--color-white);
}

.btn-outline-light {
    border: 2px solid var(--color-white);
    color: var(--color-white);
    background: transparent;
}

.btn-outline-light:hover {
    background: var(--color-white);
    color: var(--color-black);
    border-color: var(--color-white);
}

.btn-sm {
    padding: 0.375rem 1rem;
    font-size: 0.875rem;
}

/* ========================================
   Utilities
   ======================================== */
.text-white-50 {
    color: rgba(255, 251, 242, 0.5) !important;
}

.rounded-3 {
    border-radius: var(--border-radius-sm) !important;
}

.rounded-4 {
    border-radius: var(--border-radius-md) !important;
}

.shadow-sm {
    box-shadow: var(--shadow-sm) !important;
}

.shadow-md {
    box-shadow: var(--shadow-md) !important;
}

.shadow-lg {
    box-shadow: var(--shadow-lg) !important;
}

/* ========================================
   Animations
   ======================================== */

/* Base state for animated elements */
.animate-on-scroll {
    opacity: 0;
    transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

/* Fade up animation */
.animate-on-scroll.fade-in-up {
    transform: translateY(40px);
}

.animate-on-scroll.fade-in-up.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Fade down animation */
.animate-on-scroll.fade-in-down {
    transform: translateY(-40px);
}

.animate-on-scroll.fade-in-down.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Don't animate elements marked as no-animate */
.no-animate {
    opacity: 1 !important;
    transform: none !important;
}

/* Respect user motion preferences */
@media (prefers-reduced-motion: reduce) {
    .animate-on-scroll {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* ========================================
   Back to top
   ======================================== */
.back-to-top {
    position: fixed;
    right: clamp(1rem, 0.5rem + 1.5vw, 1.75rem);
    bottom: clamp(1rem, 0.5rem + 1.5vw, 1.75rem);
    z-index: 90;
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
    color: var(--color-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    line-height: var(--line-height-none);
    cursor: pointer;
    box-shadow: var(--shadow-md);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(0.5rem);
    transition:
        opacity 0.25s ease,
        visibility 0.25s ease,
        transform 0.25s ease,
        background-color 0.3s ease;
}

.back-to-top.is-visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

.back-to-top:hover,
.back-to-top:focus-visible {
    background: var(--accent-color-hover);
    color: var(--color-text-on-dark);
}

.back-to-top:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .back-to-top {
        transition: none;
        transform: none;
    }

    .back-to-top.is-visible {
        transform: none;
    }
}

/* ========================================
   Smooth Scrolling
   ======================================== */
html {
    scroll-behavior: smooth;
}

/* ========================================
   Mobile Responsive Styles
   ======================================== */

/* Tablet and below - Logo notch and hero adjustments */
@media (max-width: 768px) {
    :root {
        --logo-notch-width: 14rem;
        --logo-notch-height: 4rem;
        --logo-notch-logo-offset-y: 0.625rem;
        --logo-notch-logo-shrink: 1.875rem;
    }

    .site-header {
        min-height: calc(var(--logo-notch-height) + 1rem + var(--section-padding-x));
    }

    .logo-notch__content {
        padding: var(--logo-notch-logo-offset-y) 0.5rem 0.35rem;
    }

    .logo-notch__img {
        max-width: min(90%, calc(11rem - var(--logo-notch-logo-shrink)));
    }

    /* Hero image - better mobile background handling */
    .hero-section {
        background-position: 55% center !important;
        min-height: 35vh !important;
        max-height: 35vh !important;
        padding: 1rem 0 1.5rem !important;
    }

    .hero-section__copy {
        padding-top: 0.75rem;
    }

    .hero-section .container-fluid {
        position: relative;
        z-index: 2;
    }

    /* Card grids stack on tablet */
    .about-section__grid,
    .value-section__grid--packages {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }

    /* Feature cards */
    .feature-card__icon img,
    .feature-card__icon .qf-svg-accent {
        width: 2.5rem;
        height: 2.5rem;
    }
}

/* Tablet landscape - 769px to 991px */
@media (min-width: 769px) and (max-width: 991px) {
    .hero-section {
        min-height: 40vh !important;
        max-height: 45vh !important;
        padding: 1.5rem 0 2rem !important;
        background-position: 50% center !important;
    }
    
    .hero-section__copy {
        padding-top: 1rem;
        text-align: center;
    }
    
    .hero-section__title,
    .hero-section__tagline {
        font-size: clamp(2rem, 5vw, 3rem);
    }
}

/* Phone and below - Further mobile optimizations */
@media (max-width: 576px) {
    :root {
        --logo-notch-width: 11rem;
        --logo-notch-height: 3.2rem;
        --logo-notch-logo-offset-y: 0.5rem;
        --logo-notch-logo-shrink: 2.25rem;
    }

    .site-header {
        min-height: calc(var(--logo-notch-height) + 0.75rem + var(--section-padding-x));
        padding-top: calc(var(--section-padding-x) * 0.75);
    }

    .logo-notch__content {
        padding: var(--logo-notch-logo-offset-y) 0.35rem 0.25rem;
    }

    .logo-notch__img {
        max-width: min(85%, calc(8rem - var(--logo-notch-logo-shrink)));
    }

    /* Hero section mobile optimizations */
    .hero-section {
        background-position: 60% center !important;
        min-height: 33vh !important;
        max-height: 33vh !important;
        padding: 1rem 0 1.25rem !important;
    }

    .hero-section__copy {
        padding-top: 0.5rem;
    }

    .hero-section__title,
    .hero-section__tagline {
        font-size: clamp(1.5rem, 4.5vw, 2.25rem);
        white-space: normal;
    }

    .hero-section__body {
        font-size: clamp(0.875rem, 3vw, 1rem);
    }

    /* Ensure all card grids stack */
    .solution-section__grid,
    .about-section__grid,
    .value-section__grid--packages,
    .value-section__grid--outcomes,
    .value-audience__grid {
        grid-template-columns: 1fr !important;
        gap: 1.25rem;
    }

    /* Card sizing adjustments */
    .solution-card,
    .about-card,
    .value-card {
        padding: 1rem;
    }

    .solution-card__content {
        padding: 0.875rem;
    }

    .solution-card__media {
        min-height: 8rem;
    }

    /* Icon sizing for mobile */
    .feature-card__icon img,
    .feature-card__icon .qf-svg-accent,
    .features-audio-card__icon img,
    .features-audio-card__icon .qf-svg-accent {
        width: 2.25rem;
        height: 2.25rem;
    }

    /* Contact form mobile */
    .contact-section__grid {
        gap: 1.5rem;
    }

    .contact-form__row--split {
        grid-template-columns: 1fr !important;
        gap: 1rem;
    }

    /* Nav adjustments */
    .site-header__inner {
        padding-top: 0.5rem;
    }

    .btn-accent {
        padding: 0.5rem 1.25rem;
        font-size: 0.875rem;
    }
}

/* Extra small devices */
@media (max-width: 375px) {
    :root {
        --logo-notch-width: 9.5rem;
        --logo-notch-height: 2.8rem;
    }

    .logo-notch__img {
        max-width: min(80%, 6.5rem);
    }

    .hero-section {
        background-position: 65% center !important;
        min-height: 30vh !important;
        max-height: 30vh !important;
        padding: 0.75rem 0 1rem !important;
    }

    .hero-section__copy {
        padding-top: 0.5rem;
    }

    .hero-section__title,
    .hero-section__tagline {
        font-size: clamp(1.375rem, 4vw, 2rem);
        margin-bottom: 0.5rem;
    }
}

/* ========================================
   Premium SaaS Components
   ======================================== */

/* Image + Text Component */
.image-text-section {
    position: relative;
    padding: 60px 0;
    background: var(--color-about-challenge-bg);
}

.image-text-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: var(--features-section-overlay);
    background-repeat: no-repeat;
    background-position: left top;
    background-size: 100% auto;
    opacity: var(--features-section-overlay-opacity);
    pointer-events: none;
}

.image-text-section .qf-container {
    position: relative;
    z-index: 1;
}

.image-text {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(3rem, 6vw, 6rem);
    align-items: center;
}

.image-text__media {
    position: relative;
}

.image-text__media img {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 16px;
    display: block;
}

.image-text__placeholder {
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, #f5f5f5 0%, #e8e8e8 100%);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: var(--text-body-sm-size);
    padding: 2rem;
    text-align: center;
}

.image-text__content {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.image-text__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.image-text__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--line-height-snug);
    letter-spacing: -0.02em;
    color: var(--color-title);
    margin: 0;
}

.image-text__body {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
    color: var(--color-text);
    margin: 0;
}

.image-text__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.image-text__list-item {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
}

.image-text__list-item img {
    flex-shrink: 0;
    margin-top: 0.125rem;
    -webkit-mask: linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0);
    -webkit-mask-size: 100% 100%;
    mask-size: 100% 100%;
    background: var(--accent-color);
}

.image-text__list-item span {
    font-size: var(--text-body-size);
    line-height: var(--line-height-comfortable);
    color: var(--color-text);
}

@media (max-width: 991px) {
    .image-text {
        grid-template-columns: 1fr;
        gap: 2.5rem;
    }
    
    .image-text__media {
        order: -1;
    }
}

/* Story Timeline Component */
.story-timeline-section {
    padding-top: var(--section-padding-y);
    padding-bottom: 0;
    background: var(--color-about-fails-bg);
}

.story-timeline__header {
    text-align: center;
    margin-bottom: 1rem !important;
}

.story-timeline__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.story-timeline__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--line-height-snug);
    letter-spacing: -0.02em;
    color: var(--color-title);
    margin: 0;
}

.story-timeline__nav {
    display: flex;
    gap: 0.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--color-border);
    overflow-x: auto;
    scrollbar-width: thin;
}

.story-timeline__tab {
    display: flex;
    align-items: center;
    padding: 1rem 1.5rem;
    background: rgba(var(--accent-color-rgb), 0.4);
    border: none;
    border-bottom: 3px solid transparent;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.story-timeline__tab:hover {
    background: rgba(var(--accent-color-rgb), 0.6);
}

.story-timeline__tab--active {
    background: rgba(0, 0, 0, 0.4);
    border-bottom-color: var(--accent-color);
}

.story-timeline__tab-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.story-timeline__tab-number {
    font-family: var(--font-heading);
    font-size: var(--text-body-size);
    font-weight: 700;
    color: var(--accent-color);
}

.story-timeline__tab-title {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    font-weight: 600;
    color: var(--color-title);
}

.story-timeline__progress-bar {
    position: relative;
    height: 0.875rem;
    background: #e5e1de;
    border: 5px solid #e5e1de;
    border-radius: 999px;
    margin-bottom: 3rem;
    overflow: hidden;
}

@media (min-width: 992px) {
    .story-timeline__progress-bar {
        display: none;
    }
}

.story-timeline__progress-fill {
    height: 100%;
    width: 0%;
    background: var(--accent-color);
    border-radius: 999px;
    pointer-events: none;
    transition: width 0.1s linear;
}

.story-timeline__content {
    position: relative;
    min-height: 400px;
}

.story-timeline__stage {
    position: absolute;
    inset: 0;
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease, visibility 0.5s ease;
}

.story-timeline__stage--active {
    position: relative;
    opacity: 1;
    visibility: visible;
}

.story-timeline__media {
    position: relative;
}

.story-timeline__media img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    object-position: left top;
    border-radius: 16px;
    display: block;
}

.story-timeline__placeholder {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, #f5f5f5 0%, #e8e8e8 100%);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: var(--text-body-sm-size);
    padding: 2rem;
    text-align: center;
}

.story-timeline__text {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.story-timeline__stage-title {
    font-family: var(--font-heading);
    font-size: var(--text-h3-size);
    font-weight: var(--text-h3-weight);
    line-height: var(--line-height-normal);
    color: var(--color-title);
    margin: 0;
}

.story-timeline__stage-description {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
    color: var(--color-text);
    margin: 0;
}

@media (max-width: 991px) {
    .story-timeline__stage {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    
    .story-timeline__media {
        order: -1;
    }
}

@media (max-width: 768px) {
    .story-timeline__tab {
        padding: 0.75rem 1rem;
    }
}

/* Checklist Component */
.checklist-section {
    padding: 60px 0;
    background: var(--color-value-package-bg);
}

.checklist-section__header {
    text-align: center;
    margin-bottom: 1rem !important;
}

.checklist-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.checklist-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--line-height-snug);
    letter-spacing: -0.02em;
    color: var(--color-title);
    margin: 0;
}

.checklist {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 4rem;
}

.checklist__group {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

.checklist__label {
    font-family: var(--font-heading);
    font-size: var(--text-h4-size);
    font-weight: 600;
    color: var(--color-title);
    margin: 0;
}

.checklist__list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
}

.checklist__item {
    display: flex;
    gap: 1.5rem;
    align-items: flex-start;
}

.checklist__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #18181c;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.checklist__icon img {
    width: 24px;
    height: 24px;
    filter: brightness(0) invert(1);
}


.checklist__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.checklist__inline-icon {
    display: inline-block;
    vertical-align: middle;
    margin-right: 0.5rem;
    -webkit-mask: linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0);
    background: #18181c;
}

.checklist__title-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.checklist__title-row .checklist__inline-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    margin-right: 0;
}

.checklist__title-row .checklist__title {
    margin: 0;
}

.checklist__title {
    font-family: var(--font-heading);
    font-size: var(--text-h5-size);
    font-weight: 600;
    color: var(--color-title);
    margin: 0;
}

.checklist__body {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
    color: var(--color-text);
    margin: 0;
}

.checklist__group--addons {
    padding-top: 2rem;
    border-top: 1px solid var(--color-border);
}

.checklist__list--addons {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(2rem, 4vw, 4rem);
}

.checklist__item--addon .checklist__icon {
    background: #18181c;
    border: none;
}

.checklist__icon--plus {
    font-size: 2rem;
    font-weight: 400;
    line-height: var(--line-height-none);
    color: var(--accent-color);
}

@media (max-width: 991px) {
    .checklist__list {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .checklist__list {
        grid-template-columns: 1fr;
    }
    
    .checklist__item {
        gap: 1rem;
    }
    
    .checklist__icon {
        width: 40px;
        height: 40px;
    }
}

/* Transformation Timeline Component */
.transformation-timeline-section {
    padding: 60px 0 0 0;
    background: #F7F7F7;
}

.transformation-timeline__header {
    text-align: center;
    margin-bottom: 1rem !important;
}

.transformation-timeline__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.transformation-timeline__header .transformation-timeline__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--line-height-snug);
    letter-spacing: -0.02em;
    color: var(--color-title);
    margin: 0;
}

.transformation-timeline-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: start;
}

.transformation-timeline {
    position: relative;
}

.transformation-timeline__line {
    position: absolute;
    left: 24px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(to bottom, #18181c 0%, rgba(24, 24, 28, 0.2) 100%);
}

.transformation-timeline__item {
    display: flex;
    gap: 2rem;
    align-items: flex-start;
    margin-bottom: 3rem;
    position: relative;
}

.transformation-timeline__item:last-child {
    margin-bottom: 0;
}

.transformation-timeline__icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #18181c;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
}

.transformation-timeline__icon img {
    width: 24px;
    height: 24px;
    filter: brightness(0) invert(1);
}

.transformation-timeline__content {
    flex: 1;
    padding-top: 0.5rem;
}

.transformation-timeline__content .transformation-timeline__title {
    font-family: var(--font-heading);
    font-size: var(--text-h5-size);
    font-weight: 600;
    color: var(--color-title);
    margin: 0 0 0.75rem 0;
}

.transformation-timeline__body {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
    color: var(--color-text);
    margin: 0;
}

.transformation-timeline__media {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.transformation-timeline__media img {
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center;
    border-radius: 16px;
    display: block;
}

.transformation-timeline__placeholder {
    aspect-ratio: 4 / 3;
    background: linear-gradient(135deg, #f5f5f5 0%, #e8e8e8 100%);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

@media (max-width: 991px) {
    .transformation-timeline-grid {
        grid-template-columns: 1fr;
        gap: 3rem;
    }
    
    .transformation-timeline__media {
        order: -1;
    }
}

@media (max-width: 768px) {
    .transformation-timeline__line {
        left: 20px;
    }
    
    .transformation-timeline__icon {
        width: 40px;
        height: 40px;
    }
    
    .transformation-timeline__item {
        gap: 1.5rem;
    }
}

/* Video Component */
.video-section {
    padding-top: 60px;
    padding-bottom: 3.75rem;
    background: #E6E6E6;
}

.video-section__header {
    text-align: center;
    margin-bottom: 1rem !important;
}

.video-section__subtitle {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
    color: var(--color-text);
    max-width: 800px;
    margin: 1rem auto 0;
}

.video-section__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-section-eyebrow);
    margin: 0 0 0.75rem;
}

.video-section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: var(--text-h2-weight);
    line-height: var(--line-height-snug);
    letter-spacing: -0.02em;
    color: var(--color-title);
    margin: 0;
}

.video-container {
    max-width: 1200px;
    margin: 0 auto 3rem;
}

.video-player {
    position: relative;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: 16px;
    overflow: hidden;
}

.video-player__video {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.video-player__play-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.3);
    cursor: pointer;
    transition: opacity 0.3s ease, transform 0.3s ease;
    z-index: 1;
}

.video-player__play-overlay.hidden {
    opacity: 0;
    pointer-events: none;
}

.video-player__play-button {
    color: var(--accent-color);
    transition: transform 0.3s ease;
}

.video-player__play-overlay:hover .video-player__play-button {
    transform: scale(1.1);
}

.video-player__controls {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1rem;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent);
    display: flex;
    align-items: center;
    gap: 0.75rem;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.video-player:hover .video-player__controls,
.video-player__controls:focus-within {
    opacity: 1;
}

.video-player__play-toggle {
    width: 2rem;
    height: 2rem;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
    color: var(--color-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: var(--line-height-none);
    cursor: pointer;
    flex-shrink: 0;
    transition: background-color 0.2s ease;
}

.video-player__play-toggle:hover,
.video-player__play-toggle:focus-visible {
    background: var(--accent-color-hover);
}

.video-player__progress {
    position: relative;
    flex: 1;
    height: 0.875rem;
    background: rgba(229, 225, 222, 0.3);
    border: 5px solid rgba(229, 225, 222, 0.3);
    border-radius: 999px;
    cursor: pointer;
    overflow: hidden;
}

.video-player__progress-fill {
    height: 100%;
    width: 0%;
    background: var(--accent-color);
    border-radius: 999px;
    pointer-events: none;
    transition: width 0.1s linear;
}

.video-player__time {
    font-family: var(--font-body);
    font-size: 0.625rem;
    font-weight: 600;
    line-height: var(--line-height-none);
    color: var(--color-text-on-dark);
    background: var(--accent-color);
    padding: 0.35rem 0.65rem;
    border-radius: 999px;
    white-space: nowrap;
    flex-shrink: 0;
}

.video-player__volume {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.video-player__volume-toggle {
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--color-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    cursor: pointer;
    flex-shrink: 0;
    transition: color 0.2s ease;
}

.video-player__volume-toggle:hover,
.video-player__volume-toggle:focus-visible {
    color: var(--accent-color);
}

.video-player__volume-slider {
    width: clamp(3rem, 2rem + 4vw, 5rem);
    height: 0.875rem;
    margin: 0;
    padding: 0;
    appearance: none;
    background: transparent;
    cursor: pointer;
}

.video-player__volume-slider:focus-visible {
    outline: 2px solid var(--accent-color);
    outline-offset: 2px;
    border-radius: 999px;
}

.video-player__volume-slider::-webkit-slider-runnable-track {
    height: 0.25rem;
    background: linear-gradient(to right, var(--accent-color) 0%, var(--accent-color) var(--volume-percent, 100%), rgba(229, 225, 222, 0.3) var(--volume-percent, 100%), rgba(229, 225, 222, 0.3) 100%);
    border-radius: 999px;
}

.video-player__volume-slider::-webkit-slider-thumb {
    appearance: none;
    width: 0.625rem;
    height: 0.625rem;
    margin-top: -0.1875rem;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
}

.video-player__volume-slider::-moz-range-track {
    height: 0.25rem;
    background: rgba(229, 225, 222, 0.3);
    border-radius: 999px;
}

.video-player__volume-slider::-moz-range-progress {
    height: 0.25rem;
    background: var(--accent-color);
    border-radius: 999px;
}

.video-player__volume-slider::-moz-range-thumb {
    width: 0.625rem;
    height: 0.625rem;
    border: none;
    border-radius: 50%;
    background: var(--accent-color);
}

.video-player__fullscreen-toggle {
    width: 1.5rem;
    height: 1.5rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--color-text-on-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    cursor: pointer;
    flex-shrink: 0;
    transition: color 0.2s ease;
}

.video-player__fullscreen-toggle:hover,
.video-player__fullscreen-toggle:focus-visible {
    color: var(--accent-color);
}

.industry-strip {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: clamp(1.5rem, 3vw, 3rem);
    max-width: 1000px;
    margin: clamp(2rem, 4vw, 3rem) auto 0;
}

.industry-strip__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    text-align: center;
}

.industry-strip__item img {
    width: 32px;
    height: 32px;
    -webkit-mask: linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0);
    background: #18181c;
}

.industry-strip__item span {
    font-size: var(--text-body-sm-size);
    font-weight: 500;
    color: var(--color-text);
}

@media (max-width: 768px) {
    .industry-strip {
        gap: 1.5rem;
        margin-top: 1.5rem;
    }
    
    .industry-strip__item img {
        width: 24px;
        height: 24px;
    }
    
    .industry-strip__item span {
        font-size: 0.75rem;
    }
    
    .video-player__controls {
        padding: 0.75rem;
        gap: 0.5rem;
        flex-wrap: wrap;
    }
    
    .video-player__progress {
        order: -1;
        flex-basis: 100%;
    }
    
    .video-player__volume {
        flex: 1;
    }
}

/* Brand Statement Component */
.brand-statement-section {
    padding-top: var(--section-padding-y);
    padding-bottom: var(--section-padding-y);
    background: var(--color-proudly-namibian-section-bg);
    position: relative;
    color: var(--color-text-on-dark);
    overflow: hidden;
}

.brand-statement__overlay {
    position: absolute;
    inset: 0;
    background-image: url('../images/proudly_namibian_bg.webp');
    background-repeat: no-repeat;
    background-position: right center;
    background-size: auto 100%;
    opacity: 0.15;
    pointer-events: none;
}

.brand-statement-section .qf-container {
    position: relative;
    z-index: 1;
}

.brand-statement__header {
    text-align: center;
    margin-bottom: 1rem !important;
}

.brand-statement__eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-body-sm-size);
    font-weight: var(--text-overline-weight);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.9);
    margin: 0 0 0.75rem;
}

.brand-statement__title {
    font-family: var(--font-heading);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 700;
    line-height: var(--line-height-tight);
    letter-spacing: -0.02em;
    color: var(--color-white);
    margin: 0;
    max-width: 900px;
    margin-inline: auto;
}

.brand-statement__body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2rem, 4vw, 4rem);
    max-width: 1000px;
    margin: 0 auto 3rem;
}

.brand-statement__column p {
    font-size: var(--text-body-size);
    line-height: var(--text-body-line);
    color: rgba(255, 255, 255, 0.95);
    margin: 0;
}

.brand-statement__footer {
    text-align: center;
    font-family: var(--font-heading);
    font-size: var(--text-body-size);
    font-weight: 600;
    color: var(--color-white);
    margin: 0;
}

@media (max-width: 991px) {
    .brand-statement__overlay {
        background-size: contain;
        background-position: center right;
    }
    
    .brand-statement__body {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}

@media (max-width: 768px) {
    .brand-statement__overlay {
        background-size: cover;
        background-position: right center;
        opacity: 0.1;
    }
}

/* ========================================
   Responsive Media
   ======================================== */
img {
    max-width: 100%;
    height: auto;
}

/* ========================================
   Print Styles
   ======================================== */
@media print {
    .page-shell {
        box-shadow: none;
        border-radius: 0;
    }
}
