/* ============================================================
   Kancelaria Finansowa Stefanik — vanilla CSS, no Tailwind, no npm.
   Single stylesheet. Edit primitives in :root to re-skin the site.

   Palette (2026-05 redesign): navy base + warm cream grounds +
   one elegant beige-gold accent. Photos render in colour, unified by
   a shared warm tone filter (see .framed-media img) so they read as a set.
   ============================================================ */

:root {
    /* fonts */
    --font-sans: "Open Sans", system-ui, -apple-system, sans-serif;
    --font-display: "Open Sans", system-ui, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

    /* palette primitives */
    --color-navy:      #21212F;   /* dark sections, headings */
    --color-navy-soft: #2D2D3D;
    --color-cream:     #F7F5EF;   /* dominant warm light ground */
    --color-paper:     #FFFFFF;   /* pure white cards */
    --color-gold:      #BE9C6B;   /* beige-gold — elegant, not yellow */
    --color-gold-deep: #97774A;   /* deeper gold for text accents on light */

    /* derived text (stepped, mixed against navy) */
    --color-heading: var(--color-navy);
    --color-body:    #2D2D3D;
    --color-muted:   #5C5C6B;
    --color-faint:   #7A7A88;

    /* on dark */
    --color-on-dark:        #F7F5EF;
    --color-on-dark-body:   rgba(247, 245, 239, 0.78);
    --color-on-dark-muted:  rgba(247, 245, 239, 0.55);

    /* borders */
    --color-hairline:        rgba(33, 33, 47, 0.10);
    --color-hairline-strong: rgba(33, 33, 47, 0.22);
    --color-hairline-dark:   rgba(247, 245, 239, 0.14);

    /* layout */
    --container:        1240px;
    --container-narrow: 820px;
    --gutter:           clamp(24px, 4vw, 40px);
    --section-y:        clamp(88px, 9vw, 132px);
    --section-y-tight:  clamp(64px, 7vw, 96px);

    /* type clamps */
    --text-display: clamp(2.75rem, 5vw, 5rem);
    --text-h2:      clamp(2.5rem, 4.6vw, 4rem);
    --text-lead:    1.125rem;

    --radius: 0px;

    /* aliases consumed by prose.css (blog markdown) */
    --color-brand:        var(--color-gold-deep);
    --color-border:       var(--color-hairline);
    --color-surface:      color-mix(in oklab, var(--color-navy) 4%, var(--color-cream));
    --color-scrollbar:    var(--color-hairline-strong);
    --color-prose-bold:   var(--color-heading);
    --color-prose-italic: var(--color-heading);
    --color-prose-code:   var(--color-gold-deep);
    --color-prose-code-bg: var(--color-navy);
    --color-prose-pre:    var(--color-on-dark-body);
    --radius-container:   2px;
}

