/* ── RESET / GLOBAL ── */
*,
*::before,
*::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

:root {
    --green: #29bf12;
    --lime: #b8ff3a;
    --purple: #4700c5;
    --red: #f21b3f;
    --orange: #ff9914;
    --black: #111111;
    --white: #ffffff;
    --clime: #b8ff3a;
    --ccyan: #00e5e5;
    --cpink: #ff2de1;
    --cyellow: #ffe600;
    --bg: #ebebeb;
    --bg-light: #f4f4f4;
}

html {
    font-size: 16px;
}

body {
    font-family: 'Barlow', sans-serif;
    background: var(--bg);
    color: var(--black);
    overflow-x: hidden;
}

a {
    color: inherit;
    text-decoration: none;
}


.hero-body.second-body a,
.second-body a,
.inlined,
.hero-inline,
.about-intro-copy a,
.free-tagline a,
p.cat-intro a {
    color: var(--black);
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 4px;
    text-decoration-color: var(--red);
    transform: translateY(0);
    transition: all 0.14s;
    display: inline-block;
}

.hero-body.second-body a:hover,
.second-body a:hover,
.inlined:hover,
.hero-inline:hover,
.about-intro-copy a:hover,
.free-tagline a:hover,
p.cat-intro a:hover {
    text-underline-offset: 6px;
}

sup.red {
    color: var(--cpink);
    display: inline-block;
    padding-left: 5px;
}

p:not([class]) {
    margin-bottom: 1rem;
}

img {
    max-width: 100%;
    display: block;
}

svg image {
    mix-blend-mode: darken;
}

/* ── NAV ── */
.site-nav {
    background: var(--lime);
    border-bottom: 3px solid var(--black);
    position: sticky;
    top: 0;
    z-index: 200;
}

.nav-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 40px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    height: 62px;
}

.nav-logo {
    justify-self: start;
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.2rem;
    letter-spacing: 0.04em;
    color: var(--black);
    flex-shrink: 0;
    display: flex;
}

.nav-logo img {
    aspect-ratio: 600 / 93;
    width: min(240px, 60vw);
    height: auto;
    display:block;
}

.nav-links {
    justify-self: center;
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    padding: 0;
    width: clamp(12rem, 22vw, 13rem);
}

.nav-links li {
    display: flex;
}

.nav-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--black);
    transition: opacity 0.12s;
}

.nav-rotator {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 9ch;
}

.nav-rotator.is-animating::after {
    content: "";
    width: 2px;
    height: 1.1em;
    margin-left: 0.24em;
    background: currentColor;
    animation: nav-rotator-caret 0.9s steps(1, end) infinite;
}

@keyframes nav-rotator-caret {
    0%,
    48% {
        opacity: 1;
    }

    49%,
    100% {
        opacity: 0;
    }
}

.nav-links a:hover {
    opacity: 0.6;
}

.nav-cta {
    justify-self: end;
    display: inline-block;
    border: 2.5px solid var(--black);
    border-radius: 4px;
    padding: 8px 20px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--black);
    flex-shrink: 0;
    transition: background 0.14s, color 0.14s;
}

.link-arrow-icon {
    display: inline-block;
    width: 0.9em;
    height: 0.9em;
    margin-left: 0.34em;
    vertical-align: -0.08em;
    background-color: currentColor;
    -webkit-mask-image: url('/assets/img/new-window.svg?cb=e0dbf57');
    mask-image: url('/assets/img/new-window.svg?cb=e0dbf57');
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-position: center;
    mask-position: center;
}

.link-skip-icon {
    display: inline-block;
    width: 0.9em;
    height: 0.9em;
    margin-left: 0.34em;
    vertical-align: -0.08em;
    background-color: currentColor;
    -webkit-mask-image: url('/assets/img/skip.svg?cb=e0dbf57');
    mask-image: url('/assets/img/skip.svg?cb=e0dbf57');
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-position: center;
    mask-position: center;
}

.nav-cta:hover {
    background: var(--black);
    color: var(--lime);
}

/* ── MOBILE MENU ── */
.mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--black);
    padding: 0;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 4px;
}

.mobile-menu-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: var(--lime);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
}

.mobile-menu-overlay.is-open {
    display: flex;
}

.mobile-menu-overlay .mmo-close {
    position: absolute;
    top: 0;
    right: 0;
    background: none;
    border: none;
    cursor: pointer;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--black);
    padding: 20px 24px;
}

.mobile-menu-overlay a {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: clamp(2.4rem, 12vw, 4rem);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--black);
    line-height: 1;
    padding: 12px 0;
    border-bottom: 3px solid var(--black);
    width: 80%;
    text-align: center;
    transition: opacity 0.12s;
}

.mobile-menu-overlay a:last-of-type {
    border-bottom: none;
}

.mobile-menu-overlay a:hover {
    opacity: 0.55;
}

/* ── HERO ── */
.intro-stage {
    position: sticky;
    top: 62px;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    background: var(--bg);
    border-bottom: 0 solid var(--black);
    overflow: clip;
    z-index: 0;
    min-height: min(720px, calc(100svh - 230px));
    max-height: 720px;
}

.hero {
    position: relative;
    overflow: hidden;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: left;
}

#webgl-pixels {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    width: 100%;
    height: 100%;
    display: block;
}

.hero-inner {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 1300px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    min-height: 0;
    padding: 60px 40px 40px;
}

.hero-headline {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(3rem, 9vw, 9rem);
    line-height: 0.9;
    letter-spacing: -0.01em;
    color: var(--black);
    margin-bottom: 22px;
}

.word-boldest {
    color: #fff;
    -webkit-text-stroke: 2px var(--black);
}

.hero-body {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.7;
    color: var(--black);
    max-width: 50ch;
    margin-bottom: 0;
}

.hero-body span {
    display: block;
    font-weight: 400;
    color: #555;
}
.hero-body em.nowrap {
    font-style: normal;
    white-space: nowrap;
}

.hero-body.is-rotating-copy .hero-rotator {
    position: relative;
    display: block;
    min-height: var(--hero-rotator-height, 1.7em);
}

.hero-body.is-rotating-copy .hero-rotator-item {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    transform: translateY(8px) rotateX(-15deg);
    transform-origin: center top;
    transition: opacity 0.42s ease, transform 0.42s ease;
    will-change: opacity, transform;
}

.hero-body.is-rotating-copy .hero-rotator-item.is-active {
    opacity: 1;
    transform: translateY(0) rotateX(0deg);
}

.second-body,
.hero-body.second-body {
    margin-top: 2em;
    font-weight: normal;
}

.hero-left {
    position: relative;
    font-size: clamp(3rem, 9vw, 9rem);
    width: 12ch;
}

.hero-illustration {
    position: absolute;
    top: 50%;
    left: 100%;
    transform: translateY(-50%);
    width: clamp(300px, 7.21vw + 244.6px, 360px);
    height: clamp(300px, 7.21vw + 244.6px, 360px);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    z-index: 1;
}

.illus-svg {
    width: clamp(300px, 7.21vw + 244.6px, 360px);
    height: clamp(300px, 7.21vw + 244.6px, 360px);
    max-width: none;
}

/* ── MARQUEE ── */
.marquee-section {
    border-top: 3px solid var(--black);
    background: var(--white);
    padding: 0;
    overflow: hidden;
    position: relative;
    z-index: 2;
}

.marquee-title {
    font-family: 'Black Han Sans', sans-serif;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: auto;
    background: var(--cpink);
    display: flex;
    align-items: center;
    padding: 0 1rem;
    border-right: 3px solid black;
}

.marquee-track {
    display: flex;
    align-items: center;
    width: max-content;
    white-space: nowrap;
    animation: marquee-scroll 96s linear infinite;
}

.marquee-track:hover {
    animation-play-state: paused;
}

@keyframes marquee-scroll {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-50%);
    }
}

.mq-item {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 150px;
    min-height: 58px;
    padding: 0;
    flex-shrink: 0;
}

.mq-logo {
    display: block;
    width: auto;
    max-width: 100%;
    object-fit: contain;
    filter: none;
}

.mq-shopify {
    height: 24px;
    transform: translateY(-1px);
}

.mq-klaviyo {
    height: 22px;
    transform: translateY(2px);
}

.mq-sanity {
    height: 23px;
    transform: translateY(2px);
}

.mq-cloudflare {
    height: 28px;
    transform: translateY(-4px);
}

.mq-openai {
    height: 22px;
    transform: translateY(1px);
}

.mq-claude {
    height: 20px;
}

.mq-sep {
    display: flex;
    align-items: center;
    padding: 0 10px;
    flex-shrink: 0;
    display: none;
}

/* ── STICKY OVERRIDE (viewport too short) ── */
.no-sticky-hero .site-nav {
    position: relative;
}

.no-sticky-hero .intro-stage {
    position: relative;
    top: auto;
}

/* ── RESPONSIVE ── */
@media (max-width: 1080px) {
    .mq-item {
        min-width: 180px;
        padding: 0 24px;
    }
}

@media (max-width: 760px) {
    .intro-stage {
        position: relative;
        top: auto;
        min-height: auto;
        max-height: none;
    }

    .nav-links {
        display: none;
    }

    .nav-cta {
        display: none;
    }

    .mobile-menu-btn {
        display: block;
        margin-left: auto;
    }

    .hero-inner {
        display: block;
        min-height: 0;
        padding: 48px 24px 40px;
        padding-right: 132px;
    }

    .hero-left {
        position: relative;
        z-index: 2;
        font-size: clamp(2rem, 8vw, 9rem);
        width: 12ch;
    }

    .hero-headline {
        font-size: clamp(2rem, 8vw, 9rem);
    }

    .hero-illustration {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 0;
        width: 200px;
        justify-content: flex-end;
        align-items: flex-start;
        overflow: visible;
        pointer-events: none;
        z-index: 1;
    }

    .hero-body {
        width: 25ch;
    }

    .illus-svg {
        width: 280px;
        max-width: none;
    }

    .nav-inner {
        display: flex;
        padding: 0 24px;
    }

    .mq-item {
        min-width: 150px;
        padding: 0 18px;
    }
}

@media (max-width: 600px) {
    .marquee-track {
        animation-duration: 72s;
    }
}

@media (prefers-reduced-motion: reduce) {
    #webgl-pixels {
        display: none;
    }

    .marquee-track {
        animation: none;
    }

    .hero-body.is-rotating-copy .hero-rotator-item {
        transition: none;
        transform: none;
    }
}

/* ── CONTENT SHELL ── */
.content-shell {
    position: relative;
    z-index: 4;
    margin-top: -116px;
    padding-top: 116px;
}

body[class*="page-"] .content-shell {
    margin-top: 0;
    padding-top: 0;
}

.content-shell>#products-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    display: block;
}

body.page-products .content-shell,
body.page-discovery .content-shell,
body.page-consultancy .content-shell,
body.page-packages .content-shell,
body.page-subscriptions .content-shell {
    overflow: hidden;
    background: var(--white);
}

