/* ============================================================================
   components.css — site components
   ============================================================================ */

/* ---------------------------------------------------------------- Header --- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  padding-block: var(--sp-sm);
  transition: background var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out),
              padding var(--dur-2) var(--ease-out);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-md);
}
.site-header.is-stuck {
  /* No backdrop-filter here: filter/backdrop-filter makes the header a containing block for
     its position:fixed mobile menu, which collapses/mispositions the menu once the header
     becomes sticky on scroll. A near-solid background gives the same effect without the trap. */
  background: color-mix(in srgb, var(--c-bg) 96%, transparent);
  box-shadow: 0 1px 0 var(--c-line), var(--shadow-2);
  padding-block: calc(var(--sp-xs));
}

.brand { display: inline-flex; align-items: center; gap: 0.7rem; color: var(--c-ink); }
.brand__logo { width: auto; height: 26px; color: var(--c-ink); }
.brand:hover .brand__mark { transform: rotate(45deg); }
.brand__mark { width: 26px; height: 26px; color: var(--c-accent); transition: transform var(--dur-3) var(--ease-spring); }

/* Primary nav */
.nav { display: flex; align-items: center; gap: clamp(1.2rem, 2.5vw, 2.4rem); }
.nav__link {
  position: relative;
  font-size: var(--step--1);
  letter-spacing: 0.01em;
  color: var(--c-muted);
  padding-block: 0.4rem;
  transition: color var(--dur-1) var(--ease-out);
}
.nav__link::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 1px;
  background: var(--c-accent);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform var(--dur-2) var(--ease-out);
}
.nav__link:hover,
.nav__link[aria-current="page"] { color: var(--c-ink); }
.nav__link:hover::after,
.nav__link[aria-current="page"]::after { transform: scaleX(1); transform-origin: left; }

.nav-cta { display: inline-flex; }

/* Hamburger */
.nav-toggle {
  display: none;
  width: 44px; height: 44px;
  background: none; border: 0;
  cursor: pointer;
  align-items: center;
  justify-content: center;
}
.nav-toggle__bars { position: relative; width: 24px; height: 12px; }
.nav-toggle__bars span {
  position: absolute; left: 0; width: 100%; height: 1.5px;
  background: var(--c-ink);
  transition: transform var(--dur-2) var(--ease-out), opacity var(--dur-1);
}
.nav-toggle__bars span:nth-child(1) { top: 0; }
.nav-toggle__bars span:nth-child(2) { bottom: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(2) { transform: translateY(-5px) rotate(-45deg); }

@media (max-width: 860px) {
  .nav-toggle { display: inline-flex; }
  .nav {
    position: fixed;
    inset: 0 0 0 auto;
    width: min(86vw, 380px);
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: var(--sp-md);
    padding: var(--sp-2xl) var(--gutter);
    background: var(--c-bg-2);
    border-left: 1px solid var(--c-line);
    transform: translateX(100%);
    transition: transform var(--dur-3) var(--ease-out);
    box-shadow: var(--shadow-3);
  }
  .nav.is-open { transform: translateX(0); }
  .nav__link { font-size: var(--step-1); color: var(--c-ink); font-family: var(--font-display); }
  .nav__link::after { display: none; }
  .nav .nav-cta { margin-top: var(--sp-sm); }
  .nav-backdrop {
    position: fixed; inset: 0; z-index: 99;
    background: rgba(0,0,0,.5);
    opacity: 0; visibility: hidden;
    transition: opacity var(--dur-2) var(--ease-out), visibility var(--dur-2);
  }
  .nav-backdrop.is-open { opacity: 1; visibility: visible; }
}

/* ---------------------------------------------------------------- Buttons -- */
.btn {
  --btn-bg: var(--c-ink);
  --btn-fg: var(--c-bg);
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.9em 1.5em;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  background: var(--btn-bg);
  color: var(--btn-fg);
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
}
.btn__arrow { transition: transform var(--dur-2) var(--ease-out); }
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); }
.btn:hover .btn__arrow { transform: translateX(4px); }
.btn:active { transform: translateY(0); }

