/*
Theme Name: LeAndra Enterprises
Theme URI: https://leandraent.com
Author: SitePlot Media
Author URI: https://siteplotmedia.com
Description: Custom WordPress theme for LeAndra Enterprises — a boutique HR consultancy. Editorial, conversion-focused design with full Customizer integration, lead capture, and GDPR cookie consent.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: leandra-enterprises
*/

/* ===== DESIGN TOKENS ===== */
:root {
    /* Palette derived from LeAndra Enterprises logo:
       - Deep navy wordmark, bright blue icon gradient, silver flourish */
    --color-ink:        #183154;   /* deep navy from "LeAndra" wordmark */
    --color-ink-soft:   #2C476B;   /* secondary text */
    --color-ink-muted:  rgba(24, 49, 84, 0.7);
    --color-cream:      #FFFFFF;   /* white for buttons-on-dark and chips */
    --color-paper:      #FAFCFE;   /* page background — very light cool */
    --color-paper-2:    #E1EAF3;   /* deeper accent surface */
    --color-paper-light:#F0F5FA;   /* alt section background */
    --color-accent:     #2E86C7;   /* bright blue from logo icon */
    --color-accent-d:   #1F6BA8;   /* deeper blue — link/hover */
    --color-accent-light:#5BA3DD;  /* light blue accent */
    --color-silver:     #8B98A8;   /* cool grey — replaces brass */
    --color-line:       rgba(24, 49, 84, 0.12);
    --color-line-soft:  rgba(24, 49, 84, 0.07);
    --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
    --font-body:    'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --maxw: 1240px;
    --header-h: 76px;
    --radius: 4px;
    --shadow-card: 0 8px 24px -16px rgba(24, 49, 84, 0.2);
    --shadow-lg:   0 24px 60px -30px rgba(24, 49, 84, 0.35);
}

/* ===== RESET & BASE ===== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 16px; line-height: 1.6;
    color: var(--color-ink);
    background: var(--color-paper);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
img, svg { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: var(--color-accent); text-decoration: none; transition: color 150ms ease; }
a:hover { color: var(--color-accent-d); }
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    font-weight: 500; line-height: 1.2;
    color: var(--color-ink); margin: 0 0 0.6em 0;
}
p { margin: 0 0 1em 0; }

/* ===== LAYOUT UTILITIES ===== */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 1.5rem; }
.container--narrow { max-width: 820px; }
.section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.section--alt { background: var(--color-paper-light); }
.eyebrow {
    display: inline-block;
    font-family: var(--font-body);
    font-size: 0.75rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.14em;
    color: var(--color-accent);
    margin-bottom: 1.25rem;
}
.eyebrow::before { content: '— '; opacity: 0.6; }
.eyebrow--light { color: var(--color-silver); }
.section-header { text-align: center; max-width: 740px; margin: 0 auto 3rem; }
.section-title {
    font-size: clamp(2rem, 4vw, 2.75rem);
    line-height: 1.15; margin: 0 0 1rem 0;
}
.section-title em { color: var(--color-accent); font-style: italic; }
.section-intro {
    font-size: 1.0625rem; line-height: 1.65;
    color: var(--color-ink-muted); margin: 0;
}
.screen-reader-text {
    border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%);
    height: 1px; width: 1px; margin: -1px;
    overflow: hidden; padding: 0; position: absolute;
}
.skip-link {
    position: absolute; left: -9999px; top: 0;
    background: var(--color-ink); color: var(--color-cream);
    padding: 0.5rem 1rem; z-index: 9999;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* ===== BUTTONS ===== */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 0.55rem; padding: 0.85rem 1.5rem;
    font-family: var(--font-body); font-size: 0.9375rem;
    font-weight: 600; line-height: 1;
    border-radius: var(--radius); border: 1.5px solid transparent;
    text-decoration: none; cursor: pointer;
    transition: all 180ms ease; white-space: nowrap;
}
.btn svg { flex-shrink: 0; }
.btn--primary {
    background: var(--color-ink); color: var(--color-cream);
    border-color: var(--color-ink);
}
.btn--primary:hover {
    background: var(--color-accent); border-color: var(--color-accent);
    color: var(--color-cream); transform: translateY(-1px);
}
.btn--ghost {
    background: transparent; color: var(--color-ink);
    border-color: var(--color-ink);
}
.btn--ghost:hover { background: var(--color-ink); color: var(--color-cream); }
.btn--outline { background: transparent; color: currentColor; border-color: currentColor; }
.btn--phone {
    background: transparent; color: var(--color-ink);
    border-color: var(--color-ink);
}
.btn--phone:hover { background: var(--color-ink); color: var(--color-cream); }
.btn--lg { padding: 1rem 1.75rem; font-size: 1rem; }
.btn--sm { padding: 0.55rem 1rem; font-size: 0.8125rem; }
.btn--block { width: 100%; }

/* Phone button on DARK contexts: visible cream-on-dark */
.cta-strip .btn--phone,
.inline-cta .btn--phone {
    color: var(--color-cream);
    border-color: rgba(255, 255, 255, 0.45);
    background: transparent;
}
.cta-strip .btn--phone:hover,
.inline-cta .btn--phone:hover {
    background: var(--color-cream); color: var(--color-ink);
    border-color: var(--color-cream);
}

/* Service hero is light bg → keep ink colored phone (default works, but be explicit) */
.service-hero__ctas .btn--phone {
    color: var(--color-ink); border-color: var(--color-ink);
    background: transparent;
}
.service-hero__ctas .btn--phone:hover {
    background: var(--color-ink); color: var(--color-cream);
}

/* ===== SITE HEADER ===== */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: rgba(255, 255, 255, 0.94);
    backdrop-filter: saturate(160%) blur(12px);
    -webkit-backdrop-filter: saturate(160%) blur(12px);
    border-bottom: 1px solid var(--color-line-soft);
    transition: box-shadow 200ms ease;
}
.site-header.is-scrolled { box-shadow: 0 1px 0 var(--color-line-soft); }
.header-inner {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1.5rem; padding: 0.85rem 1.5rem;
    max-width: var(--maxw); margin: 0 auto;
    min-height: var(--header-h);
}

