/* ============================================================
   SOLMEN — Website (solmen.ch)
   Static, CMS-portable. Layout on top of tokens.css.
   ============================================================ */
@import url("tokens.css");

html, body { background: var(--papier); margin: 0; }
body { font-family: var(--font-sans); color: var(--fg); min-height: 100vh; }

/* page-entry: opacity-only fade (per motion rules).
   Base state is always visible; the fade is a pure enhancement that
   can never leave content hidden. */
@media (prefers-reduced-motion: no-preference) {
  .pagefade { animation: pageIn var(--dur-3) var(--ease) both; }
  @keyframes pageIn { from { opacity: 0; } to { opacity: 1; } }
}

/* ---------- Grid spine ---------- */
:root {
  --rail-width: 240px;
  --rail-gap: 56px;
  --section-indent: calc(var(--rail-width) + var(--rail-gap));
}

.container { max-width: 1320px; margin: 0 auto; padding: 0 56px; }
@media (max-width: 880px) { .container { padding: 0 24px; } }

/* ---------- Sections ---------- */
.section { padding: 96px 0; border-top: 1px solid var(--linie); }
.section--tight { padding: 72px 0; }
.section--first { border-top: 0; }
.section--sunken { background: var(--papier-tief); }
.section--inv { background: var(--siegel); color: var(--papier); }
.section--inv .eyebrow, .section--inv .label { color: var(--fg-inv-2); }
.section--inv .h1, .section--inv .h2, .section--inv .h3 { color: var(--papier); }

/* ---------- Navigation ---------- */
.nav {
  position: sticky; top: 0; z-index: 30;
  background: rgba(242, 237, 227, 0.92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-2) var(--ease);
}
.nav.is-scrolled { border-bottom-color: var(--linie); }
.nav__inner { display: flex; align-items: center; justify-content: space-between; height: 72px; gap: 24px; }
.nav__logo { border: 0; display: block; }
.nav__logo img { height: 26px; display: block; }
.nav__right { display: flex; align-items: center; gap: 36px; }
.nav__links { display: flex; gap: 32px; align-items: center; }
.nav__link {
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  color: var(--tinte); text-decoration: none; border: 0;
  transition: opacity var(--dur-1) var(--ease); white-space: nowrap;
}
.nav__link:hover { opacity: 0.6; }
.nav__link--accent { color: var(--oxblut); }
.nav__lang {
  display: flex; gap: 8px; align-items: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--graphit);
}
.nav__lang button { background: none; border: 0; padding: 0; font: inherit; color: inherit; cursor: pointer; }
.nav__lang button.is-active { color: var(--tinte); }
.nav__lang button:not(.is-active):hover { opacity: 0.6; }
@media (max-width: 760px) {
  .nav__links { display: none; }
}

/* ---------- Hero ---------- */
.hero { padding: 88px 0 120px; border-top: 0; }
.hero__eyebrow { margin-bottom: 32px; }
.hero__headline {
  font-family: var(--font-serif);
  font-size: clamp(44px, 7vw, 96px);
  line-height: 1.02; letter-spacing: -0.022em; color: var(--tinte);
  margin: 0; max-width: 14ch; text-wrap: balance;
}
.hero__lead {
  margin-top: 56px; display: grid;
  grid-template-columns: var(--rail-width) minmax(0, 1fr); gap: var(--rail-gap); align-items: start;
}
@media (max-width: 880px) { .hero__lead { grid-template-columns: 1fr; gap: 32px; } }
.hero__byline {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--graphit);
  text-transform: uppercase; padding-top: 8px; border-top: 1px solid var(--tinte); line-height: 18px;
}
.hero__sub { font-family: var(--font-sans); font-size: 19px; line-height: 30px; color: var(--tinte-80); max-width: 46ch; }
.hero__sub em { font-style: normal; color: var(--tinte); border-bottom: 1px solid var(--oxblut); padding-bottom: 1px; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 32px; }