/* Open Sans — variable, self-hosted (folded in from former fonts.css) */
@font-face {
    font-family: "Open Sans"; font-style: normal; font-weight: 300 800;
    font-display: swap; src: url("/static/fonts/open-sans-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: "Open Sans"; font-style: normal; font-weight: 300 800;
    font-display: swap; src: url("/static/fonts/open-sans-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
    font-family: "Open Sans"; font-style: italic; font-weight: 300 800;
    font-display: swap; src: url("/static/fonts/open-sans-italic-latin.woff2") format("woff2");
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
    font-family: "Open Sans"; font-style: italic; font-weight: 300 800;
    font-display: swap; src: url("/static/fonts/open-sans-italic-latin-ext.woff2") format("woff2");
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Minimal reset */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
img, svg, video, picture { display: block; max-width: 100%; }
button { background: none; border: 0; font: inherit; color: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button, [role="button"], a, summary { cursor: pointer; }

html { height: 100%; overflow-y: scroll; -webkit-text-size-adjust: 100%; }
body {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    background: var(--color-cream);
    color: var(--color-body);
    font-family: var(--font-sans);
    font-weight: 400;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
main { flex: 1; }

h1, h2, h3, h4 {
    font-family: var(--font-display);
    color: var(--color-heading);
    font-weight: 600;
    letter-spacing: -0.02em;
    line-height: 1.1;
}

/* Globals — after reset so they win */
::selection { background: var(--color-gold); color: var(--color-navy); }
[x-cloak] { display: none !important; }
.scroll-hide { scrollbar-width: none; }
.scroll-hide::-webkit-scrollbar { display: none; }

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap        { max-width: var(--container);        margin-inline: auto; padding-inline: var(--gutter); }
.wrap-narrow { max-width: var(--container-narrow);  margin-inline: auto; padding-inline: var(--gutter); }

.section        { padding-block: var(--section-y); }
.section--tight { padding-block: var(--section-y-tight); }
.section-dark   { background: var(--color-navy); color: var(--color-on-dark); }
.section-cream  { background: var(--color-cream); }
.section-paper2 { background: color-mix(in oklab, var(--color-navy) 4%, var(--color-cream)); }

.rule { max-width: var(--container); margin-inline: auto; border: 0; border-top: 1px solid var(--color-hairline); }

/* ============================================================
   TYPE PRIMITIVES
   ============================================================ */
.kicker {
    display: inline-block;
    font-size: 12px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--color-gold);
}
.display {
    font-size: var(--text-display);
    line-height: 1.05;
    letter-spacing: -0.03em;
    color: var(--color-heading);
}
.headline {
    font-size: var(--text-h2);
    line-height: 1.1;
    letter-spacing: -0.03em;
    color: var(--color-heading);
}
.accent { color: var(--color-gold-deep); }
.section-dark .display,
.section-dark .headline { color: var(--color-on-dark); }
.section-dark .accent   { color: var(--color-gold); }

.lead {
    font-size: var(--text-lead);
    line-height: 1.7;
    color: var(--color-body);
}
.section-dark .lead { color: var(--color-on-dark-body); }

/* Two-column section head: heading left, supporting paragraph right */
.head-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(2.5rem, 4vw, 5rem);
    align-items: end;
    margin-bottom: clamp(3rem, 6vw, 5rem);
}
.head-center { text-align: center; margin-bottom: clamp(3rem, 6vw, 5rem); }
.head-block  { max-width: 42rem; margin-bottom: clamp(3rem, 6vw, 5rem); }
.head-center .lead { margin-inline: auto; }
.stack-6 > * + * { margin-top: 1.5rem; }
.mt-kicker { margin-top: 1.5rem; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    padding: 1rem 1.75rem;
    font-size: 12px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: 600;
    transition: background-color .2s, color .2s, border-color .2s;
}
.btn-solid   { background: var(--color-navy); color: var(--color-cream); }
.btn-solid:hover { background: var(--color-gold); color: var(--color-navy); }
.btn-outline { border: 1px solid var(--color-navy); color: var(--color-navy); }
.btn-outline:hover { background: var(--color-gold); border-color: var(--color-gold); color: var(--color-navy); }
.btn-on-dark { border: 1px solid var(--color-cream); color: var(--color-cream); }
.btn-on-dark:hover { background: var(--color-cream); color: var(--color-navy); }
.btn-link {
    display: inline-flex; align-items: center; gap: .5rem;
    font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600;
    color: var(--color-navy); transition: color .2s;
}
.btn-link:hover { color: var(--color-gold); }
.btn-row { display: flex; flex-wrap: wrap; gap: 1rem; }
.btn-row--center { justify-content: center; }

/* ============================================================
   FRAMED FIGURE (offset gold borders via pseudo-elements)
   ============================================================ */
.framed { position: relative; }
.framed::before {
    content: ""; position: absolute; inset: 0;
    transform: translate(12px, -12px);
    border: 1px solid color-mix(in oklab, var(--color-gold) 55%, transparent);
    pointer-events: none;
}
.framed::after {
    content: ""; position: absolute; left: 0; bottom: 0;
    width: 5rem; height: 5rem;
    transform: translate(-12px, 12px);
    border-left: 1px solid color-mix(in oklab, var(--color-gold) 40%, transparent);
    border-bottom: 1px solid color-mix(in oklab, var(--color-gold) 40%, transparent);
    pointer-events: none;
}
.framed-media {
    position: relative;
    aspect-ratio: 3 / 4;
    border: 1px solid var(--color-hairline);
    overflow: hidden;
}
.section-dark .framed-media { border-color: var(--color-hairline-dark); }
.framed-media img {
    width: 100%; height: 100%; object-fit: cover;
    /* Unify the photo set into one warm tone — colour kept, hue variance pulled
       toward beige so no shot reads greener/cooler than its neighbours. */
    filter: saturate(0.82) contrast(1.03) sepia(0.12);
}
.figure-pad { width: 100%; max-width: 440px; margin-inline: auto; }

/* ============================================================
   NAVBAR
   ============================================================ */
.nav {
    position: sticky; top: 0; z-index: 50;
    background: color-mix(in oklab, var(--color-cream) 85%, transparent);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--color-hairline);
}
.nav-inner {
    max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter);
    height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
}
.nav-logo-img { height: 3.25rem; width: auto; }
.nav-toggle { display: none; flex-direction: column; align-items: flex-end; justify-content: center; gap: 5px; width: 2rem; height: 2rem; color: var(--color-navy); }
.nav-toggle span { display: block; height: 1px; background: currentColor; }
.nav-toggle span:nth-child(1) { width: 1.5rem; }
.nav-toggle span:nth-child(2) { width: 1rem; }
.nav-toggle span:nth-child(3) { width: 1.5rem; }
.nav-links { display: flex; align-items: center; gap: 2.25rem; }
.nav-link {
    font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600;
    color: var(--color-muted);
    text-decoration: underline; text-underline-offset: 6px; text-decoration-thickness: 1px;
    text-decoration-color: var(--color-hairline-strong);
    transition: color .2s, text-decoration-color .2s;
}
.nav-link:hover, .nav-link.is-active { color: var(--color-navy); text-decoration-color: var(--color-navy); }
.nav-cta {
    display: inline-flex; align-items: center; padding: .625rem 1.25rem;
    font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600;
    border: 1px solid var(--color-navy); color: var(--color-navy);
    transition: background-color .2s, color .2s, border-color .2s;
}
.nav-cta:hover { background: var(--color-gold); border-color: var(--color-gold); color: var(--color-navy); }
.nav-panel { display: none; border-top: 1px solid var(--color-hairline); background: var(--color-cream); }
.nav-open .nav-panel { display: block; }
.nav-panel-list { display: flex; flex-direction: column; padding: 1.5rem var(--gutter); gap: .25rem; }
.nav-panel-link {
    display: block; padding: .75rem 0; font-size: 12px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600;
    color: var(--color-body); border-bottom: 1px solid var(--color-hairline);
}
.nav-panel-cta { margin-top: 1rem; display: inline-flex; padding: .75rem 1.25rem; border: 1px solid var(--color-navy); font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--color-navy); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--color-navy); color: var(--color-cream); }
.footer-inner { max-width: var(--container); margin-inline: auto; padding: 6rem var(--gutter) 3rem; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 4rem; }
.footer-brand { max-width: 24rem; }
.footer-logo { height: 4rem; width: auto; }
.footer-tagline { margin-top: 1.5rem; font-size: var(--text-lead); line-height: 1.6; color: var(--color-on-dark-body); }
.footer-socials { margin-top: 1.75rem; display: flex; gap: 1rem; }
.footer-social { width: 2.25rem; height: 2.25rem; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--color-hairline-dark); color: var(--color-on-dark-body); transition: color .2s, border-color .2s; }
.footer-social:hover { color: var(--color-gold); border-color: var(--color-gold); }
.footer-social svg { width: 1rem; height: 1rem; }
.footer-head { font-size: 12px; letter-spacing: .24em; text-transform: uppercase; font-weight: 600; color: var(--color-gold); margin-bottom: 1.25rem; }
.footer-links, .footer-contact-list { display: flex; flex-direction: column; gap: .75rem; font-size: 15px; color: var(--color-on-dark-body); }
.footer-link { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 1px; text-decoration-color: rgba(247,245,239,0.3); transition: color .2s, text-decoration-color .2s; }
.footer-link:hover { color: var(--color-gold); text-decoration-color: var(--color-gold); }
.footer-muted { color: var(--color-on-dark-muted); }
.footer-bottom { margin-top: 4rem; padding-top: 2rem; border-top: 1px solid rgba(247,245,239,0.1); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; font-size: 13px; letter-spacing: .08em; color: var(--color-on-dark-muted); }
.footer-credit { text-decoration: underline; text-underline-offset: 4px; text-decoration-color: rgba(247,245,239,0.3); transition: color .2s; }
.footer-credit:hover { color: var(--color-gold); }