body.page-products .products-section,
body.page-discovery .products-section,
body.page-consultancy .products-section,
body.page-packages .products-section,
body.page-subscriptions .products-section {
    background: transparent;
    box-shadow: none;
}
body.page-discovery .products-section,
body.page-consultancy .products-section,
body.page-packages .products-section,
body.page-subscriptions .products-section {
    padding-top: 54px;
}

.proc-skip-link.ch-lime,
.proc-skip-link.ch-cyan,
.proc-skip-link.ch-pink,
.proc-skip-link.ch-yellow,
.proc-skip-link.ch-orange {
    background-color: inherit;
}

.proc-skip-link.ch-lime {
    background: var(--clime);
}

.proc-skip-link.ch-cyan {
    background: var(--ccyan);
}

.proc-skip-link.ch-pink {
    background: var(--cpink);
}

.proc-skip-link.ch-yellow {
    background: var(--cyellow);
}

.proc-skip-link.ch-orange {
    background: var(--orange);
}

body.page-discovery .proc-skip,
body.page-consultancy .proc-skip,
body.page-packages .proc-skip,
body.page-subscriptions .proc-skip,
body.page-products .subpage-header .proc-skip {
    display: grid;
    grid-template-columns: repeat(4, max-content);
    gap: 8px;
    justify-content: start;
    align-items: center;
}
body.page-discovery .proc-skip,
body.page-consultancy .proc-skip,
body.page-packages .proc-skip,
body.page-subscriptions .proc-skip {
    justify-content: center;
}

body.page-discovery .proc-skip-link,
body.page-consultancy .proc-skip-link,
body.page-packages .proc-skip-link,
body.page-subscriptions .proc-skip-link,
body.page-products .subpage-header .proc-skip-link {
    text-align: center;
    white-space: nowrap;
}

@media (max-width: 660px) {
    
    body.page-discovery .proc-skip-products,
    body.page-consultancy .proc-skip-products,
    body.page-packages .proc-skip-products,
    body.page-subscriptions .proc-skip-products,
    body.page-products .subpage-header .proc-skip-products {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 420px;
    }

    body.page-discovery .products-inner .proc-skip-products,
    body.page-consultancy .products-inner .proc-skip-products,
    body.page-packages .products-inner .proc-skip-products,
    body.page-subscriptions .products-inner .proc-skip-products {
        margin-left: auto;
        margin-right: auto;
    }
    body.page-discovery .products-inner .proc-skip-products>a:last-child,
    body.page-consultancy .products-inner .proc-skip-products>a:last-child,
    body.page-packages .products-inner .proc-skip-products>a:last-child,
    body.page-subscriptions .products-inner .proc-skip-products>a:last-child {
        grid-column: span 2;
    }
    
    body.page-discovery .proc-skip-link,
    body.page-consultancy .proc-skip-link,
    body.page-packages .proc-skip-link,
    body.page-subscriptions .proc-skip-link,
    body.page-products .subpage-header .proc-skip-link {
        display: block;
        width: 100%;
        box-sizing: border-box;
        padding-left: 12px;
        padding-right: 12px;
    }
}

@media (max-width: 420px) {
    body.page-discovery .proc-skip-link,
    body.page-consultancy .proc-skip-link,
    body.page-packages .proc-skip-link,
    body.page-subscriptions .proc-skip-link,
    body.page-products .subpage-header .proc-skip-link {
        font-size: 0.72rem;
        letter-spacing: 0.12em;
        padding-left: 8px;
        padding-right: 8px;
    }
}

/* ── WHO WE HELP ── */
.who-section {
    position: relative;
    background: radial-gradient(120% 90% at 50% -10%, #ffffff 0%, #f4f4f4 58%, #ececec 100%);
    /* no overflow:hidden — required for position:sticky descendants */
    scroll-margin-top: 62px; /* site-nav height */
}

.who-section .sec-heading {
    padding-bottom: 24px;
}


.who-headline {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3.4rem);
    line-height: 1;
    letter-spacing: 0.03em;
    color: transparent;
    -webkit-text-stroke: 0.5px rgba(17, 17, 17, 0.9);
    text-transform: uppercase;
    margin: 0;
}

/* ── Sticky audience switcher ── */
.who-sticky-nav {
    position: sticky;
    top: 62px; /* site-nav height */
    z-index: 50;
    background: rgba(255, 255, 255, 0.68);
    border-top: 1px solid rgba(17, 17, 17, 0.18);
    border-bottom: 1px solid rgba(17, 17, 17, 0.18);
    box-shadow: 0 8px 18px rgba(17, 17, 17, 0.08);
    backdrop-filter: saturate(130%) blur(8px);
}

.wsn-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
}

.wsn-tab {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 17px 20px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: clamp(0.8125rem, 1.2vw, 0.95rem);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.9);
    border-right: 1px solid rgba(17, 17, 17, 0.12);
    position: relative;
}

.wsn-tab.is-active,
.wsn-tab:hover {
    color: var(--wsn-accent, var(--black));
}

.wsn-tab.is-active,
.wsn-tab:hover {
    background: var(--black);
}

.wsn-tab:last-child  { border-right: 0; }

/* Animated underline — scaleX from left */
.wsn-tab::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--wsn-accent, rgba(255, 255, 255, 0.3));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
}

.wsn-tab.is-active::after,
.wsn-tab:hover::after {
    transform: scaleX(1);
}

.wsn-tab--business    { --wsn-accent: var(--clime); }
.wsn-tab--entrepreneur { --wsn-accent: var(--cpink); }
.wsn-tab--sole-trader  { --wsn-accent: var(--ccyan); }
.wsn-tab--diy          { --wsn-accent: var(--cyellow); }

.wsn-num {
    font-family: 'Barlow', sans-serif;
    font-weight: 400;
    font-size: 0.8125rem;
    opacity: 0.45;
    letter-spacing: 0;
    flex-shrink: 0;
}

/* ── Slabs outer wrapper ── */
.who-slabs-outer {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 40px 100px;
    position: relative;
    z-index: 1;
}

/* ── Individual audience slab ── */
.who-slab {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 0 72px;
    padding-top: 72px;
    align-items: start;
    /* scroll-margin accounts for site-nav + sticky-nav */
    scroll-margin-top: 138px;
}

.who-slab + .who-slab {
    margin-top: 64px;
}

/* ── Sticky audience label (left column) ── */
.who-slab-cap {
    position: sticky;
    /* Increased so ghost number never clips at top when sticky */
    top: 160px;
    align-self: start;
    padding-bottom: 32px;
}

.who-slab-ghost {
    display: block;
    font-family: 'Black Han Sans', sans-serif;
    font-size: 7rem;
    line-height: 1;
    color: transparent;
    -webkit-text-stroke: 1px rgba(17, 17, 17, 0.11);
    letter-spacing: -0.02em;
    position: absolute;
    top: -0.5em;
    left: -0.18em;
    pointer-events: none;
    user-select: none;
    transition: -webkit-text-stroke-color 0.4s;
}

.who-slab:hover .who-slab-ghost {
    -webkit-text-stroke-color: rgba(17, 17, 17, 0.22);
}

.who-slab-name {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.4rem, 2.6vw, 2rem);
    line-height: 1.05;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--who-slab-accent);
    -webkit-text-stroke: 0.5px var(--black);
    opacity: 0.5;
    position: relative; /* above ghost */
    transition: opacity 0.3s;
}

.who-slab:hover .who-slab-name {
    opacity: 0.9;
}

.who-slab.is-active .who-slab-name {
    opacity: 1;
}

.who-slab--business    { --who-slab-accent: var(--clime); }
.who-slab--entrepreneur { --who-slab-accent: var(--cpink); }
.who-slab--sole-trader  { --who-slab-accent: var(--ccyan); }
.who-slab--diy          { --who-slab-accent: var(--cyellow); }

/* ── Need items ── */
.who-needs {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: need-counter;
}

.who-need {
    counter-increment: need-counter;
}

.who-need + .who-need {
    border-top: 1px solid rgba(17, 17, 17, 0.12);
}

.who-need-link {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    gap: 7px 32px;
    align-items: center;
    padding: 28px 0 28px 36px;
    position: relative;
}

/* Subtle index number in the left gutter */
.who-need-link::before {
    content: counter(need-counter, decimal-leading-zero);
    position: absolute;
    left: 0;
    top: 32px;
    font-family: 'Barlow', sans-serif;
    font-size: 0.875rem;
    font-weight: 400;
    color: rgba(17, 17, 17, 0.26);
    letter-spacing: 0;
    transition: color 0.15s;
}

.who-need-link:hover::before {
    color: var(--black);
}

.who-need-label {
    grid-column: 1;
    grid-row: 1;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: clamp(0.95rem, 1.85vw, 1.18rem);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--black);
    line-height: 1.15;
}

.who-need-desc {
    grid-column: 1;
    grid-row: 2;
    font-size: 0.83rem;
    color: var(--black);
    opacity: 0.9;
    line-height: 1.68;
    margin: 0;
    transition: opacity 0.15s;
}

.who-need-cta {
    grid-column: 2;
    grid-row: 1 / 3;
    align-self: center;
    display: inline-block;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--black);
    background: var(--who-slab-accent);
    border: 2.5px solid var(--black);
    border-radius: 6px;
    padding: 9px 20px;
    white-space: nowrap;
    opacity: 0.4;
    transition: opacity 0.15s, background 0.15s, color 0.15s;
}

.who-need-cta:hover {
    background: var(--black);
    color: var(--who-slab-accent);
    opacity: 1;
}

.who-need-link:hover .who-need-label {
    color: var(--black);
}

.who-need-link:hover .who-need-desc {
    opacity: 1;
}

.who-need-link:hover .who-need-cta {
    opacity: 1;
}

/* Desktop scroll focus line: mirror hover emphasis on the in-line item */
@media (min-width: 781px) {
    .who-need.is-focusline .who-need-link::before {
        color: var(--black);
    }

    .who-need.is-focusline .who-need-label {
        color: var(--black);
    }

    .who-need.is-focusline .who-need-desc {
        opacity: 1;
    }

    .who-need.is-focusline .who-need-cta {
        opacity: 1;
    }
}

/* ── Responsive ── */

/* Suppress focusline when hovering any who-need across slabs */
.who-slabs.is-hovering-needs .who-need.is-focusline:not(:hover) .who-need-link::before {
    color: rgba(17, 17, 17, 0.26);
}

.who-slabs.is-hovering-needs .who-need.is-focusline:not(:hover) .who-need-desc {
    opacity: 0.9;
}

.who-slabs.is-hovering-needs .who-need.is-focusline:not(:hover) .who-need-cta {
    opacity: 0.4;
}

    /* ── Responsive ── */