.btn--primary { --btn-bg: var(--c-brand); --btn-fg: #fff; }
.btn--primary::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(120deg, var(--c-brand), #7C8BFF 60%, var(--c-brand));
  background-size: 200% 100%;
  transition: background-position var(--dur-3) var(--ease-out);
}
.btn--primary:hover::before { background-position: 100% 0; }
.btn--primary:hover { box-shadow: var(--glow-brand); }

.btn--ghost {
  --btn-bg: transparent;
  --btn-fg: var(--c-ink);
  border-color: var(--c-line);
}
.btn--ghost:hover { border-color: var(--c-ink); background: var(--c-surface); }
.theme-paper .btn--ghost { --btn-fg: var(--c-paper-ink); border-color: var(--c-paper-line); }
.theme-paper .btn--ghost:hover { border-color: var(--c-paper-ink); background: var(--c-paper-2); }

.btn--lg { padding: 1.05em 1.9em; font-size: var(--step-0); }

/* Inline text link with animated underline */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  font-weight: 600;
  font-size: var(--step--1);
  color: var(--c-brand-soft);
  width: max-content;
}
.theme-paper .link-arrow { color: var(--c-brand); }
.link-arrow svg { transition: transform var(--dur-2) var(--ease-out); }
.link-arrow:hover svg { transform: translateX(5px); }

/* ----------------------------------------------------------------- Hero ---- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  flex-direction: column;     /* stack inner content + stats; stats flow beneath, no overlap */
  justify-content: center;
  align-items: stretch;
  padding-top: clamp(7rem, 14vh, 11rem);
  padding-bottom: var(--sp-2xl);
  overflow: hidden;
}
.hero__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.hero__orbit {
  position: absolute;
  right: clamp(-22rem, -8vw, -4rem);
  top: 50%;
  width: min(74vw, 760px);
  aspect-ratio: 1;
  transform: translateY(-50%);
  color: var(--c-brand);
  opacity: .9;
}
.hero__grain { position: absolute; inset: 0; opacity: .5; mix-blend-mode: overlay; }

.hero__inner { position: relative; z-index: 1; max-width: min(100%, 60rem); }
.hero__eyebrow { margin-bottom: var(--sp-md); }
.hero h1 {
  /* Sized so the longest German compound ("Maßgeschneiderte") fits one line from 360px to QHD —
     the old var(--step-6) maxed at 9.5rem and forced mid-word hyphenation in the column. */
  font-size: clamp(2.2rem, 1.1rem + 4.8vw, 5rem);
  line-height: 1.04;
  letter-spacing: -0.025em;
  max-width: 16ch;
  hyphens: manual;            /* no ugly mid-word hyphenation of the headline */
  overflow-wrap: break-word;  /* last-resort safety only */
}
.hero h1 em {
  font-style: italic;
  color: var(--c-accent);
}
.hero__sub {
  margin-top: var(--sp-lg);
  font-size: var(--step-1);
  line-height: 1.4;
  color: var(--c-muted);
  max-width: 46ch;
}
.hero__actions { margin-top: var(--sp-xl); gap: var(--sp-md); }

/* Stats sit in normal flow beneath the CTAs at every width — the old absolute pin
   overlapped the buttons in the 860–1280px range (and produced odd full-bleed border lengths). */
.hero__meta {
  margin-top: auto;            /* push stats to the hero's bottom as a full-width section (no overlap) */
  padding-top: var(--sp-md);
  border-top: 1px solid var(--c-line);   /* full container width via the .container--wide class in markup */
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-md) var(--sp-2xl);
  align-items: baseline;
}
.hero__meta dt { font-family: var(--font-mono); font-size: var(--step--1);
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-faint); }
.hero__meta dd { font-size: var(--step-0); color: var(--c-ink); margin-top: 2px; }
.hero__meta-item { min-width: 8rem; }

/* Word-reveal animation for the hero heading */
.reveal-line { display: block; overflow: hidden; }
.reveal-line > span {
  display: block;
  transform: translateY(110%);
  animation: line-rise var(--dur-reveal) var(--ease-out) forwards;
  animation-delay: var(--d, 0ms);
}
@keyframes line-rise { to { transform: translateY(0); } }

