/* ===========================================================
   The Neuro-Somatic Architect - Design System
   Warm earth-tone editorial palette (preserved from brand)
   Cormorant Garamond (display) + Switzer (body)
   =========================================================== */
:root,
[data-theme='light'] {
    /* Type scale */
    --text-xs: clamp(0.75rem,0.7rem + 0.25vw,0.8125rem);
    --text-sm: clamp(0.8125rem,0.78rem + 0.2vw,0.9375rem);
    --text-base: clamp(1rem,0.96rem + 0.2vw,1.0625rem);
    --text-lg: clamp(1.125rem,1rem + 0.5vw,1.375rem);
    --text-xl: clamp(1.5rem,1.2rem + 1.1vw,2.1rem);
    --text-2xl: clamp(2rem,1.3rem + 2.4vw,3.3rem);
    --text-3xl: clamp(2.6rem,1.4rem + 4vw,4.6rem);

    /* Spacing */
    --space-1: .25rem;
    --space-2: .5rem;
    --space-3: .75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;
    --space-20: 5rem;
    --space-24: 6rem;
    --space-32: 8rem;

    /* Surfaces - warm cream / sand / linen */
    --color-bg: #f5f3ec;
    --color-surface: #fbfaf5;
    --color-surface-2: #fffefa;
    --color-surface-offset: #ebe3da;

    /* warm linen */
    --color-surface-deep: #e3d8cb;

    /* deeper sand */
    --color-divider: #ddd2c3;
    --color-border: #d3c6b4;

    /* Text - warm near-black brown */
    --color-text: #352f29;
    --color-text-muted: #766b5d;
    --color-text-faint: #a89c8a;
    --color-text-inverse: #f7f3ec;

    /* Accent - warm taupe / greige + deep brown */
    --color-primary: #564b3e;

    /* deep warm brown (buttons) */
    --color-primary-hover: #3f372d;
    --color-primary-active: #2d2823;
    --color-accent: #b8a490;

    /* taupe / greige */
    --color-accent-soft: #cdbca6;
    --color-gold: #a98a5c;

    /* muted antique gold */
    /* Band */
    --color-band: #564b3e;
    --color-band-text: #f2ebe0;
    --radius-sm: .375rem;
    --radius-md: .625rem;
    --radius-lg: 1rem;
    --radius-xl: 1.5rem;
    --radius-full: 9999px;
    --transition-interactive: 240ms cubic-bezier(0.16,1,0.3,1);
    --shadow-sm: 0 1px 3px rgba(53,47,41,.06);
    --shadow-md: 0 8px 24px rgba(53,47,41,.09);
    --shadow-lg: 0 24px 60px rgba(53,47,41,.14);
    --content-narrow: 680px;
    --content-default: 1080px;
    --content-wide: 1240px;
    --font-display: 'Cormorant Garamond','Georgia',serif;
    --font-body: 'Switzer','Helvetica Neue',sans-serif;
}

[data-theme='dark'] {
    /* Elegant evergreen dark scheme */
    --color-bg: #131d18;
    --color-surface: #18241e;
    --color-surface-2: #1d2b23;
    --color-surface-offset: #1b2922;
    --color-surface-deep: #213328;
    --color-divider: #2a3a31;
    --color-border: #36493d;
    --color-text: #e8efe7;
    --color-text-muted: #9fb1a4;
    --color-text-faint: #6c8074;
    --color-text-inverse: #14201a;
    --color-primary: #d6e2d6;

    /* pale sage - buttons go light in dark */
    --color-primary-hover: #e4ede3;
    --color-primary-active: #eef4ed;
    --color-accent: #8fae94;
    --color-accent-soft: #3a4f42;
    --color-gold: #c2a875;
    --color-band: #0e1814;
    --color-band-text: #e8efe7;
    --shadow-sm: 0 1px 3px rgba(0,0,0,.4);
    --shadow-md: 0 8px 24px rgba(0,0,0,.5);
    --shadow-lg: 0 24px 60px rgba(0,0,0,.6);
}