@media (max-width: 960px) {
    .who-slab {
        grid-template-columns: 160px 1fr;
        gap: 0 48px;
    }
}

@media (max-width: 780px) {

    .wsn-inner {
        padding: 0 12px;
    }

    .wsn-tab {
        padding: 14px 12px;
    }

    .who-slabs-outer {
        padding: 0 24px 72px;
    }

    .who-slab {
        grid-template-columns: 1fr;
        padding-top: 52px;
    }

    .who-slab + .who-slab {
        margin-top: 48px;
    }

    /* keep a positioning context for the ghost number without using sticky */
    .who-slab-cap {
        position: relative;
        top: auto;
        padding-bottom: 20px;
    }

    .who-slab-name {
        opacity: 1;
    }

    .who-need-link {
        padding-left: 0;
        grid-template-columns: 1fr;
        grid-template-rows: auto auto auto;
        gap: 8px;
    }

    .who-need-link::before {
        display: none;
    }

    .who-need-cta {
        display: inline-block;
        grid-column: 1;
        grid-row: 3;
        align-self: start;
        justify-self: start;
        margin-top: 4px;
        opacity: 1;
    }

    .who-need-link:hover {
        transform: none;
    }
}

@media (max-width: 560px) {
    .wsn-inner {
        flex-wrap: wrap;
    }

    .wsn-tab {
        flex: 1 1 50%;
        border-bottom: 1px solid rgba(17, 17, 17, 0.1);
    }

    .wsn-tab:nth-child(2) {
        border-right: 0;
    }

    .wsn-tab:nth-child(3),
    .wsn-tab:nth-child(4) {
        border-bottom: 0;
    }

    .wsn-tab:last-child {
        border-right: 0;
    }
}

/* ── PRODUCTS ── */
.products-section {
    border-top: 0;
    background: #ffffff;
    box-shadow: 0 -24px 64px rgba(17, 17, 17, 0.14);
    position: relative;
    overflow: hidden;
}

#products-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    display: block;
}

.sec-heading {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3.4rem);
    letter-spacing: 0.03em;
    text-align: center;
    padding: 32px 40px 0;
    border-top: 3px solid var(--black);
    position: relative;
    z-index: 1;
    color: transparent;
    -webkit-text-stroke: 0.5px var(--black);
    text-transform: uppercase;
}

.products-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 24px 40px 56px;
    position: relative;
    z-index: 1;
}

.main-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
    margin-bottom: 20px;
}

.main-cards .p-card {
    flex: 1 1 calc(25% - 15px);
    max-width: calc(25% - 15px);
    min-width: 200px;
}

.p-card {
    border: 3px solid var(--black);
    border-radius: 14px;
    overflow: hidden;
    position: relative;
    display: flex;
    flex-direction: column;
    transition: transform 0.14s, box-shadow 0.14s;
}

.p-card-badge {
    position: absolute;
    top: 2px;
    right: 2px;
    width: 58px;
    height: 58px;
    z-index: 3;
    pointer-events: none;
    border-radius: 50%;
    background: var(--red);
    color: var(--white);
    display: grid;
    place-items: center;
    text-align: center;
    padding: 8px 6px;
    filter: drop-shadow(0 4px 0 rgba(17, 17, 17, 0.18));
}

.p-card-badge-label {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 11px;
    font-weight: 700;
    line-height: 0.95;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.p-card:hover {
    transform: translateY(-5px) translateX(-2px);
    box-shadow: 6px 8px 0 0 var(--black);
}

.p-card-header {
    padding: 14px 18px 12px;
    border-bottom: 3px solid var(--black);
}

.p-card-header h3 {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.25rem;
    line-height: 1;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--black);
}

.p-card-body {
    padding: 16px 18px 18px;
    background: var(--white);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.p-price {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 2.2rem;
    line-height: 1.05;
    color: var(--black);
    margin-bottom: 12px;
}

.p-desc {
    font-size: 0.85rem;
    line-height: 1.55;
    color: #444;
    flex: 1;
    margin-bottom: 18px;
}

.p-features {
    list-style: none;
    padding: 0;
    flex: 1;
    margin-bottom: 18px;
}

.p-features li {
    font-size: 0.8rem;
    line-height: 1.45;
    color: #444;
    padding: 3px 0 3px 18px;
    position: relative;
}

.p-features li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 3px;
    font-weight: 700;
    font-size: 0.78rem;
}

s {
    text-decoration: line-through;
    text-decoration-color: var(--black);
    text-decoration-thickness: 0.05em;
    color: rgb(from var(--cpink) r g b / 0.8);
    font-weight: 400;
    font-family: 'Barlow', sans-serif;
    font-size: max(0.5em, 13px);
    letter-spacing: -0.02em;
}

.p-btn {
    display: block;
    text-align: center;
    border: 2.5px solid var(--black);
    border-radius: 6px;
    padding: 11px 14px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.85rem;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    color: var(--black);
    background: transparent;
    transition: background 0.14s, color 0.14s;
}

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

.ch-lime {
    background: var(--clime);
}

.ch-cyan {
    background: var(--ccyan);
}

.ch-pink {
    background: var(--cpink);
}

.ch-yellow {
    background: var(--cyellow);
}

.ch-orange {
    background: var(--orange);
}

.sub-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px;
}

.sub-cards .sub-card {
    flex: 1 1 calc(25% - 15px);
    max-width: calc(25% - 15px);
    min-width: 180px;
}

.sub-card {
    border: 3px solid var(--black);
    border-radius: 14px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.14s, box-shadow 0.14s;
}

.sub-card:hover {
    transform: translateY(-4px) translateX(-2px);
    box-shadow: 5px 7px 0 0 var(--black);
}

.sub-card-header {
    padding: 12px 16px 10px;
    border-bottom: 3px solid var(--black);
}

.sub-card-header h3 {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.1rem;
    line-height: 1;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--black);
}

.sub-card-body {
    padding: 14px 16px 16px;
    background: var(--white);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.sub-price {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.6rem;
    line-height: 1;
    margin-bottom: 8px;
}

.sub-desc {
    font-size: 0.78rem;
    line-height: 1.55;
    color: #555;
    flex: 1;
    margin-bottom: 16px;
}

.sub-btn {
    display: block;
    text-align: center;
    border: 2.5px solid var(--black);
    border-radius: 6px;
    padding: 10px 12px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.8rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--black);
    background: transparent;
    transition: background 0.14s, color 0.14s;
}

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

/* ── PROCESS ── */
.process-section {
    background: #f4f4f4;
    border-top: 3px solid var(--black);
    padding: 0 40px 60px;
}

/* ── ABOUT INTRO (process page) ── */
.about-intro {
    background: #f4f4f4;
    padding: 56px 40px 56px;
}

.about-intro-inner {
    max-width: 1300px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.35fr 1fr;
    gap: 48px;
    align-items: center;
    padding: 0 40px;
}

.about-intro-copy {
    color: var(--black);
}

.about-heading {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.8rem, 3.4vw, 2.6rem);
    line-height: 1.05;
    letter-spacing: 0.01em;
    margin: 0 0 20px;
    font-weight: normal;
}

.about-intro-copy p {
    font-size: 1rem;
    line-height: 1.65;
    margin: 0 0 14px;
    color: #1a1a1a;
}

.about-intro-illus {
    display: flex;
    align-items: center;
    justify-content: center;
}

.about-illus-svg {
    width: clamp(180px, 22vw, 260px);
    height: clamp(180px, 22vw, 260px);
    max-width: 100%;
    display: block;
}

@media (max-width: 760px) {
    .about-intro {
        padding: 40px 24px;
    }

    .about-intro-inner {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .about-illus-svg {
        width: 220px;
        height: 220px;
    }
}

.proc-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3.4rem);
    letter-spacing: 0.03em;
    text-align: center;
    padding: 32px 0 44px;
    text-transform: uppercase;
}

.proc-skip {
    text-align: center;
    margin: 0;
    padding: 28px 0 36px;
}

.proc-skip-home {
    text-align: center;
    padding: 32px 0 0;
}

.proc-skip-products {
    text-align: left;
    padding: 18px 0 0;
}
.proc-skip-products.proc-skip-centered {
    text-align: center;
}

.process-inner {
    max-width: 1300px;
    margin: 0 auto;
}

.proc-skip-link {
    display: inline-block;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--black);
    background: var(--clime);
    border: 2.5px solid var(--black);
    border-radius: 6px;
    padding: 9px 20px;
    transition: transform 120ms ease, box-shadow 120ms ease;
}

.proc-skip-link:hover {
    transform: translateY(-2px) translateX(-1px);
    box-shadow: 4px 5px 0 0 var(--black);
}

.proc-grid {
    display: grid;
    grid-template-columns: 1fr 64px 1fr;
    row-gap: 18px;
    position: relative;
    max-width: 1000px;
    margin: 0 auto;
}

.proc-grid::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 22px;
    bottom: 22px;
    width: 3px;
    background: var(--black);
    transform: translateX(-50%);
    z-index: 0;
}

.proc-c1 {
    grid-column: 1;
}

.proc-c2 {
    grid-column: 2;
}

.proc-c3 {
    grid-column: 3;
}

.proc-r1 {
    grid-row: 1;
}

.proc-r2 {
    grid-row: 2;
}

.proc-r3 {
    grid-row: 3;
}

.proc-r4 {
    grid-row: 4;
}

.proc-r5 {
    grid-row: 5;
}

.proc-r6 {
    grid-row: 6;
}

.proc-dot-cell {
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    position: relative;
}

.dot-circle {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 3px solid var(--black);
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}

.step-card {
    border: 3px solid var(--black);
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    align-items: stretch;
    transition: transform 0.14s, box-shadow 0.14s;
}

.step-card:hover {
    transform: translateY(-3px);
    box-shadow: 4px 5px 0 0 var(--black);
}

.step-letter {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 2.2rem;
    line-height: 1;
    padding: 16px 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 3px solid var(--black);
    min-width: 3.3ch;
    flex-shrink: 0;
    color: var(--black);
}

.step-body {
    padding: 14px 16px;
    background: var(--white);
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.step-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.step-name {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 1rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--black);
}

.step-icon {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
    flex-shrink: 0;
}

.step-desc {
    font-size: 0.78rem;
    line-height: 1.55;
    color: rgba(0, 0, 0, 0.7);
}

.sc-green {
    background: var(--green);
}

.sc-teal {
    background: var(--ccyan);
}

.sc-red {
    background: var(--red);
}

.sc-lime {
    background: var(--clime);
}

.sc-mag {
    background: var(--cpink);
}

.sc-orange {
    background: var(--orange);
}

.sc-yellow {
    background: var(--cyellow);
}

.dc-green {
    background: var(--green);
    border-color: var(--green);
}

.dc-teal {
    background: var(--ccyan);
    border-color: var(--ccyan);
}

.dc-red {
    background: var(--red);
    border-color: var(--red);
}