/* ---------- Section heading ---------- */
.section-head {
  display: grid; grid-template-columns: var(--rail-width) minmax(0, 1fr);
  gap: var(--rail-gap); align-items: baseline;
}
@media (max-width: 880px) { .section-head { grid-template-columns: 1fr; gap: 16px; } }
.section-head__label {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--graphit);
  text-transform: uppercase; padding-top: 16px; border-top: 2px solid var(--tinte);
}
.section-head__title {
  font-family: var(--font-serif); font-size: clamp(34px, 4.4vw, 56px); line-height: 1.08;
  letter-spacing: -0.015em; color: var(--tinte); margin: 0; max-width: 18ch; text-wrap: balance;
}
.section-head__intro {
  grid-column: 2; max-width: 52ch; margin-top: 20px;
  font-size: 17px; line-height: 27px; color: var(--tinte-80);
}
@media (max-width: 880px) { .section-head__intro { grid-column: 1; } }
.section-head--inv .section-head__label { color: var(--fg-inv-2); border-top-color: var(--papier); }
.section-head--inv .section-head__title { color: var(--papier); }
.section-head--inv .section-head__intro { color: #C7BFAF; }

/* indented content block under a section-head */
.indented { margin-left: var(--section-indent); }
@media (max-width: 1024px) { .indented { margin-left: 0; } }

/* ---------- Two-column "Was wir tun / Und was nicht" ---------- */
.what { margin-top: 56px; display: grid; grid-template-columns: 1fr 1fr; border-top: 2px solid var(--tinte); }
@media (max-width: 880px) { .what { grid-template-columns: 1fr; } }
.what__col { padding: 48px 40px 52px; }
.what__col:first-child { border-right: 1px solid var(--linie); }
@media (max-width: 880px) {
  .what__col { padding: 40px 0 8px; }
  .what__col:first-child { border-right: 0; border-bottom: 1px solid var(--linie); padding-bottom: 40px; }
}
.what__head { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--graphit); text-transform: uppercase; margin-bottom: 24px; }
.what__head--accent { color: var(--oxblut); }
.what__title { font-family: var(--font-serif); font-size: 32px; line-height: 38px; letter-spacing: -0.01em; color: var(--tinte); margin: 0 0 28px; }
.what__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; }
.what__item { display: flex; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--linie); font-size: 16px; line-height: 24px; color: var(--tinte-80); }
.what__item:last-child { border-bottom: 0; }
.what__item-num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--stein); width: 28px; flex-shrink: 0; padding-top: 4px; }

/* ---------- Method (process) ---------- */
.method { margin-top: 56px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.method--3 { grid-template-columns: repeat(3, 1fr); gap: 48px; }
@media (max-width: 880px) { .method { grid-template-columns: 1fr 1fr; gap: 32px 24px; } }
@media (max-width: 760px) { .method--3 { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 520px) { .method { grid-template-columns: 1fr; } }
.method__step { display: flex; flex-direction: column; gap: 12px; min-width: 0; overflow-wrap: break-word; }
.method__num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--oxblut); text-transform: uppercase; }
.method__rule { width: 32px; height: 1px; background: var(--tinte); margin-bottom: 4px; }
.method__title { font-family: var(--font-serif); font-size: 22px; line-height: 28px; color: var(--tinte); margin: 0; text-wrap: balance; }
.method__body { font-family: var(--font-sans); font-size: 14px; line-height: 22px; color: var(--graphit); }
.method__q { font-family: var(--font-serif); font-style: italic; font-size: 15px; line-height: 20px; color: var(--oxblut); margin-top: -4px; }