/* Brand */
.brand {
    display: inline-flex; align-items: center; gap: 0.7rem;
    text-decoration: none; color: var(--color-ink); flex-shrink: 0;
}
.brand__mark {
    display: inline-flex; align-items: center; justify-content: center;
    height: 50px; width: auto; flex-shrink: 0;
    line-height: 0;
}
.brand__mark img {
    height: 100%; width: auto; display: block;
}
.brand__text { display: flex; flex-direction: column; line-height: 1.15; }
.brand__name {
    font-family: var(--font-display); font-weight: 500;
    font-size: 1.1875rem; color: var(--color-ink);
    letter-spacing: -0.005em;
}
.brand__tagline {
    font-size: 0.6875rem; text-transform: uppercase;
    letter-spacing: 0.12em; color: var(--color-ink-muted);
    margin-top: 2px;
}
.brand--footer .brand__name { color: var(--color-cream); }
.brand--footer .brand__tagline { color: rgba(255, 255, 255, 0.6); }

/* Primary nav — base / desktop */
.primary-nav { display: flex; align-items: center; gap: 2rem; }
.primary-nav ul {
    list-style: none; margin: 0; padding: 0;
    display: flex; align-items: center; gap: 1.75rem;
}
.primary-nav ul a {
    color: var(--color-ink); text-decoration: none;
    font-size: 0.9375rem; font-weight: 500;
    padding: 0.4rem 0; border-bottom: 1.5px solid transparent;
    transition: color 150ms ease, border-color 150ms ease;
}
.primary-nav ul a:hover,
.primary-nav ul .current-menu-item > a,
.primary-nav ul .current_page_item > a {
    color: var(--color-accent); border-bottom-color: var(--color-accent);
}

/* On desktop: show the desktop nav, completely hide the mobile slide-out panel */
.primary-nav--mobile { display: none; }

.header-phone {
    display: inline-flex; align-items: center; gap: 0.45rem;
    color: var(--color-ink); font-size: 0.875rem; font-weight: 500;
    text-decoration: none; padding: 0.4rem 0;
}
.header-phone:hover { color: var(--color-accent); }
.header-phone svg { color: var(--color-accent); }
.header-cta { padding: 0.6rem 1.2rem !important; font-size: 0.875rem; }

/* Mobile nav toggle */
.nav-toggle {
    display: none; flex-direction: column; justify-content: center; align-items: center;
    gap: 5px; width: 44px; height: 44px;
    background: transparent; border: 1px solid var(--color-line);
    border-radius: var(--radius); padding: 0; margin-left: auto;
}
.nav-toggle__bar {
    display: block; width: 20px; height: 1.5px;
    background: var(--color-ink);
    transition: transform 200ms ease, opacity 200ms ease;
}
.nav-toggle.is-active .nav-toggle__bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle.is-active .nav-toggle__bar:nth-child(2) { opacity: 0; }
.nav-toggle.is-active .nav-toggle__bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.site-main { min-height: 60vh; }

/* ===== HERO (Homepage) ===== */
.hero {
    position: relative;
    padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(3rem, 6vw, 5rem);
    overflow: hidden;
}
.hero__deco { position: absolute; inset: 0; color: var(--color-accent); pointer-events: none; z-index: 0; }
.hero__deco svg { width: 100%; height: 100%; }
.hero__inner {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    gap: clamp(2rem, 5vw, 5rem);
    align-items: center;
    position: relative; z-index: 1;
}
.hero__content { min-width: 0; }
.hero__title {
    font-size: clamp(2.25rem, 4.8vw, 3.75rem);
    line-height: 1.08; margin: 0 0 1.25rem 0;
    letter-spacing: -0.01em;
}
.hero__title em { color: var(--color-accent); font-style: italic; }
.hero__subtitle {
    font-size: 1.0625rem; line-height: 1.65;
    color: var(--color-ink-muted);
    max-width: 580px; margin: 0 0 1.75rem 0;
}
.hero__ctas { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 2.25rem; }
.hero__credentials {
    display: flex; flex-wrap: wrap; gap: 2.5rem;
    padding-top: 1.75rem;
    border-top: 1px solid var(--color-line-soft);
}
.cred { display: flex; flex-direction: column; }
.cred__num {
    font-family: var(--font-display); font-size: 1.875rem;
    line-height: 1; color: var(--color-accent); font-weight: 500;
}
.cred__label {
    font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--color-ink-muted); margin-top: 0.5rem;
    max-width: 160px; line-height: 1.4; white-space: pre-line;
}

.hero__visual { position: relative; }
.hero__image { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-lg); }
.hero__visual-card {
    position: relative; background: var(--color-paper-light);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius); padding: 2.5rem 2.25rem;
    box-shadow: var(--shadow-lg);
}
.hero__visual-corner { position: absolute; width: 36px; height: 36px; color: var(--color-accent); }
.hero__visual-corner--tl { top: -1px; left: -1px; }
.hero__visual-corner--br { bottom: -1px; right: -1px; }
.hero__visual-corner svg { width: 100%; height: 100%; }
.hero__visual-mark {
    display: block; font-family: var(--font-display);
    font-size: 3.5rem; line-height: 0.5;
    color: var(--color-accent); margin-bottom: 0;
}
.hero__visual-quote p {
    font-family: var(--font-display);
    font-size: 1.1875rem; line-height: 1.5;
    color: var(--color-ink); margin: 0 0 1.5rem 0;
}
.hero__visual-quote cite {
    display: flex; flex-direction: column;
    font-style: normal; padding-top: 1.25rem;
    border-top: 1px solid var(--color-line);
}
.hero__visual-quote cite span { font-weight: 600; font-size: 0.9375rem; color: var(--color-ink); }
.hero__visual-quote cite small { font-size: 0.8125rem; color: var(--color-ink-muted); margin-top: 2px; }
.hero__visual-stats {
    display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
    margin-top: 1.75rem; padding-top: 1.5rem;
    border-top: 1px solid var(--color-line);
}
.hero__visual-stats strong {
    display: block; font-family: var(--font-display);
    font-size: 1.5rem; color: var(--color-accent);
    line-height: 1; margin-bottom: 0.35rem;
}
.hero__visual-stats span {
    font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--color-ink-muted); line-height: 1.4;
}

