@layer reset, tokens, layout, components, utilities;

@layer reset {
  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
  html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
  body { min-height: 100vh; }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  button { font: inherit; border: none; background: none; cursor: pointer; }
  ul { list-style: none; }
  input, textarea { font: inherit; color: inherit; }
  h1, h2, h3, h4 { font-family: var(--font-heading); line-height: 1.15; font-weight: 600; }
}

@layer tokens {
  :root {
    --font-heading: 'Unbounded', sans-serif;
    --font-body: 'Inter', sans-serif;

    --c-bg: #FBF6EF;
    --c-bg-alt: #F2E9DA;
    --c-surface: #FFFDF9;
    --c-ink: #2A231D;
    --c-ink-soft: #5C5044;
    --c-ink-faint: #8A7C6C;

    --c-primary: #B44B2E;
    --c-primary-dark: #8E3821;
    --c-primary-light: #E8A582;

    --c-secondary: #3A4436;
    --c-secondary-dark: #262E24;

    --c-accent: #D3A23F;
    --c-cream: #FAF3E6;

    --shadow-sm: 0 1px 2px rgba(42,35,29,.07), 0 1px 1px rgba(42,35,29,.05);
    --shadow-md: 0 10px 28px -10px rgba(42,35,29,.22), 0 3px 8px rgba(42,35,29,.09);
    --shadow-lg: 0 26px 54px -14px rgba(42,35,29,.28), 0 10px 20px -6px rgba(42,35,29,.14);

    --radius-sm: 10px;
    --radius-md: 18px;
    --radius-lg: 28px;
    --radius-xl: 40px;
    --radius-pill: 999px;

    --space-3xs: .25rem;
    --space-2xs: .5rem;
    --space-xs: .75rem;
    --space-sm: 1rem;
    --space-md: 1.5rem;
    --space-lg: 2.5rem;
    --space-xl: 4rem;
    --space-2xl: 6rem;
    --space-3xl: 9rem;

    --header-h: 76px;

    --fs-h1: clamp(2.6rem, 1.6rem + 4.2vw, 5.4rem);
    --fs-h2: clamp(1.9rem, 1.4rem + 2.2vw, 3.2rem);
    --fs-h3: clamp(1.3rem, 1.1rem + 1vw, 1.85rem);
    --fs-body-lg: clamp(1.1rem, 1rem + .35vw, 1.35rem);

    --ease: cubic-bezier(.22,.9,.32,1);
    --transition: .35s var(--ease);
  }
}

@layer layout {
  html { background: var(--c-bg); }
  body {
    font-family: var(--font-body);
    color: var(--c-ink);
    background: var(--c-bg);
    font-size: 1rem;
    line-height: 1.65;
    padding-top: var(--header-h);
    overflow-x: hidden;
  }
  .u-container {
    width: 100%;
    max-width: 1240px;
    margin-inline: auto;
    padding-inline: clamp(1.25rem, 4vw, 2.5rem);
  }
  main section { padding-block: var(--space-2xl); position: relative; }
  .s-hero { padding-top: clamp(3rem, 8vw, 5rem); padding-bottom: clamp(3rem, 8vw, 6rem); }
}