/* ---------- Mandate / audience cards ---------- */
.mandat-grid { margin-top: 56px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--linie); border: 1px solid var(--linie); }
@media (max-width: 880px) { .mandat-grid { grid-template-columns: 1fr; } }
.mandat-card { background: var(--papier-hell); padding: 40px 32px 44px; display: flex; flex-direction: column; gap: 16px; min-height: 280px; }
.mandat-card__head { display: flex; align-items: center; gap: 12px; }
.mandat-card__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--graphit); text-transform: uppercase; }
.mandat-card__title { font-family: var(--font-serif); font-size: 26px; line-height: 32px; color: var(--tinte); margin: 4px 0 0; }
.mandat-card__body { font-family: var(--font-sans); font-size: 14px; line-height: 22px; color: var(--graphit); margin-top: auto; padding-top: 16px; border-top: 1px solid var(--linie); }

/* ---------- Icon (mask, recolours SVG to ink) ---------- */
.icon { display: inline-block; flex-shrink: 0; width: 28px; height: 28px; background: var(--tinte);
  -webkit-mask: var(--ic) center / contain no-repeat; mask: var(--ic) center / contain no-repeat; }
.icon--accent { background: var(--oxblut); }
.icon--inv { background: var(--papier); }
.icon--graphit { background: var(--graphit); }

/* ---------- Editorial quote ---------- */
.quote { max-width: 920px; }
.quote__mark { font-family: var(--font-serif); font-size: 96px; line-height: 1; color: var(--oxblut); margin-bottom: -16px; display: block; }
.quote__text { font-family: var(--font-serif); font-size: clamp(26px, 3.6vw, 44px); line-height: 1.2; letter-spacing: -0.01em; color: var(--tinte); margin: 0; }
.quote__attr { margin-top: 32px; font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--graphit); text-transform: uppercase; display: flex; align-items: center; gap: 12px; }
.quote__attr::before { content: ""; display: inline-block; width: 32px; height: 1px; background: var(--tinte); }

/* ---------- Contact (inverted) ---------- */
.contact { margin-left: var(--section-indent); display: grid; grid-template-columns: 1fr 1fr; gap: var(--rail-gap); align-items: start; }
@media (max-width: 880px) { .contact { margin-left: 0; grid-template-columns: 1fr; } }
.contact__title { font-family: var(--font-serif); font-size: clamp(38px, 5vw, 64px); line-height: 1.05; letter-spacing: -0.015em; color: var(--papier); margin: 0; }
.contact__sub { font-family: var(--font-sans); font-size: 16px; line-height: 24px; color: #B8B0A0; margin: 24px 0 32px; max-width: 38ch; }
.contact__details { font-family: var(--font-mono); font-size: 13px; line-height: 22px; color: #B8B0A0; letter-spacing: 0.02em; }
.contact__details .row { display: grid; grid-template-columns: 120px 1fr; padding: 10px 0; border-bottom: 1px solid var(--rule-inv); gap: 12px; }
.contact__details strong { color: var(--papier); font-weight: 500; }

/* ---------- Footer ---------- */
.footer { background: var(--papier-tief); padding: 64px 0 32px; border-top: 1px solid var(--linie); }
.footer__grid { display: grid; grid-template-columns: var(--rail-width) repeat(3, minmax(0,1fr)); gap: var(--rail-gap); margin-bottom: 48px; }
@media (max-width: 880px) { .footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; } }
.footer__col h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--graphit); text-transform: uppercase; margin: 0 0 16px; font-weight: 500; }
.footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.footer__col a { font-family: var(--font-sans); font-size: 14px; color: var(--tinte); text-decoration: none; border: 0; }
.footer__col a:hover { opacity: 0.6; }
.footer__blurb { font-family: var(--font-sans); font-size: 13px; line-height: 20px; color: var(--graphit); max-width: 280px; margin: 16px 0 0; }
.footer__legal { display: flex; justify-content: space-between; align-items: center; gap: 24px; padding-top: 24px; border-top: 1px solid var(--linie); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--graphit); flex-wrap: wrap; }

/* ============================================================
   INVESTOR PAGE — components
   ============================================================ */

