/* ===================================================================
   Tiliaderm — Generische Inhaltsseiten (Über uns, Kontakt, Impressum,
   Datenschutz, AGB …). Editoriale Lese-Spalte + verlässliches
   responsives Padding (behebt „Text klebt am Rand" auf Mobile).
   =================================================================== */

.tilia-page {
  max-width: 1240px;
  margin: 0 auto;
  padding: 56px 32px 80px;
  width: 100%;
}

.tilia-page .wp-block-post-title,
.tilia-page > h1:first-child {
  font-family: var(--font-brand);
  font-weight: 600;
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: -0.02em;
  line-height: 1.08;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0 0 32px;
}

/* Lese-Breite für Fließtext */
.tilia-page p,
.tilia-page ul,
.tilia-page ol { max-width: 760px; color: var(--fg-1); line-height: 1.7; }
.tilia-page p { margin: 0 0 18px; }
.tilia-page .tilia-lead { font-family: var(--font-sans); font-size: 1.25rem; color: var(--fg-2); line-height: 1.5; max-width: 720px; }

.tilia-page h2 {
  font-family: var(--font-brand); font-weight: 600; text-transform: uppercase;
  letter-spacing: -0.01em; font-size: clamp(1.5rem, 2.5vw, 2rem);
  margin: 48px 0 16px; color: var(--ink);
}
.tilia-page h3 { font-family: var(--font-serif); font-weight: 600; font-size: 1.375rem; margin: 28px 0 12px; color: var(--ink); }
.tilia-page a:not(.btn) { color: var(--tilia-700); }
.tilia-page a:not(.btn):hover { color: var(--tilia-600); }

/* Akkordeon (details/summary) im Marken-Look */
.tilia-page details.tilia-acc { border-top: 1px solid var(--border); }
.tilia-page details.tilia-acc:last-of-type { border-bottom: 1px solid var(--border); }
.tilia-page details.tilia-acc > summary {
  list-style: none; cursor: pointer; position: relative;
  font-family: var(--font-brand); font-weight: 600; font-size: 1.0625rem;
  color: var(--ink); padding: 20px 40px 20px 0; letter-spacing: -0.005em;
}
.tilia-page details.tilia-acc > summary::-webkit-details-marker { display: none; }
.tilia-page details.tilia-acc > summary::after {
  content: "+"; position: absolute; right: 2px; top: 50%; transform: translateY(-50%);
  font-family: var(--font-sans); font-weight: 400; font-size: 24px; line-height: 1; color: var(--tilia-600);
}
.tilia-page details.tilia-acc[open] > summary::after { content: "\2212"; }
.tilia-page details.tilia-acc .tilia-acc-body { padding: 0 0 22px; }
.tilia-page details.tilia-acc .tilia-acc-body p { max-width: 820px; color: var(--fg-2); }

/* Kontakt-Layout (Formular + Infospalte) */
.tilia-contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: start; max-width: 1100px; }
.tilia-contact-aside { background: var(--bg-brand-soft); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px; }
.tilia-contact-aside .tilia-phone { font-family: var(--font-serif); font-size: 1.5rem; color: var(--tilia-700); }