/* ===== SERVICES GRID ===== */
.services-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
.service-card {
    background: var(--color-paper-light);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius);
    padding: 2rem 1.75rem;
    text-decoration: none; color: var(--color-ink);
    display: flex; flex-direction: column;
    transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}
.service-card:hover {
    transform: translateY(-4px); border-color: var(--color-accent);
    box-shadow: var(--shadow-card);
}
.service-card__num {
    font-family: var(--font-display); font-size: 1rem;
    color: var(--color-accent); letter-spacing: 0.05em;
    margin-bottom: 0.75rem;
}
.service-card__icon { color: var(--color-accent); margin-bottom: 1rem; display: inline-flex; }
.service-card__title {
    font-family: var(--font-display); font-size: 1.375rem;
    line-height: 1.2; margin: 0 0 0.75rem 0;
}
.service-card__desc {
    font-size: 0.9375rem; line-height: 1.6;
    color: var(--color-ink-muted);
    margin: 0 0 1.25rem 0; flex: 1;
}
.service-card__cta {
    display: inline-flex; align-items: center; gap: 0.45rem;
    font-size: 0.8125rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--color-accent);
}
.service-card__cta svg { transition: transform 180ms ease; }
.service-card:hover .service-card__cta svg { transform: translateX(3px); }

/* ===== PROCESS / APPROACH ===== */
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.75rem; }
.process-step {
    background: var(--color-paper);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius);
    padding: 1.75rem;
    transition: transform 200ms ease;
}
.process-step:hover { transform: translateY(-3px); }
.process-step__num {
    display: inline-block; font-family: var(--font-display);
    font-size: 1.125rem; color: var(--color-accent);
    letter-spacing: 0.05em; margin-bottom: 0.75rem;
}
.process-step__title { font-family: var(--font-display); font-size: 1.25rem; line-height: 1.25; margin: 0 0 0.6rem; }
.process-step__text { font-size: 0.9375rem; line-height: 1.6; color: var(--color-ink-muted); margin: 0; }

/* ===== CTA STRIP ===== */
.cta-strip {
    background: var(--color-ink); color: var(--color-cream);
    padding: clamp(3rem, 6vw, 5rem) 0;
}
.cta-strip__inner {
    display: flex; align-items: center; justify-content: space-between;
    gap: 3rem;
}
.cta-strip__content { max-width: 620px; }
.cta-strip .eyebrow { color: var(--color-silver); }
.cta-strip__title {
    font-size: clamp(1.625rem, 3vw, 2.25rem); line-height: 1.2;
    color: var(--color-cream); margin: 0 0 1rem 0;
}
.cta-strip__text {
    color: rgba(255, 255, 255, 0.82);
    font-size: 1rem; line-height: 1.65; margin: 0;
}
.cta-strip__actions { display: flex; flex-direction: column; gap: 0.75rem; flex-shrink: 0; }
.cta-strip .btn--primary {
    background: var(--color-cream); color: var(--color-ink); border-color: var(--color-cream);
}
.cta-strip .btn--primary:hover {
    background: var(--color-silver); color: var(--color-ink); border-color: var(--color-silver);
}

/* ===== PAGE BANNER ===== */
.page-banner {
    padding: clamp(3rem, 6vw, 4.5rem) 0 clamp(1.5rem, 3vw, 2.5rem);
    background: var(--color-paper-light);
    border-bottom: 1px solid var(--color-line-soft);
    text-align: center;
}
.page-banner__title {
    font-size: clamp(2rem, 4.5vw, 3rem); line-height: 1.15;
    margin: 0 auto 0.75rem; max-width: 880px;
}
.page-banner__title em { color: var(--color-accent); font-style: italic; }
.page-banner__intro {
    font-size: 1.0625rem; line-height: 1.65;
    color: var(--color-ink-muted);
    max-width: 720px; margin: 1rem auto 0;
}
.page-banner__date {
    font-size: 0.8125rem; text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--color-ink-muted); margin-top: 0.75rem;
}
.page-banner--legal { text-align: left; padding-bottom: 1.5rem; }
.page-banner--legal .page-banner__title { margin-left: 0; max-width: none; }

/* ===== BIO SECTION ===== */
.bio-section { background: var(--color-paper); }
.bio-grid { display: grid; grid-template-columns: 380px 1fr; gap: 4rem; align-items: start; }
.bio-image { position: relative; padding: 1rem; }
.bio-image__frame {
    position: relative; overflow: hidden;
    border-radius: var(--radius); aspect-ratio: 4 / 5;
    background: var(--color-paper-light);
    box-shadow: var(--shadow-lg);
}
.bio-image__frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bio-image__corner { position: absolute; width: 50px; height: 50px; color: var(--color-accent); }
.bio-image__corner svg { width: 100%; height: 100%; }
.bio-image__corner--tl { top: 0; left: 0; }
.bio-image__corner--br { bottom: 0; right: 0; }
.bio-content { min-width: 0; }
.bio-content__name { font-size: clamp(1.875rem, 3.5vw, 2.5rem); line-height: 1.1; margin: 0.75rem 0 0.25rem; }
.bio-content__headline {
    font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--color-accent); margin: 0 0 1.5rem 0;
    font-weight: 600; font-family: var(--font-body);
}
.bio-content__body p { font-size: 1.0625rem; line-height: 1.7; color: var(--color-ink-soft); margin: 0 0 1.25rem 0; }
.bio-content__quote {
    background: var(--color-paper-light);
    border-left: 3px solid var(--color-accent);
    padding: 1.5rem 1.75rem 1.5rem 2.25rem;
    margin: 2rem 0; position: relative;
}
.bio-content__quote-mark {
    position: absolute; top: 0.5rem; left: 0.75rem;
    font-family: var(--font-display); font-size: 2.75rem; line-height: 1;
    color: var(--color-accent); opacity: 0.3;
}
.bio-content__quote p {
    font-family: var(--font-display);
    font-size: 1.125rem; line-height: 1.5; font-style: italic;
    color: var(--color-ink); margin: 0;
}
.bio-content__credentials {
    list-style: none; padding: 0; margin: 2rem 0 0 0;
    display: grid; grid-template-columns: 1fr; gap: 0.8rem;
}
.bio-content__credentials li {
    display: flex; align-items: flex-start; gap: 0.65rem;
    font-size: 0.9375rem; color: var(--color-ink); line-height: 1.45;
}
.bio-content__credentials li svg { color: var(--color-accent); flex-shrink: 0; margin-top: 2px; }

