/* ────────────────────────────────────────────────────────────
   HERO
   ──────────────────────────────────────────────────────────── */
.hero {
  min-height: 92vh;
  padding-top: var(--s-32);
  padding-bottom: var(--s-16);
  display: flex;
  align-items: center;
  position: relative;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-16);
  align-items: center;
}
@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--s-12); }
  .hero__portrait { order: -1; max-width: 320px; margin: 0 auto; }
}
.hero__name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(3rem, 7vw, 5.5rem);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 0 0 var(--s-4);
  color: var(--ink);
}
.hero__name .italic-display {
  display: block;
  color: var(--ink-faint);
  font-size: 0.5em;
  font-weight: 400;
  letter-spacing: 0;
  margin-bottom: var(--s-2);
}
.hero__credentials {
  font-family: var(--font-meta);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: var(--s-6);
}
.hero__lede {
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 1.5vw, 1.3rem);
  line-height: 1.55;
  max-width: 42ch;
  color: var(--ink-soft);
  margin-bottom: var(--s-8);
}
.hero__affiliations {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2) var(--s-4);
  font-family: var(--font-meta);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.hero__affiliations span:not(:last-child)::after {
  content: '·';
  margin-left: var(--s-4);
  opacity: 0.6;
}
.hero__portrait {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--paper-light);
  box-shadow: var(--neu-shadow-raised);
}
.hero__portrait img {
  width: 100%;
  display: block;
}

/* ────────────────────────────────────────────────────────────
   ABOUT
   ──────────────────────────────────────────────────────────── */
.about {
  background: var(--paper);
}
.about__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--s-12);
  align-items: start;
}
@media (max-width: 900px) {
  .about__grid { grid-template-columns: 1fr; gap: var(--s-8); }
}
.about__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--r-md);
  background: var(--paper-light);
  box-shadow: var(--neu-shadow-raised-sm);
}
.about__photo img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.about__body p {
  font-size: 1.05rem;
  line-height: 1.7;
  max-width: 60ch;
  color: var(--ink-soft);
}

/* ────────────────────────────────────────────────────────────
   MEDIA STRIP — featured outlets (static, no marquee)
   ──────────────────────────────────────────────────────────── */
.media-strip {
  padding: var(--s-16) 0;
  background: var(--paper-light);
  border-top: 1px solid var(--navy-line);
  border-bottom: 1px solid var(--navy-line);
}
.media-strip__label {
  text-align: center;
  margin-bottom: var(--s-8);
}
.media-strip__track {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-8) var(--s-12);
  align-items: center;
  justify-items: center;
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--s-6);
  /* Override marquee animation if present in DOM. */
  animation: none !important;
  width: auto;
}
.media-strip__logo {
  height: 32px;
  width: auto;
  max-width: 140px;
  flex: none;
  filter: grayscale(1) contrast(0.9) opacity(0.65);
  transition: filter 300ms var(--ease-soft);
}
.media-strip__logo:hover {
  filter: grayscale(0) contrast(1) opacity(1);
}
@media (max-width: 900px) {
  .media-strip__track { grid-template-columns: repeat(3, 1fr); gap: var(--s-6) var(--s-8); }
  .media-strip__logo  { height: 28px; }
}
@media (max-width: 480px) {
  .media-strip__track { grid-template-columns: repeat(2, 1fr); }
}

/* ────────────────────────────────────────────────────────────
   BOOKS PREVIEW
   ──────────────────────────────────────────────────────────── */
.books-preview {
  background: var(--paper);
}
.books-preview__head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-bottom: var(--s-12);
}
.books-preview__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-8);
}
@media (max-width: 760px) {
  .books-preview__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .books-preview__grid { grid-template-columns: 1fr; }
}

/* ────────────────────────────────────────────────────────────
   CONSULTING
   ──────────────────────────────────────────────────────────── */
.consulting {
  background: var(--paper-light);
}
.consulting__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-12);
  align-items: center;
}
@media (max-width: 900px) {
  .consulting__grid { grid-template-columns: 1fr; }
}
.consulting__image {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  position: relative;
  border-radius: var(--r-md);
  box-shadow: var(--neu-shadow-raised-sm);
}
.consulting__image img {
  width: 100%; height: 100%; object-fit: cover;
}
.consulting__body p {
  font-size: 1.05rem;
  line-height: 1.7;
  max-width: 52ch;
  color: var(--ink-soft);
}

/* ────────────────────────────────────────────────────────────
   RESEARCH — curated article cards (neumorphic)
   ──────────────────────────────────────────────────────────── */