/* ============================================================
   EYEBROW pill
   ============================================================ */
.eyebrow {
    display: inline-flex; align-items: center; padding: .375rem 1rem;
    font-size: 12px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600;
    color: var(--color-gold); border: 1px solid var(--color-hairline-strong); border-radius: 999px;
}

/* ============================================================
   HOME — hero
   ============================================================ */
.hero { padding-block: clamp(3rem, 5vw, 5rem) var(--section-y); }
.hero-grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: clamp(2.5rem, 4vw, 4rem); }
.hero-figure { display: flex; flex-direction: column; min-width: 0; }
.hero-portrait { position: relative; aspect-ratio: auto; height: 720px; }
.hero-portrait .framed-media { aspect-ratio: auto; height: 100%; }
.hero-caption { margin-top: 1rem; display: flex; justify-content: space-between; align-items: baseline; }
.hero-name { font-size: 13px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; color: var(--color-faint); }
.hero-role { font-size: 15px; color: var(--color-muted); }
.hero-content { display: flex; flex-direction: column; justify-content: center; min-width: 0; }
.hero-title { margin-top: 1.5rem; }
.hero-lead { margin-top: 2.25rem; max-width: 36rem; }
.hero-actions { margin-top: 3rem; }

/* stats row (home + reviews) */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.stat { padding: clamp(2rem, 3vw, 2.5rem); border-right: 1px solid var(--color-hairline); }
.stat:last-child { border-right: 0; }
.stat-num { font-family: var(--font-display); font-size: clamp(3rem, 5.2vw, 4.5rem); line-height: 1; letter-spacing: -0.03em; color: var(--color-heading); }
.stat-unit { color: var(--color-gold); font-size: 0.55em; vertical-align: top; }
.stat-label { margin-top: 1rem; font-size: 14px; line-height: 1.5; color: var(--color-muted); max-width: 14ch; }