@media (prefers-color-scheme:dark){
    :root:not([data-theme]) {
        --color-bg: #131d18;
        --color-surface: #18241e;
        --color-surface-2: #1d2b23;
        --color-surface-offset: #1b2922;
        --color-surface-deep: #213328;
        --color-divider: #2a3a31;
        --color-border: #36493d;
        --color-text: #e8efe7;
        --color-text-muted: #9fb1a4;
        --color-text-faint: #6c8074;
        --color-text-inverse: #14201a;
        --color-primary: #d6e2d6;
        --color-primary-hover: #e4ede3;
        --color-primary-active: #eef4ed;
        --color-accent: #8fae94;
        --color-accent-soft: #3a4f42;
        --color-gold: #c2a875;
        --color-band: #0e1814;
        --color-band-text: #e8efe7;
    }
}

/* ---------- Layout primitives ---------- */
.container {
    width: 100%;
    max-width: var(--content-wide);
    margin-inline: auto;
    padding-inline: clamp(var(--space-5),5vw,var(--space-16));
}

.section-label {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: var(--space-4);
}

[data-theme='dark'] .section-label {
    color: var(--color-gold);
}

.eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: .28em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: var(--space-5);
}

em {
    font-style: italic;
}

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    letter-spacing: .02em;
    padding: .85rem 1.7rem;
    border-radius: var(--radius-full);
    border: 1px solid transparent;
    line-height: 1;
    text-align: center;
}

.btn-sm {
    padding: .6rem 1.2rem;
    font-size: var(--text-xs);
    letter-spacing: .06em;
}

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

.btn-primary:hover {
    background: var(--color-primary-hover);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.btn-ghost {
    background: transparent;
    color: var(--color-text);
    border-color: var(--color-border);
}

.btn-ghost:hover {
    border-color: var(--color-text);
    transform: translateY(-2px);
}

.btn-block {
    width: 100%;
}

/* Lux little CTA button - refined outline pill with gold hairline dot */
.btn-lux {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    position: relative;
    background: transparent;
    color: var(--color-text);
    border: 1px solid var(--color-border);
    font-family: var(--font-body);
    line-height: 1;
    padding: .66rem 1.3rem;
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: .18em;
    text-transform: uppercase;
    border-radius: var(--radius-full);
    overflow: hidden;
    isolation: isolate;
}

.btn-lux::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    border-radius: inherit;
    background: var(--color-primary);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .42s cubic-bezier(0.16,1,0.3,1);
}

.btn-lux:hover {
    color: var(--color-text-inverse);
    border-color: var(--color-primary);
}

.btn-lux:hover::before {
    transform: scaleX(1);
}

.btn-lux .lux-dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--color-gold);
    display: inline-block;
    transition: background var(--transition-interactive);
}

.btn-lux:hover .lux-dot {
    background: var(--color-text-inverse);
}

/* ---------- Header ---------- */
.site-header {
    position: sticky;
    top: 0;
    z-index: 80;
    background: color-mix(in oklab,var(--color-bg) 86%,transparent);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid transparent;
    transition: border-color var(--transition-interactive),box-shadow var(--transition-interactive),background var(--transition-interactive);
}

.site-header.scrolled {
    border-bottom-color: var(--color-divider);
    box-shadow: var(--shadow-sm);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
    min-height: 72px;
}

.brand {
    display: flex;
    align-items: center;
    gap: .6rem;
    color: var(--color-text);
}

.brand-mark {
    color: var(--color-accent);
    display: grid;
    place-items: center;
}

[data-theme='dark'] .brand-mark {
    color: var(--color-gold);
}

.brand-text {
    font-family: var(--font-display);
    font-size: 1.18rem;
    font-weight: 500;
    letter-spacing: .01em;
    white-space: nowrap;
}

.nav {
    display: flex;
    gap: var(--space-8);
}

.nav a {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    position: relative;
    padding: .25rem 0;
}

.nav a::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -2px;
    width: 0;
    height: 1px;
    background: var(--color-text);
    transition: width var(--transition-interactive);
}

.nav a:hover {
    color: var(--color-text);
}

.nav a:hover::after {
    width: 100%;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: var(--space-3);
}

