/* =========================================================================
   Thonik — Base Stylesheet
   Reset · Typografie · Layout · Komponenten
   Lädt nach tokens.css. Mobile-first, WCAG-AA.
   ========================================================================= */

/* --- Fonts (self-hosted, font-display: swap) ----------------------------- */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("/fonts/Inter-Variable.woff2") format("woff2");
}
@font-face {
  font-family: "Inter Display";
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url("/fonts/InterDisplay-Variable.woff2") format("woff2");
}

/* --- Reset --------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; color: inherit; }
button { cursor: pointer; background: none; border: none; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; padding: 0; }
table { border-collapse: collapse; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* --- Typografie ---------------------------------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  line-height: var(--lh-heading);
  color: var(--brand-primary);
  letter-spacing: -0.01em;
  text-wrap: balance;
}
h1 { font-size: clamp(2.25rem, 5vw, 3.75rem); line-height: var(--lh-display); letter-spacing: -0.02em; }
h2 { font-size: clamp(1.875rem, 3.5vw, 2.25rem); }
h3 { font-size: var(--fs-xl); }
h4 { font-size: var(--fs-lg); }
p { max-width: 68ch; }
strong { font-weight: var(--fw-semibold); }
.lead { font-size: var(--fs-md); color: var(--text); }
.muted { color: var(--text-muted); }
.eyebrow {
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-block;
}
.tabular { font-variant-numeric: tabular-nums; }

/* --- Layout -------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.section { padding-block: var(--space-9); }
.section--tight { padding-block: var(--space-7); }
.section--subtle { background: var(--bg-subtle); }
.section--dark {
  background: var(--brand-primary-900);
  color: var(--text-on-dark);
}
.section--dark h1, .section--dark h2, .section--dark h3 { color: var(--text-on-dark); }
.section__head { max-width: 60ch; margin-bottom: var(--space-6); }
.section__head .lead { margin-top: var(--space-3); color: var(--text-muted); }

.grid { display: grid; gap: var(--space-5); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; } }

/* --- Skip-Link (a11y) ---------------------------------------------------- */
.skip-link {
  position: absolute;
  left: var(--space-4);
  top: -100px;
  z-index: 1000;
  background: var(--brand-primary);
  color: var(--text-on-dark);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-btn);
  transition: top var(--t-fast) var(--ease);
}
.skip-link:focus { top: var(--space-4); }