@layer components {

  
  .c-header {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    background: var(--c-surface);
    box-shadow: 0 1px 0 rgba(42,35,29,.06);
    transition: box-shadow var(--transition);
  }
  .c-header.is-scrolled { box-shadow: var(--shadow-md); }
  .c-header__inner {
    height: var(--header-h);
    display: flex; align-items: center; gap: var(--space-md);
  }
  .c-logo { display: flex; align-items: center; gap: .6rem; margin-right: auto; }
  .c-logo__text { font-family: var(--font-heading); font-weight: 600; font-size: 1.15rem; letter-spacing: -.01em; }
  .c-hamburger { width: 44px; height: 44px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px; border-radius: var(--radius-sm); transition: background var(--transition); flex-shrink: 0; }
  .c-hamburger:hover { background: var(--c-bg-alt); }
  .c-hamburger__line { width: 22px; height: 2px; background: var(--c-ink); border-radius: 2px; transition: transform .35s var(--ease), opacity .35s var(--ease); }
  .c-hamburger.is-active .c-hamburger__line:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .c-hamburger.is-active .c-hamburger__line:nth-child(2) { opacity: 0; }
  .c-hamburger.is-active .c-hamburger__line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .c-header__cta { flex-shrink: 0; }

  
  .c-nav-drawer__backdrop { position: fixed; inset: 0; background: rgba(26,21,17,.45); opacity: 0; pointer-events: none; transition: opacity var(--transition); z-index: 90; }
  .c-nav-drawer.is-open .c-nav-drawer__backdrop { opacity: 1; pointer-events: auto; }
  .c-nav-drawer__panel { background: var(--c-surface); z-index: 95; }
  .c-nav-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-md); border-bottom: 1px solid var(--c-bg-alt); }
  .c-nav-drawer__close { width: 40px; height: 40px; border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; transition: background var(--transition); }
  .c-nav-drawer__close:hover { background: var(--c-bg-alt); }
  .c-nav-drawer__list { padding: var(--space-sm) var(--space-md); }
  .c-nav-drawer__link { display: block; padding: var(--space-sm) var(--space-2xs); font-family: var(--font-heading); font-size: 1.15rem; font-weight: 500; color: var(--c-ink); border-bottom: 1px solid var(--c-bg-alt); transition: color var(--transition), padding-left var(--transition); }
  .c-nav-drawer__link:hover, .c-nav-drawer__link.is-active { color: var(--c-primary); padding-left: var(--space-sm); }
  .c-nav-drawer__foot { padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-xs); border-top: 1px solid var(--c-bg-alt); }
  .c-nav-drawer__foot a { font-size: .9rem; color: var(--c-ink-soft); display: flex; align-items: center; gap: .5rem; transition: color var(--transition); }
  .c-nav-drawer__foot a:hover { color: var(--c-primary); }

  @media (max-width: 899px) {
    .c-nav-drawer { position: static; }
    .c-nav-drawer__backdrop { display: none; }
    .c-nav-drawer__panel { position: static; width: 100%; max-height: 0; overflow: hidden; box-shadow: none; transition: max-height .45s var(--ease); }
    .c-nav-drawer.is-open .c-nav-drawer__panel { max-height: 620px; box-shadow: var(--shadow-md); }
  }
  @media (min-width: 900px) {
    .c-nav-drawer__panel { position: fixed; top: 0; left: 0; height: 100vh; width: 360px; max-width: 88vw; display: flex; flex-direction: column; transform: translateX(-100%); transition: transform .5s var(--ease); box-shadow: var(--shadow-lg); }
    .c-nav-drawer.is-open .c-nav-drawer__panel { transform: translateX(0); }
    .c-nav-drawer__list { flex: 1; }
  }

  
  .c-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    padding: .85rem 1.6rem; border-radius: var(--radius-pill);
    font-family: var(--font-heading); font-weight: 500; font-size: .95rem;
    transition: transform var(--transition), box-shadow var(--transition), background var(--transition), color var(--transition);
    min-height: 44px; white-space: nowrap;
  }
  .c-btn--primary { background: var(--c-primary); color: var(--c-cream); box-shadow: var(--shadow-sm); }
  .c-btn--primary:hover { background: var(--c-primary-dark); transform: translateY(-2px); box-shadow: var(--shadow-md); }
  .c-btn--outline { border: 1.5px solid var(--c-ink); color: var(--c-ink); }
  .c-btn--outline:hover { background: var(--c-ink); color: var(--c-cream); transform: translateY(-2px); }
  .c-btn--ghost { color: var(--c-ink-soft); }
  .c-btn--ghost:hover { color: var(--c-ink); }
  .c-btn--light { background: var(--c-cream); color: var(--c-primary-dark); box-shadow: var(--shadow-md); }
  .c-btn--light:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
  .c-btn--outline-white { border: 1.5px solid rgba(255,255,255,.8); color: #fff; }
  .c-btn--outline-white:hover { background: #fff; color: var(--c-primary-dark); transform: translateY(-2px); }

  
  .s-hero { background: radial-gradient(120% 100% at 50% 0%, var(--c-bg-alt) 0%, var(--c-bg) 55%); overflow: visible; }
  .s-hero__inner { text-align: center; max-width: 820px; margin-inline: auto; }
  .s-hero__eyebrow { display: inline-block; font-size: .85rem; letter-spacing: .06em; text-transform: uppercase; color: var(--c-primary-dark); font-weight: 600; margin-bottom: var(--space-sm); }
  .s-hero__title { font-size: var(--fs-h1); letter-spacing: -.02em; margin-bottom: var(--space-md); }
  .s-hero__lead { font-size: var(--fs-body-lg); color: var(--c-ink-soft); max-width: 640px; margin-inline: auto; margin-bottom: var(--space-lg); }
  .s-hero__actions { display: flex; gap: var(--space-sm); justify-content: center; flex-wrap: wrap; }
  .s-hero__media { position: relative; max-width: 780px; margin: var(--space-2xl) auto 0; }
  .s-hero__image { width: 100%; aspect-ratio: 16/10; object-fit: cover; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }

  .c-badge-float {
    position: absolute; display: inline-flex; align-items: center; gap: .5rem;
    background: var(--c-surface); padding: .7rem 1.1rem; border-radius: var(--radius-pill);
    font-size: .82rem; font-weight: 600; box-shadow: var(--shadow-md); color: var(--c-ink);
    animation: floaty 6s ease-in-out infinite;
  }
  .c-badge-float i { color: var(--c-primary); }
  .c-badge-float--1 { top: 6%; left: -4%; animation-delay: 0s; }
  .c-badge-float--2 { top: 18%; right: -6%; animation-delay: .6s; }
  .c-badge-float--3 { bottom: 14%; left: -6%; animation-delay: 1.2s; }
  .c-badge-float--4 { bottom: 2%; right: -3%; animation-delay: 1.8s; }
  @keyframes floaty { 0%,100% { transform: translateY(0) rotate(-1deg); } 50% { transform: translateY(-10px) rotate(1deg); } }
  @media (max-width: 780px) {
    .c-badge-float { position: static; display: inline-flex; margin: .3rem; }
    .s-hero__media { display: flex; flex-direction: column; align-items: center; }
  }

  
  .s-section-head { max-width: 640px; margin-bottom: var(--space-xl); }
  .s-section-head__eyebrow { display: block; font-size: .8rem; letter-spacing: .06em; text-transform: uppercase; color: var(--c-primary-dark); font-weight: 600; margin-bottom: var(--space-2xs); }
  .s-section-head__title { font-size: var(--fs-h2); margin-bottom: var(--space-sm); letter-spacing: -.015em; }
  .s-section-head__lead { color: var(--c-ink-soft); font-size: 1.05rem; }
  .s-section-head--light .s-section-head__title, .s-section-head--light .s-section-head__lead { color: var(--c-cream); }
  .s-section-head--light .s-section-head__eyebrow { color: var(--c-accent); }

  
  .s-phases { background: var(--c-bg-alt); }
  .c-bento-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-md);
    grid-template-areas: "a a b b" "a a c d";
  }
  .c-bento-card--a { grid-area: a; }
  .c-bento-card--b { grid-area: b; }
  .c-bento-card--c { grid-area: c; }
  .c-bento-card--d { grid-area: d; }
  .c-bento-card {
    background: var(--c-surface); border-radius: var(--radius-lg); padding: var(--space-lg);
    box-shadow: var(--shadow-sm); transition: transform var(--transition), box-shadow var(--transition);
    display: flex; flex-direction: column; gap: var(--space-xs); overflow: hidden;
  }
  .c-bento-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
  .c-bento-card__image { width: calc(100% + var(--space-lg)*2); margin: calc(var(--space-lg)*-1) calc(var(--space-lg)*-1) 0; margin-bottom: var(--space-sm); aspect-ratio: 16/10; object-fit: cover; }
  .c-bento-card--a { padding-bottom: var(--space-lg); }
  .c-bento-card--a .c-bento-card__image { aspect-ratio: 16/11; }
  .c-bento-card__num { font-family: var(--font-heading); font-size: 2.2rem; color: var(--c-primary-light); font-weight: 700; line-height: 1; }
  .c-bento-card--c .c-bento-card__num, .c-bento-card--d .c-bento-card__num { font-size: 1.6rem; }
  .c-bento-card__title { font-size: var(--fs-h3); }
  .c-bento-card__text { color: var(--c-ink-soft); }
  .c-bento-card--d { background: var(--c-primary); color: var(--c-cream); }
  .c-bento-card--d .c-bento-card__text { color: rgba(250,243,230,.85); }

  .c-bento-grid--alt { grid-template-columns: repeat(4,1fr); grid-template-areas: none; }
  .c-bento-grid--alt .c-bento-card--sm { grid-column: span 1; }

  @media (max-width: 900px) {
    .c-bento-grid { grid-template-columns: 1fr; grid-template-areas: "a" "b" "c" "d"; }
    .c-bento-grid--alt { grid-template-columns: repeat(2,1fr); }
  }
  @media (max-width: 560px) {
    .c-bento-grid--alt { grid-template-columns: 1fr; }
  }

  .c-single-image { margin-top: var(--space-lg); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); }
  .c-single-image img { width: 100%; aspect-ratio: 21/9; object-fit: cover; }

  
  .c-audience-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: var(--space-md); }
  .c-audience-card { background: var(--c-surface); border-radius: var(--radius-md); padding: var(--space-lg) var(--space-md); text-align: center; box-shadow: var(--shadow-sm); transition: transform var(--transition), box-shadow var(--transition); }
  .c-audience-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
  .c-audience-card i { font-size: 1.6rem; color: var(--c-primary); margin-bottom: var(--space-sm); }
  .c-audience-card h3 { font-size: 1.05rem; margin-bottom: var(--space-2xs); font-family: var(--font-heading); }
  .c-audience-card p { color: var(--c-ink-soft); font-size: .92rem; }

  
  .s-glossary { background: var(--c-bg-alt); }
  .c-glossary-grid { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
  .c-tooltip { position: relative; cursor: help; }
  .c-tooltip--chip { background: var(--c-surface); border: 1px solid rgba(42,35,29,.1); border-radius: var(--radius-pill); padding: .7rem 1.3rem; font-weight: 600; color: var(--c-primary-dark); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition), transform var(--transition); }
  .c-tooltip--chip:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
  .c-tooltip:not(.c-tooltip--chip) { border-bottom: 1.5px dashed var(--c-primary); font-weight: 600; color: var(--c-primary-dark); }
  .c-tooltip__bubble {
    position: absolute; left: 50%; bottom: calc(100% + 12px); transform: translateX(-50%) translateY(6px);
    background: var(--c-ink); color: var(--c-cream); padding: .85rem 1.1rem; border-radius: var(--radius-sm);
    font-size: .8rem; font-weight: 400; line-height: 1.45; width: max-content; max-width: 250px;
    box-shadow: var(--shadow-md); opacity: 0; pointer-events: none; transition: opacity .25s ease, transform .25s ease; z-index: 40;
  }
  .c-tooltip__bubble::after { content:''; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:6px solid transparent; border-top-color: var(--c-ink); }
  .c-tooltip:hover .c-tooltip__bubble, .c-tooltip:focus .c-tooltip__bubble, .c-tooltip.is-visible .c-tooltip__bubble { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }
  .c-tooltip:focus { outline: 2px solid var(--c-primary); outline-offset: 3px; border-radius: 4px; }

  
  .s-modules { background: var(--c-secondary); color: var(--c-cream); }
  .c-module-list { display: flex; flex-direction: column; }
  .c-module-row { display: flex; gap: var(--space-md); padding: var(--space-md) 0; border-bottom: 1px solid rgba(250,243,230,.14); }
  .c-module-row__num { font-family: var(--font-heading); font-size: 1.8rem; color: var(--c-accent); font-weight: 700; flex-shrink: 0; width: 60px; }
  .c-module-row__content h3 { font-size: 1.2rem; margin-bottom: .4rem; }
  .c-module-row__content p { color: rgba(250,243,230,.75); }
  .c-module-images { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); margin-top: var(--space-lg); }
  .c-module-images img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
  @media (max-width: 700px) { .c-module-images { grid-template-columns: 1fr; } }

  
  .s-quote__block { max-width: 780px; margin-inline: auto; text-align: center; font-family: var(--font-heading); font-size: clamp(1.4rem, 1.1rem + 1.4vw, 2.1rem); line-height: 1.4; color: var(--c-ink); position: relative; }
  .s-quote__mark { font-size: 3.5rem; color: var(--c-primary-light); line-height: 0; display: block; margin-bottom: var(--space-sm); font-family: var(--font-heading); }
  .s-quote__block footer { margin-top: var(--space-md); font-family: var(--font-body); font-size: .95rem; color: var(--c-ink-faint); font-weight: 500; }

  
  .c-contact-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: var(--space-md); }
  .c-contact-card { background: var(--c-surface); border-radius: var(--radius-md); padding: var(--space-lg); box-shadow: var(--shadow-sm); transition: transform var(--transition), box-shadow var(--transition); }
  .c-contact-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
  .c-contact-card i { font-size: 1.4rem; color: var(--c-primary); margin-bottom: var(--space-sm); }
  .c-contact-card h3 { font-size: 1rem; margin-bottom: .4rem; font-family: var(--font-heading); }
  .c-contact-card p, .c-contact-card a { color: var(--c-ink-soft); }
  .c-contact-card a:hover { color: var(--c-primary); }

  
  .s-cta { background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-dark) 100%); color: var(--c-cream); }
  .s-cta__inner { text-align: center; max-width: 620px; margin-inline: auto; display: flex; flex-direction: column; align-items: center; gap: var(--space-sm); }
  .s-cta__inner h2 { font-size: var(--fs-h2); }
  .s-cta__inner p { color: rgba(250,243,230,.85); font-size: 1.05rem; }

  
  .c-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); align-items: center; }
  .c-split--reverse { direction: rtl; }
  .c-split--reverse > * { direction: ltr; }
  .c-split__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
  .c-split__content h2 { font-size: var(--fs-h2); margin-bottom: var(--space-sm); }
  .c-split__content p { color: var(--c-ink-soft); margin-bottom: var(--space-sm); }
  @media (max-width: 850px) {
    .c-split, .c-split--reverse { grid-template-columns: 1fr; direction: ltr; }
  }

  
  .c-compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
  .c-compare-card { background: var(--c-surface); border-radius: var(--radius-lg); padding: var(--space-lg); box-shadow: var(--shadow-sm); }
  .c-compare-card--accent { background: var(--c-secondary); color: var(--c-cream); }
  .c-compare-card__tag { display: inline-block; font-family: var(--font-heading); font-weight: 600; margin-bottom: var(--space-sm); font-size: 1.1rem; }
  .c-compare-card ul { display: flex; flex-direction: column; gap: var(--space-sm); }
  .c-compare-card li { padding-left: 1.4rem; position: relative; color: var(--c-ink-soft); }
  .c-compare-card--accent li { color: rgba(250,243,230,.85); }
  .c-compare-card li::before { content: '—'; position: absolute; left: 0; color: var(--c-primary); }
  .c-compare-card--accent li::before { color: var(--c-accent); }
  @media (max-width: 700px) { .c-compare-grid { grid-template-columns: 1fr; } }

  
  .s-page-hero { background: var(--c-bg-alt); padding-top: clamp(3rem, 7vw, 4.5rem); padding-bottom: clamp(2.5rem, 6vw, 3.5rem); text-align: center; }
  .s-page-hero__title { font-size: var(--fs-h1); max-width: 820px; margin: 0 auto var(--space-sm); letter-spacing: -.02em; }
  .s-page-hero__lead { font-size: var(--fs-body-lg); color: var(--c-ink-soft); max-width: 660px; margin-inline: auto; }

  
  .c-timeline { display: flex; flex-direction: column; gap: var(--space-md); }
  .c-timeline__item { display: flex; gap: var(--space-md); }
  .c-timeline__num { font-family: var(--font-heading); font-size: 1.8rem; font-weight: 700; color: var(--c-primary-light); width: 56px; flex-shrink: 0; }
  .c-timeline__item h3 { font-size: 1.15rem; margin-bottom: .3rem; }
  .c-timeline__item p { color: var(--c-ink-soft); }

  
  .c-accordion { display: flex; flex-direction: column; gap: var(--space-sm); }
  .c-accordion__item { background: var(--c-surface); border-radius: var(--radius-md); padding: var(--space-md) var(--space-lg); box-shadow: var(--shadow-sm); }
  .c-accordion__item summary { cursor: pointer; font-family: var(--font-heading); font-weight: 500; font-size: 1.05rem; list-style: none; position: relative; padding-right: var(--space-lg); }
  .c-accordion__item summary::-webkit-details-marker { display: none; }
  .c-accordion__item summary::after { content: '+'; position: absolute; right: 0; top: 0; font-size: 1.4rem; color: var(--c-primary); transition: transform var(--transition); }
  .c-accordion__item[open] summary::after { transform: rotate(45deg); }
  .c-accordion__item p { margin-top: var(--space-sm); color: var(--c-ink-soft); }

  
  .c-essay { max-width: 720px; margin-inline: auto; display: flex; flex-direction: column; gap: var(--space-md); }
  .c-essay__lead { font-size: var(--fs-body-lg); font-weight: 500; }
  .c-essay p { color: var(--c-ink-soft); }
  .c-essay .s-quote__block { margin-block: var(--space-md); }

  
  .s-mindmap { padding: 0; background: var(--c-secondary-dark); }
  .s-mindmap__image img { width: 100%; height: clamp(280px, 45vw, 520px); object-fit: cover; }
  .s-mindmap__caption { color: var(--c-cream); text-align: center; max-width: 640px; margin-inline: auto; padding-block: var(--space-lg); font-size: 1.1rem; }

  
  .c-form__progress { display: flex; gap: var(--space-md); margin-bottom: var(--space-lg); }
  .c-form__step-indicator { font-size: .85rem; font-weight: 600; color: var(--c-ink-faint); padding-bottom: .5rem; border-bottom: 2px solid var(--c-bg-alt); transition: color var(--transition), border-color var(--transition); }
  .c-form__step-indicator.is-active { color: var(--c-primary-dark); border-color: var(--c-primary); }
  .c-form__step { display: none; }
  .c-form__step.is-active { display: block; animation: fadeUp .45s var(--ease); }
  @keyframes fadeUp { from { opacity: 0; transform: translateY(10px);} to { opacity: 1; transform: translateY(0);} }
  .c-form__field { margin-bottom: var(--space-md); }
  .c-form__field label { display: block; font-weight: 600; margin-bottom: .4rem; font-size: .9rem; }
  .c-form__field input, .c-form__field textarea {
    width: 100%; padding: .85rem 1rem; border: 1.5px solid rgba(42,35,29,.14); border-radius: var(--radius-sm);
    background: var(--c-bg); transition: border-color var(--transition), box-shadow var(--transition);
  }
  .c-form__field input:focus, .c-form__field textarea:focus { outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 3px rgba(180,75,46,.15); }
  .c-checkbox { display: flex; align-items: flex-start; gap: .6rem; font-size: .9rem; color: var(--c-ink-soft); margin-bottom: var(--space-md); }
  .c-checkbox input { margin-top: .25rem; width: 18px; height: 18px; flex-shrink: 0; }
  .c-checkbox a { color: var(--c-primary-dark); font-weight: 600; }
  .c-form__actions { display: flex; gap: var(--space-sm); flex-wrap: wrap; }

  
  .c-newsletter { background: var(--c-surface); border-radius: var(--radius-lg); padding: var(--space-lg); box-shadow: var(--shadow-sm); display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-md); justify-content: space-between; }
  .c-newsletter__text h2 { font-size: 1.4rem; margin-bottom: .4rem; }
  .c-newsletter__text p { color: var(--c-ink-soft); max-width: 460px; }
  .c-newsletter__form { display: flex; gap: .6rem; flex-wrap: wrap; }
  .c-newsletter__form input { padding: .85rem 1rem; border: 1.5px solid rgba(42,35,29,.14); border-radius: var(--radius-pill); min-width: 220px; background: var(--c-bg); }
  .c-newsletter__form input:focus { outline: none; border-color: var(--c-primary); }
  .c-newsletter__success { color: var(--c-primary-dark); font-weight: 600; }

  
  .c-map-frame { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); }

  
  .s-thanks { min-height: calc(100vh - var(--header-h) - 260px); background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-dark) 100%); display: flex; align-items: center; padding-block: var(--space-3xl); }
  .s-thanks__inner { text-align: center; max-width: 640px; margin-inline: auto; color: var(--c-cream); display: flex; flex-direction: column; align-items: center; gap: var(--space-md); }
  .s-thanks__eyebrow { text-transform: uppercase; letter-spacing: .08em; font-weight: 600; color: var(--c-accent); font-size: .85rem; }
  .s-thanks__inner h1 { font-size: var(--fs-h1); }
  .s-thanks__inner p { color: rgba(250,243,230,.9); font-size: 1.1rem; }

  
  .s-legal { background: var(--c-bg); padding-top: clamp(2.5rem, 6vw, 3.5rem); }
  .c-legal { max-width: 820px; margin-inline: auto; }
  .c-legal h1 { font-size: var(--fs-h2); margin-bottom: var(--space-2xs); }
  .c-legal__updated { color: var(--c-ink-faint); margin-bottom: var(--space-lg); font-size: .9rem; }
  .c-legal h2 { font-size: 1.25rem; margin-top: var(--space-lg); margin-bottom: var(--space-sm); font-family: var(--font-heading); }
  .c-legal p { color: var(--c-ink-soft); margin-bottom: var(--space-sm); }
  .c-legal a { color: var(--c-primary-dark); font-weight: 600; }
  .c-legal__table { width: 100%; border-collapse: collapse; margin-bottom: var(--space-md); background: var(--c-surface); border-radius: var(--radius-sm); overflow: hidden; box-shadow: var(--shadow-sm); }
  .c-legal__table th, .c-legal__table td { text-align: left; padding: .75rem 1rem; border-bottom: 1px solid var(--c-bg-alt); font-size: .92rem; }
  .c-legal__table th { color: var(--c-ink-faint); font-weight: 600; width: 40%; }

  
  .c-footer { background: #241D18; color: var(--c-cream); padding-top: var(--space-2xl); margin-top: auto; }
  .c-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-lg); padding-bottom: var(--space-lg); }
  .c-footer__col--brand p { color: rgba(250,243,230,.7); margin-top: var(--space-sm); max-width: 280px; }
  .c-footer__col h3 { font-size: .95rem; text-transform: uppercase; letter-spacing: .04em; margin-bottom: var(--space-sm); color: var(--c-accent); }
  .c-footer__col ul { display: flex; flex-direction: column; gap: .55rem; }
  .c-footer__col a { color: rgba(250,243,230,.75); transition: color var(--transition); }
  .c-footer__col a:hover { color: #fff; }
  .c-footer__col address { font-style: normal; color: rgba(250,243,230,.75); margin-bottom: .5rem; }
  .c-footer__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-sm); padding-block: var(--space-md); border-top: 1px solid rgba(250,243,230,.12); font-size: .85rem; color: rgba(250,243,230,.6); }
  .c-footer__cookie-btn { color: rgba(250,243,230,.75); text-decoration: underline; font-size: .85rem; transition: color var(--transition); }
  .c-footer__cookie-btn:hover { color: #fff; }
  @media (max-width: 800px) { .c-footer__grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 500px) { .c-footer__grid { grid-template-columns: 1fr; } }

  
  .c-modal { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity var(--transition); }
  .c-modal.is-open { opacity: 1; pointer-events: auto; }
  .c-modal__backdrop { position: absolute; inset: 0; background: rgba(26,21,17,.55); backdrop-filter: blur(2px); }
  .c-modal__panel {
    position: relative; background: var(--c-surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
    max-width: 520px; width: calc(100% - 2.5rem); max-height: 88vh; overflow-y: auto; padding: var(--space-lg);
    transform: scale(.95) translateY(10px); transition: transform var(--transition);
  }
  .c-modal.is-open .c-modal__panel { transform: scale(1) translateY(0); }
  .c-modal__panel h2 { font-size: 1.4rem; margin-bottom: var(--space-sm); }
  .c-modal__panel p { color: var(--c-ink-soft); margin-bottom: var(--space-md); font-size: .92rem; }
  .c-modal__toggles { display: flex; flex-direction: column; gap: var(--space-sm); margin-bottom: var(--space-lg); }
  .c-toggle { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); padding: var(--space-sm); background: var(--c-bg); border-radius: var(--radius-sm); }
  .c-toggle span { font-weight: 600; font-size: .9rem; display: flex; flex-direction: column; gap: .2rem; }
  .c-toggle small { font-weight: 400; color: var(--c-ink-faint); }
  .c-toggle input { width: 42px; height: 24px; appearance: none; background: rgba(42,35,29,.2); border-radius: var(--radius-pill); position: relative; cursor: pointer; transition: background var(--transition); flex-shrink: 0; }
  .c-toggle input::before { content:''; position:absolute; width:18px; height:18px; background:#fff; border-radius:50%; top:3px; left:3px; transition: transform var(--transition); box-shadow: var(--shadow-sm); }
  .c-toggle input:checked { background: var(--c-primary); }
  .c-toggle input:checked::before { transform: translateX(18px); }
  .c-toggle input:disabled { opacity: .6; cursor: not-allowed; }
  .c-modal__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
}

@layer utilities {
  .u-visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
  .u-hidden { display: none !important; }
  .u-text-center { text-align: center; }
  [data-animate] { opacity: 0; }
  [data-animate].is-visible { opacity: 1; }
}