/* --------------------------------------------------------- Marquee strip -- */
.marquee {
  --speed: 38s;
  overflow: hidden;
  border-block: 1px solid var(--c-line);
  padding-block: var(--sp-md);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.theme-paper .marquee { border-color: var(--c-paper-line); }
.marquee__track { display: flex; width: max-content; gap: var(--sp-2xl);
  animation: marquee var(--speed) linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item {
  display: inline-flex; align-items: center; gap: var(--sp-md);
  font-family: var(--font-display);
  font-size: var(--step-2);
  color: var(--c-muted);
  white-space: nowrap;
}
.marquee__item svg { width: 0.7em; height: 0.7em; color: var(--c-accent); flex: none; }
@keyframes marquee { to { transform: translateX(calc(-50% - var(--sp-2xl) / 2)); } }

/* --------------------------------------------------- Leistungen (editorial) */
.service-list { border-top: 1px solid var(--c-line); }
.theme-paper .service-list { border-color: var(--c-paper-line); }
.service {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-md) var(--sp-lg);
  align-items: start;
  padding-block: clamp(var(--sp-lg), 4vw, var(--sp-2xl));
  border-bottom: 1px solid var(--c-line);
  position: relative;
}
.theme-paper .service { border-color: var(--c-paper-line); }
.service__num {
  font-family: var(--font-mono);
  font-size: var(--step--1);
  color: var(--c-accent);
  padding-top: 0.6em;
  letter-spacing: 0.1em;
}
.theme-paper .service__num { color: var(--c-accent-deep); }
.service__body { display: grid; gap: var(--sp-md); }
@media (min-width: 880px) {
  .service { grid-template-columns: 4rem minmax(0,0.9fr) minmax(0,1.1fr); align-items: start; }
  .service__body { grid-template-columns: subgrid; grid-column: 2 / 4;
    display: grid; gap: var(--sp-xl); grid-auto-flow: column;
    grid-template-columns: minmax(0,0.9fr) minmax(0,1.1fr); }
}
.service__icon {
  width: 46px; height: 46px; color: var(--c-ink);
  margin-bottom: var(--sp-sm);
}
.theme-paper .service__icon { color: var(--c-paper-ink); }
.service h3 { font-size: var(--step-3); transition: transform var(--dur-3) var(--ease-out); }
.service:hover h3 { transform: translateX(8px); }
.service h3 em { color: var(--c-accent); font-style: normal; }
.service__tags { display: flex; flex-wrap: wrap; gap: var(--sp-2xs); margin-top: var(--sp-sm); }
.tag {
  font-family: var(--font-mono);
  font-size: var(--step--1);
  letter-spacing: 0.04em;
  padding: 0.35em 0.8em;
  border: 1px solid var(--c-line);
  border-radius: var(--r-pill);
  color: var(--c-muted);
}
.theme-paper .tag { border-color: var(--c-paper-line); color: var(--c-paper-muted); }

/* --------------------------------------------------------------- Process --- */
.steps { counter-reset: step; display: grid; gap: var(--sp-lg); }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(4, 1fr); } }
.step {
  position: relative;
  padding-top: var(--sp-lg);
  border-top: 2px solid var(--c-line);
}
.step::before {
  counter-increment: step;
  content: counter(step, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: var(--step--1);
  color: var(--c-accent);
  position: absolute;
  top: var(--sp-sm);
  letter-spacing: 0.12em;
}
.step__bar { position: absolute; top: -2px; left: 0; height: 2px; width: 0;
  background: var(--c-brand); transition: width var(--dur-reveal) var(--ease-out); }
.step.in-view .step__bar { width: 38%; }
.step h3 { font-size: var(--step-1); margin-top: var(--sp-lg); }
.step p { color: var(--c-muted); margin-top: var(--sp-2xs); font-size: var(--step-0); }

/* --------------------------------------------------------- Pakete / tiers -- */
.tiers { display: grid; gap: var(--sp-lg); }
@media (min-width: 880px) { .tiers { grid-template-columns: repeat(3, 1fr); } }
.tier {
  display: flex;
  flex-direction: column;
  padding: clamp(var(--sp-lg), 3vw, var(--sp-xl));
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: var(--r-lg);
  transition: transform var(--dur-3) var(--ease-out), border-color var(--dur-2);
}
.tier:hover { transform: translateY(-6px); border-color: var(--c-surface-2); }
.tier--featured {
  background: linear-gradient(180deg, color-mix(in srgb, var(--c-brand) 14%, var(--c-surface)), var(--c-surface));
  border-color: color-mix(in srgb, var(--c-brand) 45%, transparent);
  box-shadow: var(--shadow-3);
}
.tier__flag {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: var(--step--1);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-bg);
  background: var(--c-accent);
  padding: 0.3em 0.8em;
  border-radius: var(--r-pill);
  margin-bottom: var(--sp-md);
}
.tier__name { font-size: var(--step-2); }
.tier__for { color: var(--c-muted); font-size: var(--step--1); margin-top: 0.4em; min-height: 2.8em; }
.tier__price { margin-top: var(--sp-md); display: flex; align-items: baseline; gap: 0.4em; }
.tier__price b { font-family: var(--font-display); font-size: var(--step-3); font-weight: 400;
  font-variant-numeric: tabular-nums; letter-spacing: -0.02em; }