/* areas */
.area-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--color-hairline); }
.area-card { display: flex; flex-direction: column; padding: clamp(2rem, 3vw, 3rem); border-right: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); background: var(--color-cream); transition: background-color .2s; }
.area-card:last-child { border-right: 0; }
.area-card:hover { background: var(--color-paper); }
.area-num { font-family: var(--font-display); font-size: 14px; letter-spacing: .32em; color: var(--color-gold); margin-bottom: 5rem; }
.area-title { font-size: 26px; color: var(--color-heading); margin-bottom: 1.75rem; }
.area-list { border-top: 1px solid var(--color-hairline); margin-bottom: 2.5rem; }
.area-item { padding: .875rem 0; border-bottom: 1px solid var(--color-hairline); font-size: var(--text-lead); color: var(--color-body); }
.area-link { margin-top: auto; }

/* triptych */
.triptych-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
.triptych-fig:nth-child(2) { transform: translateY(2.5rem); }
.triptych-fig .framed-media { aspect-ratio: 3 / 4; }

/* why (dark) */
.why-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(3rem, 6vw, 6rem); }
.why-intro-lead { margin-top: 2.25rem; max-width: 28rem; }
.why-list { display: flex; flex-direction: column; }
.why-item { display: grid; grid-template-columns: 60px 1fr; gap: 1.5rem; padding: 1.75rem 0; border-top: 1px solid var(--color-hairline-dark); align-items: start; }
.why-item:last-child { border-bottom: 1px solid var(--color-hairline-dark); }
.why-num { font-family: var(--font-display); font-size: 17px; letter-spacing: .2em; color: var(--color-gold); }
.why-title { font-size: 20px; color: var(--color-on-dark); margin-bottom: .5rem; }
.why-body { font-size: var(--text-lead); line-height: 1.6; color: var(--color-on-dark-body); }

/* process */
.process-list { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--color-hairline); }
.step { padding: clamp(2rem, 2.5vw, 2.25rem); border-right: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.step:last-child { border-right: 0; }
.step-num { font-family: var(--font-display); font-size: 22px; letter-spacing: .06em; color: var(--color-gold); margin-bottom: 3.5rem; }
.step-title { font-size: 20px; color: var(--color-heading); margin-bottom: .875rem; }
.step-body { font-size: var(--text-lead); line-height: 1.65; color: var(--color-body); }

/* office (dark) */
.office-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: center; }
.office-fig { width: 100%; max-width: 480px; aspect-ratio: 3 / 4; }
.office-fig .framed-media { aspect-ratio: auto; height: 100%; }
.office-lead { margin-top: 1.75rem; max-width: 28rem; }
.office-cta { margin-top: 2.5rem; }

/* reviews carousel (home) */
.reviews-track { display: flex; gap: 1.75rem; overflow-x: auto; scroll-snap-type: x mandatory; padding-bottom: .5rem; }
.review {
    scroll-snap-align: start; flex-shrink: 0;
    padding: clamp(2.5rem, 3vw, 3rem);
    background: var(--color-paper); border: 1px solid var(--color-hairline);
    display: flex; flex-direction: column; gap: 1.5rem;
}
.reviews-track .review { width: calc((100% - 1.75rem) / 2); }
.review-mark { font-family: var(--font-display); font-size: 80px; line-height: 0.4; color: var(--color-gold); }
.review-text { font-family: var(--font-display); font-style: italic; font-size: 21px; line-height: 1.45; letter-spacing: -0.02em; color: var(--color-body); flex-grow: 1; }
.review-meta { padding-top: 1.5rem; border-top: 1px solid var(--color-hairline); display: flex; justify-content: space-between; align-items: flex-end; gap: 1rem; }
.review-name { font-size: 15px; font-weight: 600; color: var(--color-heading); }
.review-role { font-size: 13px; letter-spacing: .02em; color: var(--color-faint); margin-top: .125rem; }
.review-stars { color: var(--color-gold); letter-spacing: 4px; font-size: 14px; flex-shrink: 0; }
.reviews-note { text-align: center; margin-top: 4rem; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; font-weight: 600; color: var(--color-faint); }
/* review card on dark + feature spans */
.review--dark { background: var(--color-navy); color: var(--color-on-dark); border-color: var(--color-hairline-dark); }
.review--dark .review-text { color: var(--color-on-dark); }
.review--dark .review-meta { border-color: var(--color-hairline-dark); }
.review--dark .review-name { color: var(--color-on-dark); }
.review--dark .review-role { color: var(--color-on-dark-muted); }
.review--feature { grid-column: span 2; }