/* --- Buttons ------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-btn);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  line-height: 1.2;
  text-align: center;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  border: 1.5px solid transparent;
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--accent); color: #fff; }
.btn--primary:hover { background: var(--accent-700); }
.btn--secondary { background: var(--brand-primary); color: var(--text-on-dark); }
.btn--secondary:hover { background: var(--brand-primary-700); }
.btn--ghost { background: transparent; color: var(--brand-primary); border-color: var(--border); }
.btn--ghost:hover { border-color: var(--brand-primary); background: var(--bg-card); }
.btn--on-dark { background: transparent; color: var(--text-on-dark); border-color: var(--border-dark); }
.btn--on-dark:hover { background: rgba(244, 239, 230, 0.08); }
/* WhatsApp — eigener Wiedererkennungs-Stil (offizielles WhatsApp-Grün) */
.btn--wa { background: transparent; color: #1B9E4B; border-color: #25D366; }
.btn--wa svg { color: #25D366; }
.btn--wa:hover { background: #25D366; color: #fff; border-color: #25D366; }
.btn--wa:hover svg { color: #fff; }
.chip--wa { border-color: #25D366; }
.chip--wa svg { color: #25D366; }
.chip--wa:hover { border-color: #1EBE5B; background: rgba(37, 211, 102, 0.07); }
.link-wa { color: #25D366; font-weight: var(--fw-semibold); }
.link-wa:hover { color: #1EBE5B; }
.btn--lg { padding: var(--space-4) var(--space-6); font-size: var(--fs-md); }
.btn--block { width: 100%; }
.btn[disabled], .btn[aria-busy="true"] { opacity: 0.6; pointer-events: none; }

/* --- Fokus-Sichtbarkeit (a11y) ------------------------------------------- */
:where(a, button, input, textarea, select, summary, [tabindex]):focus-visible {
  outline: 3px solid var(--accent);
  outline-offset: 2px;
  border-radius: 2px;
}

/* --- Cards --------------------------------------------------------------- */
.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.card--link:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }
.card__icon {
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border-radius: var(--radius-btn);
  background: var(--bg-subtle);
  color: var(--accent);
  margin-bottom: var(--space-4);
}
.card h3 { font-size: var(--fs-lg); margin-bottom: var(--space-2); }
.card p { color: var(--text-muted); font-size: var(--fs-sm); }
.card__more {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: var(--space-4);
  color: var(--accent); font-weight: var(--fw-semibold); font-size: var(--fs-sm);
}
.card__more:hover { color: var(--accent-700); }

/* --- Hero ---------------------------------------------------------------- */
.hero { padding-block: var(--space-9) var(--space-8); }
.hero__inner { display: grid; gap: var(--space-7); align-items: center; }
@media (min-width: 901px) { .hero__inner { grid-template-columns: 1.1fr 0.9fr; } }
.hero h1 { margin-bottom: var(--space-4); }
.hero .lead { margin-bottom: var(--space-6); max-width: 52ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* Dual-Value-Prop: zwei Pfade */
.paths { display: grid; gap: var(--space-4); }
@media (min-width: 560px) { .paths { grid-template-columns: 1fr 1fr; } }
.path {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-tile);
  padding: var(--space-6);
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.path--primary { border-color: var(--accent); border-width: 1.5px; }
.path h2 { font-size: var(--fs-lg); }
.path p { font-size: var(--fs-sm); color: var(--text-muted); flex: 1; }

/* --- Trust-Band ---------------------------------------------------------- */
.trustband { background: var(--brand-primary); color: var(--text-on-dark); }
.trustband ul {
  display: flex; flex-wrap: wrap; gap: var(--space-5);
  justify-content: space-between;
  padding-block: var(--space-5);
}
.trustband li {
  display: flex; align-items: center; gap: var(--space-3);
  font-size: var(--fs-sm); font-weight: var(--fw-medium);
  flex: 1 1 220px;
}
.trustband svg { color: var(--accent); flex-shrink: 0; }

/* --- 4-Schritte-Prozess (Stepper) ---------------------------------------- */
.steps { display: grid; gap: var(--space-5); counter-reset: step; }
@media (min-width: 768px) { .steps { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 768px) { .steps--3 { grid-template-columns: repeat(3, 1fr); } }
.step { position: relative; padding-top: calc(40px + var(--space-4)); }
.step__num {
  position: absolute; top: 0; left: 0;
  width: 40px; height: 40px;
  display: grid; place-items: center;
  background: var(--accent); color: #fff;
  border-radius: 50%;
  font-family: var(--font-display); font-weight: var(--fw-bold);
}
.step h3 { font-size: var(--fs-md); margin-bottom: var(--space-2); }
.step p { font-size: var(--fs-sm); color: var(--text-muted); }

/* --- FAQ-Akkordeon (<details>/<summary>) --------------------------------- */
.faq { max-width: 800px; }
.faq__item {
  border-bottom: 1px solid var(--border);
}
.faq__item summary {
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-4);
  padding: var(--space-5) 0;
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-md);
  color: var(--brand-primary);
  cursor: pointer;
  list-style: none;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item summary::after {
  content: "+";
  font-size: var(--fs-xl); font-weight: var(--fw-regular);
  color: var(--accent);
  transition: transform var(--t-fast) var(--ease);
  flex-shrink: 0;
}
.faq__item[open] summary::after { transform: rotate(45deg); }
.faq__item .faq__answer { padding-bottom: var(--space-5); color: var(--text); }
.faq__item .faq__answer p { color: var(--text-muted); }

/* --- Formulare ----------------------------------------------------------- */
.form { display: grid; gap: var(--space-5); }
.form__row { display: grid; gap: var(--space-5); }
@media (min-width: 640px) { .form__row--2 { grid-template-columns: 1fr 1fr; } }
.field { display: grid; gap: var(--space-2); }
.field > label { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text); }
.field .req { color: var(--accent); }
.field .hint { font-size: var(--fs-xs); color: var(--text-muted); }
.field input,
.field textarea,
.field select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-btn);
  background: var(--bg-card);
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.field input:focus,
.field textarea:focus,
.field select:focus {
  outline: none;
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 3px rgb(16 42 67 / 0.10);
}
.field textarea { min-height: 120px; resize: vertical; }
.field--required input,
.field--required textarea,
.field--required select { border-left: 3px solid var(--warning); }
.field--error input,
.field--error textarea,
.field--error select { border-color: var(--error); }

/* Radio-Gruppe (Zustand) */
.radio-group { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.radio-group label {
  display: inline-flex; align-items: center; gap: 6px;
  padding: var(--space-2) var(--space-4);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-btn);
  cursor: pointer; font-size: var(--fs-sm);
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.radio-group input { accent-color: var(--accent); }
.radio-group label:has(input:checked) { border-color: var(--accent); background: #fff; }

/* Consent / Checkbox */
.consent { display: flex; gap: var(--space-3); align-items: flex-start; font-size: var(--fs-sm); }
.consent input { margin-top: 3px; accent-color: var(--accent); flex-shrink: 0; }
.consent a { color: var(--accent); text-decoration: underline; }

/* File-Upload */
.field input[type="file"] {
  padding: var(--space-3);
  background: var(--bg-subtle);
  border-style: dashed;
}

/* Honeypot — visuell und für Screenreader versteckt, aber im DOM */
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px; height: 1px;
  overflow: hidden;
}

/* WhatsApp-Affordance neben Submit */
.form__submit-row { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-4); }
.wa-hint { font-size: var(--fs-sm); color: var(--text-muted); }
.wa-hint a { color: #25D366; font-weight: var(--fw-semibold); }

/* Form-Status (SSR-Fehler / clientseitig) */
.form__status { padding: var(--space-4); border-radius: var(--radius-btn); font-size: var(--fs-sm); }
.form__status--error { background: #FBEAE9; color: var(--error); border: 1px solid #F1C9C6; }
.form__status--success { background: var(--success-bg); color: var(--success); border: 1px solid #BFE0CD; }

/* --- CTA-Band ------------------------------------------------------------ */
.cta-band { background: var(--brand-primary-900); color: var(--text-on-dark); }
.cta-band__inner {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between;
  gap: var(--space-5); padding-block: var(--space-7);
}
.cta-band h2 { color: var(--text-on-dark); }
.cta-band .actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* --- Direktkontakt-Chips ------------------------------------------------- */
.contact-chips { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-btn);
  background: var(--bg-card);
  font-weight: var(--fw-medium); font-size: var(--fs-sm);
}
.chip svg { color: var(--accent); }
.chip:hover { border-color: var(--brand-primary); }

/* --- Fade-up Scroll-Animation ------------------------------------------- */
.fade-up { opacity: 0; transform: translateY(12px); transition: opacity var(--t-mid) var(--ease), transform var(--t-mid) var(--ease); }
.fade-up.is-visible { opacity: 1; transform: none; }
.no-js .fade-up { opacity: 1; transform: none; }

/* --- Prose (Impressum/Datenschutz) -------------------------------------- */
.prose { max-width: 760px; }
.prose h2 { margin-top: var(--space-7); margin-bottom: var(--space-3); font-size: var(--fs-xl); }
.prose h3 { margin-top: var(--space-5); margin-bottom: var(--space-2); font-size: var(--fs-md); }
.prose p, .prose ul { margin-bottom: var(--space-4); color: var(--text); }
.prose ul { list-style: disc; padding-left: var(--space-5); }
.prose li { margin-bottom: var(--space-2); }
.prose a { color: var(--accent); text-decoration: underline; }

/* --- Header / Nav -------------------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(244, 239, 230, 0.92);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-header);
}
.site-header__inner {
  display: flex; align-items: center; gap: var(--space-5);
  height: var(--header-h);
}
.brand { display: inline-flex; align-items: center; gap: var(--space-3); font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-lg); color: var(--brand-primary); }
.brand svg, .brand img { height: 28px; width: auto; }
.nav { display: flex; align-items: center; gap: var(--space-5); margin-left: auto; }
.nav__links { display: flex; gap: var(--space-5); }
.nav__links a { font-size: var(--fs-sm); font-weight: var(--fw-medium); color: var(--text); padding-block: var(--space-2); border-bottom: 2px solid transparent; transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); }
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--brand-primary); border-color: var(--accent); }
.nav__meta { display: flex; align-items: center; gap: var(--space-3); }
.lang-switch { display: flex; gap: 2px; font-size: var(--fs-sm); font-weight: var(--fw-medium); }
.lang-switch a { padding: 2px 6px; border-radius: 3px; color: var(--text-muted); }
.lang-switch a[aria-current="true"] { color: var(--brand-primary); background: var(--bg-card); }

.nav-toggle { display: none; width: 44px; height: 44px; margin-left: auto; align-items: center; justify-content: center; }
.nav-toggle svg { color: var(--brand-primary); }

@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; }
  .nav {
    position: fixed; inset: var(--header-h) 0 auto 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--bg); border-bottom: 1px solid var(--border);
    margin-left: 0; padding: var(--space-4) var(--gutter) var(--space-5);
    transform: translateY(-110%);
    visibility: hidden; pointer-events: none;
    transition: transform var(--t-mid) var(--ease), visibility 0s linear var(--t-mid);
    box-shadow: var(--shadow-header);
  }
  .nav.is-open { transform: translateY(0); visibility: visible; pointer-events: auto; transition: transform var(--t-mid) var(--ease); }
  .nav__links { flex-direction: column; gap: 0; }
  .nav__links a { padding: var(--space-4) 0; border-bottom: 1px solid var(--border); }
  .nav__meta { margin-top: var(--space-4); justify-content: space-between; }
}

/* --- Footer -------------------------------------------------------------- */
.site-footer { background: var(--brand-primary-900); color: var(--text-on-dark); padding-block: var(--space-8) var(--space-6); }
.site-footer a { color: var(--text-on-dark); }
.footer-grid { display: grid; gap: var(--space-6); grid-template-columns: 1.5fr 1fr 1fr; }
@media (max-width: 768px) { .footer-grid { grid-template-columns: 1fr; gap: var(--space-6); } }
.site-footer .footer__title { color: var(--text-on-dark); font-size: var(--fs-sm); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: var(--space-4); opacity: 0.8; }
.site-footer .brand { color: var(--text-on-dark); margin-bottom: var(--space-4); }
.footer-nav li, .footer-contact li { margin-bottom: var(--space-3); font-size: var(--fs-sm); }
.footer-nav a:hover, .footer-contact a:hover { color: var(--accent); }
.footer-bottom {
  display: flex; flex-wrap: wrap; gap: var(--space-4); justify-content: space-between;
  margin-top: var(--space-7); padding-top: var(--space-5);
  border-top: 1px solid var(--border-dark);
  font-size: var(--fs-xs); color: rgba(244, 239, 230, 0.7);
}
.footer-bottom a:hover { color: var(--accent); }

/* --- Cookie-Banner (minimal, funktional) -------------------------------- */
.cookie-banner {
  position: fixed; left: var(--space-4); right: var(--space-4); bottom: var(--space-4);
  z-index: 200; max-width: 640px; margin-inline: auto;
  background: var(--brand-primary-900); color: var(--text-on-dark);
  border-radius: var(--radius-card); box-shadow: 0 8px 32px rgb(10 28 46 / 0.4);
  padding: var(--space-5);
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-4);
}
.cookie-banner p { font-size: var(--fs-sm); flex: 1 1 280px; max-width: none; }
.cookie-banner a { color: var(--accent); text-decoration: underline; }
.cookie-banner[hidden] { display: none; }

/* --- Orbital-Timeline (Leistungen) -------------------------------------- */
.orbital-section { background: var(--brand-primary-900); color: var(--text-on-dark); overflow: hidden; }
.orbital-section .section__head { margin-inline: auto; text-align: center; }
.orbital-section h2 { color: var(--text-on-dark); }
.orbital-section .lead { color: rgba(244, 239, 230, 0.8); }
.orbital-hint { font-size: var(--fs-sm); color: rgba(244, 239, 230, 0.6); margin-top: var(--space-3); }

.orbital { position: relative; display: grid; place-items: center; margin-top: var(--space-7); }
.orbital__stage {
  position: relative;
  width: 100%; max-width: 620px;
  height: clamp(380px, 82vw, 500px);
  margin-inline: auto;
}
/* Zentraler Kern */
.orbital__hub {
  position: absolute; left: 50%; top: 50%;
  width: 54px; height: 54px; margin: -27px 0 0 -27px;
  border-radius: 50%;
  background: rgba(244, 239, 230, 0.08);
  display: grid; place-items: center; z-index: 5;
}
.orbital__hub::before, .orbital__hub::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid rgba(244, 239, 230, 0.25);
  animation: orbital-ping 2.4s cubic-bezier(0, 0, 0.2, 1) infinite;
}
.orbital__hub::after { animation-delay: 1.2s; }
.orbital__hub-core { width: 26px; height: 26px; border-radius: 50%; background: rgba(244, 239, 230, 0.92); }
@keyframes orbital-ping { 0% { transform: scale(1); opacity: 0.7; } 80%, 100% { transform: scale(2.1); opacity: 0; } }

.orbital__ring {
  position: absolute; left: 50%; top: 50%;
  width: 76%; aspect-ratio: 1; transform: translate(-50%, -50%);
  border: 1px solid rgba(244, 239, 230, 0.14); border-radius: 50%;
}

/* Knoten — werden per JS positioniert (transform via inline style) */
.orbital__node { position: absolute; left: 50%; top: 50%; will-change: transform; }
.orbital__node-inner { position: relative; transform: translate(-50%, -50%); }
.orbital__dot {
  width: 58px; height: 58px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--accent); color: #fff;
  border: 3px solid rgba(255, 255, 255, 0.3);
  box-shadow: 0 6px 22px rgba(232, 83, 27, 0.5);
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.orbital__dot:hover { background: var(--accent-700); }
.orbital__node.is-related .orbital__dot { background: var(--accent-700); border-color: #fff; }
.orbital__node.is-active .orbital__dot {
  background: var(--accent); color: #fff; border-color: #fff;
  transform: scale(1.45);
  box-shadow: 0 0 0 10px rgba(232, 83, 27, 0.22), 0 10px 28px rgba(232, 83, 27, 0.55);
}
.orbital__label {
  position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%);
  white-space: nowrap; font-size: var(--fs-sm); font-weight: var(--fw-bold);
  letter-spacing: 0.01em; color: #fff;
  text-shadow: 0 1px 8px rgba(10, 28, 46, 0.9);
  transition: transform var(--t-fast) var(--ease);
}
.orbital__node.is-active .orbital__label { transform: translateX(-50%) scale(1.08); }

/* Aufklapp-Karte */
.orbital__card {
  position: absolute; top: calc(100% + 28px); left: 50%; transform: translateX(-50%);
  width: 260px; max-width: 78vw; z-index: 60;
  background: var(--bg-card); color: var(--text);
  border: 1px solid var(--border); border-radius: var(--radius-card);
  box-shadow: 0 12px 32px rgb(10 28 46 / 0.45);
  padding: var(--space-5); text-align: left;
}
.orbital__card::before {
  content: ""; position: absolute; top: -7px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 12px; height: 12px; background: var(--bg-card);
  border-left: 1px solid var(--border); border-top: 1px solid var(--border);
}
.orbital__card[hidden] { display: none; }
.orbital__card h3 { font-size: var(--fs-md); margin-bottom: var(--space-2); }
.orbital__card p { font-size: var(--fs-sm); color: var(--text-muted); }
.orbital__card-related { margin-top: var(--space-4); padding-top: var(--space-3); border-top: 1px solid var(--border); }
.orbital__card-related .lbl { font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); display: block; margin-bottom: var(--space-2); }
.orbital__chip {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: var(--fs-xs); padding: 3px 8px; margin: 0 4px 4px 0;
  border: 1px solid var(--border); border-radius: var(--radius-btn);
  color: var(--brand-primary); background: var(--bg-subtle);
}
.orbital__chip:hover { border-color: var(--accent); color: var(--accent-700); }
.orbital__card-cta { display: inline-flex; align-items: center; gap: 6px; margin-top: var(--space-4); color: var(--accent); font-weight: var(--fw-semibold); font-size: var(--fs-sm); }

/* Fallback ohne JS: Karten-Grid */
.orbital__fallback { display: none; }
.no-js .orbital__stage { display: none; }
.no-js .orbital__fallback {
  display: grid; gap: var(--space-5); width: 100%;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 640px) { .no-js .orbital__fallback { grid-template-columns: 1fr; } }
.orbital__fallback .card { background: rgba(244, 239, 230, 0.06); border-color: rgba(244, 239, 230, 0.18); }
.orbital__fallback .card h3 { color: var(--text-on-dark); }
.orbital__fallback .card p { color: rgba(244, 239, 230, 0.75); }

/* --- Header-Overlay über Hero-Bild (transparent → solid bei Scroll) ------ */
body.has-hero { } /* hook */
body.has-hero .site-header:not(.is-scrolled) {
  background: transparent; border-bottom-color: transparent; box-shadow: none;
  backdrop-filter: none;
}
body.has-hero .site-header:not(.is-scrolled) .brand,
body.has-hero .site-header:not(.is-scrolled) .nav__links a,
body.has-hero .site-header:not(.is-scrolled) .lang-switch a,
body.has-hero .site-header:not(.is-scrolled) .nav-toggle { color: var(--text-on-dark); }
body.has-hero .site-header:not(.is-scrolled) .nav__links a:hover,
body.has-hero .site-header:not(.is-scrolled) .nav__links a[aria-current="page"] { border-color: var(--accent); color: #fff; }
body.has-hero .site-header:not(.is-scrolled) .lang-switch a[aria-current="true"] { background: rgba(244, 239, 230, 0.16); color: #fff; }
/* Markenzeichen hell/dunkel je nach Zustand */
.brand__mark--light { display: none; }
body.has-hero .site-header:not(.is-scrolled) .brand__mark--dark { display: none; }
body.has-hero .site-header:not(.is-scrolled) .brand__mark--light { display: block; }
/* Auf Mobile bei offenem Menü wieder lesbar (solides Panel) */
@media (max-width: 900px) {
  body.has-hero .site-header:not(.is-scrolled) .nav.is-open .nav__links a,
  body.has-hero .site-header:not(.is-scrolled) .nav.is-open .lang-switch a { color: var(--text); }
}

/* --- Hero mit Hintergrundbild ------------------------------------------- */
.hero--image {
  position: relative;
  margin-top: calc(-1 * var(--header-h));
  padding-top: calc(var(--header-h) + var(--space-9));
  padding-bottom: var(--space-9);
  background-color: var(--brand-primary-900);
  background-image: linear-gradient(180deg, rgba(10, 28, 46, 0.55) 0%, rgba(10, 28, 46, 0.35) 40%, rgba(10, 28, 46, 0.78) 100%), url("/img/hero-hafen-panorama.jpg");
  background-image: linear-gradient(180deg, rgba(10, 28, 46, 0.55) 0%, rgba(10, 28, 46, 0.35) 40%, rgba(10, 28, 46, 0.78) 100%), image-set(url("/img/hero-hafen-panorama.webp") type("image/webp"), url("/img/hero-hafen-panorama.jpg") type("image/jpeg"));
  background-size: cover; background-position: center; background-repeat: no-repeat;
  color: var(--text-on-dark);
}
.hero--image h1 { color: var(--text-on-dark); }
.hero--image .lead { color: rgba(244, 239, 230, 0.9); }
.hero--image .eyebrow { color: var(--accent); }
/* Mobil: eigenes Hochformat-Bild (Art Direction); fehlt es, greift das Panorama. */
@media (max-width: 640px) {
  .hero--image {
    background-image: linear-gradient(180deg, rgba(10, 28, 46, 0.5) 0%, rgba(10, 28, 46, 0.35) 35%, rgba(10, 28, 46, 0.82) 100%), url("/img/hero-mobil.jpg");
    background-image: linear-gradient(180deg, rgba(10, 28, 46, 0.5) 0%, rgba(10, 28, 46, 0.35) 35%, rgba(10, 28, 46, 0.82) 100%), image-set(url("/img/hero-mobil.webp") type("image/webp"), url("/img/hero-mobil.jpg") type("image/jpeg"));
  }
}

/* --- Bild-Platzhalter (bis echte Assets vorliegen) ---------------------- */
.img-ph {
  position: relative; display: grid; place-items: center;
  background: var(--bg-subtle);
  border: 1px dashed var(--border);
  border-radius: var(--radius-card);
  color: var(--text-muted); overflow: hidden;
}
.img-ph::after {
  content: attr(data-label);
  position: absolute; bottom: var(--space-3); left: var(--space-3); right: var(--space-3);
  font-size: var(--fs-xs); color: var(--text-muted); text-align: center;
}
.img-ph__icon { color: var(--brand-primary); opacity: 0.35; }
.img-ph--wide { aspect-ratio: 16 / 7; }
.img-ph--4x3 { aspect-ratio: 4 / 3; }

/* --- Responsive-Bild-Frame (pic) ---------------------------------------- */
.pic {
  position: relative; overflow: hidden;
  border-radius: var(--radius-card);
  background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-900) 100%);
}
.pic img { display: block; width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }
.pic__ph {
  position: absolute; inset: 0; z-index: 0;
  display: grid; place-items: center; gap: var(--space-2);
  padding: var(--space-4); text-align: center;
  color: rgba(244, 239, 230, 0.55); font-size: var(--fs-xs); letter-spacing: 0.04em;
}
.pic__ph svg { opacity: 0.4; }
.pic.is-missing img { display: none; }
.pic--16x7 { aspect-ratio: 16 / 7; }
.pic--3x2 { aspect-ratio: 3 / 2; }
.pic--4x3 { aspect-ratio: 4 / 3; }
.pic--1x1 { aspect-ratio: 1 / 1; }
.pic--3x4 { aspect-ratio: 3 / 4; }
.pic--4x5 { aspect-ratio: 4 / 5; }
.pic img { object-position: center; }

/* --- Kennzahlen-Band (facts) -------------------------------------------- */
.facts { background: var(--bg-subtle); }
.facts__grid { display: grid; gap: var(--space-4); grid-template-columns: repeat(4, 1fr); margin-top: var(--space-6); }
@media (max-width: 760px) { .facts__grid { grid-template-columns: repeat(2, 1fr); } }
.fact { text-align: center; padding: var(--space-5) var(--space-3); border-radius: var(--radius-card); background: var(--bg-card); border: 1px solid var(--border); }
.fact__num { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: clamp(2rem, 5vw, 3rem); line-height: 1; color: var(--brand-primary); font-variant-numeric: tabular-nums; }
.fact__num .suf { color: var(--accent); }
.fact__label { margin-top: var(--space-3); font-size: var(--fs-sm); color: var(--text-muted); max-width: 22ch; margin-inline: auto; }

/* --- Galerie / Foto-Slider ---------------------------------------------- */
.gallery { margin-top: var(--space-6); }
.gallery__track {
  display: flex; gap: var(--space-4);
  overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth;
  padding: var(--space-2) var(--gutter) var(--space-4);
  -webkit-overflow-scrolling: touch; scrollbar-width: thin;
}
.gallery__item {
  flex: 0 0 min(74%, 320px); scroll-snap-align: center;
  padding: 0; border: 0; background: none; cursor: zoom-in;
}
.gallery__item .pic { box-shadow: var(--shadow-card); transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); }
.gallery__item:hover .pic { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }
.gallery__dots { display: flex; gap: var(--space-2); justify-content: center; margin-top: var(--space-3); }
.gallery__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--border); transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); }
.gallery__dot.is-active { background: var(--accent); transform: scale(1.3); }

/* --- Lightbox ------------------------------------------------------------ */
.lightbox { position: fixed; inset: 0; z-index: 300; background: rgba(10, 28, 46, 0.94); display: none; align-items: center; justify-content: center; padding: var(--space-6); }
.lightbox.is-open { display: flex; }
.lightbox__img { max-width: min(1100px, 92vw); max-height: 80vh; object-fit: contain; border-radius: var(--radius-card); background: var(--brand-primary-900); box-shadow: 0 20px 60px rgb(0 0 0 / 0.5); }
.lightbox__cap { position: absolute; bottom: var(--space-5); left: 0; right: 0; text-align: center; color: rgba(244, 239, 230, 0.85); font-size: var(--fs-sm); padding: 0 var(--space-7); }
.lightbox__btn { position: absolute; background: rgba(244, 239, 230, 0.12); color: #fff; width: 48px; height: 48px; border-radius: 50%; display: grid; place-items: center; transition: background var(--t-fast) var(--ease); }
.lightbox__btn:hover { background: rgba(244, 239, 230, 0.26); }
.lightbox__close { top: var(--space-5); right: var(--space-5); }
.lightbox__prev { left: clamp(8px, 2vw, 24px); top: 50%; transform: translateY(-50%); }
.lightbox__next { right: clamp(8px, 2vw, 24px); top: 50%; transform: translateY(-50%); }
@media (max-width: 560px) { .lightbox__prev { left: 8px; } .lightbox__next { right: 8px; } .lightbox__btn { width: 42px; height: 42px; } }

/* --- Tabs (A–D-Ware) ----------------------------------------------------- */
.tabs__list { display: flex; flex-wrap: wrap; gap: var(--space-1); border-bottom: 1px solid var(--border); margin-bottom: var(--space-5); }
.tabs__tab { padding: var(--space-3) var(--space-4); font-family: var(--font-display); font-weight: var(--fw-semibold); font-size: var(--fs-sm); color: var(--text-muted); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease); }
.tabs__tab:hover { color: var(--brand-primary); }
.tabs__tab[aria-selected="true"] { color: var(--brand-primary); border-color: var(--accent); }
.tabs__panel[hidden] { display: none; }
.tabs__panel { font-size: var(--fs-base); color: var(--text); }
.tabs__panel strong { color: var(--brand-primary); }

/* --- Utility ------------------------------------------------------------- */
.stack-sm > * + * { margin-top: var(--space-3); }
.stack > * + * { margin-top: var(--space-5); }
.text-center { text-align: center; }
.mt-6 { margin-top: var(--space-6); }
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