.dc-lime {
    background: var(--clime);
    border-color: var(--clime);
}

.dc-mag {
    background: var(--cpink);
    border-color: var(--cpink);
}

.dc-orange {
    background: var(--orange);
    border-color: var(--orange);
}

.dc-yellow {
    background: var(--cyellow);
    border-color: var(--cyellow);
}

/* ── PRE-FOOTER QUOTE ── */
.pre-footer-quote {
    background: var(--ccyan);
    border-top: 3px solid var(--black);
    position: relative;
    z-index: 4;
    overflow: hidden;
}

.pre-footer-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 64px 40px 72px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: start;
}

.testimonial-card {
    background: var(--white);
    border: 3px solid var(--black);
    border-radius: 16px;
    padding: 32px 36px 28px;
    width: 100%;
    box-shadow: 8px 8px 0 var(--black);
}

.testimonial-stars {
    color: var(--orange);
    font-size: 1.8rem;
    letter-spacing: 0.08em;
    margin-bottom: 20px;
    line-height: 1;
    display: inline-block;
    transform: skewX(-10deg);
}

.testimonial-quote {
    font-family: 'Barlow', sans-serif;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.2;
    color: var(--black);
    margin-bottom: 26px;
}

.testimonial-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-top: 20px;
    border-top: 1.5px solid #e8e8e8;
}

.testimonial-avatar {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: 2.5px solid var(--black);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.15rem;
    color: var(--black);
    flex-shrink: 0;
}

.testimonial-avatar.ta-clime {
    background: var(--clime);
}

.testimonial-avatar.ta-orange {
    background: var(--orange);
}

.testimonial-avatar.ta-pink {
    background: var(--cpink);
}

.testimonial-name {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 1rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--black);
    line-height: 1.15;
}

.testimonial-handle {
    font-size: 0.78rem;
    color: #444;
    margin-top: 2px;
}

.testimonial-badge {
    margin-left: auto;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.65rem;
    font-weight: 400;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #444;
    flex-shrink: 0;
}

/* ── FOOTER ── */
.site-footer {
    position: relative;
    z-index: 4;
    background: var(--black);
    color: var(--white);
    border-top: 3px solid var(--black);
}

.footer-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 44px 40px;
    display: grid;
    grid-template-columns: 220px 1fr 1.4fr;
    gap: 48px;
    align-items: start;
}

.footer-brand {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.25rem;
    line-height: 1.2;
}

.footer-brand img {
    width:180px;
    height:auto;
    display:block;
    filter:invert(1);
}

.footer-brand .sub-label {
    display: block;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.85rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: #bebebe;
    margin-top: 4px;
}

.footer-links-col h4 {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.7rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #bebebe;
    margin-bottom: 16px;
}

.footer-links-col ul {
    list-style: none;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
}

.footer-links-col a {
    font-size: 0.9rem;
    font-weight: 500;
    color: #bebebe;
    transition: color 0.14s;
}

.footer-links-col a:hover {
    color: var(--lime);
}

.footer-quote {
    font-size: 1rem;
    font-style: italic;
    line-height: 1.7;
    color: #ccc;
    border-left: 4px solid var(--lime);
    padding-left: 20px;
}

.footer-quote cite {
    display: block;
    margin-top: 14px;
    font-style: normal;
    font-size: 0.78rem;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: #bebebe;
}

.footer-bottom {
    max-width: 1300px;
    margin: 0 auto;
    padding: 16px 40px;
    border-top: 1px solid #222;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}

.footer-copy {
    margin: 0;
    font-size: 0.75rem;
    color: #fff;
}

.footer-policies {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    font-size: 0.78rem;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.footer-policies li {
    display: inline;
}

.footer-policies a {
    color: #fff;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color .2s ease;
}

.footer-policies a:hover {
    border-bottom-color: #fff;
}

/* ── SECTION ORDERING: pre-footer + footer sink to bottom of wrapper ── */
.page-sections-wrapper {
    display: flex;
    flex-direction: column;
}

.page-sections-wrapper .pre-footer-quote {
    order: 98;
}

.page-sections-wrapper .site-footer {
    order: 99;
}

/* ── RESPONSIVE OVERRIDES (products/process/footer) ── */
@media (max-width: 1080px) {
    .main-cards .p-card {
        flex-basis: calc(50% - 10px);
        max-width: calc(50% - 10px);
    }

    .sub-cards .sub-card {
        flex-basis: calc(50% - 10px);
        max-width: calc(50% - 10px);
    }

    .pre-footer-inner {
        grid-template-columns: repeat(2, 1fr);
    }

    .testimonial-card:nth-child(3) {
        display: none;
    }
}

@media (max-width: 760px) {
    .content-shell {
        margin-top: 0;
        padding-top: 0;
    }

    .products-inner {
        padding-left: 24px;
        padding-right: 24px;
    }

    .process-section {
        padding-left: 24px;
        padding-right: 24px;
    }

    .pre-footer-inner {
        padding: 44px 24px 52px;
        grid-template-columns: 1fr;
    }

    .testimonial-card {
        padding: 24px 22px 20px;
    }

    .testimonial-card:nth-child(2),
    .testimonial-card:nth-child(3) {
        display: none;
    }

    .testimonial-quote {
        font-size: 1.5rem;
    }

    .footer-inner {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 32px 24px;
    }

    .footer-bottom {
        padding-left: 24px;
        padding-right: 24px;
        flex-direction: column-reverse;
        align-items: flex-start;
        gap: 14px;
    }

    .footer-policies {
        gap: 14px;
    }

    .sec-heading {
        padding-left: 24px;
        padding-right: 24px;
    }

    .main-cards .p-card {
        flex-basis: 100%;
        max-width: 100%;
    }

    .p-card-badge {
        width: 54px;
        height: 54px;
        top: 2px;
        right: 2px;
        padding: 7px 5px;
    }

    .p-card-badge-label {
        font-size: 10px;
    }

    .sub-cards .sub-card {
        flex-basis: 100%;
        max-width: 100%;
    }
}

@media (max-width: 600px) {
    .proc-grid {
        display: flex !important;
        flex-direction: column;
        gap: 12px;
    }

    .proc-grid::before {
        display: none;
    }

    .proc-dot-cell,
    .proc-empty {
        display: none !important;
    }

    .step-card {
        width: 100%;
    }
}

/* ── SUBPAGE HEADER ── */
.subpage-header {
    position: relative;
    z-index: 4;
    background: var(--bg);
    border-bottom: 3px solid var(--black);
    overflow: clip;
}

.subpage-header #webgl-pixels {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    width: 100%;
    height: 100%;
    display: block;
}

.subpage-header-inner {
    position: relative;
    z-index: 1;
    max-width: 1300px;
    margin: 0 auto;
    padding: 36px 40px 32px;
}

.subpage-meta {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.68rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.55);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.subpage-meta a {
    color: inherit;
    transition: opacity 0.12s;
}

.subpage-meta a:hover {
    opacity: 0.5;
}

.subpage-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2.4rem, 6vw, 5rem);
    line-height: 0.92;
    letter-spacing: -0.01em;
    text-transform: uppercase;
    color: var(--black);
    margin: 14px 0;
}

.subpage-tagline {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.6;
    color: rgba(17, 17, 17, 0.7);
    max-width: 56ch;
    margin-bottom: 22px;
}

body.page-blog .content-shell,
body.page-blog-post .content-shell {
    background: var(--white);
    overflow: hidden;
}

.blog-listing-intro,
.blog-feed-shell,
.blog-article-wrap {
    position: relative;
    z-index: 2;
}

.blog-listing-intro-inner,
.blog-feed,
.blog-article-layout {
    max-width: 1300px;
    margin: 0 auto;
    padding-left: 40px;
    padding-right: 40px;
}

.blog-listing-intro-inner {
    padding-top: 52px;
    padding-bottom: 10px;
}

.blog-listing-eyebrow,
.blog-section-kicker,
.blog-card-date {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.74rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.blog-listing-eyebrow,
.blog-section-kicker {
    color: rgba(17, 17, 17, 0.62);
    margin-bottom: 10px;
}

.blog-listing-copy {
    max-width: 66ch;
    color: rgba(17, 17, 17, 0.72);
    line-height: 1.7;
    margin-top: 12px;
}

.blog-taxonomy-intro {
    margin-top: 22px;
}

.blog-feed {
    padding-top: 18px;
    padding-bottom: 28px;
}

.blog-feed-items {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
}

.blog-card {
    border: 3px solid var(--black);
    border-radius: 16px;
    overflow: hidden;
    background: linear-gradient(180deg, #ffffff 0%, #faf7ef 100%);
    box-shadow: 0 0 0 0 var(--black);
    transition: transform 0.14s, box-shadow 0.14s;
    cursor: pointer;
}

.blog-card:hover {
    transform: translateY(-4px) translateX(-1px);
    box-shadow: 6px 8px 0 0 var(--black);
}

.blog-card:hover .blog-card-title a {
    opacity: 0.72;
}

.blog-card-media {
    position: relative;
    display: block;
    border-bottom: 3px solid var(--black);
    background: linear-gradient(180deg, #fcf8ea 0%, #f5efe1 100%);
}

.blog-card-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    border: 2px solid var(--black);
    border-radius: 999px;
    background: var(--cyellow);
    color: var(--black);
    padding: 6px 10px;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.blog-card-body {
    padding: 18px 18px 20px;
}

.blog-card-date {
    color: rgba(17, 17, 17, 0.58);
    margin-bottom: 10px;
}

.blog-card-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.35rem, 2vw, 1.8rem);
    line-height: 1.02;
    text-transform: uppercase;
    margin-bottom: 12px;
}

.blog-card-title a:hover {
    opacity: 0.72;
}

.blog-card .blog-media-frame {
    border: 0;
    border-radius: 0;
}

.blog-card-description {
    color: #444;
    line-height: 1.7;
}

.blog-card-tags,
.blog-tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

.blog-tag-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border: 2px solid var(--black);
    border-radius: 999px;
    padding: 7px 12px;
    background: var(--clime);
    color: var(--black);
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.74rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.blog-tag-pill:hover {
    background: var(--cpink);
}

.blog-feed-footer {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 40px 68px;
}

.blog-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.blog-pagination[hidden] {
    display: none;
}

.blog-page-link {
    min-width: 44px;
    text-align: center;
    border: 2px solid var(--black);
    border-radius: 999px;
    padding: 8px 12px;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    background: var(--white);
}

.blog-page-link.is-current {
    background: var(--black);
    color: var(--white);
}

.blog-page-link--nav {
    background: var(--ccyan);
}

.blog-next-link {
    display: inline-flex;
    margin-top: 16px;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.82rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.65);
}

.blog-autoload-sentinel {
    height: 1px;
    width: 100%;
}

.blog-media-frame {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 14px;
    border: 3px solid var(--black);
    background: #f4efe2;
}

.blog-media-frame.is-horizontal {
    aspect-ratio: 16 / 9;
}