/* ===== VALUES ===== */
.values-section { background: var(--color-paper-light); }
.values-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; margin-top: 3rem; }
.value-card {
    background: var(--color-paper);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius);
    padding: 2rem;
    transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}
.value-card:hover {
    transform: translateY(-3px); border-color: var(--color-accent);
    box-shadow: var(--shadow-card);
}
.value-card__num { font-family: var(--font-display); font-size: 1.125rem; color: var(--color-accent); margin-bottom: 0.5rem; display: inline-block; }
.value-card__title { font-family: var(--font-display); font-size: 1.375rem; line-height: 1.2; margin: 0 0 0.75rem; }
.value-card__text { font-size: 0.9375rem; line-height: 1.65; color: var(--color-ink-muted); margin: 0; }

/* ===== TESTIMONIALS ===== */
.testimonials-section { background: var(--color-paper); }
.testimonials-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.75rem; margin-top: 3rem; }
.testimonial {
    position: relative; background: var(--color-paper-light);
    border: 1px solid var(--color-line-soft); border-radius: var(--radius);
    padding: 2.5rem 2.25rem 2rem; margin: 0;
    transition: transform 200ms ease, border-color 200ms ease;
}
.testimonial:hover { transform: translateY(-3px); border-color: var(--color-accent); }
.testimonial__mark {
    position: absolute; top: 0.5rem; left: 1.25rem;
    font-family: var(--font-display); font-size: 4rem; line-height: 1;
    color: var(--color-accent); opacity: 0.28;
}
.testimonial__quote { margin: 0 0 1.5rem; padding: 0; border: 0; }
.testimonial__quote p {
    font-family: var(--font-display);
    font-size: 1.0625rem; line-height: 1.6; font-style: italic;
    color: var(--color-ink); margin: 0;
}
.testimonial__cite {
    display: flex; flex-direction: column; gap: 0.2rem;
    padding-top: 1.25rem; border-top: 1px solid var(--color-line);
}
.testimonial__name { font-family: var(--font-display); font-size: 1rem; color: var(--color-ink); font-weight: 500; }
.testimonial__title { font-size: 0.8125rem; color: var(--color-ink-muted); line-height: 1.45; }
.testimonial__context {
    font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em;
    color: var(--color-accent); margin-top: 0.35rem; font-weight: 600;
}

/* ===== SERVICES HUB ===== */
.services-hub { display: flex; flex-direction: column; gap: 4.5rem; }
.services-hub__row {
    display: grid; grid-template-columns: 1fr 1.5fr;
    gap: 3rem; align-items: center;
}
.services-hub__row--reverse .services-hub__visual { order: 2; }
.services-hub__visual {
    position: relative; padding: 3rem 2rem;
    background: var(--color-paper-light);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius); text-align: center;
    aspect-ratio: 1;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
}
.services-hub__num {
    position: absolute; top: 1.5rem; left: 1.75rem;
    font-family: var(--font-display); font-size: 1.125rem;
    color: var(--color-accent); letter-spacing: 0.05em;
}
.services-hub__icon { color: var(--color-accent); }
.services-hub__title { font-size: clamp(1.75rem, 3vw, 2.25rem); line-height: 1.15; margin: 0.5rem 0 1rem; }
.services-hub__lead { font-size: 1.0625rem; line-height: 1.65; color: var(--color-ink-muted); margin: 0 0 1.5rem; }

/* ===== SERVICE DETAIL ===== */
.service-hero {
    background: var(--color-paper-light);
    padding: clamp(2.5rem, 5vw, 4rem) 0;
    border-bottom: 1px solid var(--color-line-soft);
}
.service-hero__grid {
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 3rem; align-items: center;
}
.service-hero__content { min-width: 0; }
.service-hero__title { font-size: clamp(2rem, 4vw, 2.75rem); line-height: 1.15; margin: 0 0 1rem; }
.service-hero__lead { font-size: 1.125rem; line-height: 1.6; color: var(--color-ink-soft); margin: 0 0 1.5rem; }
.service-hero__meta {
    display: flex; gap: 2rem; margin: 1.5rem 0;
    padding: 1.5rem 0;
    border-top: 1px solid var(--color-line);
    border-bottom: 1px solid var(--color-line);
    flex-wrap: wrap;
}
.meta-item { display: flex; flex-direction: column; gap: 0.25rem; }
.meta-item__label {
    font-size: 0.6875rem; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--color-ink-muted); font-weight: 600;
}
.meta-item__value { font-family: var(--font-display); font-size: 1rem; color: var(--color-ink); font-weight: 500; }
.service-hero__ctas { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.service-hero__visual { display: flex; align-items: center; justify-content: center; }
.service-hero__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 200px; height: 200px;
    background: var(--color-paper);
    border: 1px solid var(--color-line-soft);
    border-radius: 50%; color: var(--color-accent);
    box-shadow: var(--shadow-card);
}

.service-body-section { padding: clamp(3rem, 6vw, 5rem) 0; }
.service-body-grid {
    display: grid; grid-template-columns: 1fr 380px;
    gap: 4rem; align-items: start;
}
.service-body { min-width: 0; }