.research {
  background: var(--paper);
}
.research__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--s-6);
  margin-top: var(--s-12);
}
.article-card {
  display: block;
  padding: var(--s-6);
  border: 0;
  border-radius: var(--r-md);
  background: var(--paper);
  box-shadow: var(--neu-shadow-raised-sm);
  position: relative;
  transition: transform 300ms var(--ease-soft), box-shadow 300ms var(--ease-soft);
}
.article-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--neu-shadow-hover);
  color: var(--ink);
}
.article-card__outlet {
  font-family: var(--font-meta);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--vermilion);
  margin-bottom: var(--s-3);
}
.article-card__title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  line-height: 1.3;
  margin-bottom: var(--s-3);
  color: var(--ink);
}
.article-card__cta {
  font-family: var(--font-meta);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* ────────────────────────────────────────────────────────────
   WORKSHOPS PREVIEW
   ──────────────────────────────────────────────────────────── */
.workshops {
  background: var(--paper-light);
}
.workshops__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-12);
  margin-top: var(--s-8);
}
@media (max-width: 900px) {
  .workshops__grid { grid-template-columns: 1fr; }
}
.workshops__col h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.5rem;
  color: var(--ink);
  margin-bottom: var(--s-6);
}
.workshops__list {
  list-style: none;
  margin: 0; padding: 0;
}
.workshops__list li {
  padding: var(--s-3) 0 var(--s-3) var(--s-6);
  border-bottom: 1px solid var(--navy-line);
  position: relative;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--ink-soft);
}
.workshops__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 14px;
  height: 1px;
  background: var(--ink-faint);
  transform: translateY(-0.5px);
}

/* ────────────────────────────────────────────────────────────
   CONTACT — navy ground, dark-neumorphic accents
   ──────────────────────────────────────────────────────────── */
.contact {
  background: var(--navy);
  color: var(--paper-light);
  padding: var(--s-32) 0;
  position: relative;
}
.contact .eyebrow { color: rgba(251, 250, 247, 0.7); }
.contact .eyebrow::before { background: rgba(251, 250, 247, 0.55); }
.contact h2 { color: var(--paper-light); }
.contact a {
  color: var(--paper-light);
  border-bottom-color: rgba(251, 250, 247, 0.28);
}
.contact a:hover { color: var(--vermilion-warm); border-bottom-color: var(--vermilion-warm); }

.contact__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-12);
  margin-top: var(--s-8);
}
@media (max-width: 760px) {
  .contact__grid { grid-template-columns: 1fr; gap: var(--s-8); }
}
.contact__list {
  list-style: none;
  margin: 0; padding: 0;
}
.contact__list li {
  padding: var(--s-3) 0;
  border-bottom: 1px solid rgba(251, 250, 247, 0.1);
  font-size: 1rem;
}
.contact__list li strong {
  display: block;
  font-family: var(--font-meta);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(251, 250, 247, 0.5);
  margin-bottom: var(--s-1);
}

/* ─── Contact form ──────────────────────────────────── */
.contact__lede {
  max-width: 56ch;
  color: rgba(251, 250, 247, 0.78);
  font-size: 1.05rem;
  line-height: 1.6;
  margin: 0 0 var(--s-8);
}
.contact-form {
  display: block;
  margin: var(--s-8) 0 0;
}
/* Honeypot — visible to bots, hidden from humans */
.hp-field {
  position: absolute;
  left: -10000px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
}
.contact-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-6);
}
@media (max-width: 600px) {
  .contact-form .form-row { grid-template-columns: 1fr; }
}
.contact-form .form-group {
  margin-bottom: var(--s-6);
}
.contact-form label {
  display: block;
  font-family: var(--font-meta);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(251, 250, 247, 0.55);
  margin-bottom: var(--s-2);
}
.contact-form .form-optional {
  letter-spacing: 0.05em;
  text-transform: none;
  color: rgba(251, 250, 247, 0.35);
  font-size: 0.78rem;
}
.contact-form .form-required {
  color: var(--vermilion-warm);
  margin-left: 2px;
}
.contact-form input,
.contact-form textarea {
  width: 100%;
  padding: var(--s-3) var(--s-4);
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--paper-light);
  background: rgba(251, 250, 247, 0.04);
  border: 1px solid rgba(251, 250, 247, 0.18);
  border-radius: var(--r-sm);
  transition: border-color 200ms var(--ease-soft), background 200ms var(--ease-soft);
}
.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: rgba(251, 250, 247, 0.32);
  font-style: italic;
}
.contact-form input:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--vermilion-warm);
  background: rgba(251, 250, 247, 0.07);
}
.contact-form textarea {
  resize: vertical;
  min-height: 160px;
  line-height: 1.6;
}
.char-count {
  text-align: right;
  font-family: var(--font-meta);
  font-size: 0.72rem;
  color: rgba(251, 250, 247, 0.4);
  margin-top: var(--s-1);
}
/* Hide Turnstile widget — invisible mode */
.cf-turnstile {
  display: none;
}
.contact-submit {
  margin-top: var(--s-6);
}
.contact-submit:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.contact-submit.is-loading {
  cursor: wait;
}