/* Hairline metric row (no count-up; numbers appear, they do not animate) */
.metrics { margin-top: 56px; display: grid; grid-template-columns: repeat(4, 1fr); border-top: 2px solid var(--tinte); }
@media (max-width: 880px) { .metrics { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .metrics { grid-template-columns: 1fr; } }
.metric { padding: 28px 28px 32px; border-bottom: 1px solid var(--linie); border-right: 1px solid var(--linie); min-width: 0; overflow-wrap: break-word; }
.metric:nth-child(4n) { border-right: 0; }
@media (max-width: 880px) { .metric:nth-child(4n) { border-right: 1px solid var(--linie); } .metric:nth-child(2n) { border-right: 0; } }
@media (max-width: 460px) { .metric { border-right: 0 !important; } }
.metric__val { font-family: var(--font-serif); font-size: 40px; line-height: 1; letter-spacing: -0.01em; color: var(--tinte); }
.metric__val small { font-size: 22px; color: var(--graphit); }
.metric__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--graphit); margin-top: 14px; line-height: 16px; }
.metric__note { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; color: var(--stein); margin-top: 6px; }

/* The gap — competitor rows */
.gap { margin-top: 56px; display: flex; flex-direction: column; border-top: 2px solid var(--tinte); }
.gap__row { display: grid; grid-template-columns: var(--rail-width) minmax(0,1fr) 220px; gap: var(--rail-gap); padding: 28px 0; border-bottom: 1px solid var(--linie); align-items: start; }
@media (max-width: 880px) { .gap__row { grid-template-columns: 1fr; gap: 8px; } }
.gap__who { font-family: var(--font-sans); font-weight: 500; font-size: 17px; color: var(--tinte); }
.gap__who small { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--stein); margin-top: 6px; }
.gap__limit { font-size: 15px; line-height: 23px; color: var(--tinte-80); min-width: 0; }
.gap__verdict { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--oxblut); padding-top: 2px; }
.gap__row--us { border-bottom: 0; background: var(--papier-hell); margin: 0 -24px; padding: 32px 24px; grid-template-columns: var(--rail-width) minmax(0,1fr) 220px; border-top: 2px solid var(--tinte); }
@media (max-width: 880px) { .gap__row--us { grid-template-columns: 1fr; margin: 0; } }
.gap__row--us .gap__who { color: var(--oxblut); }
.gap__row--us .gap__verdict { color: var(--signal-ok); }

/* Model / tiers ladder */
.tiers { margin-top: 56px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--linie); border: 1px solid var(--linie); }
@media (max-width: 760px) { .tiers { grid-template-columns: 1fr; } }
.tier { background: var(--papier-hell); padding: 32px 28px 36px; display: flex; flex-direction: column; gap: 14px; min-width: 0; }
.tier__step { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--oxblut); }
.tier__name { font-family: var(--font-serif); font-size: 24px; line-height: 28px; color: var(--tinte); margin: 0; }
.tier__desc { font-size: 14px; line-height: 22px; color: var(--graphit); }
.tier__proc { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--tinte-80); margin-top: auto; padding-top: 14px; border-top: 1px solid var(--linie); }

/* Two-up text blocks (problem manifestations, validate list) */
.cols2 { margin-top: 48px; display: grid; grid-template-columns: 1fr 1fr; gap: var(--rail-gap); }
@media (max-width: 880px) { .cols2 { grid-template-columns: 1fr; gap: 32px; } }
.factlist { list-style: none; margin: 0; padding: 0; }
.factlist li { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--linie); font-size: 15px; line-height: 23px; color: var(--tinte-80); }
.factlist li:last-child { border-bottom: 0; }
.factlist .ic { width: 20px; height: 20px; margin-top: 2px; }
.block__h { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--graphit); margin-bottom: 18px; }
.block__h--accent { color: var(--oxblut); }
.block__h--ok { color: var(--signal-ok); }