/* ---- Trainer-/Fakultäts-Profile (einheitliches Layout für alle 6) ---- */
.tilia-trainer-role {
  font-size: 12.5px; font-weight: 500; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg-brand);
  margin: -8px 0 28px !important; max-width: none !important;
}
.tilia-trainer-portrait {
  width: 100%; max-width: 260px; aspect-ratio: 3/4; float: right;
  margin: 0 0 24px 32px; border-radius: var(--radius-lg);
  background:
    radial-gradient(70% 70% at 30% 30%, rgba(212,169,116,0.22), transparent 60%),
    linear-gradient(160deg, var(--tilia-700), var(--tilia-500));
  position: relative; overflow: hidden; box-shadow: var(--shadow-md);
}
.tilia-trainer-portrait::after {
  content: ""; position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2081.8%2097.9%22%20width%3D%2281.8%22%20height%3D%2297.9%22%3E%3Cpath%20fill%3D%22%231F3A2E%22%20d%3D%22M78.4%2C35.3C72.9%2C20.2%2C54.1%2C2.4%2C41.2.1h-.6c0-.1-.5.3-.5.3C30.5%2C7.2%2C7.8%2C24.5%2C3.4%2C38.5c-4.5%2C11.6-5.9%2C28.5%2C5.2%2C38.1%2C8.7%2C8.4%2C21.6%2C9.3%2C29.9%2C5.1v13.8c0%2C.6.2%2C1.2.6%2C1.6.5.4%2C1.1.7%2C1.7.7h0c1.3%2C0%2C2.4-1.1%2C2.4-2.3v-14.2c4.9%2C2%2C9.5%2C3%2C13.8%2C3s11.2-2%2C15.4-5.8c9.7-9%2C12.2-26.8%2C6-43.2Z%22%2F%3E%3C%2Fsvg%3E") no-repeat;
  background-size: 55%; background-position: 115% 112%;
  opacity: 0.14; filter: brightness(2.4);
}
/* Mit echtem Foto: Gradient + Lindenblatt-Platzhalter weg, Bild füllt die Box */
.tilia-trainer-portrait.has-photo { background: none; }
.tilia-trainer-portrait.has-photo::after { content: none; }
.tilia-trainer-portrait img {
  display: block; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 22%; border-radius: inherit;
}
@media (max-width: 600px) {
  .tilia-trainer-portrait { float: none; max-width: 200px; margin: 0 0 24px; }
}

/* ---- Team-/Fakultäts-Übersicht (/team/) ---- */
.tilia-team-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
  margin: 8px 0 8px; padding: 0; list-style: none;
}
.tilia-team-card {
  display: flex; flex-direction: column; text-decoration: none;
  background: var(--paper-pure, #fff); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.tilia-team-card:hover {
  transform: translateY(-4px); box-shadow: var(--shadow-md);
  border-color: var(--tilia-300, #bcd0b8);
}
.tilia-team-photo { aspect-ratio: 3/4; overflow: hidden; background: var(--bg-brand-soft, #eef1ea); }
.tilia-team-photo img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: 50% 22%; }
.tilia-team-body { padding: 18px 20px 22px; }
.tilia-team-role {
  font-size: 12px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-brand); margin: 0 0 6px;
}
.tilia-team-name { font-size: 1.18rem; line-height: 1.25; color: var(--fg-1); margin: 0 0 12px; }
.tilia-team-link { font-size: 13px; font-weight: 500; color: var(--tilia-700); }
.tilia-team-card:hover .tilia-team-link { text-decoration: underline; }
@media (max-width: 860px) { .tilia-team-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; } }
@media (max-width: 520px) { .tilia-team-grid { grid-template-columns: 1fr; } }

/* ---- Trainer-Profilseiten: zweispaltiges Vita-Layout ---- */
.tilia-profile { display: grid; grid-template-columns: 260px 1fr; gap: 56px; align-items: start; margin-top: 8px; }
.tilia-profile-aside { position: sticky; top: 100px; }
.tilia-profile-photo {
  aspect-ratio: 3/4; border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-md); background: var(--bg-brand-soft, #eef1ea);
}
.tilia-profile-photo img { display: block; width: 100%; height: 100%; object-fit: cover; object-position: 50% 22%; }
.tilia-profile-role {
  font-size: 12px; font-weight: 500; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-brand); margin: 16px 0 0; max-width: none !important;
}
.tilia-profile-main { min-width: 0; }
.tilia-profile-main > .tilia-profile-intro:first-child { margin-top: 0; }
.tilia-profile-intro { font-size: 1.12rem; line-height: 1.6; color: var(--fg-2); margin: 0 0 8px; }
.tilia-cv-block { margin-top: 36px; }
.tilia-cv-block > h2 {
  font-size: 13px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--tilia-700); margin: 0 0 14px; padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.tilia-cv-block > p { margin: 0 0 12px; line-height: 1.6; color: var(--fg-1); }