/* Contact form CTA — embossed from the navy surface (overrides .btn--vermilion).
   Uses an analogous navy palette so the button reads as the same material as the
   section background, lifted by light/shadow only — not a contrasting sticker. */
.contact .btn--vermilion.contact-submit {
  background: var(--navy-soft);
  color: var(--paper-light);
  box-shadow:
       3px  3px 10px rgba(0, 6, 20, 0.55),
      -3px -3px 10px rgba(86, 112, 168, 0.22);
}
.contact .btn--vermilion.contact-submit:hover {
  background: #34416A;
  color: var(--paper-light);
  box-shadow:
       4px  4px 14px rgba(0, 6, 20, 0.6),
      -4px -4px 14px rgba(96, 124, 184, 0.28);
}
.contact .btn--vermilion.contact-submit:active {
  transform: translateY(1px);
  box-shadow:
      inset 2px  2px 6px rgba(0, 6, 20, 0.55),
      inset -2px -2px 6px rgba(86, 112, 168, 0.18);
}

/* Form messages */
.contact-msg {
  padding: var(--s-4) var(--s-6);
  border-radius: var(--r-sm);
  margin: var(--s-6) 0;
  font-size: 1rem;
  line-height: 1.6;
}
.contact-msg--error {
  background: rgba(184, 55, 28, 0.18);
  border: 1px solid rgba(200, 65, 42, 0.45);
  color: #ffd6cc;
}
.contact-msg--success {
  background: rgba(241, 230, 206, 0.06);
  border: 1px solid rgba(241, 230, 206, 0.18);
  text-align: center;
  padding: var(--s-12);
}
.contact-msg--success h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 2rem;
  color: var(--paper-light);
  margin: 0 0 var(--s-3);
}
.contact-msg--success p {
  color: rgba(251, 250, 247, 0.7);
  margin: 0;
}

/* Alt contact strip (institutional links) below form */
.contact__alt {
  margin-top: var(--s-16);
  padding-top: var(--s-8);
  border-top: 1px solid rgba(251, 250, 247, 0.1);
}
.contact__alt-label {
  margin-bottom: var(--s-6);
}

/* ────────────────────────────────────────────────────────────
   FOOTER
   ──────────────────────────────────────────────────────────── */
.footer {
  background: var(--navy);
  color: rgba(251, 250, 247, 0.5);
  padding: var(--s-6) 0;
  font-family: var(--font-meta);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  text-align: center;
  border-top: 1px solid rgba(251, 250, 247, 0.08);
}
.footer__legal {
  margin-left: var(--s-3);
}
.footer__legal a {
  color: rgba(251, 250, 247, 0.65);
  border-bottom: 0;
  transition: color 200ms var(--ease-soft);
}
.footer__legal a:hover { color: var(--paper-light); }
.footer__legal span { margin: 0 var(--s-2); opacity: 0.4; }

/* ────────────────────────────────────────────────────────────
   LEGAL pages — Impressum, Datenschutz
   ──────────────────────────────────────────────────────────── */
.legal-section {
  padding: var(--s-12) 0 var(--s-24);
}
.legal-section .container-mid > h2 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.5rem;
  color: var(--ink);
  margin: var(--s-12) 0 var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--navy-line);
}
.legal-section .container-mid > h2:first-child { margin-top: 0; }
.legal-section p {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--ink-soft);
  margin: 0 0 var(--s-4);
}
.legal-section a {
  color: var(--ink);
  border-bottom: 1px solid var(--ink-faint);
  transition: color 200ms var(--ease-soft), border-color 200ms var(--ease-soft);
}
.legal-section a:hover {
  color: var(--vermilion);
  border-bottom-color: var(--vermilion);
}
.legal-section code {
  font-family: var(--font-meta);
  font-size: 0.92em;
  background: var(--paper-deep);
  padding: 1px 6px;
  border-radius: 3px;
}