/* Team */
.team { margin-top: 56px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
@media (max-width: 880px) { .team { grid-template-columns: 1fr; gap: 1px; background: var(--linie); border: 1px solid var(--linie); } }
.member { display: flex; flex-direction: column; gap: 8px; }
@media (max-width: 880px) { .member { background: var(--papier-hell); padding: 28px 24px; } }
.member__photo {
  width: 100%; aspect-ratio: 4 / 5; background: var(--papier-tief);
  border: 1px solid var(--linie); margin-bottom: 16px; position: relative; overflow: hidden;
  background-image: repeating-linear-gradient(135deg, transparent 0 11px, rgba(92,86,74,0.06) 11px 12px);
}
.member__photo span { position: absolute; left: 12px; bottom: 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--stein); }
.member__photo img, .founder-feature__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
.member__name { font-family: var(--font-serif); font-size: 22px; line-height: 26px; color: var(--tinte); }
.member__role { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--oxblut); }
.member__bio { font-size: 14px; line-height: 22px; color: var(--graphit); margin-top: 4px; }

/* Pull statement / vision band */
.statement { margin-top: 8px; max-width: 24ch; }
.statement__big { font-family: var(--font-serif); font-size: clamp(28px, 3.6vw, 44px); line-height: 1.18; letter-spacing: -0.01em; color: var(--papier); margin: 0; }
.statement__big em { font-style: normal; color: var(--oxblut-licht); }

/* Investment terms list (inverted) */
.terms { display: flex; flex-direction: column; }
.terms .row { display: grid; grid-template-columns: 1fr auto; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--rule-inv); align-items: baseline; }
.terms .row:last-child { border-bottom: 0; }
.terms__k { font-family: var(--font-sans); font-size: 15px; color: #C7BFAF; }
.terms__v { font-family: var(--font-mono); font-size: 14px; letter-spacing: 0.02em; color: var(--papier); text-align: right; }
.terms__v small { color: var(--fg-inv-2); }

/* Disclaimer footnote */
.disclaimer { margin-top: 40px; font-family: var(--font-mono); font-size: 11px; line-height: 18px; letter-spacing: 0.02em; color: var(--stein); max-width: 70ch; padding-top: 16px; border-top: 1px solid var(--linie); }
.disclaimer b { color: var(--graphit); font-weight: 500; }

/* small inline confidential tag */
.tag-conf { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--oxblut); border: 1px solid #E5C9C6; background: var(--oxblut-papier); padding: 4px 10px; border-radius: var(--r-pill); }

/* generic prose lead */
.lead { font-size: 19px; line-height: 30px; color: var(--tinte-80); max-width: 50ch; }
.lead em { font-style: normal; color: var(--tinte); border-bottom: 1px solid var(--oxblut); padding-bottom: 1px; }

/* qualitative metric tiles (no figures) */
.metrics--text .metric__val { font-size: 25px; line-height: 30px; }

/* emotional coda under the mandate two-column block */
.what__coda { margin-top: 48px; font-family: var(--font-serif); font-size: clamp(26px, 3.2vw, 38px); line-height: 1.22; letter-spacing: -0.012em; color: var(--tinte); max-width: 22ch; text-wrap: balance; }
.what__coda em { font-style: normal; color: var(--oxblut); }

/* market sectors */
.sectors { margin-top: 56px; display: grid; grid-template-columns: repeat(5, 1fr); gap: 1px; background: var(--linie); border: 1px solid var(--linie); }
@media (max-width: 760px) { .sectors { grid-template-columns: 1fr 1fr; } }
.sector { background: var(--papier-hell); padding: 28px 22px; display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.sector__idx { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--oxblut); }
.sector__name { font-family: var(--font-serif); font-size: 20px; line-height: 24px; color: var(--tinte); text-wrap: balance; }

/* team — founders + featured advisor */
.founders { margin-top: 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
@media (max-width: 760px) { .founders { grid-template-columns: 1fr; gap: 36px; } }
.founders .member__photo { background-color: var(--papier-hell); }
.founder-feature { margin-top: 32px; display: grid; grid-template-columns: 300px minmax(0, 1fr); gap: 48px; align-items: center; background: var(--papier-hell); border: 1px solid var(--linie); border-left: 2px solid var(--oxblut); padding: 40px; }
@media (max-width: 760px) { .founder-feature { grid-template-columns: 1fr; gap: 24px; padding: 28px; } }
.founder-feature__photo { aspect-ratio: 4 / 5; background: var(--papier-tief); border: 1px solid var(--linie); position: relative; overflow: hidden; background-image: repeating-linear-gradient(135deg, transparent 0 11px, rgba(92,86,74,0.06) 11px 12px); }
.founder-feature__photo span { position: absolute; left: 12px; bottom: 12px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--stein); }
.founder-feature__role { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--oxblut); }
.founder-feature__name { font-family: var(--font-serif); font-size: clamp(30px, 3.6vw, 44px); line-height: 1.05; letter-spacing: -0.015em; color: var(--tinte); margin: 8px 0 0; }
.founder-feature__meta { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--graphit); margin-top: 12px; }
.founder-feature__stmt { font-family: var(--font-serif); font-size: 21px; line-height: 30px; color: var(--tinte-80); margin: 20px 0 0; max-width: 48ch; }