.tilia-cv { margin: 0; display: grid; gap: 0; }
.tilia-cv-row {
  display: grid; grid-template-columns: 130px 1fr; gap: 24px;
  padding: 12px 0; border-bottom: 1px solid var(--border-subtle, #ece8e1);
}
.tilia-cv-row:last-child { border-bottom: 0; }
.tilia-cv-row dt { margin: 0; font-weight: 600; font-size: 0.9rem; color: var(--tilia-700); }
.tilia-cv-row dd { margin: 0; line-height: 1.55; color: var(--fg-1); }
@media (max-width: 768px) {
  .tilia-profile { grid-template-columns: 1fr; gap: 28px; }
  .tilia-profile-aside { position: static; max-width: 220px; }
  .tilia-cv-row { grid-template-columns: 1fr; gap: 4px; padding: 12px 0; }
  .tilia-cv-row dt { color: var(--fg-brand); }
}

/* ---- Auth-Seiten (Login / Registrierung / Kennwort vergessen) ---- */
.tilia-auth { max-width: 480px; margin: 4px auto 0; }
.tilia-auth .tilia-lead { margin-bottom: 28px; }
.tilia-auth-form { display: grid; gap: 16px; max-width: 480px; }
.tilia-auth-form label { display: grid; gap: 6px; font-size: 13px; font-weight: 500; color: var(--fg-2); }
.tilia-auth-form input {
  font-family: var(--font-sans); font-size: 15px; color: var(--fg-1);
  background: var(--paper-pure); border: 1px solid var(--border-strong);
  border-radius: var(--radius-md); padding: 12px 14px; outline: none; width: 100%;
}
.tilia-auth-form input:focus { border-color: var(--tilia-600); box-shadow: 0 0 0 3px rgba(61,107,90,.18); }
.tilia-auth-form button { justify-self: start; margin-top: 4px; }
.tilia-auth-alt { margin-top: 24px; font-size: 14px; color: var(--fg-3); }
.tilia-auth-alt a { font-weight: 500; }
/* Tutor-Login/Registrierung innerhalb der Auth-Spalte zentrieren */
.tilia-auth .tutor-frontend-dashboard,
.tilia-auth .tutor-registration-wrap,
.tilia-auth [class*="tutor-login"] { max-width: 480px; }

/* Forminator-Absenden-Button in Marken-Grün */
.tilia-page .forminator-button,
.tilia-page .forminator-button-submit,
.forminator-ui.forminator-custom-form .forminator-button.forminator-button-submit {
  background: var(--tilia-700) !important;
  background-image: none !important;
  border-color: var(--tilia-700) !important;
  color: var(--paper) !important;
  border-radius: var(--radius-md) !important;
}
.tilia-page .forminator-button:hover,
.forminator-ui.forminator-custom-form .forminator-button.forminator-button-submit:hover {
  background: var(--tilia-800) !important;
  border-color: var(--tilia-800) !important;
}

/* Tabellen + Medien + lange Strings: nie über den Container hinaus
   (behebt Overflow in AGB/Trainer-Lebensläufen/Cookie-Richtlinie auf Mobile) */
.tilia-page { overflow-wrap: anywhere; }
.tilia-page img,
.tilia-page iframe,
.tilia-page video,
.tilia-page pre { max-width: 100%; height: auto; }
.tilia-page table { width: 100%; max-width: 100%; border-collapse: collapse; }
.tilia-page th,
.tilia-page td { overflow-wrap: anywhere; word-break: break-word; vertical-align: top; }

/* ---- Responsive ---- */
@media (max-width: 1024px) {
  .tilia-page { padding: 48px 24px 64px; }
  .tilia-contact-grid { gap: 40px; }
}
@media (max-width: 768px) {
  /* Tabellen mit festen Spaltenbreiten zwingen sich sonst über den Rand */
  .tilia-page table { table-layout: fixed; }
  .tilia-page td,
  .tilia-page th { padding-left: 0; }
}
@media (max-width: 768px) {
  .tilia-page { padding: 40px 20px 56px; }
  .tilia-contact-grid { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 480px) {
  .tilia-page { padding: 32px 16px 48px; }
  .tilia-page .wp-block-post-title { margin-bottom: 22px; }
}