/* faq (dark) */
.faq-item { border-top: 1px solid var(--color-hairline-dark); }
.faq-item:last-child { border-bottom: 1px solid var(--color-hairline-dark); }
.faq-summary { list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; padding: 2rem 0; font-family: var(--font-display); font-size: clamp(20px, 2vw, 26px); letter-spacing: -0.02em; color: var(--color-on-dark); }
.faq-summary::-webkit-details-marker { display: none; }
.faq-toggle { color: var(--color-gold); font-size: 26px; font-weight: 300; transition: transform .2s; }
.faq-item[open] .faq-toggle { transform: rotate(45deg); }
.faq-answer { padding: 0 4rem 2.25rem 0; font-size: var(--text-lead); line-height: 1.7; color: var(--color-on-dark-body); max-width: 720px; }

/* shared final CTA */
.cta { background: var(--color-paper); }
.cta-inner { max-width: 760px; margin-inline: auto; padding-inline: var(--gutter); text-align: center; }
.cta .headline, .cta .lead { margin-inline: auto; }
.cta .lead { margin-top: 2rem; max-width: 36rem; }
.cta-actions { margin-top: 3rem; }

/* ============================================================
   ABOUT
   ============================================================ */
.about-intro-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: clamp(3.5rem, 6vw, 6rem); align-items: start; }
.about-lead { margin-top: 2.25rem; max-width: 36rem; }
.meta-grid { margin-top: 3.5rem; padding-top: 2.5rem; border-top: 1px solid var(--color-hairline); display: grid; grid-template-columns: 1fr 1fr; gap: 1.75rem 2.5rem; }
.meta-label { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: var(--color-faint); margin-bottom: .375rem; }
.meta-value { font-size: var(--text-lead); color: var(--color-body); }
.about-img { aspect-ratio: 3 / 4; }

.story-head { margin-bottom: 4rem; }
.story-body { display: flex; flex-direction: column; gap: 1.75rem; font-size: 19px; line-height: 1.75; color: var(--color-body); }
.story-body em { color: var(--color-heading); font-style: italic; }
.story-body .lead-para { font-weight: 500; }
.dropcap::first-letter { font-family: var(--font-display); float: left; font-size: 5.5rem; line-height: 0.85; margin: .25rem .75rem 0 0; color: var(--color-gold); }

.approach-top { display: grid; grid-template-columns: 0.9fr 1fr; gap: clamp(3.5rem, 5vw, 5rem); margin-bottom: clamp(4rem, 6vw, 6rem); align-items: center; }
.approach-intro { display: flex; flex-direction: column; gap: 2.5rem; }
.principles { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--color-hairline-dark); }
.principle { padding: 3rem 0; border-bottom: 1px solid var(--color-hairline-dark); }
.principle:nth-child(odd)  { padding-right: 3.5rem; }
.principle:nth-child(even) { padding-left: 3.5rem; border-left: 1px solid var(--color-hairline-dark); }
.principle-num { font-family: var(--font-display); font-size: 15px; letter-spacing: .3em; color: var(--color-gold); display: block; margin-bottom: 1.5rem; }
.principle-title { font-size: 21px; color: var(--color-on-dark); margin-bottom: .75rem; }
.principle-body { font-size: var(--text-lead); line-height: 1.65; color: var(--color-on-dark-body); }

.expertise-grid { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--color-hairline); }
.expertise-card { padding: clamp(2rem, 3vw, 3rem); border-bottom: 1px solid var(--color-hairline); background: var(--color-cream); }
.expertise-card:nth-child(odd) { border-right: 1px solid var(--color-hairline); }
.expertise-title { font-size: 22px; color: var(--color-heading); margin-bottom: 1rem; }
.expertise-body { font-size: var(--text-lead); line-height: 1.65; color: var(--color-body); }

.bigquote { text-align: center; }
.bigquote-mark { font-family: var(--font-display); font-size: 120px; line-height: 0.4; color: var(--color-gold); margin-bottom: 1.5rem; }
.bigquote-text { font-family: var(--font-display); font-style: italic; font-size: clamp(1.75rem, 3.4vw, 3rem); line-height: 1.35; letter-spacing: -0.02em; color: var(--color-on-dark); text-wrap: balance; }
.bigquote-cite { margin-top: 3rem; font-size: 13px; letter-spacing: .16em; text-transform: uppercase; font-weight: 600; color: var(--color-on-dark-muted); }

/* ============================================================
   OFFER
   ============================================================ */
.offer-intro-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: center; }
.offer-intro-lead2 { margin-top: 1.25rem; max-width: 36rem; color: var(--color-muted); }