/* ============================================================
   LEGAL PAGES — Impressum / Datenschutz
   ============================================================ */
.legal-hero { padding: 80px 0 8px; border-top: 0; }
.legal-hero .eyebrow { margin-bottom: 24px; }
.legal-hero__title { font-family: var(--font-serif); font-size: clamp(40px, 6vw, 72px); line-height: 1.04; letter-spacing: -0.02em; color: var(--tinte); margin: 0; max-width: 16ch; }
.legal-hero__updated { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--graphit); margin-top: 24px; }

.legal { max-width: 760px; margin: 56px 0 0; }
.legal__sec { padding: 36px 0; border-top: 1px solid var(--linie); }
.legal__sec:first-child { border-top: 2px solid var(--tinte); }
.legal__num { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--oxblut); margin-bottom: 12px; }
.legal__h { font-family: var(--font-serif); font-size: 26px; line-height: 32px; letter-spacing: -0.01em; color: var(--tinte); margin: 0 0 16px; }
.legal p { font-size: 16px; line-height: 25px; color: var(--tinte-80); margin: 0 0 12px; }
.legal p:last-child { margin-bottom: 0; }
.legal strong { color: var(--tinte); font-weight: 500; }
.legal a { color: var(--oxblut); }
.legal ul { list-style: none; margin: 8px 0 12px; padding: 0; }
.legal li { display: flex; gap: 12px; padding: 8px 0; border-bottom: 1px solid var(--linie-fein); font-size: 15px; line-height: 23px; color: var(--tinte-80); }
.legal li:last-child { border-bottom: 0; }
.legal li::before { content: "—"; color: var(--stein); flex-shrink: 0; }
.legal__meta { display: grid; grid-template-columns: 180px minmax(0,1fr); gap: 2px 20px; margin-top: 4px; }
@media (max-width: 560px) { .legal__meta { grid-template-columns: 1fr; gap: 2px; } }
.legal__meta dt { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--graphit); padding: 8px 0; }
.legal__meta dd { margin: 0; padding: 8px 0; font-size: 16px; line-height: 24px; color: var(--tinte); }
@media (min-width: 561px) { .legal__meta dt, .legal__meta dd { border-top: 1px solid var(--linie-fein); } .legal__meta dt:first-of-type, .legal__meta dd:first-of-type { border-top: 0; } }
.ph { font-family: var(--font-mono); font-size: 0.92em; color: var(--oxblut); background: var(--oxblut-papier); padding: 1px 6px; border-radius: var(--r-1); }