.theme-toggle {
    width: 38px;
    height: 38px;
    border-radius: var(--radius-full);
    display: grid;
    place-items: center;
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}

.theme-toggle:hover {
    color: var(--color-text);
    border-color: var(--color-text);
}

.menu-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
}

.menu-toggle span {
    width: 22px;
    height: 1.5px;
    background: var(--color-text);
    transition: var(--transition-interactive);
}

.menu-toggle[aria-expanded='true'] span:nth-child(1) {
    transform: translateY(6.5px) rotate(45deg);
}

.menu-toggle[aria-expanded='true'] span:nth-child(2) {
    opacity: 0;
}

.menu-toggle[aria-expanded='true'] span:nth-child(3) {
    transform: translateY(-6.5px) rotate(-45deg);
}

.mobile-nav {
    display: none;
    flex-direction: column;
    gap: var(--space-2);
    padding: 0 clamp(var(--space-5),5vw,var(--space-16)) 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s cubic-bezier(0.16,1,0.3,1),padding .4s;
}

.mobile-nav.open {
    max-height: 420px;
    padding-block: var(--space-4) var(--space-8);
}

.mobile-nav a {
    padding: .85rem 0;
    font-size: var(--text-lg);
    font-family: var(--font-display);
    border-bottom: 1px solid var(--color-divider);
}

.mobile-nav a.mobile-lux {
    border-bottom: none;
    margin-top: var(--space-5);
    align-self: flex-start;
}

/* ---------- Hero ---------- */
.hero {
    position: relative;
    padding-block: clamp(var(--space-12),7vw,var(--space-24)) clamp(var(--space-16),8vw,var(--space-32));
}

.hero-grid {
    display: grid;
    grid-template-columns: 1.05fr .85fr;
    gap: clamp(var(--space-10),6vw,var(--space-24));
    align-items: center;
}

.hero-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-3xl);
    line-height: 1.02;
    letter-spacing: -.01em;
    margin-bottom: var(--space-6);
}

.hero-title em {
    color: var(--color-accent);
    font-style: italic;
}

[data-theme='dark'] .hero-title em {
    color: var(--color-gold);
}

.hero-lede {
    font-size: var(--text-lg);
    color: var(--color-text-muted);
    max-width: 34ch;
    margin-bottom: var(--space-8);
    line-height: 1.55;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-4);
    margin-bottom: var(--space-8);
}

.hero-byline {
    font-size: var(--text-sm);
    color: var(--color-text-faint);
    letter-spacing: .02em;
}

.hero-portrait {
    position: relative;
}

.portrait-frame {
    position: relative;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    z-index: 2;
    background: var(--color-surface-offset);
}

.portrait-frame img {
    width: 100%;
    aspect-ratio: 1/1.32;
    object-fit: cover;
    object-position: 50% 28%;
}

.portrait-frame figcaption {
    position: absolute;
    left: 0;
    bottom: 0;
    right: 0;
    padding: var(--space-8) var(--space-6) var(--space-5);
    font-family: var(--font-display);
    font-size: 1.4rem;
    color: #fff;
    background: linear-gradient(to top,rgba(45,38,30,.7),transparent);
    letter-spacing: .01em;
}

.portrait-accent {
    position: absolute;
    inset: auto -18px -18px auto;
    width: 62%;
    height: 62%;
    border: 1px solid var(--color-accent);
    border-radius: var(--radius-xl);
    z-index: 1;
}

.hero-scroll {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: var(--space-6);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    color: var(--color-text-faint);
    font-size: var(--text-xs);
    letter-spacing: .2em;
    text-transform: uppercase;
}

.hero-scroll svg {
    animation: bob 2.4s ease-in-out infinite;
}

@keyframes bob{
    0%,
    100% {
        transform: translateY(0);
    }

    50% {
        transform: translateY(6px);
    }
}

/* ---------- Statement ---------- */
.statement {
    background: var(--color-surface-offset);
    padding-block: clamp(var(--space-16),8vw,var(--space-24));
}