.offer-index { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.offer-index-link { display: flex; flex-direction: column; gap: .5rem; padding: 2rem 1.75rem; transition: background-color .2s; border-right: 1px solid var(--color-hairline); }
.offer-index-link:last-child { border-right: 0; }
.offer-index-link:hover { background: var(--color-paper); }
.offer-index-num { font-family: var(--font-display); font-size: 13px; letter-spacing: .3em; color: var(--color-gold); }
.offer-index-name { font-family: var(--font-display); font-size: 22px; color: var(--color-heading); }
.offer-index-sub { font-size: 14px; color: var(--color-faint); }

.service { scroll-margin-top: 5rem; }
.service-head { display: grid; grid-template-columns: 120px 1fr; gap: 2.5rem; align-items: start; margin-bottom: clamp(3rem, 5vw, 5rem); }
.service-num { font-family: var(--font-display); font-size: clamp(4.5rem, 8vw, 7.25rem); line-height: 0.9; letter-spacing: -0.03em; color: var(--color-gold); }
.service-body-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(3rem, 6vw, 6rem); align-items: start; }
.service-lede { font-size: var(--text-lead); line-height: 1.7; color: var(--color-body); }
.section-dark .service-lede { color: var(--color-on-dark-body); }
.service-list { border-top: 1px solid var(--color-hairline); }
.section-dark .service-list { border-color: var(--color-hairline-dark); }
.service-list-item { display: flex; justify-content: space-between; gap: 1.5rem; padding: 1.25rem 0; font-size: 17px; border-bottom: 1px solid var(--color-hairline); }
.section-dark .service-list-item { border-color: var(--color-hairline-dark); }
.service-name { color: var(--color-heading); font-weight: 600; }
.section-dark .service-name { color: var(--color-on-dark); }
.service-sub { color: var(--color-faint); font-size: 14px; letter-spacing: .02em; text-align: right; }
.section-dark .service-sub { color: var(--color-on-dark-muted); }

.audience-grid { margin-top: 4rem; display: grid; grid-template-columns: 1fr 1fr; column-gap: 2rem; text-align: left; }
.audience-item { display: grid; grid-template-columns: 28px 1fr; gap: 1rem; align-items: start; padding: 1.75rem 0; border-top: 1px solid var(--color-hairline); }
.audience-dot { font-family: var(--font-display); font-size: 28px; line-height: 0.5; color: var(--color-gold); margin-top: .5rem; }
.audience-item p { font-size: var(--text-lead); line-height: 1.5; color: var(--color-body); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-intro-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(3rem, 6vw, 6rem); align-items: center; }
.contact-methods { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.contact-method { display: flex; flex-direction: column; gap: .75rem; padding: 2.25rem; border-right: 1px solid var(--color-hairline); transition: background-color .2s; }
.contact-method:last-child { border-right: 0; }
a.contact-method:hover { background: var(--color-paper); }
.contact-method-label { font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--color-gold); }
.contact-method-value { font-family: var(--font-display); font-size: 21px; line-height: 1.25; letter-spacing: -0.02em; color: var(--color-heading); }
.contact-method-value--sm { font-size: 19px; line-height: 1.3; letter-spacing: -0.01em; }
.contact-method-note { font-size: 13px; color: var(--color-faint); letter-spacing: .04em; margin-top: auto; }

.contact-map-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(3rem, 5vw, 5rem); margin-bottom: 4rem; align-items: end; }
.contact-map-lead { margin-top: 1.5rem; max-width: 30rem; }
.map-link { margin-top: 2rem; display: inline-flex; align-items: center; gap: .75rem; font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--color-navy); border-bottom: 1px solid var(--color-navy); padding-bottom: .25rem; transition: color .2s, border-color .2s; }
.map-link:hover { color: var(--color-gold); border-color: var(--color-gold); }
.map-rows { display: flex; flex-direction: column; }
.map-row { display: grid; grid-template-columns: 100px 1fr; gap: 1.5rem; padding: 1.25rem 0; border-top: 1px solid var(--color-hairline); align-items: start; }
.map-row:last-child { border-bottom: 1px solid var(--color-hairline); }
.map-row-label { font-size: 12px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; color: var(--color-gold); }
.map-row-value { font-size: var(--text-lead); line-height: 1.55; color: var(--color-body); }
.map-embed { aspect-ratio: 21 / 9; border: 1px solid var(--color-hairline-strong); background: color-mix(in oklab, var(--color-navy) 8%, var(--color-cream)); overflow: hidden; }
.map-embed iframe { width: 100%; height: 100%; border: 0; }
.map-note { margin-top: 1rem; font-size: 13px; letter-spacing: .06em; color: var(--color-faint); text-align: right; }

.socials-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(3rem, 4vw, 4rem); align-items: center; }
.socials-intro .headline { font-size: 32px; margin-top: 1rem; }
.socials-lead { margin-top: 1.25rem; max-width: 29rem; }
.social-list { display: flex; flex-direction: column; }
.social-row { display: flex; justify-content: space-between; align-items: center; padding: 1.75rem 0; border-top: 1px solid var(--color-hairline-dark); color: var(--color-on-dark); transition: padding-left .3s, color .3s; }
.social-row:last-child { border-bottom: 1px solid var(--color-hairline-dark); }
.social-row:hover { padding-left: 1rem; color: var(--color-gold); }
.social-name { font-family: var(--font-display); font-size: 22px; }
.social-handle { font-size: 14px; letter-spacing: .04em; color: var(--color-on-dark-muted); }