.blog-media-frame.is-vertical {
    aspect-ratio: 9 / 16;
}

.blog-media-frame img,
.blog-media-frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.blog-media-frame img {
    object-fit: cover;
}

.blog-article-layout {
    padding-top: 52px;
    padding-bottom: 72px;
}

.blog-article-layout--side {
    display: grid;
    grid-template-columns: minmax(250px, 320px) minmax(0, 1fr);
    gap: 38px;
    align-items: start;
}

.blog-article-column {
    min-width: 0;
}

.blog-inline-media {
    margin-bottom: 28px;
}

.blog-side-media {
    position: sticky;
    top: 88px;
}

.blog-post-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 28px;
    margin-bottom: 24px;
    color: rgba(17, 17, 17, 0.68);
}

.blog-post-meta-row strong {
    color: var(--black);
}

.blog-prose {
    max-width: 72ch;
}

.blog-prose > * + * {
    margin-top: 18px;
}

.blog-prose h2,
.blog-prose h3,
.blog-prose h4 {
    font-family: 'Black Han Sans', sans-serif;
    line-height: 1.05;
    text-transform: uppercase;
}

.blog-prose h2 {
    font-size: clamp(1.7rem, 2.6vw, 2.3rem);
}

.blog-prose h3 {
    font-size: clamp(1.2rem, 2vw, 1.55rem);
}

.blog-prose p,
.blog-prose li,
.blog-prose blockquote {
    line-height: 1.8;
    color: #222;
}

.blog-prose ul,
.blog-prose ol {
    padding-left: 1.4rem;
}

.blog-prose a {
    text-decoration: underline;
    text-decoration-thickness: 0.08em;
}

.blog-prose pre {
    overflow-x: auto;
    padding: 16px 18px;
    border: 3px solid var(--black);
    border-radius: 14px;
    background: #f7f7f7;
}

.blog-prose blockquote {
    border-left: 4px solid var(--black);
    padding-left: 18px;
    font-style: italic;
}

.blog-post-tags {
    margin-top: 36px;
    padding-top: 24px;
    border-top: 2px dashed rgba(17, 17, 17, 0.24);
}

@media (max-width: 980px) {
    .blog-feed-items {
        grid-template-columns: minmax(0, 1fr);
    }

    .blog-article-layout--side {
        grid-template-columns: minmax(0, 1fr);
    }

    .blog-side-media {
        position: static;
        max-width: 420px;
    }
}

@media (max-width: 760px) {
    .blog-listing-intro-inner,
    .blog-feed,
    .blog-feed-footer,
    .blog-article-layout {
        padding-left: 20px;
        padding-right: 20px;
    }

    .blog-listing-intro-inner,
    .blog-article-layout {
        padding-top: 32px;
    }

    .blog-article-layout {
        padding-bottom: 48px;
    }

    .blog-post-meta-row {
        flex-direction: column;
        gap: 6px;
    }
}

/* ── AVAILABILITY ── */
.availability-section {
    position: relative;
    z-index: 4;
    background: var(--white);
    border-top: 3px solid var(--black);
}

.availability-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 52px 40px 68px;
    display: grid;
    grid-template-columns: 300px 1fr;
    gap: 56px;
    align-items: start;
}

.avail-status-block {
    border: 3px solid var(--black);
    border-radius: 14px;
    overflow: hidden;
}

.avail-status-hdr {
    background: var(--black);
    color: var(--lime);
    font-family: 'Black Han Sans', sans-serif;
    font-size: 0.95rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 14px 20px;
}

.avail-status-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.avail-status-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 20px;
    border-bottom: 2px solid var(--black);
}

.avail-status-item:last-child {
    border-bottom: none;
}

.status-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 2px solid var(--black);
}

.sd-green {
    background: var(--green);
}

.sd-orange {
    background: var(--orange);
}

.sd-red {
    background: var(--red);
}

.sd-loading {
    background: #c9c9c9;
}

.slot-notice {
    margin-top: 12px;
}

.avail-type-label {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.78rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--black);
    flex: 1;
}

.avail-type-value {
    font-size: 0.8rem;
    font-weight: 500;
    color: #666;
}

[data-availability-status-block] .avail-type-value {
    min-width: 84px;
    text-align: right;
}

.avail-next-slot {
    margin-top: 14px;
    padding: 12px 16px;
    background: var(--clime);
    border: 2.5px solid var(--black);
    border-radius: 8px;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--black);
    display: flex;
    align-items: center;
    gap: 10px;
}

.avail-next-slot strong {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1rem;
}

.avail-prose {
    display: flex;
    flex-direction: column;
    gap: 36px;
}

.avail-prose-heading {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.4rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--black);
    margin-bottom: 12px;
    border-bottom: 2.5px solid var(--black);
    padding-bottom: 8px;
}

.avail-prose-body {
    font-size: 0.92rem;
    line-height: 1.75;
    color: #333;
    margin-bottom: 1em;
}

.avail-prose-ul {
    list-style: none;
    padding: 0;
    margin: 10px 0 0;
}

.avail-prose-ul li {
    font-size: 0.88rem;
    line-height: 1.55;
    color: #333;
    padding: 9px 0 9px 22px;
    position: relative;
    border-bottom: 1px solid #eee;
}

.avail-prose-ul li:last-child {
    border-bottom: none;
}

.avail-prose-ul li::before {
    content: '—';
    position: absolute;
    left: 0;
    font-weight: 700;
    color: #bbb;
}

.note-callout {
    background: var(--cyellow);
    border: 2.5px solid var(--black);
    border-radius: 8px;
    padding: 14px 18px;
    font-size: 0.85rem;
    line-height: 1.6;
    color: var(--black);
    font-weight: 500;
}

.note-callout-top {
    margin-top: 14px;
}

/* ── PROSE / TEXT CONTENT SECTIONS ── */
.prose-section {
    position: relative;
    z-index: 4;
    background: #fafafa;
    border-top: 3px solid var(--black);
}

.prose-inner {
    max-width: 820px;
    margin: 0 auto;
    padding: 52px 40px 68px;
}

.prose-section-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.6rem, 3.5vw, 2.6rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--black);
    margin-bottom: 44px;
    padding-bottom: 14px;
    border-bottom: 3px solid var(--black);
}

.prose-block {
    margin-bottom: 40px;
}

.prose-block:last-child {
    margin-bottom: 0;
}

.prose-block-heading {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: #999;
    margin-bottom: 10px;
}

.prose-block p {
    font-size: 0.95rem;
    line-height: 1.8;
    color: #333;
    margin-bottom: 10px;
}

.prose-ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.prose-ul li {
    font-size: 0.92rem;
    line-height: 1.55;
    color: #333;
    padding: 10px 0 10px 26px;
    position: relative;
    border-bottom: 1px solid #ebebeb;
}

.prose-ul li:last-child {
    border-bottom: none;
}

.prose-ul li::before {
    content: '·';
    position: absolute;
    left: 8px;
    top: 10px;
    font-size: 1.4rem;
    line-height: 0.9;
    color: var(--green);
}

.prose-ol {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: prose-counter;
}

.prose-ol li {
    font-size: 0.92rem;
    line-height: 1.55;
    color: #333;
    padding: 12px 0 12px 48px;
    position: relative;
    border-bottom: 1px solid #ebebeb;
    counter-increment: prose-counter;
}

.prose-ol li:last-child {
    border-bottom: none;
}

.prose-ol li::before {
    content: counter(prose-counter);
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    font-family: 'Black Han Sans', sans-serif;
    font-size: 0.9rem;
    line-height: 32px;
    color: var(--black);
    width: 32px;
    height: 32px;
    background: var(--clime);
    border: 2.5px solid var(--black);
    border-radius: 50%;
    text-align: center;
}

.prose-note {
    background: var(--cyellow);
    border: 2.5px solid var(--black);
    border-radius: 8px;
    padding: 14px 18px;
    font-size: 0.85rem;
    line-height: 1.65;
    color: var(--black);
    font-weight: 500;
}

/* ── LANDING PAGE CTA ── */
.lp-cta-section {
    position: relative;
    z-index: 4;
    background: var(--white);
    border-top: 3px solid var(--black);
}

.lp-cta-inner {
    max-width: 820px;
    margin: 0 auto;
    padding: 56px 40px 68px;
    text-align: center;
}

.lp-cta-kicker {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.76rem;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.58);
    margin-bottom: 14px;
}

.lp-cta-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.8rem, 4vw, 3rem);
    line-height: 1.04;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    color: var(--black);
    margin: 0 0 16px;
}

.lp-cta-copy {
    max-width: 58ch;
    margin: 0 auto 24px;
    font-size: 1rem;
    line-height: 1.7;
    color: #333;
}

.lp-cta-button {
    display: inline-block;
    min-width: min(100%, 320px);
    border: 2.5px solid var(--black);
    border-radius: 10px;
    padding: 16px 26px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.98rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--black);
    transition: transform 120ms ease, box-shadow 120ms ease, background 0.14s, color 0.14s;
}

.lp-cta-button:hover {
    transform: translateY(-2px) translateX(-1px);
    box-shadow: 4px 5px 0 0 var(--black);
}

.lp-hero-actions {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
}

.audience-lp-meta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 18px;
    padding: 8px 14px;
    border: 2px solid var(--black);
    border-radius: 999px;
    background: var(--white);
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--black);
}

.audience-lp-meta strong {
    font-weight: 700;
}

.audience-lp-meta span {
    opacity: 0.55;
}

.audience-lp-summary {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
    gap: 24px;
    align-items: start;
}

.audience-lp-summary-card {
    background: var(--white);
    border: 3px solid var(--black);
    border-radius: 14px;
    overflow: hidden;
}

.audience-lp-summary-card-header {
    padding: 14px 18px;
    border-bottom: 3px solid var(--black);
}

.audience-lp-summary-card-header p {
    margin: 0;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--black);
}

.audience-lp-summary-card-body {
    padding: 20px 22px 24px;
}

.audience-lp-summary-card-body p {
    margin: 0 0 14px;
    font-size: 0.94rem;
    line-height: 1.7;
    color: #333;
}

.audience-lp-summary-card-body p:last-child {
    margin-bottom: 0;
}

.audience-lp-keyphrase {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid #e6e6e6;
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #666;
}

.audience-lp-keyphrase strong {
    color: var(--black);
}

.audience-lp-points {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 3px solid var(--black);
    border-radius: 14px;
    overflow: hidden;
    background: var(--white);
}

.audience-lp-points li {
    padding: 16px 18px 16px 52px;
    position: relative;
    border-bottom: 2px solid var(--black);
    font-size: 0.9rem;
    line-height: 1.6;
    color: #333;
}

.audience-lp-points li:last-child {
    border-bottom: none;
}