/* Prose */
.prose { color: var(--color-ink-soft); font-size: 1.0625rem; line-height: 1.75; }
.prose p { margin: 0 0 1.25rem 0; }
.prose h2 { font-size: 1.625rem; margin: 2.25rem 0 1rem; color: var(--color-ink); }
.prose h3 { font-size: 1.25rem; margin: 1.75rem 0 0.75rem; color: var(--color-ink); }
.prose ul, .prose ol { margin: 0 0 1.25rem; padding-left: 1.5rem; }
.prose li { margin-bottom: 0.5rem; }
.prose a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 2px; }
.prose strong { color: var(--color-ink); font-weight: 600; }

/* Deliverables */
.deliverables {
    margin-top: 3rem; padding: 2rem 2.25rem;
    background: var(--color-paper-light);
    border-left: 3px solid var(--color-accent);
    border-radius: 0 var(--radius) var(--radius) 0;
}
.deliverables__title { font-family: var(--font-display); font-size: 1.375rem; margin: 0 0 1.25rem; }
.deliverables__list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: 0.75rem; }
.deliverables__list li { display: flex; align-items: flex-start; gap: 0.65rem; font-size: 0.9375rem; line-height: 1.5; }
.deliverables__list li svg { color: var(--color-accent); flex-shrink: 0; margin-top: 2px; }

/* FAQ */
.faq { margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid var(--color-line); }
.faq__title { font-size: 1.625rem; margin: 0 0 1.5rem; }
.faq__list { display: flex; flex-direction: column; gap: 0.5rem; }
.faq__item {
    border: 1px solid var(--color-line-soft); border-radius: var(--radius);
    background: var(--color-paper-light); overflow: hidden;
    transition: border-color 200ms ease;
}
.faq__item[open] { border-color: var(--color-accent); }
.faq__q {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem; padding: 1.1rem 1.5rem; cursor: pointer;
    font-family: var(--font-display); font-size: 1.0625rem;
    color: var(--color-ink); font-weight: 500;
    list-style: none; user-select: none;
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q:hover { background: rgba(46, 134, 199, 0.04); }
.faq__icon { display: inline-flex; color: var(--color-accent); transition: transform 200ms ease; flex-shrink: 0; }
.faq__item[open] .faq__icon { transform: rotate(180deg); }
.faq__a { padding: 0 1.5rem 1.25rem; }
.faq__a p { color: var(--color-ink-muted); margin: 0; line-height: 1.65; font-size: 0.9375rem; }

/* Sidebar inline CTA */
.service-sidebar { position: sticky; top: calc(var(--header-h) + 1.5rem); }
.inline-cta {
    background: var(--color-ink); color: var(--color-cream);
    padding: 2rem; border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
}
.inline-cta__title { font-family: var(--font-display); font-size: 1.375rem; color: var(--color-cream); margin: 0 0 0.5rem; }
.inline-cta__intro { font-size: 0.9375rem; line-height: 1.55; color: rgba(255, 255, 255, 0.78); margin: 0 0 1.5rem; }
.inline-cta__divider {
    display: flex; align-items: center; margin: 1.25rem 0;
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.15em; font-weight: 600;
}
.inline-cta__divider::before,
.inline-cta__divider::after {
    content: ''; flex: 1; height: 1px;
    background: rgba(255, 255, 255, 0.18);
}
.inline-cta__divider span { padding: 0 0.65rem; }

/* ===== CONTACT PAGE ===== */
.contact-section { padding: clamp(3rem, 5vw, 4.5rem) 0; }
.contact-grid {
    display: grid; grid-template-columns: 360px 1fr;
    gap: 3.5rem; align-items: start;
}
.contact-info { display: flex; flex-direction: column; gap: 1.25rem; }
.contact-card {
    background: var(--color-paper-light);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius); padding: 1.5rem;
    transition: border-color 200ms ease;
}
.contact-card:hover { border-color: var(--color-accent); }
.contact-card__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 42px; height: 42px;
    background: var(--color-ink); color: var(--color-cream);
    border-radius: 50%; margin-bottom: 0.9rem;
}
.contact-card__title { font-family: var(--font-display); font-size: 1.0625rem; margin: 0 0 0.35rem; color: var(--color-ink); }
.contact-card__detail { font-size: 0.9375rem; color: var(--color-ink); margin: 0 0 0.4rem; line-height: 1.45; white-space: pre-line; }
.contact-card__detail a { color: inherit; text-decoration: none; }
.contact-card__detail a:hover { color: var(--color-accent); }
.contact-card__note { font-size: 0.8125rem; color: var(--color-ink-muted); margin: 0; line-height: 1.5; }

.contact-form-wrap {
    background: var(--color-paper);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius); padding: 2.5rem;
    box-shadow: var(--shadow-card);
}
.contact-form__title { font-family: var(--font-display); font-size: 1.625rem; margin: 0 0 0.5rem; color: var(--color-ink); }
.contact-form__intro { color: var(--color-ink-muted); margin: 0 0 1.75rem; line-height: 1.6; font-size: 0.9375rem; }

/* ===== FORMS ===== */
.leandra-form { display: flex; flex-direction: column; gap: 1rem; }
.leandra-form .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.leandra-form .field { display: flex; flex-direction: column; gap: 0.35rem; }
.leandra-form label {
    font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--color-ink-muted); font-weight: 600;
}
.leandra-form .req { color: var(--color-accent); }
.leandra-form input,
.leandra-form select,
.leandra-form textarea {
    font-family: var(--font-body);
    font-size: 0.9375rem; padding: 0.7rem 0.85rem;
    background: var(--color-paper);
    border: 1px solid var(--color-line);
    border-radius: var(--radius); color: var(--color-ink);
    transition: border-color 150ms ease, background 150ms ease;
}
.leandra-form input:focus,
.leandra-form select:focus,
.leandra-form textarea:focus {
    outline: none; border-color: var(--color-accent);
    background: var(--color-paper-light);
}
.leandra-form textarea { resize: vertical; min-height: 110px; }
.leandra-form .field--consent { flex-direction: row; align-items: flex-start; gap: 0.6rem; }
.leandra-form .field--consent label {
    font-size: 0.8125rem; text-transform: none; letter-spacing: normal;
    font-weight: 400; color: var(--color-ink-muted); line-height: 1.5;
}