/* ============================================================
   REVIEWS PAGE
   ============================================================ */
.reviews-stats { margin-top: 4rem; display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--color-hairline); border-bottom: 1px solid var(--color-hairline); }
.reviews-stat { display: flex; flex-direction: column; gap: .5rem; padding: 2.5rem 1.5rem; border-right: 1px solid var(--color-hairline); }
.reviews-stat:last-child { border-right: 0; }
.reviews-stat-num { font-family: var(--font-display); font-size: 44px; line-height: 1; letter-spacing: -0.03em; color: var(--color-heading); }
.reviews-stat-label { font-size: 12px; letter-spacing: .18em; text-transform: uppercase; font-weight: 600; color: var(--color-faint); margin-top: .5rem; }
.reviews-disclaimer-note { margin-top: 2rem; font-size: 12px; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; color: var(--color-faint); }

.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.75rem; }
.reviews-grid .review { width: auto; }
.reviews-grid .review--feature { grid-column: span 2; }
.review-text--feature { font-size: 23px; }
.reviews-disclaimer { margin-top: 4rem; padding: 2.5rem clamp(2rem, 3vw, 3rem); background: color-mix(in oklab, var(--color-navy) 4%, var(--color-cream)); border-left: 2px solid var(--color-gold); display: flex; align-items: center; }
.reviews-disclaimer p { color: var(--color-muted); font-size: 15px; line-height: 1.6; max-width: 720px; }

.bigtest-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(3rem, 5vw, 5rem); align-items: center; }
.bigtest-quote { font-family: var(--font-display); font-style: italic; font-size: clamp(1.875rem, 3.6vw, 3.25rem); line-height: 1.32; letter-spacing: -0.02em; color: var(--color-on-dark); margin-bottom: 3rem; }
.bigtest-name { font-weight: 600; color: var(--color-on-dark); font-size: var(--text-lead); }
.bigtest-role { font-size: 13px; letter-spacing: .06em; color: var(--color-on-dark-muted); margin-top: .25rem; }

/* ============================================================
   BLOG
   ============================================================ */
.blog-wrap { max-width: 48rem; margin-inline: auto; padding: 8rem var(--gutter) 6rem; }
.blog-head { margin-bottom: 4rem; }
.blog-eyebrow { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 1rem; }
.blog-title { font-family: var(--font-display); font-weight: 400; letter-spacing: -0.02em; font-size: clamp(2.5rem, 5vw, 4rem); color: var(--color-heading); }
.blog-empty { padding: 4rem 0; color: var(--color-body); }
.blog-years { display: flex; flex-direction: column; gap: 4rem; }
.blog-year-label { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-muted); margin-bottom: .5rem; }
.blog-list { border-top: 1px solid var(--color-hairline); }
.blog-entry { padding: 2.25rem 0; border-bottom: 1px solid var(--color-hairline); display: flex; flex-direction: column; }
.blog-date { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-muted); flex-shrink: 0; margin-bottom: .75rem; }
.blog-entry-title { font-family: var(--font-display); font-weight: 400; font-size: 1.125rem; line-height: 1.4; margin-bottom: .5rem; }
.blog-entry-link { color: var(--color-gold); text-decoration: underline; text-underline-offset: 2px; }
.blog-entry-desc { font-size: 14px; line-height: 1.6; color: var(--color-body); }

.post-wrap { max-width: 48rem; margin-inline: auto; padding: 8rem var(--gutter) 6rem; }
.post-head { margin-bottom: 3.5rem; }
.post-meta { display: flex; align-items: center; gap: .75rem; font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-gold); margin-bottom: 1.5rem; }
.post-title { font-family: var(--font-display); font-weight: 400; line-height: 1.15; letter-spacing: -0.02em; font-size: clamp(2rem, 5vw, 3.5rem); color: var(--color-heading); }
.post-footer { margin-top: 5rem; padding-top: 2rem; border-top: 1px solid var(--color-hairline); }
.post-back { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--color-gold); text-decoration: underline; text-underline-offset: 4px; }

/* ============================================================
   STATUS — private client-facing build-progress page (/status/, noindex)
   ============================================================ */
.status-page  { display: grid; place-items: center; padding: clamp(3rem, 8vw, 6rem) var(--gutter); }
.status-card  { width: 100%; max-width: 600px; background: var(--color-paper); border: 1px solid var(--color-hairline); padding: clamp(2rem, 5vw, 3.5rem); }
.status-eyebrow { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; font-weight: 600; color: var(--color-gold-deep); margin-bottom: .75rem; }
.status-title { font-size: clamp(1.6rem, 3vw, 2.2rem); line-height: 1.1; color: var(--color-heading); }
.status-sub   { color: var(--color-muted); margin-top: .75rem; margin-bottom: 2.75rem; }