.audience-lp-points li::before {
    content: attr(data-step);
    position: absolute;
    left: 16px;
    top: 16px;
    font-family: 'Black Han Sans', sans-serif;
    font-size: 0.96rem;
    color: var(--black);
}

@media (max-width: 900px) {
    .audience-lp-summary {
        grid-template-columns: 1fr;
    }
}

.lp-hero-button {
    display: inline-block;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.82rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--black);
    border: 2.5px solid var(--black);
    border-radius: 8px;
    padding: 11px 20px;
    transition: transform 120ms ease, box-shadow 120ms ease, background 0.14s, color 0.14s;
}

.lp-hero-button:hover {
    transform: translateY(-2px) translateX(-1px);
    box-shadow: 4px 5px 0 0 var(--black);
}

.lp-float-cta {
    position: fixed;
    z-index: 9000;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 2.5px solid var(--black);
    color: var(--black);
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.8rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    transition: transform 120ms ease, box-shadow 120ms ease, background 0.14s, color 0.14s;
}

.lp-float-cta:hover {
    transform: translateY(-2px) translateX(-1px);
}

.lp-float-cta--corner {
    right: 26px;
    bottom: 88px;
    border-radius: 12px;
    padding: 14px 20px;
    box-shadow: 6px 7px 0 0 var(--black);
}

.lp-float-cta--corner-left {
    left: 26px;
    right: auto;
}

.lp-float-cta--corner:hover {
    box-shadow: 8px 9px 0 0 var(--black);
}

.lp-float-cta--side {
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
    writing-mode: vertical-rl;
    text-orientation: mixed;
    border-radius: 12px 0 0 12px;
    padding: 18px 10px;
    box-shadow: -5px 6px 0 0 var(--black);
}

.lp-float-cta--side:hover {
    transform: translateY(calc(-50% - 2px)) translateX(-1px);
    box-shadow: -7px 8px 0 0 var(--black);
}

.lp-float-cta--dock {
    left: 50%;
    bottom: 88px;
    transform: translateX(-50%);
    border-radius: 12px;
    padding: 14px 24px;
    min-width: 300px;
    box-shadow: 0 7px 0 0 var(--black);
}

.lp-float-cta--dock:hover {
    transform: translateX(-50%) translateY(-2px);
    box-shadow: 0 9px 0 0 var(--black);
}

/* ── PER-PAGE PRE-FOOTER QUOTE COLOUR OVERRIDES ── */
/* discovery → lime, consultancy → pink, packages → cyan, subscriptions → yellow */
body.page-process       .pre-footer-quote { background: var(--cyellow); }
body.page-availability  .pre-footer-quote { background: var(--cpink); }
body.page-products      .pre-footer-quote { background: var(--clime); }
body.page-use-cases     .pre-footer-quote { background: var(--clime); }
body.page-privacy       .pre-footer-quote { background: var(--ccyan); }
body.page-terms         .pre-footer-quote { background: var(--cyellow); }
body.page-refund        .pre-footer-quote { background: var(--cpink); }
body.page-sitemap       .pre-footer-quote { background: var(--ccyan); }
body.page-discovery     .pre-footer-quote { background: var(--clime); }
body.page-consultancy   .pre-footer-quote { background: var(--cpink); }
body.page-packages      .pre-footer-quote { background: var(--ccyan); }
body.page-subscriptions .pre-footer-quote { background: var(--cyellow); }

/* ── POLICY / LEGAL PAGES ── */
.policy-section {
    padding: 56px 0 80px;
}

.policy-inner {
    max-width: 760px;
    margin: 0 auto;
    padding: 0 40px;
    font-size: 1rem;
    line-height: 1.7;
    color: #1a1a1a;
}

.policy-inner h2 {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    font-size: 1.6rem;
    margin: 36px 0 12px;
}

.policy-inner h2:first-child {
    margin-top: 0;
}

.policy-inner p,
.policy-inner ul {
    margin: 0 0 16px;
}

.policy-inner ul {
    padding-left: 22px;
}

.policy-inner li {
    margin-bottom: 6px;
}

.policy-inner a {
    color: var(--black);
    text-decoration: underline;
}

.policy-updated {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.78rem;
    color: #666;
    margin-bottom: 28px;
}

.cookie-settings-open-btn {
    display: inline-block;
    border: 2.5px solid var(--black);
    border-radius: 4px;
    padding: 8px 18px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--black);
    background: var(--clime);
    cursor: pointer;
    transition: background 0.14s, color 0.14s;
}

.cookie-settings-open-btn:hover {
    background: var(--black);
    color: var(--clime);
}

/* ── SITEMAP PAGE ── */
.sitemap-section {
    position: relative;
    z-index: 4;
    background: linear-gradient(180deg, #fafafa 0%, #f2f2f2 100%);
    border-top: 3px solid var(--black);
    padding: 52px 0 76px;
}

.sitemap-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 40px;
}

.sitemap-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.sitemap-stat-card {
    background: var(--white);
    border: 3px solid var(--black);
    border-radius: 18px;
    box-shadow: 8px 8px 0 var(--black);
    padding: 24px 24px 20px;
}

.sitemap-stat-label {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.58);
    margin-bottom: 12px;
}

.sitemap-stat-value {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2rem, 5vw, 3.4rem);
    line-height: 0.95;
    color: var(--black);
    margin-bottom: 10px;
}

.sitemap-stat-note {
    font-size: 0.92rem;
    line-height: 1.6;
    color: #4a4a4a;
}

.sitemap-panel {
    background: rgba(255, 255, 255, 0.94);
    border: 3px solid var(--black);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 10px 10px 0 var(--black);
}

.sitemap-panel-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 400px);
    gap: 24px;
    align-items: end;
    padding: 28px 30px 24px;
    background: linear-gradient(135deg, var(--lime) 0%, var(--white) 72%);
    border-bottom: 3px solid var(--black);
}

.sitemap-panel-kicker {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.6);
    margin-bottom: 10px;
}

.sitemap-panel-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.8rem, 3.5vw, 3rem);
    line-height: 0.95;
    text-transform: uppercase;
    color: var(--black);
}

.sitemap-panel-copy {
    font-size: 0.95rem;
    line-height: 1.7;
    color: rgba(17, 17, 17, 0.72);
}

.sitemap-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.sitemap-row {
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 18px 30px;
    border-bottom: 1.5px solid #e9e9e9;
}

.sitemap-row:last-child {
    border-bottom: none;
}

.sitemap-row-index {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 2.5px solid var(--black);
    background: var(--white);
    display: grid;
    place-items: center;
    font-family: 'Black Han Sans', sans-serif;
    font-size: 0.88rem;
    color: var(--black);
}

.sitemap-url {
    display: inline-block;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 1.15rem;
    letter-spacing: 0.01em;
    color: var(--black);
    overflow-wrap: anywhere;
}

.sitemap-url:hover {
    text-decoration: underline;
}

.sitemap-path {
    margin-top: 4px;
    font-size: 0.85rem;
    line-height: 1.5;
    color: rgba(17, 17, 17, 0.52);
    overflow-wrap: anywhere;
}

.sitemap-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 132px;
    border: 2px solid var(--black);
    border-radius: 999px;
    padding: 9px 14px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.7rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--black);
}

.sitemap-badge.is-lime {
    background: var(--clime);
}

.sitemap-badge.is-pink {
    background: var(--cpink);
}

.sitemap-badge.is-cyan {
    background: var(--ccyan);
}

.sitemap-badge.is-yellow {
    background: var(--cyellow);
}

.sitemap-badge.is-purple {
    background: var(--purple);
    color: var(--white);
}

.sitemap-badge.is-dark {
    background: var(--black);
    color: var(--white);
}

@media (max-width: 760px) {
    .policy-inner {
        padding: 0 24px;
    }

    .policy-section {
        padding: 40px 0 60px;
    }

    .sitemap-section {
        padding: 36px 0 56px;
    }

    .sitemap-inner {
        padding: 0 24px;
    }

    .sitemap-summary-grid {
        grid-template-columns: 1fr;
    }

    .sitemap-panel-head {
        grid-template-columns: 1fr;
        padding: 24px 22px 20px;
    }

    .sitemap-row {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 18px 22px;
    }

    .sitemap-row-index {
        width: 40px;
        height: 40px;
    }

    .sitemap-badge {
        min-width: 0;
        justify-self: start;
    }
}

.cat-intro {
    max-width: 55ch;
    margin: 0 auto 28px;
    text-align: center;
    font-size: 1rem;
    line-height: 1.6;
    color: rgba(17, 17, 17, 0.72);
}

/* ── HOME LANDING SECTION ── */
.products-section .products-inner {
    padding-top: 0;
}

.home-landing-band {
    position: relative;
    overflow: clip;
    padding: clamp(3.5rem, 5vw, 5rem) clamp(1rem, 3vw, 2rem);
}

.home-landing-band--people {
    background:
        radial-gradient(circle at 12% 18%, rgb(from var(--clime) r g b / 0.34) 0 7rem, transparent 7rem),
        radial-gradient(circle at 86% 16%, rgb(from var(--ccyan) r g b / 0.18) 0 6.5rem, transparent 6.5rem),
        radial-gradient(circle at 78% 82%, rgb(from var(--cpink) r g b / 0.16) 0 8rem, transparent 8rem),
        radial-gradient(circle at 28% 72%, rgb(from var(--cyellow) r g b / 0.22) 0 5rem, transparent 5rem),
        radial-gradient(circle at 58% 26%, rgb(from var(--black) r g b / 0.05) 0 9rem, transparent 9rem),
        radial-gradient(circle at 92% 64%, rgb(from var(--black) r g b / 0.04) 0 4rem, transparent 4rem),
        var(--bg);
}

.home-landing-band::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 18% 42%, rgb(from var(--cyellow) r g b / 0.32) 0 0.7rem, transparent 0.7rem),
        radial-gradient(circle at 82% 76%, rgb(from var(--cpink) r g b / 0.2) 0 0.6rem, transparent 0.6rem),
        radial-gradient(circle at 34% 18%, rgb(from var(--ccyan) r g b / 0.18) 0 1.2rem, transparent 1.2rem),
        radial-gradient(circle at 68% 58%, rgb(from var(--clime) r g b / 0.18) 0 0.9rem, transparent 0.9rem),
        radial-gradient(circle at 52% 88%, rgb(from var(--black) r g b / 0.08) 0 1.4rem, transparent 1.4rem),
        radial-gradient(circle at 8% 86%, rgb(from var(--black) r g b / 0.05) 0 2rem, transparent 2rem),
        radial-gradient(circle at 94% 12%, rgb(from var(--black) r g b / 0.05) 0 2.4rem, transparent 2.4rem);
    opacity: 0.65;
}

.home-landing-inner {
    position: relative;
    z-index: 1;
    max-width: 1320px;
    margin: 0 auto;
}

.home-landing-grid {
    display: grid;
    gap: clamp(1.5rem, 3vw, 3rem);
    align-items: start;
}