/* Form inside dark inline-cta */
.inline-cta .leandra-form label { color: rgba(255, 255, 255, 0.78); }
.inline-cta .leandra-form input,
.inline-cta .leandra-form select,
.inline-cta .leandra-form textarea {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--color-cream);
}
.inline-cta .leandra-form input::placeholder,
.inline-cta .leandra-form textarea::placeholder { color: rgba(255, 255, 255, 0.4); }
.inline-cta .leandra-form input:focus,
.inline-cta .leandra-form select:focus,
.inline-cta .leandra-form textarea:focus {
    border-color: var(--color-silver);
    background: rgba(255, 255, 255, 0.1);
}
.inline-cta .leandra-form select option { color: var(--color-ink); }
.inline-cta .leandra-form .field--consent label { color: rgba(255, 255, 255, 0.7); }
.inline-cta button[type="submit"] {
    background: var(--color-cream); color: var(--color-ink); border-color: var(--color-cream);
}
.inline-cta button[type="submit"]:hover { background: var(--color-silver); }

.form-message {
    padding: 0.85rem 1rem; border-radius: var(--radius);
    font-size: 0.9375rem; line-height: 1.5;
}
.form-message--success {
    background: rgba(34, 139, 34, 0.1); color: #1e5e1e;
    border: 1px solid rgba(34, 139, 34, 0.3);
}
.form-message--error {
    background: rgba(46, 134, 199, 0.1); color: var(--color-accent);
    border: 1px solid rgba(46, 134, 199, 0.3);
}
.spinner {
    display: inline-block; width: 14px; height: 14px;
    border: 2px solid currentColor; border-right-color: transparent;
    border-radius: 50%; animation: spin 700ms linear infinite;
    vertical-align: -3px; margin-right: 0.4rem;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ===== SITE FOOTER ===== */
.site-footer {
    background: var(--color-ink);
    color: rgba(255, 255, 255, 0.78);
    padding: 4rem 0 1.5rem;
}
.footer-grid {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr 1.2fr;
    gap: 3rem; padding-bottom: 3rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}
.footer-col { min-width: 0; }
.footer-col--brand .brand { margin-bottom: 1.25rem; }
.footer-tagline {
    font-size: 0.9375rem; line-height: 1.6;
    color: rgba(255, 255, 255, 0.7);
    margin: 0 0 1.25rem 0; max-width: 340px;
}
.footer-social { display: flex; gap: 0.75rem; }
.footer-social a {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    background: rgba(255, 255, 255, 0.08);
    color: var(--color-cream); border-radius: 50%;
    transition: background 180ms ease, transform 180ms ease;
}
.footer-social a:hover { background: var(--color-accent); transform: translateY(-2px); }
.footer-heading {
    font-family: var(--font-display);
    font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.12em;
    color: var(--color-cream); margin: 0 0 1.25rem; font-weight: 600;
}
.footer-menu { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.65rem; }
.footer-menu a {
    color: rgba(255, 255, 255, 0.75);
    font-size: 0.9375rem; text-decoration: none;
    transition: color 150ms ease;
}
.footer-menu a:hover { color: var(--color-cream); }
.footer-contact { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.8rem; }
.footer-contact li {
    display: flex; align-items: flex-start; gap: 0.6rem;
    font-size: 0.9375rem; line-height: 1.5;
    color: rgba(255, 255, 255, 0.75);
}
.footer-contact li svg { color: var(--color-silver); flex-shrink: 0; margin-top: 3px; }
.footer-contact a { color: inherit; text-decoration: none; }
.footer-contact a:hover { color: var(--color-cream); }
.footer-bottom {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1.5rem; padding-top: 1.5rem; flex-wrap: wrap;
}
.copyright { font-size: 0.8125rem; color: rgba(255, 255, 255, 0.6); margin: 0; }
.footer-legal { list-style: none; margin: 0; padding: 0; display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer-legal a { color: rgba(255, 255, 255, 0.6); font-size: 0.8125rem; text-decoration: none; }
.footer-legal a:hover { color: var(--color-cream); }

/* ===== POLICY PAGES ===== */
.policy-page { background: var(--color-paper); }
.policy-content { padding: 2rem 0 3rem; }
.policy-content h2 {
    font-size: 1.5rem; margin: 2.5rem 0 1rem;
    padding-top: 1rem; border-top: 1px solid var(--color-line-soft);
    color: var(--color-ink);
}
.policy-content h2:first-child { border-top: 0; margin-top: 0; padding-top: 0; }
.policy-content h3 { font-size: 1.125rem; margin: 1.5rem 0 0.5rem; }
.policy-content ul, .policy-content ol { padding-left: 1.5rem; }
.policy-content li { margin-bottom: 0.5rem; }
.policy-content a { color: var(--color-accent); text-decoration: underline; }
.policy-footer {
    margin-top: 3rem; padding-top: 2rem;
    border-top: 1px solid var(--color-line);
    font-size: 0.9375rem; color: var(--color-ink-muted);
}

/* ===== 404 ===== */
.error-404 { text-align: center; padding: 5rem 0 4rem; }
.error-404__inner { max-width: 600px; margin: 0 auto; }
.error-404__code {
    display: block; font-family: var(--font-display);
    font-size: clamp(5rem, 12vw, 8rem);
    color: var(--color-accent); line-height: 1;
    margin-bottom: 1rem; opacity: 0.85;
}
.error-404__title { font-size: clamp(1.625rem, 4vw, 2.5rem); margin: 0 0 1rem; }
.error-404__text { color: var(--color-ink-muted); margin: 0 0 2rem; line-height: 1.6; }
.error-404__actions { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }

/* ===== COOKIE BANNER ===== */
.cookie-banner {
    position: fixed; bottom: 1.5rem; left: 1.5rem; right: 1.5rem;
    max-width: 1100px; margin: 0 auto;
    background: var(--color-ink); color: var(--color-cream);
    border-radius: 6px;
    box-shadow: 0 30px 80px -20px rgba(0,0,0,0.5);
    z-index: 9000;
    opacity: 0; transform: translateY(20px);
    transition: opacity 280ms ease, transform 280ms ease;
}
.cookie-banner.is-visible { opacity: 1; transform: translateY(0); }
.cookie-banner__inner {
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 2rem; padding: 1.5rem 1.75rem; align-items: center;
}
.cookie-banner__title { font-family: var(--font-display); font-size: 1.0625rem; margin: 0 0 0.35rem; color: var(--color-cream); }
.cookie-banner__message { font-size: 0.875rem; line-height: 1.55; color: rgba(255, 255, 255, 0.82); margin: 0; }
.cookie-banner__link { color: var(--color-silver); text-decoration: underline; text-underline-offset: 2px; margin-left: 0.35rem; }
.cookie-banner__actions { display: flex; gap: 0.5rem; flex-wrap: wrap; justify-content: flex-end; }
.cookie-banner .btn--primary {
    background: var(--color-cream); color: var(--color-ink); border-color: var(--color-cream);
}
.cookie-banner .btn--primary:hover { background: var(--color-silver); }
.cookie-banner .btn--ghost,
.cookie-banner .btn--outline {
    color: var(--color-cream); border-color: rgba(255, 255, 255, 0.3);
}
.cookie-banner .btn--ghost:hover,
.cookie-banner .btn--outline:hover { background: rgba(255, 255, 255, 0.08); }

/* Cookie preferences modal */
.cookie-prefs {
    position: fixed; inset: 0; z-index: 9100;
    display: flex; align-items: center; justify-content: center;
    padding: 1.5rem;
    opacity: 0; transition: opacity 280ms ease; pointer-events: none;
}
.cookie-prefs.is-visible { opacity: 1; pointer-events: auto; }
.cookie-prefs__overlay {
    position: absolute; inset: 0;
    background: rgba(24, 49, 84, 0.65);
    backdrop-filter: blur(4px);
}
.cookie-prefs__panel {
    position: relative; background: var(--color-paper);
    border-radius: 6px; max-width: 640px; width: 100%;
    max-height: 88vh; display: flex; flex-direction: column;
    box-shadow: 0 30px 80px -20px rgba(0,0,0,0.45);
    transform: translateY(20px); transition: transform 280ms ease;
}
.cookie-prefs.is-visible .cookie-prefs__panel { transform: translateY(0); }
.cookie-prefs__header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.5rem 1.75rem;
    border-bottom: 1px solid var(--color-line-soft);
}
.cookie-prefs__header h2 { font-size: 1.375rem; margin: 0; }
.cookie-prefs__close {
    background: transparent; border: 0; color: var(--color-ink);
    padding: 0.5rem; border-radius: var(--radius);
    display: flex; align-items: center;
}
.cookie-prefs__close:hover { background: var(--color-line-soft); }
.cookie-prefs__body { padding: 1.5rem 1.75rem; overflow-y: auto; flex: 1; }
.cookie-prefs__intro { font-size: 0.9375rem; color: var(--color-ink-muted); line-height: 1.6; margin: 0 0 1.5rem; }
.cookie-prefs__footer {
    display: flex; gap: 0.6rem; justify-content: flex-end;
    padding: 1.25rem 1.75rem;
    border-top: 1px solid var(--color-line-soft);
    background: var(--color-paper-light);
    border-radius: 0 0 6px 6px; flex-wrap: wrap;
}
.cookie-cat { padding: 1.25rem 0; border-bottom: 1px solid var(--color-line-soft); }
.cookie-cat:last-child { border-bottom: 0; }
.cookie-cat__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.cookie-cat__title { font-family: var(--font-display); font-size: 1.0625rem; margin: 0; color: var(--color-ink); }
.cookie-cat__desc { font-size: 0.875rem; line-height: 1.55; color: var(--color-ink-muted); margin: 0.5rem 0 0; }
.cookie-cat__note { font-size: 0.75rem; color: var(--color-accent); margin: 0.4rem 0 0; font-weight: 600; }

/* Toggle */
.toggle {
    position: relative; display: inline-block;
    width: 44px; height: 24px; flex-shrink: 0;
}
.toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle__slider {
    position: absolute; inset: 0;
    background: var(--color-line); border-radius: 24px; cursor: pointer;
    transition: background 200ms ease;
}
.toggle__slider::before {
    content: ''; position: absolute;
    height: 18px; width: 18px; left: 3px; bottom: 3px;
    background: #fff; border-radius: 50%;
    transition: transform 200ms ease;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.toggle input:checked + .toggle__slider { background: var(--color-accent); }
.toggle input:checked + .toggle__slider::before { transform: translateX(20px); }
.toggle input:disabled + .toggle__slider { opacity: 0.55; cursor: not-allowed; }

.cookie-reopen {
    position: fixed; bottom: 1.25rem; left: 1.25rem;
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--color-ink); color: var(--color-cream); border: 0;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 8px 20px -8px rgba(24, 49, 84,0.5);
    z-index: 8000;
    transition: transform 180ms ease, background 180ms ease;
}
.cookie-reopen:hover { background: var(--color-accent); transform: translateY(-2px); }

body.nav-open,
body.cookie-prefs-open { overflow: hidden; }

/* ===== ANIMATIONS ===== */
.reveal {
    opacity: 0; transform: translateY(20px);
    transition: opacity 600ms ease, transform 600ms ease;
}
.reveal.is-in,
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1024px) {
    .hero__inner,
    .services-hub__row,
    .bio-grid,
    .contact-grid,
    .service-body-grid,
    .service-hero__grid {
        grid-template-columns: 1fr; gap: 2.5rem;
    }
    .services-hub__row--reverse .services-hub__visual { order: 0; }
    .service-sidebar { position: static; }
    .services-grid { grid-template-columns: repeat(2, 1fr); }
    .process-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; }
    .footer-col--brand {
        grid-column: 1 / -1; max-width: 540px;
        padding-bottom: 1.5rem; border-bottom: 1px solid rgba(255, 255, 255,0.08);
        margin-bottom: 1.5rem;
    }
    .cookie-banner__inner { grid-template-columns: 1fr; }
    .cookie-banner__actions { justify-content: flex-start; }
}