.statement-grid {
    display: grid;
    grid-template-columns: .95fr 1.05fr;
    gap: clamp(var(--space-8),5vw,var(--space-16));
    align-items: center;
}

/* Flip: photo on the left, copy on the right (source order unchanged) */
.statement-media {
    grid-column: 1;
    grid-row: 1;
}

.statement-copy {
    grid-column: 2;
    grid-row: 1;
    max-width: 34ch;
    justify-self: end;
}

.statement-text {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-xl);
    line-height: 1.22;
    letter-spacing: -.005em;
}

.statement-text em {
    color: var(--color-accent);
    font-style: italic;
}

[data-theme='dark'] .statement-text em {
    color: var(--color-gold);
}

.statement-media {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}

.statement-media img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
}

/* ---------- About ---------- */
.about {
    padding-block: clamp(var(--space-16),9vw,var(--space-32));
}

/* Two-column About: compact image left, wide text right.
   Heading spans full width above; the wide text column keeps the
   section short by giving every line a generous measure. */
.about-wrap {
    max-width: var(--content-wide);
    display: grid;
    grid-template-columns: minmax(280px, 360px) 1fr;
    column-gap: clamp(var(--space-10),4vw,var(--space-16));
    align-items: start;
}

.about-wrap .section-label,
.about-wrap .about-lead {
    grid-column: 1 / -1;
}

.about-frame {
    grid-column: 1;
    align-self: start;
    position: sticky;
    top: 96px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}

.about-frame img {
    width: 100%;
    aspect-ratio: 4/5;
    object-fit: cover;
    object-position: 50% 20%;
}

.about-wrap .prose {
    grid-column: 2;
}

.credentials {
    margin-top: var(--space-6);
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.credentials li {
    font-size: var(--text-xs);
    letter-spacing: .04em;
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    padding: .4rem .85rem;
}

.about-lead {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-xl);
    line-height: 1.15;
    margin-bottom: var(--space-8);
    max-width: 32ch;
}

.prose p {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    margin-bottom: var(--space-5);
    line-height: 1.7;
}

.prose p:first-of-type {
    color: var(--color-text);
}

.prose em {
    font-style: italic;
    color: var(--color-text);
}

/* ---------- Quote band ---------- */
.quote-band {
    background: var(--color-band);
    color: var(--color-band-text);
    padding-block: clamp(var(--space-12),6vw,var(--space-20));
}

.quote-band blockquote {
    max-width: 58ch;
    margin-inline: auto;
    text-align: center;
}

.quote-band p {
    font-family: var(--font-display);
    font-style: italic;
    font-weight: 400;
    font-size: var(--text-xl);
    line-height: 1.34;
    max-width: none;
}

.quote-band p br {
    display: none;
}

@media (min-width:760px){
    .quote-band p br {
        display: inline;
    }
}

.quote-band p::before {
    content: '“';
    color: var(--color-accent);
    margin-right: .04em;
}

.quote-band p::after {
    content: '”';
    color: var(--color-accent);
}

/* ---------- Method ---------- */
.method {
    padding-block: clamp(var(--space-16),9vw,var(--space-32));
}

.method-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(var(--space-10),5vw,var(--space-16));
}

.method-intro {
    max-width: var(--content-narrow);
}

.method-intro h2 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-2xl);
    margin-bottom: var(--space-4);
    line-height: 1.1;
}

.method-sub {
    color: var(--color-text-muted);
    font-size: var(--text-lg);
    max-width: 48ch;
}

.method-body {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: clamp(var(--space-8),5vw,var(--space-16));
    align-items: center;
}

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

.method-list li {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-5);
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: var(--space-6);
}

.method-num {
    font-family: var(--font-display);
    font-size: 1.7rem;
    color: var(--color-accent);
    grid-row: span 2;
    line-height: 1;
}

[data-theme='dark'] .method-num {
    color: var(--color-gold);
}

.method-list h3 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-lg);
    margin-bottom: var(--space-2);
}

.method-list p {
    color: var(--color-text-muted);
    font-size: var(--text-base);
    max-width: 52ch;
}

.method-media {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
}

.method-media img {
    width: 100%;
    aspect-ratio: 4/3;
    object-fit: cover;
}