.tier__price span { color: var(--c-faint); font-size: var(--step--1); }
.tier__list { margin-top: var(--sp-lg); display: grid; gap: var(--sp-sm); }
.tier__list li { display: flex; gap: 0.7em; align-items: flex-start; font-size: var(--step-0);
  color: var(--c-muted); }
.tier__list svg { flex: none; width: 18px; height: 18px; color: var(--c-accent); margin-top: 0.3em; }
.tier__cta { margin-top: var(--sp-lg); }
.tier__cta .btn { width: 100%; justify-content: center; }

/* --------------------------------------------------------- Testimonials ---- */
.quote-feature {
  font-family: var(--font-display);
  font-size: var(--step-4);
  line-height: 1.18;
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.quote-feature .q-mark { color: var(--c-accent); }
.cite { display: flex; align-items: center; gap: var(--sp-sm); margin-top: var(--sp-lg); }
.cite__avatar {
  width: 46px; height: 46px; border-radius: var(--r-pill); flex: none;
  display: grid; place-items: center;
  background: var(--c-surface-2); color: var(--c-accent);
  font-family: var(--font-mono); font-size: var(--step-0); letter-spacing: 0.04em;
  border: 1px solid var(--c-line);
}
.theme-paper .cite__avatar { background: var(--c-paper-2); border-color: var(--c-paper-line); color: var(--c-accent-deep); }
.cite__name { font-weight: 600; font-size: var(--step-0); }
.cite__role { color: var(--c-muted); font-size: var(--step--1); }

.testimonials { display: grid; gap: var(--sp-lg); }
@media (min-width: 760px) { .testimonials { grid-template-columns: repeat(2, 1fr); } }
.testimonial {
  padding: clamp(var(--sp-lg), 3vw, var(--sp-xl));
  border: 1px solid var(--c-paper-line);
  border-radius: var(--r-lg);
  background: var(--c-paper);
  display: flex; flex-direction: column; gap: var(--sp-md);
}
.testimonial__stars { display: flex; gap: 2px; color: var(--c-accent-deep); }
.testimonial__stars svg { width: 18px; height: 18px; }
.testimonial p { font-size: var(--step-1); line-height: 1.45; }

/* ------------------------------------------------------------ Stats band --- */
.stats { display: grid; gap: var(--sp-xl); }
@media (min-width: 640px) { .stats { grid-template-columns: repeat(3, 1fr); } }
.stat { border-top: 1px solid var(--c-line); padding-top: var(--sp-md); }
.theme-paper .stat { border-color: var(--c-paper-line); }
.stat__num {
  font-family: var(--font-display);
  font-size: var(--step-5);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.stat__num .suffix { color: var(--c-accent); }
.theme-paper .stat__num .suffix { color: var(--c-accent-deep); }
.stat__label { color: var(--c-muted); margin-top: var(--sp-2xs); font-size: var(--step-0); }
.theme-paper .stat__label { color: var(--c-paper-muted); }

/* ---------------------------------------------------------------- CTA band - */
.cta-band { position: relative; overflow: hidden; }
.cta-band__orbit { position: absolute; right: -8%; bottom: -40%;
  width: min(60vw, 520px); color: var(--c-brand); opacity: .25; pointer-events: none; }
.cta-band__inner { position: relative; z-index: 1; display: grid; gap: var(--sp-lg); }
.cta-band h2 { font-size: var(--step-5); max-width: 16ch; }
.cta-band .cluster { margin-top: var(--sp-sm); }

/* --------------------------------------------------------- Contact / form -- */
.contact-grid { display: grid; gap: clamp(var(--sp-xl), 5vw, var(--sp-2xl)); }
@media (min-width: 920px) { .contact-grid { grid-template-columns: 1fr 1.1fr; } }

.field { display: grid; gap: var(--sp-2xs); }
.field label { font-family: var(--font-mono); font-size: var(--step--1);
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-muted); }
.theme-paper .field label { color: var(--c-paper-muted); }
.field input, .field textarea, .field select {
  width: 100%;
  padding: 0.85em 1em;
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: var(--r-md);
  color: var(--c-ink);
  transition: border-color var(--dur-2) var(--ease-out), box-shadow var(--dur-2);
}
.theme-paper .field input, .theme-paper .field textarea, .theme-paper .field select {
  background: #fff; border-color: var(--c-paper-line); color: var(--c-paper-ink);
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none;
  border-color: var(--c-brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-brand) 25%, transparent);
}
.field textarea { resize: vertical; min-height: 8rem; }
.field-row { display: grid; gap: var(--sp-md); }
@media (min-width: 520px) { .field-row { grid-template-columns: 1fr 1fr; } }