.home-landing-title,
.home-concept-headline {
    max-width: 10ch;
    margin-bottom: 1.35rem;
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2.8rem, 6vw, 5.8rem);
    font-weight: 400;
    line-height: 0.92;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.home-landing-copy {
    max-width: 40rem;
    font-size: 1rem;
    line-height: 1.6;
}

.home-landing-copy p + p {
    margin-top: 0.8rem;
}

.home-concept-label,
.home-landing-tag {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.2rem;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.home-concept-label::before,
.home-landing-tag::before {
    content: attr(data-num);
    display: inline-grid;
    place-items: center;
    width: 2.35rem;
    height: 2.35rem;
    font-size: 1rem;
    background: var(--white);
}

.home-cta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 1.6rem;
}

.home-cta-row .p-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: min(100%, 13rem);
    min-height: 3.2rem;
    padding: 0.8rem 1.2rem;
}

.home-cta-row .p-btn--pink {
    background: var(--cpink);
    color: var(--white);
}

.home-cta-row .p-btn--pink:hover {
    background: var(--black);
    color: var(--white);
}

.home-landing-grid--people {
    grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.95fr);
}

.home-people-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(18rem, 0.95fr);
}

.home-audience-list {
    display: grid;
    gap: 0.85rem;
    align-content: start;
}

.home-audience-item {
    padding: 0.35rem 0;
}

.home-audience-item p {
    margin-bottom: 0;
}

.home-audience-item strong,
.home-decision-points strong {
    display: block;
    margin-bottom: 0.25rem;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: clamp(1.35rem, 2vw, 1.8rem);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.home-people-note {
    display: inline-block;
    margin-top: 1rem;
    max-width: 55ch;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

@media (min-width: 1200px) {
    .home-landing-band--people {
        background:
            radial-gradient(circle at 12% 18%, rgb(from var(--clime) r g b / 0.34) 0 7rem, transparent 7rem),
            radial-gradient(circle at 86% 16%, rgb(from var(--ccyan) r g b / 0.18) 0 6.5rem, transparent 6.5rem),
            radial-gradient(circle at 78% 82%, rgb(from var(--cpink) r g b / 0.16) 0 8rem, transparent 8rem),
            radial-gradient(circle at 28% 72%, rgb(from var(--cyellow) r g b / 0.22) 0 5rem, transparent 5rem),
            radial-gradient(circle at 58% 26%, rgb(from var(--black) r g b / 0.05) 0 9rem, transparent 9rem),
            radial-gradient(circle at 92% 64%, rgb(from var(--black) r g b / 0.04) 0 4rem, transparent 4rem),
            radial-gradient(circle at 6% 72%, rgb(from var(--clime) r g b / 0.2) 0 4.5rem, transparent 4.5rem),
            radial-gradient(circle at 24% 38%, rgb(from var(--ccyan) r g b / 0.16) 0 3.5rem, transparent 3.5rem),
            radial-gradient(circle at 42% 82%, rgb(from var(--cpink) r g b / 0.14) 0 5.5rem, transparent 5.5rem),
            radial-gradient(circle at 64% 12%, rgb(from var(--cyellow) r g b / 0.18) 0 4rem, transparent 4rem),
            radial-gradient(circle at 74% 44%, rgb(from var(--black) r g b / 0.04) 0 6rem, transparent 6rem),
            radial-gradient(circle at 96% 34%, rgb(from var(--black) r g b / 0.05) 0 3rem, transparent 3rem),
            var(--bg);
    }

    .home-landing-band--people::before {
        background:
            radial-gradient(circle at 18% 42%, rgb(from var(--cyellow) r g b / 0.32) 0 0.7rem, transparent 0.7rem),
            radial-gradient(circle at 82% 76%, rgb(from var(--cpink) r g b / 0.2) 0 0.6rem, transparent 0.6rem),
            radial-gradient(circle at 34% 18%, rgb(from var(--ccyan) r g b / 0.18) 0 1.2rem, transparent 1.2rem),
            radial-gradient(circle at 68% 58%, rgb(from var(--clime) r g b / 0.18) 0 0.9rem, transparent 0.9rem),
            radial-gradient(circle at 52% 88%, rgb(from var(--black) r g b / 0.08) 0 1.4rem, transparent 1.4rem),
            radial-gradient(circle at 8% 86%, rgb(from var(--black) r g b / 0.05) 0 2rem, transparent 2rem),
            radial-gradient(circle at 94% 12%, rgb(from var(--black) r g b / 0.05) 0 2.4rem, transparent 2.4rem),
            radial-gradient(circle at 14% 10%, rgb(from var(--cpink) r g b / 0.14) 0 1.1rem, transparent 1.1rem),
            radial-gradient(circle at 26% 64%, rgb(from var(--ccyan) r g b / 0.16) 0 0.85rem, transparent 0.85rem),
            radial-gradient(circle at 46% 28%, rgb(from var(--cyellow) r g b / 0.18) 0 1.5rem, transparent 1.5rem),
            radial-gradient(circle at 62% 74%, rgb(from var(--clime) r g b / 0.14) 0 1.1rem, transparent 1.1rem),
            radial-gradient(circle at 76% 24%, rgb(from var(--black) r g b / 0.06) 0 1.8rem, transparent 1.8rem),
            radial-gradient(circle at 88% 54%, rgb(from var(--black) r g b / 0.05) 0 1.2rem, transparent 1.2rem),
            radial-gradient(circle at 98% 84%, rgb(from var(--cpink) r g b / 0.12) 0 1.6rem, transparent 1.6rem);
    }
}

@media (max-width: 980px) {
    .home-landing-grid--people,
    .home-people-grid {
        grid-template-columns: 1fr;
    }

    .home-landing-title,
    .home-concept-headline {
        max-width: none;
    }
}

@media (max-width: 720px) {
    .home-landing-band {
        padding-inline: 1rem;
    }

    .home-cta-row {
        flex-direction: column;
    }

    .home-cta-row .p-btn {
        width: 100%;
    }
}

body.page-products .products-inner {
    padding-top: 0;
}

/* ── PRODUCT DETAIL ── */
.product-detail {
    position: relative;
    z-index: 4;
    background: var(--white);
    border-top: 3px solid var(--black);
}

.product-detail-inner {
    max-width: 1000px;
    margin: 0 auto;
    padding: 56px 40px 72px;
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 56px;
    align-items: start;
}

.product-summary {
    border: 3px solid var(--black);
    border-radius: 14px;
    overflow: hidden;
    background: var(--white);
    position: sticky;
    top: 86px;
}

.product-summary-header {
    padding: 16px 20px 14px;
    border-bottom: 3px solid var(--black);
}

.product-summary-header .ps-label {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.66rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: rgba(17, 17, 17, 0.65);
    margin-bottom: 4px;
}

.product-summary-header .ps-name {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.5rem;
    line-height: 1;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--black);
}

.product-summary-body {
    padding: 18px 20px 22px;
    background: var(--white);
}

.product-summary-price {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 2.2rem;
    line-height: 1.05;
    color: var(--black);
    margin-bottom: 14px;
}

.product-summary-facts {
    list-style: none;
    padding: 0;
    margin: 0 0 18px;
    border-top: 1.5px solid #ececec;
}

.product-summary-facts li {
    border-bottom: 1.5px solid #ececec;
    padding: 10px 0;
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 12px;
    font-size: 0.82rem;
    line-height: 1.45;
}

.product-summary-facts dt,
.product-summary-facts .ps-key {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.7rem;
    color: rgba(17, 17, 17, 0.55);
}

.product-summary-facts dd,
.product-summary-facts .ps-val {
    margin: 0;
    color: #222;
}

.product-summary-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border: 2.5px solid var(--black);
    border-radius: 8px;
    min-height: 56px;
    padding: 14px 18px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.92rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--white);
    background: var(--purple);
    transition: background 0.14s, color 0.14s;
}
.product-summary-cta.product-cta-red {
    background: var(--red);
    pointer-events: none;
}

.product-summary-cta.is-disabled {
    background: var(--red);
    color: var(--white);
    pointer-events: none;
}

.product-summary-cta:hover {
    background: var(--black);
    color: var(--white);
}

.product-summary-cta.is-disabled:hover {
    background: var(--red);
    color: var(--white);
}

.product-summary-purchase {
    display: grid;
    grid-template-columns: minmax(0, 142px) minmax(0, 1fr);
    gap: 10px;
    align-items: stretch;
}

.product-quantity {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: stretch;
    min-height: 56px;
    border: 2.5px solid var(--black);
    border-radius: 8px;
    background: var(--purple);
    color: var(--white);
    overflow: hidden;
}

.product-quantity.is-disabled {
    background: var(--red);
}

.product-quantity-btn,
.product-quantity-value {
    min-height: 100%;
    border: 0;
    background: transparent;
    color: inherit;
    font-family: 'Barlow Condensed', sans-serif;
    text-transform: uppercase;
}

.product-quantity-btn {
    cursor: pointer;
    font-size: 1.4rem;
    line-height: 1;
    transition: background 0.14s, color 0.14s;
}

.product-quantity-btn:hover:not(:disabled) {
    background: var(--black);
}

.product-quantity-btn:disabled {
    cursor: default;
    opacity: 0.45;
}

.product-quantity-value {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 46px;
    padding: 0 10px;
    font-size: 0.98rem;
    letter-spacing: 0.14em;
}

.product-summary-notice {
    margin-top: 12px;
    font-size: 0.92rem;
    line-height: 1.55;
    color: #333;
}

.product-summary-notice[hidden] {
    display: none;
}

@media (max-width: 560px) {
    .product-summary-purchase {
        grid-template-columns: 1fr;
    }
}

.product-body {
    font-family: 'Barlow', sans-serif;
}

.product-body h2 {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(1.6rem, 3.2vw, 2.4rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--black);
    margin: 0 0 16px;
    padding-bottom: 12px;
    border-bottom: 3px solid var(--black);
}

.product-body h2:not(:first-child) {
    margin-top: 44px;
}

.product-body p {
    font-size: 1rem;
    line-height: 1.75;
    color: #333;
    margin: 0 0 14px;
}

.product-body ul {
    list-style: none;
    padding: 0;
    margin: 0 0 14px;
}

.product-body ul li {
    position: relative;
    padding: 10px 0 10px 26px;
    font-size: 0.96rem;
    line-height: 1.6;
    color: #333;
    border-bottom: 1px solid #ececec;
}

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

.product-body ul li::before {
    content: '✓';
    position: absolute;
    left: 4px;
    top: 11px;
    font-weight: 400;
    color: var(--green);
}

.product-body .note {
    background: var(--cyellow);
    border: 2.5px solid var(--black);
    border-radius: 8px;
    padding: 14px 18px;
    font-size: 0.92rem;
    line-height: 1.65;
    color: var(--black);
    font-weight: 500;
    margin: 14px 0;
}