/* ---------- Series ---------- */
.series {
    background: var(--color-surface-offset);
    padding-block: clamp(var(--space-16),9vw,var(--space-32));
}

.series-head {
    max-width: var(--content-narrow);
    margin-bottom: clamp(var(--space-10),5vw,var(--space-16));
}

.series-head h2 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-2xl);
    margin-bottom: var(--space-4);
    line-height: 1.08;
}

.series-sub {
    color: var(--color-text-muted);
    font-size: var(--text-lg);
}

.tiers {
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: var(--space-6);
    align-items: start;
}

.tier {
    position: relative;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    transition: transform var(--transition-interactive),box-shadow var(--transition-interactive),border-color var(--transition-interactive);
}

.tier:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.tier-featured {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-md);
}

.tier-gold {
    border-color: var(--color-gold);
}

.tier-flag {
    position: absolute;
    top: -12px;
    left: var(--space-8);
    background: var(--color-accent);
    color: #2d261e;
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .3rem .8rem;
    border-radius: var(--radius-full);
}

.tier-eyebrow {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--color-accent);
}

.tier-gold .tier-eyebrow {
    color: var(--color-gold);
}

.tier-name {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-xl);
    line-height: 1.05;
}

.tier-head {
    margin-bottom: var(--space-2);
}

.tier-desc {
    color: var(--color-text-muted);
    font-size: var(--text-base);
    line-height: 1.65;
    flex: 1;
}

.tier-format {
    font-size: var(--text-sm);
    color: var(--color-text);
    padding-top: var(--space-4);
    border-top: 1px solid var(--color-divider);
}

.tier-format span {
    display: block;
    font-size: var(--text-xs);
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--color-text-faint);
    margin-bottom: .3rem;
}

.tier-scarcity {
    font-size: var(--text-sm);
    font-style: italic;
    color: var(--color-gold);
    font-family: var(--font-display);
}

.tier-link {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text);
    margin-top: auto;
}

.tier-link:hover {
    color: var(--color-accent);
}

/* ---------- Closing (texture divider) ---------- */
.closing {
    position: relative;
    padding-block: clamp(var(--space-20),12vw,var(--space-32));
    overflow: hidden;
    isolation: isolate;
}

.closing-bg {
    position: absolute;
    inset: 0;
    z-index: -2;
}

.closing-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center 42%;
}

.closing::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(180deg,color-mix(in oklab,var(--color-bg) 72%,transparent),color-mix(in oklab,var(--color-bg) 54%,transparent));
}

[data-theme='dark'] .closing::after {
    background: linear-gradient(180deg,color-mix(in oklab,var(--color-bg) 80%,transparent),color-mix(in oklab,var(--color-bg) 64%,transparent));
}

.closing-inner {
    max-width: 62ch;
    margin-inline: auto;
    text-align: center;
}

.closing blockquote p {
    font-family: var(--font-display);
    font-weight: 400;
    font-style: italic;
    font-size: var(--text-xl);
    line-height: 1.34;
    margin-bottom: var(--space-5);
    max-width: none;
}

.closing blockquote p br {
    display: none;
}

@media (min-width:760px){
    .closing blockquote p br {
        display: inline;
    }
}

.closing cite {
    font-family: var(--font-body);
    font-style: normal;
    font-size: var(--text-xs);
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--color-text-muted);
}

.closing cite::before {
    content: '';
    display: block;
    width: 32px;
    height: 1px;
    background: currentColor;
    opacity: .4;
    margin: 0 auto var(--space-3);
}

/* ---------- Contact ---------- */
.contact {
    background: var(--color-surface-offset);
    padding-block: clamp(var(--space-16),9vw,var(--space-32));
}

/* Centered email invitation (replaces the form) */
.contact-invite {
    max-width: 860px;
    margin-inline: auto;
    text-align: center;
}

.contact-invite h2 {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: var(--text-2xl);
    margin-bottom: var(--space-5);
    line-height: 1.08;
}

.contact-lede {
    color: var(--color-text-muted);
    margin-inline: auto;
    margin-bottom: var(--space-8);
    max-width: 64ch;
}