.form-note { font-size: var(--step--1); color: var(--c-muted); }
.theme-paper .form-note { color: var(--c-paper-muted); }

.form-success {
  display: none;
  padding: var(--sp-lg);
  border: 1px solid color-mix(in srgb, var(--c-brand) 40%, transparent);
  border-radius: var(--r-lg);
  background: color-mix(in srgb, var(--c-brand) 10%, var(--c-surface));
}
.theme-paper .form-success { background: color-mix(in srgb, var(--c-brand) 8%, #fff); }
.form-success.is-visible { display: block; animation: pop var(--dur-3) var(--ease-spring); }
@keyframes pop { from { opacity: 0; transform: scale(.96); } to { opacity: 1; transform: scale(1); } }
.form-success h3 { font-size: var(--step-2); margin-bottom: var(--sp-2xs); }

/* Contact detail list */
.contact-info { display: grid; gap: var(--sp-lg); }
.contact-info dt { font-family: var(--font-mono); font-size: var(--step--1);
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-faint); }
.contact-info dd { font-size: var(--step-1); margin-top: 0.3em; font-family: var(--font-display); }
.contact-info a:hover { color: var(--c-brand-soft); }
.theme-paper .contact-info a:hover { color: var(--c-brand); }

.hours { width: 100%; border-collapse: collapse; }
.hours th, .hours td { text-align: left; padding: 0.55em 0; border-bottom: 1px solid var(--c-line);
  font-size: var(--step-0); }
.theme-paper .hours th, .theme-paper .hours td { border-color: var(--c-paper-line); }
.hours th { font-weight: 400; color: var(--c-muted); }
.hours td { text-align: right; font-variant-numeric: tabular-nums; }
.hours tr:last-child th, .hours tr:last-child td { border-bottom: 0; }

.map-frame {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--c-line);
  aspect-ratio: 16 / 10;
  background: var(--c-surface);
  filter: grayscale(1) contrast(1.05) brightness(.85);
  transition: filter var(--dur-3) var(--ease-out);
}
.map-frame:hover { filter: grayscale(0) contrast(1) brightness(1); }
.map-frame iframe { width: 100%; height: 100%; border: 0; }

/* ----------------------------------------------------------------- Footer -- */
.site-footer { background: var(--c-bg-2); border-top: 1px solid var(--c-line);
  padding-block: var(--sp-2xl) var(--sp-lg); }
.footer-grid { display: grid; gap: var(--sp-xl); }
@media (min-width: 760px) { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1.2fr; } }
.footer__brand .brand__logo { height: 30px; }
.footer__tagline { color: var(--c-muted); margin-top: var(--sp-md); max-width: 32ch; }
.footer h4 { font-family: var(--font-mono); font-weight: 500; font-size: var(--step--1);
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-faint); margin-bottom: var(--sp-md); }
.footer__links { display: grid; gap: var(--sp-2xs); }
.footer__links a { color: var(--c-muted); transition: color var(--dur-1); width: max-content; }
.footer__links a:hover { color: var(--c-ink); }
.footer-bottom {
  margin-top: var(--sp-2xl);
  padding-top: var(--sp-md);
  border-top: 1px solid var(--c-line);
  display: flex; flex-wrap: wrap; gap: var(--sp-sm) var(--sp-lg);
  align-items: center; justify-content: space-between;
  font-size: var(--step--1); color: var(--c-faint);
}
.footer-bottom a { color: var(--c-muted); }
.footer-bottom a:hover { color: var(--c-ink); }

/* Cookie notice */
.cookie {
  position: fixed;
  left: var(--gutter); right: var(--gutter); bottom: var(--sp-md);
  z-index: 120;
  max-width: 540px;
  margin-inline: auto;
  display: flex; flex-wrap: wrap; gap: var(--sp-md); align-items: center; justify-content: space-between;
  padding: var(--sp-md) var(--sp-lg);
  background: var(--c-surface);
  border: 1px solid var(--c-line);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-3);
  transform: translateY(150%);
  transition: transform var(--dur-3) var(--ease-out);
}
.cookie.is-visible { transform: translateY(0); }
.cookie p { font-size: var(--step--1); color: var(--c-muted); flex: 1 1 14rem; }
.cookie a { text-decoration: underline; color: var(--c-ink); }