.status-phases { position: relative; }
.status-phase  {
    position: relative;
    display: grid;
    grid-template-columns: 1.5rem 1fr auto;
    gap: .15rem 1.25rem;
    align-items: start;
    padding-bottom: 2rem;
}
.status-phase:last-child { padding-bottom: 0; }
/* connecting line from each marker to the next */
.status-phase:not(:last-child)::before {
    content: ""; position: absolute;
    left: .75rem; top: 1.85rem; bottom: -.15rem; width: 2px;
    transform: translateX(-1px);
    background: var(--color-hairline);
}
.status-phase.is-done:not(:last-child)::before { background: var(--color-gold); }

.status-phase-marker {
    grid-column: 1; grid-row: 1 / span 2;
    width: 1.5rem; height: 1.5rem; margin-top: 1px;
    border-radius: 999px; border: 2px solid var(--color-hairline-strong);
    background: var(--color-paper); position: relative; z-index: 1;
}
.is-done .status-phase-marker { background: var(--color-gold); border-color: var(--color-gold); }
.is-done .status-phase-marker::after {
    content: "✓"; position: absolute; inset: 0;
    display: grid; place-items: center;
    font-size: 12px; font-weight: 700; color: var(--color-navy);
}
.is-active .status-phase-marker {
    border-color: var(--color-gold);
    box-shadow: 0 0 0 4px color-mix(in oklab, var(--color-gold) 22%, transparent);
}
.is-active .status-phase-marker::after {
    content: ""; position: absolute; inset: 4px;
    border-radius: 999px; background: var(--color-gold);
}

.status-phase-label { grid-column: 2; grid-row: 1; font-weight: 600; color: var(--color-heading); }
.is-todo .status-phase-label { color: var(--color-muted); font-weight: 500; }
.status-phase-note  { grid-column: 2; grid-row: 2; font-size: .875rem; color: var(--color-muted); margin-top: .15rem; }
.status-phase-tag   {
    grid-column: 3; grid-row: 1 / span 2; align-self: center; white-space: nowrap;
    font-size: 11px; letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
    color: var(--color-navy); background: var(--color-gold);
    padding: .35rem .7rem; border-radius: 999px;
}

.status-foot { margin-top: 2.5rem; padding-top: 1.5rem; border-top: 1px solid var(--color-hairline); display: grid; gap: .6rem; }
.status-foot-row { display: flex; justify-content: space-between; font-size: .875rem; color: var(--color-muted); }
.status-foot-row strong { color: var(--color-heading); font-weight: 600; }

/* ============================================================
   RESPONSIVE — match prior Tailwind lg/md/sm breakpoints
   ============================================================ */
@media (max-width: 1024px) {
    .nav-toggle { display: inline-flex; }
    .nav-links { display: none; }
    .hero-grid,
    .why-grid, .office-grid, .about-intro-grid, .approach-top,
    .offer-intro-grid, .service-body-grid, .contact-intro-grid,
    .contact-map-grid, .socials-grid, .bigtest-grid { grid-template-columns: 1fr; }
    .hero-portrait { height: auto; aspect-ratio: 3 / 4; }
    .head-split { grid-template-columns: 1fr; align-items: start; }
    .principles { grid-template-columns: 1fr; }
    .principle:nth-child(even) { padding-left: 0; border-left: 0; }
    .principle:nth-child(odd) { padding-right: 0; }
    .service-head { grid-template-columns: 1fr; gap: 1rem; }
    .offer-index { grid-template-columns: repeat(3, 1fr); }
    .offer-index-link:nth-child(3n) { border-right: 0; }
    .reviews-grid { grid-template-columns: repeat(2, 1fr); }
    .reviews-grid .review--feature { grid-column: span 2; }
}
@media (max-width: 768px) {
    .stats, .process-list, .contact-methods { grid-template-columns: repeat(2, 1fr); }
    .stat:nth-child(2n), .step:nth-child(2n), .contact-method:nth-child(2n) { border-right: 0; }
    .area-grid, .expertise-grid, .triptych-grid { grid-template-columns: 1fr; }
    .area-card, .expertise-card { border-right: 0; }
    .triptych-fig:nth-child(2) { transform: none; }
    .reviews-track .review { width: 88%; }
    .offer-index { grid-template-columns: repeat(2, 1fr); }
    .offer-index-link:nth-child(2n) { border-right: 0; }
    .meta-grid, .audience-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .stats, .reviews-stats { grid-template-columns: 1fr; }
    .stat, .reviews-stat { border-right: 0; border-bottom: 1px solid var(--color-hairline); }
    .reviews-grid { grid-template-columns: 1fr; }
    .reviews-grid .review--feature { grid-column: span 1; }
    .footer-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .faq-answer { padding-right: 1rem; }
}