/* category index hero CTA pill - already styled via .proc-skip-link */

@media (max-width: 900px) {
    .product-detail-inner {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 40px 24px 56px;
    }

    .product-summary {
        position: static;
    }
}

@media (max-width: 760px) {
    .lp-cta-inner {
        padding: 40px 24px 52px;
    }

    .lp-hero-actions {
        width: 100%;
    }

    .lp-hero-button {
        text-align: center;
    }

    .lp-cta-button {
        width: 100%;
        min-width: 0;
    }

    .lp-float-cta,
    .lp-float-cta--side,
    .lp-float-cta--dock,
    .lp-float-cta--corner {
        left: 16px;
        right: 16px;
        top: auto;
        bottom: 78px;
        width: auto;
        min-width: 0;
        writing-mode: horizontal-tb;
        text-orientation: initial;
        transform: none;
        border-radius: 999px;
        padding: 14px 18px;
        box-shadow: 0 6px 0 0 var(--black);
    }

    .lp-float-cta:hover,
    .lp-float-cta--side:hover,
    .lp-float-cta--dock:hover,
    .lp-float-cta--corner:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 0 0 var(--black);
    }
}

/* ── RESPONSIVE: SUBPAGE / AVAILABILITY / PROSE ── */
@media (max-width: 900px) {
    .availability-inner {
        grid-template-columns: 1fr;
        gap: 32px;
        padding: 36px 24px 52px;
    }
}

@media (max-width: 760px) {
    .subpage-header-inner {
        padding: 28px 24px 24px;
    }

    .prose-inner {
        padding: 36px 24px 52px;
    }
}

/* ============== FAQ (process page) ============== */
.faq-section {
    background: #f4f4f4;
    border-top: 3px solid var(--black);
    padding: 56px 40px 72px;
}

.faq-inner {
    max-width: 820px;
    margin: 0 auto;
}

.faq-section-title {
    font-family: 'Black Han Sans', sans-serif;
    font-size: clamp(2.2rem, 4.4vw, 3rem);
    line-height: 0.95;
    text-transform: uppercase;
    margin: 0 0 28px;
    padding-bottom: 16px;
    border-bottom: 3px solid var(--black);
    letter-spacing: 0.5px;
}

.faq-stack {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.faq-item {
    background: var(--white);
    border: 3px solid var(--black);
    border-radius: 12px;
    overflow: hidden;
    transition: transform 120ms ease, box-shadow 120ms ease;
}

.faq-item:hover {
    transform: translateY(-2px) translateX(-1px);
    box-shadow: 4px 5px 0 0 var(--black);
}

.faq-item[open] {
    box-shadow: 4px 5px 0 0 var(--black);
    transform: translateY(-2px) translateX(-1px);
}

.faq-q {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 20px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    text-transform: uppercase;
    font-size: 1.05rem;
    letter-spacing: 0.5px;
    color: var(--black);
    user-select: none;
}

.faq-q::-webkit-details-marker {
    display: none;
}

.faq-q::after {
    content: '';
    width: 28px;
    height: 28px;
    display: inline-flex;
    box-sizing: border-box;
    border: 2.5px solid var(--black);
    border-radius: 50%;
    background-color: var(--white);
    background-image: url('/assets/img/cross.svg?cb=e0dbf57');
    background-repeat: no-repeat;
    background-position: center;
    background-size: 14px 14px;
    background-blend-mode: darken;
    flex-shrink: 0;
    transition: background-color 150ms ease, transform 200ms ease;
}

.faq-q em.highlight {
    color: var(--cpink);
    display: inline;
    font-style: normal;
}
.faq-q em.highlight.lime {
    color: var(--clime);
}
.faq-q em.highlight.green {
    color: var(--green);
}
.faq-q em.highlight.red {
    color: var(--red);
}
.faq-q em.highlight.cyan {
    color: var(--ccyan);
}
.faq-q em.highlight.orange {
    color: var(--orange);
}
.faq-q em.highlight.red {
    color: var(--red);
}

.faq-item[open] .faq-q::after {
    transform: rotate(45deg);
}

.faq-a {
    padding: 14px 20px 20px;
    border-top: 1.5px solid #e6e6e6;
    font-family: 'Barlow', sans-serif;
    font-size: 0.96rem;
    line-height: 1.7;
    color: #333;
}

.faq-a a {
    color: var(--cpink);
    text-decoration: underline;}

.faq-a p {
    margin: 0 0 12px;
}

.faq-a p:last-child {
    margin-bottom: 0;
}

.faq-ul {
    list-style: none;
    padding: 0;
    margin: 8px 0 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.faq-ul li {
    position: relative;
    padding-left: 22px;
    font-family: 'Barlow', sans-serif;
    font-size: 0.96rem;
    line-height: 1.6;
    color: #333;
}

.faq-ul li::before {
    content: '';
    position: absolute;
    left: 4px;
    top: 0.6em;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--green);
    border: 1.5px solid var(--black);
}

@media (max-width: 760px) {
    .faq-section {
        padding: 40px 22px 56px;
    }

    .faq-q {
        font-size: 0.98rem;
        padding: 14px 16px;
    }

    .faq-a {
        padding: 12px 16px 16px;
    }
}

/* change user selection colour to pink when selecting text on the site */
::selection {
    background: var(--black);
    color: var(--cpink);
}

@view-transition {
    navigation: auto;
}

/* ── COOKIE BANNER ── */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--black);
    color: var(--cpink);
    border-top: 3px solid var(--cpink);
    z-index: 9998;
    min-height: 62px;
    overflow: hidden;
    transition: min-height 280ms ease;
}

.cookie-banner.is-expanded {
    min-height: auto;
}

.cookie-banner-inner {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.cookie-banner-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 10px 40px;
    min-height: 62px;
}

.cookie-banner-copy {
    flex: 1;
    min-width: 0;
}

.cookie-banner-message {
    font-family: 'Barlow Condensed', sans-serif;
    font-size: clamp(14px, 1vw, 17px);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    line-height: 1.3;
    margin: 0 0 2px;
}

.cookie-banner-description {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: clamp(13px, 0.9vw, 14px);
    letter-spacing: 0.08em;
    line-height: 1.32;
    color: var(--white);
    margin: 0;
}

.cookie-banner-buttons {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}

.cookie-btn {
    display: inline-block;
    text-align: center;
    border: 2.5px solid var(--white);
    border-radius: 4px;
    padding: 8px 18px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    background: transparent;
    transition: background 0.14s, color 0.14s;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
}

.cookie-btn:hover {
    background: var(--black);
    color: var(--orange);
}

.cookie-btn-allow {
    color: var(--clime);
    background: var(--black);
}

.cookie-btn-allow:hover {
    background: var(--clime);
    color: var(--black);
}

.cookie-btn-deny {
    color: #F8637C;
    background: var(--black);
}

.cookie-btn-deny:hover {
    color: var(--black);
    background: var(--red);
}

.cookie-btn-wtf {
    color: var(--cpink);
    background: var(--black);
}

.cookie-btn-wtf:hover {
    background: var(--cpink);
    color: var(--black);
}

.cookie-btn-wtf[aria-expanded="true"] {
    color: var(--black);
    background: var(--cpink);
}
.cookie-btn-wtf[aria-expanded="true"]:hover {
    background: var(--black);
    color: var(--cpink);
}

.cookie-settings {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: max-height 280ms ease, opacity 280ms ease, padding 280ms ease;
    border-top: 1.5px solid var(--white);
}

.cookie-banner.is-expanded .cookie-settings {
    max-height: 1000px;
    opacity: 1;
    padding: 28px 40px;
}

.cookie-settings-header {
    font-family: 'Black Han Sans', sans-serif;
    font-size: 1.2rem;
    line-height: 1;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    margin: 0 0 16px;
    color: var(--white);
    margin: 0 auto;
}

.cookie-settings-description {
    font-size: 0.88rem;
    line-height: 1.6;
    margin-bottom: 24px;
    max-width: 64ch;
}

.cookie-settings-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.cookie-setting {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

.cookie-setting-label {
    flex: 1;
}

.cookie-setting-title {
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.85rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    margin: 0 0 4px;
    color: var(--white);
}

.cookie-setting-description {
    font-size: 0.8rem;
    line-height: 1.5;
    margin: 0;
}

.cookie-toggle {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 28px;
    border: 2.5px solid var(--black);
    border-radius: 999px;
    background: var(--white);
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.2s, box-shadow 0.2s;
}

.cookie-toggle:hover {
    box-shadow: 2px 3px 0 0 var(--black);
}

.cookie-toggle.is-on {
    background: var(--clime);
}

.cookie-toggle::before {
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    background: var(--black);
    border-radius: 50%;
    transition: transform 0.2s;
    left: 3px;
}

.cookie-toggle.is-on::before {
    transform: translateX(20px);
}

.cookie-settings-apply {
    display: inline-block;
    text-align: center;
    border: 2.5px solid var(--black);
    border-radius: 4px;
    padding: 10px 24px;
    font-family: 'Barlow Condensed', sans-serif;
    font-weight: 400;
    font-size: 0.78rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--black);
    background: var(--clime);
    transition: background 0.14s, color 0.14s;
    cursor: pointer;
    margin-top: 24px;
}

.cookie-settings-apply:hover {
    background: var(--cpink);
    color: var(--black);
}

@media (max-width: 760px) {
    .cookie-banner-summary {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
        padding: 14px 24px;
    }

    .cookie-banner-copy {
        width: 100%;
    }

    .cookie-banner-message {
        margin-bottom: 2px;
    }

    .cookie-banner-description {
        margin-bottom: 0;
    }

    .cookie-banner-buttons {
        width: 100%;
        justify-content: flex-start;
        gap: 8px;
    }

    .cookie-btn {
        padding: 8px 14px;
        font-size: 0.68rem;
    }

    .cookie-banner-summary {
        padding: 12px 24px;
        gap: 8px;
    }

    .cookie-banner-message {
        font-size: 13px;
        margin-bottom: 1px;
    }

    .cookie-banner-description {
        font-size: 13px;
        line-height: 1.3;
    }

    .cookie-banner-buttons {
        flex-wrap: wrap;
    }

    .cookie-settings {
        padding: 0 !important;
    }

    .cookie-banner.is-expanded .cookie-settings {
        padding: 20px 24px !important;
    }

    .cookie-settings-header {
        font-size: 1rem;
    }

    .cookie-setting {
        flex-direction: column;
        align-items: flex-start;
    }

    .cookie-toggle {
        width: 44px;
        height: 26px;
    }

    .cookie-toggle::before {
        width: 18px;
        height: 18px;
    }

    .cookie-toggle.is-on::before {
        transform: translateX(18px);
    }
}

body.has-cookie-banner {
    padding-bottom: 62px;
}

body.has-cookie-banner.cookie-banner-expanded {
    padding-bottom: auto;
}

.nowrap {
    white-space: nowrap;
}