/* ----------------------------------------------------- Page hero (subpages) */
.page-hero { padding-top: clamp(8rem, 16vh, 12rem); padding-bottom: var(--sp-xl); }
.page-hero h1 { font-size: var(--step-5); max-width: 18ch; }
.page-hero .lead { margin-top: var(--sp-lg); }
.breadcrumb { font-family: var(--font-mono); font-size: var(--step--1);
  letter-spacing: 0.06em; color: var(--c-faint); margin-bottom: var(--sp-md); }
.breadcrumb a:hover { color: var(--c-ink); }

/* Prose for legal pages */
.prose { max-width: var(--measure); }
.prose > * + * { margin-top: var(--sp-md); }
.prose h2 { font-size: var(--step-2); margin-top: var(--sp-xl); }
.prose h3 { font-size: var(--step-1); margin-top: var(--sp-lg); font-family: var(--font-body); font-weight: 600; }
.prose p, .prose li { color: var(--c-muted); }
.theme-paper .prose p, .theme-paper .prose li { color: var(--c-paper-muted); }
.prose a { color: var(--c-brand-soft); text-decoration: underline; }
.theme-paper .prose a { color: var(--c-brand); }
.prose ul { padding-left: 1.2em; display: grid; gap: var(--sp-2xs); }
.placeholder-note {
  font-family: var(--font-mono);
  font-size: var(--step--1);
  color: var(--c-accent);
  border: 1px dashed color-mix(in srgb, var(--c-accent) 50%, transparent);
  border-radius: var(--r-md);
  padding: 0.6em 0.9em;
  /* Block-level but hugging its content: inline-block baseline-aligns and can
     ride up over the preceding paragraph when its text wraps. */
  display: block;
  width: fit-content;
  max-width: 100%;
}

/* FAQ accordion: keep closed answers fully out of flow so they can't overflow
   their collapsed summary and overlap following content. */
.faq:not([open]) > :not(summary) { display: none; }

/* About / team */
.team { display: grid; gap: var(--sp-lg); }
@media (min-width: 640px) { .team { grid-template-columns: repeat(3, 1fr); } }
.member__photo {
  aspect-ratio: 3 / 4;
  border-radius: var(--r-lg);
  background: linear-gradient(160deg, var(--c-surface-2), var(--c-surface));
  border: 1px solid var(--c-line);
  display: grid; place-items: center;
  overflow: hidden;
}
.member__initials { font-family: var(--font-display); font-size: var(--step-5); color: var(--c-faint); }
.member h3 { font-size: var(--step-1); margin-top: var(--sp-md); font-family: var(--font-display); }
.member p { color: var(--c-muted); font-size: var(--step--1); }

/* Values list */
.values { display: grid; gap: var(--sp-lg); }
@media (min-width: 760px) { .values { grid-template-columns: repeat(3, 1fr); } }
.value { padding-top: var(--sp-md); border-top: 1px solid var(--c-line); }
.theme-paper .value { border-color: var(--c-paper-line); }
.value svg { width: 36px; height: 36px; color: var(--c-accent); margin-bottom: var(--sp-md); }
.theme-paper .value svg { color: var(--c-accent-deep); }
.value h3 { font-size: var(--step-1); font-family: var(--font-display); }
.value p { color: var(--c-muted); margin-top: var(--sp-2xs); }
.theme-paper .value p { color: var(--c-paper-muted); }

/* Logo wall (clients — demo) */
.logo-wall { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px;
  background: var(--c-line); border: 1px solid var(--c-line); border-radius: var(--r-lg); overflow: hidden; }
@media (min-width: 640px) { .logo-wall { grid-template-columns: repeat(4, 1fr); } }
.logo-wall__cell { background: var(--c-bg); display: grid; place-items: center;
  padding: var(--sp-lg); aspect-ratio: 16 / 7; }
.logo-wall__cell span { font-family: var(--font-display); font-size: var(--step-1);
  color: var(--c-faint); letter-spacing: 0.02em; transition: color var(--dur-2); }
.logo-wall__cell:hover span { color: var(--c-ink); }