/* Backdrop overlay — hidden on desktop, shown when mobile menu is open */
.nav-backdrop { display: none; }

@media (max-width: 768px) {
    /* Remove the desktop nav and its inline children from mobile */
    .primary-nav--desktop { display: none !important; }

    /* Show the hamburger toggle */
    .nav-toggle { display: inline-flex; }

    /* On mobile, kill the backdrop-filter on the header.
       backdrop-filter creates a containing block for position: fixed
       descendants — but the slide-out panel now lives OUTSIDE the header
       so this is a belt-and-suspenders precaution. */
    .site-header {
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        background: var(--color-paper);
    }

    /* Backdrop overlay covering the whole viewport */
    .nav-backdrop {
        display: block;
        position: fixed; inset: 0;
        background: rgba(24, 49, 84, 0.55);
        opacity: 0;
        pointer-events: none;
        transition: opacity 240ms ease;
        z-index: 1000;
    }
    body.nav-open .nav-backdrop {
        opacity: 1;
        pointer-events: auto;
    }

    /* The slide-out panel — lives at body level, fixed to the viewport */
    .primary-nav--mobile {
        display: flex;
        position: fixed;
        top: 0; right: 0; bottom: 0;
        width: 86%; max-width: 340px;
        background: var(--color-paper);
        padding: 0;
        flex-direction: column;
        gap: 0;
        align-items: stretch;
        transform: translateX(100%);
        transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1);
        z-index: 1001;
        box-shadow: -10px 0 40px -10px rgba(24, 49, 84, 0.25);
        overflow: hidden;
    }
    .primary-nav--mobile.is-open { transform: translateX(0); }

    /* Top strip: title + close button */
    .primary-nav__head {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 1rem 1.25rem;
        padding-top: calc(1rem + env(safe-area-inset-top, 0px));
        border-bottom: 1px solid var(--color-line-soft);
        background: var(--color-paper);
        flex-shrink: 0;
    }
    .primary-nav__title {
        font-family: var(--font-display);
        font-size: 0.75rem;
        text-transform: uppercase;
        letter-spacing: 0.14em;
        color: var(--color-ink-muted);
        font-weight: 600;
    }
    .primary-nav__close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 40px; height: 40px;
        background: transparent;
        border: 1px solid var(--color-line);
        border-radius: var(--radius);
        color: var(--color-ink);
        padding: 0;
        cursor: pointer;
        transition: background 150ms ease, color 150ms ease, border-color 150ms ease;
    }
    .primary-nav__close:hover,
    .primary-nav__close:focus-visible {
        background: var(--color-ink);
        color: var(--color-cream);
        border-color: var(--color-ink);
        outline: none;
    }

    /* Scrollable body of the slide-out panel */
    .primary-nav--mobile .primary-nav__body {
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        padding: 1.25rem 1.25rem 2rem;
        padding-bottom: calc(2rem + env(safe-area-inset-bottom, 0px));
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        flex: 1;
    }

    /* Menu links stack vertically inside the mobile panel */
    .primary-nav--mobile ul {
        flex-direction: column;
        align-items: stretch;
        gap: 0;
        margin: 0 0 0.5rem 0;
    }
    .primary-nav--mobile ul a {
        display: block;
        padding: 0.95rem 0;
        font-size: 1.0625rem;
        border-bottom: 1px solid var(--color-line-soft);
    }
    .primary-nav--mobile ul li:last-child a { border-bottom: 0; }

    /* Phone link inside the panel */
    .primary-nav__phone {
        display: inline-flex;
        align-items: center;
        gap: 0.6rem;
        padding: 0.85rem 0;
        font-size: 1rem;
        font-weight: 500;
        color: var(--color-ink);
        text-decoration: none;
        margin-top: 0.5rem;
        border-top: 1px solid var(--color-line-soft);
    }
    .primary-nav__phone svg { color: var(--color-accent); }
    .primary-nav__phone:hover { color: var(--color-accent); }

    /* CTA button inside the panel */
    .primary-nav__cta {
        display: inline-flex !important;
        justify-content: center;
        margin-top: 1rem;
        padding: 0.95rem 1.25rem !important;
        font-size: 0.9375rem;
        width: 100%;
    }

    .brand__tagline { display: none; }
    .services-grid { grid-template-columns: 1fr; }
    .process-grid { grid-template-columns: 1fr; }
    .values-grid { grid-template-columns: 1fr; }
    .testimonials-grid { grid-template-columns: 1fr; }
    .leandra-form .field-row { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .footer-col--brand { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }
    .footer-bottom { flex-direction: column; align-items: flex-start; }
    .footer-legal { gap: 1rem; }
    .cta-strip__inner { flex-direction: column; align-items: flex-start; gap: 2rem; }
    .cta-strip__actions { flex-direction: row; flex-wrap: wrap; }
    .hero__credentials { gap: 1.5rem 2rem; }
    .contact-form-wrap { padding: 1.75rem; }
    .service-hero__icon { width: 140px; height: 140px; }
    .deliverables { padding: 1.5rem 1.5rem 1.5rem 1.75rem; }
    .cookie-banner { left: 0.75rem; right: 0.75rem; bottom: 0.75rem; }
    .cookie-banner__inner { padding: 1.25rem; }
}

@media (max-width: 480px) {
    .hero__visual-card { padding: 1.75rem 1.5rem; }
    .hero__visual-quote p { font-size: 1.125rem; }
    .hero__visual-stats { grid-template-columns: 1fr; gap: 0.75rem; }
    .service-hero__meta { gap: 1.25rem; }
    .testimonial { padding: 2rem 1.5rem 1.5rem; }
    .testimonial__mark { font-size: 3rem; }
    .header-inner { padding: 0.7rem 1rem; }
    .brand__mark { width: 40px; height: 40px; }
    .brand__name { font-size: 1rem; }
}