.contact-email-btn {
    font-size: var(--text-sm);
    letter-spacing: .04em;
    text-transform: none;
    padding: .9rem 1.7rem;
    margin-bottom: var(--space-8);
    border-radius: var(--radius-sm);
}

.contact-email-btn::before {
    border-radius: inherit;
}

.contact-assurance {
    font-family: var(--font-display);
    font-style: italic;
    font-size: var(--text-lg);
    color: var(--color-text);
    margin-inline: auto;
    max-width: 44ch;
}

/* ---------- Footer ---------- */
.site-footer {
    background: var(--color-band);
    color: var(--color-band-text);
    padding-top: clamp(var(--space-12),6vw,var(--space-20));
}

.footer-inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-8);
    align-items: center;
    padding-bottom: var(--space-10);
    border-bottom: 1px solid rgba(255,255,255,.1);
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: .6rem;
    font-family: var(--font-display);
    font-size: 1.25rem;
}

.footer-brand .brand-mark {
    color: var(--color-accent);
}

.footer-tag {
    font-family: var(--font-display);
    font-style: italic;
    font-size: var(--text-lg);
    color: var(--color-accent-soft);
    grid-column: 1/-1;
    max-width: 46ch;
}

.footer-tag {
    color: #c2b09a;
}

[data-theme='dark'] .footer-tag {
    color: #aab8a4;
}

.footer-nav {
    display: flex;
    gap: var(--space-6);
    justify-self: end;
}

.footer-nav a {
    font-size: var(--text-sm);
    color: var(--color-band-text);
    opacity: .8;
}

.footer-nav a:hover {
    opacity: 1;
}

.footer-base {
    padding-block: var(--space-6);
    color: var(--color-accent-soft);
}

.footer-base p {
    font-size: var(--text-xs);
    letter-spacing: .04em;
    color: #a89683;
}

[data-theme='dark'] .footer-base p {
    color: #7f9285;
}

/* ---------- Reveal animation ---------- */
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .8s cubic-bezier(0.16,1,0.3,1),transform .8s cubic-bezier(0.16,1,0.3,1);
}

.reveal.in {
    opacity: 1;
    transform: none;
}

@media (prefers-reduced-motion:reduce){
    .reveal {
        opacity: 1;
        transform: none;
    }
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
    .nav {
        display: none;
    }

    .menu-toggle {
        display: flex;
    }

    .nav-cta {
        display: none;
    }

    .mobile-nav {
        display: flex;
    }

    .hero-grid {
        grid-template-columns: 1fr;
        gap: var(--space-12);
    }

    .hero-portrait {
        max-width: 440px;
    }

    /* Stack the About on smaller screens: heading, image, then text */
    .about-wrap {
        grid-template-columns: 1fr;
        row-gap: var(--space-8);
    }

    .about-wrap .section-label,
    .about-wrap .about-lead,
    .about-frame,
    .about-wrap .prose {
        grid-column: 1;
    }

    .about-frame {
        position: static;
        width: 100%;
        max-width: 460px;
    }

    .statement-grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    /* Reset the desktop flip so mobile stacks in source order (copy, then photo) */
    .statement-copy,
    .statement-media {
        grid-column: 1;
        grid-row: auto;
        justify-self: stretch;
    }

    .statement-copy {
        max-width: none;
    }

    .statement-media {
        max-width: 560px;
    }

    .method-body {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }

    .method-media {
        position: static;
        max-width: 420px;
        margin-inline: auto;
    }

    .tiers {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }

    .tier-featured {
        order: -1;
    }
}

@media (max-width:560px){
    .footer-inner {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    .footer-nav {
        justify-self: start;
        flex-wrap: wrap;
        gap: var(--space-4);
    }

    .hero-actions {
        gap: var(--space-3);
    }

    .hero-actions .btn {
        flex: 1 1 auto;
    }

    .portrait-accent {
        display: none;
    }

    .method-list li {
        column-gap: var(--space-4);
    }

    .method-num {
        font-size: 1.4rem;
    }
}
