/* ==================================================================
   my-coach.ch – Hauptstyles
   Kräftiges, klares Design: Schwarz · Orange (#ff774c) · Creme (#efeae3)
   Headlines: League Spartan (Versalien) · Body: Inter
   ================================================================== */

:root{
  --ink:#000000;          /* Headlines */
  --text:#1c1a17;         /* Fliesstext (leicht weicher als reines Schwarz) */
  --accent:#ff774c;       /* Orange – Buttons, Akzente */
  --accent-dark:#e85f33;  /* Orange dunkler – Links/Hover auf hellem Grund */
  --bg:#efeae3;           /* Creme – Seitenhintergrund */
  --bg-alt:#e7dfd2;       /* etwas dunkleres Creme für Abwechslung */
  --card:#ffffff;
  --line:#ddd4c8;         /* Kartenrahmen auf Creme */
  --dark:#0b0400;         /* Footer / dunkle Sektionen */
  --dark-2:#181818;
  --muted:#6f665c;
  --radius:8px;           /* leicht abgerundet */
  --radius-card:12px;
  --shadow:0 24px 50px -28px rgba(0,0,0,.5);
  --shadow-sm:0 10px 24px -18px rgba(0,0,0,.45);
  --container:1240px;
  --font-head:'League Spartan','Arial Narrow',sans-serif;
  --font-body:'Inter','Segoe UI',system-ui,-apple-system,Arial,sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--font-body); color:var(--text);
  background:var(--bg); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--accent-dark); text-decoration:none; }
a:hover{ color:var(--ink); }

h1,h2,h3,h4{ font-family:var(--font-head); color:var(--ink); margin:0 0 .5em; }
h1,h2{ text-transform:uppercase; font-weight:600; letter-spacing:.005em; }
h1{ font-size:clamp(2.6rem,6vw,4.7rem); line-height:.98; }
h2{ font-size:clamp(2rem,4vw,3.2rem); line-height:1.02; }
h3{ font-size:1.4rem; font-weight:500; line-height:1.2; }
h4{ font-size:1.05rem; font-weight:500; }
p{ margin:0 0 1rem; }

.container{ width:min(100% - 2.5rem, var(--container)); margin-inline:auto; }
.narrow{ max-width:780px; margin-inline:auto; }
.center{ text-align:center; }
.muted{ color:var(--muted); }
.eyebrow{
  font-family:var(--font-head); text-transform:uppercase; letter-spacing:.22em;
  font-size:.8rem; font-weight:600; color:var(--accent-dark); margin:0 0 1rem;
  display:inline-flex; align-items:center; gap:.6rem;
}
.eyebrow::before{ content:""; width:28px; height:2px; background:var(--accent); display:inline-block; }
.center .eyebrow{ justify-content:center; }
.lead{ font-size:1.2rem; line-height:1.55; color:var(--text); }
.section{ padding:4rem 0; }
/* Sektion direkt nach einer anderen: doppelten Leerraum auffangen.
   Schlichte Sektion nach beliebiger Sektion -> oberen Abstand entfernen. */
.section + .section:not(.section-alt):not(.section-dark):not(.example-section){ padding-top:0; }
/* Zwei GLEICHFARBIGE Blöcke direkt hintereinander wirken als eine Fläche:
   den doppelten Abstand zusammenfassen (sonst grosse einfarbige Lücke). */
.section-alt + .section-alt,
.section-dark + .section-dark{ padding-top:0; }
.section-dark + .lead-magnet .lm-inner{ padding-top:0; }
.section-alt{ background:var(--bg-alt); }
.section-dark{ background:var(--dark); color:#efe9e1; }
.section-dark h1,.section-dark h2,.section-dark h3{ color:#fff; }
.section-head{ max-width:760px; margin:0 auto 2.4rem; }
.section-head.center{ text-align:center; }
.section-sub{ color:var(--muted); font-size:1.08rem; }

.skip-link{ position:absolute; left:-999px; top:0; background:#000; color:#fff; padding:.6rem 1rem; z-index:1000; }
.skip-link:focus{ left:0; }

/* ---- Buttons (eckig, Versalien) ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:var(--font-head); font-weight:600; text-transform:uppercase; letter-spacing:.04em;
  font-size:.95rem; padding:1rem 2.2rem; border:2px solid var(--accent); border-radius:var(--radius);
  background:var(--accent); color:#fff; cursor:pointer; transition:background .18s, border-color .18s, color .18s, transform .18s;
  line-height:1;
}
.btn:hover{ background:var(--ink); border-color:var(--ink); color:#fff; transform:translateY(-2px); }
.btn-primary{ background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-outline{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn-outline:hover{ background:var(--ink); color:#fff; }
.btn-light{ background:#fff; color:var(--ink); border-color:#fff; }
.btn-light:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.btn-ghost-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.6); }
.btn-ghost-light:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.btn-lg{ padding:1.15rem 2.6rem; font-size:1rem; }
.btn-sm{ padding:.7rem 1.4rem; font-size:.85rem; }
.btn-block{ display:flex; width:100%; }

/* ==================== HEADER ==================== */
.site-header{
  position:sticky; top:0; z-index:100; background:rgba(239,234,227,.92);
  backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid transparent; transition:box-shadow .25s, border-color .25s;
}
.site-header.scrolled{ box-shadow:0 10px 30px -22px rgba(0,0,0,.6); border-color:var(--line); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; min-height:80px; }
.brand{ display:flex; align-items:center; gap:.7rem; color:var(--ink); }
.brand:hover{ color:var(--ink); }
.brand img{ width:50px; height:50px; }
.brand-text{ font-family:var(--font-head); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:1.3rem; line-height:1; display:flex; flex-direction:column; }
.brand-text small{ font-family:var(--font-body); font-weight:500; font-size:.6rem; letter-spacing:.18em; color:var(--muted); margin-top:4px; text-transform:uppercase; }

.nav-list{ list-style:none; display:flex; align-items:center; gap:.2rem; margin:0; padding:0; }
.nav-list a{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.04em; font-weight:500; font-size:.92rem; color:var(--ink); padding:.55rem .8rem; }
.nav-list a:hover,.nav-list a[aria-current="page"]{ color:var(--accent-dark); }
.nav-cta a{ margin-left:.5rem; color:#fff; }
.nav-cta a:hover{ color:#fff; }
.nav-toggle{ display:none; }

/* ==================== HERO ==================== */
.hero{ position:relative; isolation:isolate; color:#fff; min-height:86vh; display:grid; align-items:center; }
.hero-media{ position:absolute; inset:0; z-index:-1; }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero-media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(11,4,0,.88) 0%, rgba(11,4,0,.72) 42%, rgba(11,4,0,.45) 100%); }
.hero-content{ padding:7rem 0; max-width:760px; }
.hero h1{ color:#fff; margin-bottom:1.2rem; text-shadow:0 2px 24px rgba(0,0,0,.55); }
.hero .lead{ text-shadow:0 1px 14px rgba(0,0,0,.5); }
.hero .eyebrow,.hero-badges{ text-shadow:0 1px 10px rgba(0,0,0,.5); }
.hero .eyebrow{ color:#ffb79c; }
.hero .eyebrow::before{ background:var(--accent); }
.hero .lead{ color:rgba(255,255,255,.94); font-size:1.3rem; max-width:600px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; margin:2rem 0 1.8rem; }
.hero-badges{ list-style:none; display:flex; flex-wrap:wrap; gap:1.4rem; padding:0; margin:0; font-size:.95rem; color:rgba(255,255,255,.92); font-weight:500; }
.hero-badges li{ display:flex; align-items:center; gap:.4rem; }

/* ==================== SPLIT ==================== */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.split.reverse{ direction:rtl; }
.split.reverse > *{ direction:ltr; }
.quote{ font-family:var(--font-head); font-weight:500; font-size:1.35rem; line-height:1.3; color:var(--ink);
  border-left:4px solid var(--accent); padding-left:1.3rem; margin-top:1.5rem; }

/* Porträt – eckig, passend zum Look (bewusst dezent, nicht dominant) */
.portrait{ width:100%; max-width:290px; aspect-ratio:3/4; object-fit:cover; object-position:center top;
  border-radius:var(--radius-card); box-shadow:var(--shadow-sm); display:block; }
.split .portrait{ margin-inline:auto; }
.portrait-caption{ margin-top:1rem; font-family:var(--font-head); text-transform:uppercase; letter-spacing:.1em; font-size:.8rem; color:var(--muted); }
.photo-placeholder{ aspect-ratio:4/5; background:var(--bg-alt); border:1px solid var(--line); display:flex; align-items:center; justify-content:center; }

/* ==================== CARDS / ANGEBOTE ==================== */
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.cards-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-card); padding:2.2rem 2rem;
  transition:transform .18s, border-color .18s, box-shadow .18s; position:relative; }
.card:hover{ transform:translateY(-4px); border-color:var(--accent); box-shadow:var(--shadow-sm); }
.card-icon{ font-size:2.2rem; margin-bottom:.8rem; }
.card h3{ text-transform:uppercase; font-weight:600; letter-spacing:.01em; font-size:1.2rem; }
.card p{ color:var(--text); margin-bottom:1.2rem; }
.card-link{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; font-weight:600; font-size:.85rem; color:var(--accent-dark); }
.card-link:hover{ color:var(--ink); }

/* nummerierte Angebot-Karten mit Orange-Top-Line */
.offer-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.offer-cards .card{ border-top:4px solid var(--accent); padding-top:2rem; }
.offer-num{ font-family:var(--font-head); font-weight:700; font-size:1rem; color:var(--accent-dark); letter-spacing:.1em; }

.trust .trust-item{ background:var(--card); border:1px solid var(--line); padding:1.8rem; }
.trust-item strong{ display:block; font-family:var(--font-head); text-transform:uppercase; font-size:1.05rem; letter-spacing:.02em; margin-bottom:.5rem; color:var(--ink); }
.trust-item span{ color:var(--text); }
.section-dark .trust-item{ background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.12); }
.section-dark .trust-item strong{ color:#fff; }
.section-dark .trust-item span{ color:rgba(255,255,255,.82); }
.mini-card{ background:var(--card); border:1px solid var(--line); padding:1.4rem; text-align:center; }
.mini-card strong{ display:block; font-family:var(--font-head); text-transform:uppercase; font-size:1.05rem; margin-bottom:.3rem; }
.mini-card span{ color:var(--muted); font-size:.95rem; }

/* ==================== WHY-US (Reasons) ==================== */
.reasons{ list-style:none; padding:0; margin:0; display:grid; grid-template-columns:1fr 1fr; gap:1.4rem 2.4rem; }
.reasons li{ display:grid; grid-template-columns:auto 1fr; gap:1rem; align-items:start; }
.reasons .rnum{ font-family:var(--font-head); font-weight:700; font-size:1.5rem; color:var(--accent); line-height:1; }
.reasons strong{ display:block; font-family:var(--font-head); text-transform:uppercase; font-size:1rem; letter-spacing:.02em; margin-bottom:.2rem; color:#fff; }
.reasons span{ color:rgba(255,255,255,.82); }

/* ==================== STEPS ==================== */
.steps{ list-style:none; counter-reset:s; display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; padding:0; margin:0; }
.steps li{ background:var(--card); border:1px solid var(--line); padding:2.2rem 1.8rem; }
.step-num{ display:inline-flex; align-items:center; justify-content:center; width:54px; height:54px; background:var(--accent);
  color:#fff; font-family:var(--font-head); font-weight:700; font-size:1.5rem; margin-bottom:1rem; }
.steps h3{ text-transform:uppercase; font-size:1.1rem; font-weight:600; margin-bottom:.3rem; }
.steps p{ color:var(--text); margin:0; }

/* ==================== OFFER (Detailseite) ==================== */
.offers{ display:flex; flex-direction:column; gap:2rem; }
.offer{ display:grid; grid-template-columns:auto 1fr; gap:2rem; background:var(--card); border:1px solid var(--line);
  border-left:5px solid var(--accent); padding:2.6rem; scroll-margin-top:100px; }
.offer-tag{ font-family:var(--font-head); font-size:3rem; font-weight:700; color:var(--accent); line-height:1; }
.offer-claim{ color:var(--accent-dark); font-weight:600; font-size:1.15rem; margin-bottom:.6rem; }
.offer-cols{ display:grid; grid-template-columns:1fr 1fr; gap:1.8rem; margin-top:1.4rem; }
.offer-cols h3{ font-family:var(--font-head); text-transform:uppercase; font-size:.95rem; letter-spacing:.06em; color:var(--muted); }
.ticks,.cred-list{ list-style:none; padding:0; margin:0; }
.ticks li{ position:relative; padding-left:1.7rem; margin-bottom:.5rem; color:var(--text); }
.ticks li::before{ content:""; position:absolute; left:0; top:.55em; width:9px; height:9px; background:var(--accent); }
.cred-list li{ position:relative; padding-left:1.7rem; margin-bottom:.6rem; color:var(--text); }
.cred-list li::before{ content:""; position:absolute; left:0; top:.55em; width:9px; height:9px; background:var(--accent); }

/* ==================== PREISE ==================== */
.price-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; margin-bottom:1.5rem; }
.price-card{ background:var(--card); border:1px solid var(--line); padding:2rem 1.5rem; text-align:center; }
.price-card.highlight{ border:2px solid var(--accent); }
.price-card h3{ font-family:var(--font-head); text-transform:uppercase; font-size:1rem; letter-spacing:.05em; color:var(--muted); }
.price{ font-family:var(--font-head); font-weight:700; font-size:1.9rem; color:var(--ink); margin:.3rem 0 0; }
.price span,.price-sub span{ font-size:.8rem; font-weight:500; color:var(--muted); }
.price-sub{ font-family:var(--font-head); font-weight:600; font-size:1.3rem; color:var(--text); margin:.1rem 0 .4rem; }

/* ==================== FAQ ==================== */
.faq{ display:flex; flex-direction:column; gap:.8rem; }
.faq details{ background:var(--card); border:1px solid var(--line); padding:.4rem 1.4rem; }
.faq summary{ cursor:pointer; font-family:var(--font-head); text-transform:uppercase; font-size:1rem; font-weight:600; letter-spacing:.01em;
  padding:1rem 0; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq summary::after{ content:"+"; color:var(--accent); font-size:1.6rem; line-height:1; }
.faq details[open] summary::after{ content:"–"; }
.faq details p{ padding-bottom:1.1rem; margin:0; color:var(--text); }

/* ==================== LEAD-MAGNET / NEWSLETTER ==================== */
.lead-magnet{ background:var(--dark); color:#fff; }
.lm-inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:3rem; align-items:center; }
.lead-magnet .lm-inner{ padding:4.5rem 0; }
.lead-magnet h2{ color:#fff; }
.lead-magnet .eyebrow{ color:#ffb79c; }
.lead-magnet p{ color:rgba(255,255,255,.85); }
.lm-list{ list-style:none; padding:0; margin:1rem 0 0; }
.lm-list li{ position:relative; padding-left:1.7rem; margin-bottom:.5rem; color:rgba(255,255,255,.9); }
.lm-list li::before{ content:""; position:absolute; left:0; top:.55em; width:9px; height:9px; background:var(--accent); }
.lm-form{ background:#fff; color:var(--text); padding:2.2rem; border-top:5px solid var(--accent); }
.lm-form h3{ text-transform:uppercase; font-size:1.2rem; font-weight:600; }
.lm-form .field input{ background:#faf7f2; }
.newsletter-inline{ background:var(--card); border:1px solid var(--line); border-left:5px solid var(--accent); padding:2.2rem; }
/* Broschüren-Mockup im Lead-Block (statt Stockfoto) */
.brochure-mock{ position:relative; display:flex; justify-content:center; margin:1.5rem 0; }
.brochure-mock img{ width:100%; max-width:340px; box-shadow:0 30px 60px -25px rgba(0,0,0,.7); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-card); transform:rotate(-2deg); }

/* ==================== WILLKOMMENS-BLOCK (Startseite, ohne Porträt) ==================== */
.welcome{ display:grid; grid-template-columns:1.1fr .9fr; gap:3.5rem; align-items:center; }
.welcome-media img{ width:100%; max-width:420px; aspect-ratio:3/4; object-fit:cover; border-radius:var(--radius-card); box-shadow:var(--shadow); margin-inline:auto; display:block; }
.welcome-quote{ font-family:var(--font-head); font-weight:500; font-size:clamp(1.4rem,2.4vw,1.9rem); line-height:1.25; color:var(--ink); margin:0 0 1.4rem; }
.signature{ border-top:2px solid var(--accent); display:inline-block; padding-top:.7rem; margin-top:.4rem; }
.signature strong{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.04em; font-size:1.05rem; color:var(--ink); display:block; }
.signature span{ font-size:.9rem; color:var(--muted); }

/* ==================== BILD-BAND mit Zitat ==================== */
.image-band{ position:relative; min-height:42vh; display:grid; align-items:center; isolation:isolate; color:#fff; }
.image-band img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-1; }
.image-band::after{ content:""; position:absolute; inset:0; background:rgba(11,4,0,.55); z-index:-1; }
.image-band blockquote{ margin:0; max-width:780px; font-family:var(--font-head); font-weight:500; text-transform:uppercase;
  font-size:clamp(1.6rem,3.2vw,2.6rem); line-height:1.1; color:#fff; padding:4rem 0; }
.image-band cite{ display:block; font-family:var(--font-body); text-transform:none; font-style:normal; font-size:1rem; color:#ffb79c; margin-top:1rem; letter-spacing:.02em; }

/* ==================== ANGEBOT mit Bild (Coaching-Seite) ==================== */
.offer{ grid-template-columns:1fr; gap:0; padding:0; overflow:hidden; border-radius:var(--radius-card);
  transition:transform .2s, box-shadow .2s, border-color .2s; }
.offer:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--accent); }
.offer-media{ position:relative; aspect-ratio:21/7; overflow:hidden; }
.offer-media img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.offer:hover .offer-media img{ transform:scale(1.05); }
.offer-media .offer-tag{ position:absolute; left:1.6rem; bottom:1rem; color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.6); margin:0; }
.offer-body{ padding:2.4rem 2.6rem; }
@media (max-width:760px){ .offer-media{ aspect-ratio:16/9; } .offer-body{ padding:1.8rem; } }

/* ==================== KLEINES PORTRÄT (Über mich) ==================== */
.portrait-sm{ width:100%; max-width:240px; aspect-ratio:3/4; object-fit:cover; object-position:center top;
  border-radius:var(--radius-card); box-shadow:var(--shadow-sm); display:block; }
.bio-card{ display:grid; grid-template-columns:240px 1fr; gap:2rem; align-items:start; background:var(--card); border:1px solid var(--line); border-left:5px solid var(--accent); padding:2.2rem; }
@media (max-width:680px){ .bio-card{ grid-template-columns:1fr; } .portrait-sm{ max-width:200px; } }

/* ==================== CTA-BANNER ==================== */
.cta-banner{ background:var(--accent); color:#fff; }
.cta-inner{ display:flex; align-items:center; justify-content:space-between; gap:2rem; padding:3.8rem 0; flex-wrap:wrap; }
.cta-banner h2{ color:#fff; margin-bottom:.4rem; }
.cta-banner p{ color:rgba(255,255,255,.92); margin:0; max-width:540px; }
.cta-actions{ display:flex; flex-wrap:wrap; gap:1rem; }
.cta-banner .btn-light{ background:#fff; color:var(--ink); border-color:#fff; }
.cta-banner .btn-light:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.cta-banner .btn-ghost-light{ border-color:rgba(255,255,255,.7); }

/* ==================== PAGE-HERO (Unterseiten – mit Headerbild) ==================== */
.page-hero{ color:#fff; padding:6rem 0 4.5rem;
  background-image:linear-gradient(90deg, rgba(11,4,0,.9) 0%, rgba(11,4,0,.66) 60%, rgba(11,4,0,.5) 100%), url('../img/hero-coaching.jpg');
  background-size:cover; background-position:center; }
.page-hero h1{ color:#fff; text-shadow:0 2px 20px rgba(0,0,0,.5); }
.page-hero .eyebrow{ color:#ffb79c; }
.page-hero .lead{ color:rgba(255,255,255,.92); max-width:740px; text-shadow:0 1px 12px rgba(0,0,0,.45); }

/* ==================== KONTAKT / FORMULARE ==================== */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:3.5rem; align-items:start; }
.contact-list{ list-style:none; padding:0; margin:0 0 1.4rem; }
.contact-list li{ display:flex; flex-direction:column; padding:.8rem 0; border-bottom:1px solid var(--line); }
.ci-label{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.1em; font-size:.75rem; color:var(--muted); margin-bottom:.2rem; }
.contact-form-wrap{ background:var(--card); border:1px solid var(--line); border-top:5px solid var(--accent); padding:2.2rem; }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-weight:600; margin-bottom:.4rem; font-size:.95rem; color:var(--ink); }
.field input,.field select,.field textarea{ width:100%; padding:.85rem 1rem; border:1px solid var(--line); border-radius:var(--radius);
  font-family:inherit; font-size:1rem; background:#fff; color:var(--text); transition:border-color .15s, box-shadow .15s; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(255,119,76,.18); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field-check{ display:flex; gap:.6rem; align-items:flex-start; margin:0 0 1.2rem; }
.field-check input{ width:auto; margin-top:.3rem; flex:0 0 auto; }
.field-check label{ font-weight:400; font-size:.9rem; color:var(--text); margin:0; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-note{ font-size:.82rem; color:var(--muted); margin-top:.9rem; }
.alert{ padding:1rem 1.2rem; margin-bottom:1.2rem; border-radius:var(--radius); }
.alert.success{ background:#eef4e8; border:1px solid #cfe0bf; color:#3c5a2c; }
.alert.error{ background:#fdeee9; border:1px solid #f3c7b6; color:#a8431f; }

/* ==================== BLOG ==================== */
.post-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.post-card{ background:var(--card); border:1px solid var(--line); transition:transform .18s, border-color .18s, box-shadow .18s; }
.post-card:hover{ transform:translateY(-4px); border-color:var(--accent); box-shadow:var(--shadow-sm); }
.post-card-body{ padding:1.8rem; }
.post-card time{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.08em; font-size:.78rem; color:var(--accent-dark); font-weight:600; }
.post-card h2{ font-size:1.35rem; line-height:1.1; margin:.5rem 0 .6rem; }
.post-card h2 a{ color:var(--ink); }
.post-card h2 a:hover{ color:var(--accent-dark); }
.post-card p{ color:var(--text); }
.empty-state{ text-align:center; background:var(--card); border:1px solid var(--line); padding:3rem; }
.empty-state p{ max-width:480px; margin:0 auto 1.4rem; color:var(--text); }
.blog-single h1{ text-transform:none; font-size:clamp(2rem,4vw,3rem); }
.post-meta{ color:var(--muted); font-size:.9rem; margin-bottom:2rem; }
.prose{ font-size:1.08rem; color:var(--text); }
.prose h2{ text-transform:none; font-size:1.6rem; margin-top:2rem; }
.prose ul{ padding-left:1.2rem; } .prose li{ margin-bottom:.4rem; }
.prose img{ max-width:100%; height:auto; border-radius:var(--radius-card); margin:1rem 0; }

/* ==================== FOOTER ==================== */
.site-footer{ background:var(--dark); color:rgba(255,255,255,.78); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:2.2rem; padding:4rem 0 2.5rem; }
.brand-footer{ color:#fff; margin-bottom:.8rem; }
.brand-footer img{ width:48px; height:48px; }
.brand-footer .brand-text{ color:#fff; }
.footer-claim{ color:rgba(255,255,255,.6); max-width:300px; }
.site-footer h3{ color:#fff; font-family:var(--font-head); text-transform:uppercase; font-size:1rem; letter-spacing:.05em; margin-bottom:1rem; }
.footer-links{ list-style:none; padding:0; margin:0; }
.footer-links li{ margin-bottom:.55rem; }
.footer-links a{ color:rgba(255,255,255,.75); }
.footer-links a:hover{ color:var(--accent); }
.footer-contact{ font-style:normal; line-height:1.9; margin-bottom:1rem; }
.footer-contact a{ color:rgba(255,255,255,.85); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); }
.footer-bottom-inner{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.6rem; padding:1.3rem 0; font-size:.85rem; color:rgba(255,255,255,.55); }
.footer-legal a{ color:rgba(255,255,255,.55); }
.footer-legal a:hover{ color:var(--accent); }

/* ==================== LEGAL / 404 ==================== */
.legal h2{ font-size:1.5rem; margin-top:2rem; text-transform:uppercase; }
.legal h2:first-child{ margin-top:0; }
.legal ul{ padding-left:1.2rem; } .legal p,.legal li{ color:var(--text); }
.legal .legal-note{ margin-top:2.5rem; font-size:.85rem; color:var(--muted); }
.legal .todo{ background:#fff4d6; border:1px solid #ecd58a; padding:0 .35rem; color:#7a5b12; }
.error-page{ padding:6rem 0; }
.error-actions{ display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; margin-top:1.5rem; }

/* ==================== HOVER-FEINHEITEN ==================== */
a{ transition:color .15s ease; }
.btn{ transition:background .18s, border-color .18s, color .18s, transform .18s, box-shadow .18s; }
.btn-primary:hover{ box-shadow:0 14px 28px -12px rgba(255,119,76,.6); }
.btn-outline:hover,.btn-light:hover,.btn-ghost-light:hover{ box-shadow:0 12px 26px -14px rgba(0,0,0,.45); }
.card:hover{ box-shadow:var(--shadow); }
.card:hover .card-link{ color:var(--accent-dark); }
.card-link{ transition:color .15s, transform .15s; display:inline-block; }
.card-link:hover{ transform:translateX(3px); }
/* animierte Navigations-Unterstreichung */
.nav-list > li:not(.nav-cta) > a{ position:relative; }
.nav-list > li:not(.nav-cta) > a::after{ content:""; position:absolute; left:.8rem; right:.8rem; bottom:.3rem; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform .22s ease; }
.nav-list > li:not(.nav-cta) > a:hover::after,.nav-list > li:not(.nav-cta) > a[aria-current="page"]::after{ transform:scaleX(1); }
/* Bild-Zoom in Blöcken */
.welcome-media{ overflow:hidden; border-radius:var(--radius-card); }
.welcome-media img,.portrait,.portrait-sm{ transition:transform .5s ease; }
.welcome-media:hover img{ transform:scale(1.04); }
.brochure-mock img{ transition:transform .35s ease, box-shadow .35s ease; }
.brochure-mock:hover img{ transform:rotate(-1deg) scale(1.03); }
.faq summary{ transition:color .15s; }
.faq summary:hover{ color:var(--accent-dark); }
.price-card{ transition:transform .18s, border-color .18s, box-shadow .18s; }
.price-card:hover{ transform:translateY(-3px); border-color:var(--accent); box-shadow:var(--shadow-sm); }
.mini-card{ transition:transform .18s, border-color .18s; }
.mini-card:hover{ transform:translateY(-3px); border-color:var(--accent); }
.contact-list li{ transition:padding-left .15s; }

/* ==================== BÜCHER ==================== */
.book{ display:grid; grid-template-columns:280px 1fr; gap:2.6rem; align-items:start;
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-card); padding:2.4rem; box-shadow:var(--shadow-sm); scroll-margin-top:100px; }
.book + .book{ margin-top:2rem; }
.book.reverse{ grid-template-columns:1fr 280px; }
.book.reverse .book-media{ order:2; }
.book-cover, .book-cover-ph{ width:100%; aspect-ratio:2/3; border-radius:8px; box-shadow:0 26px 50px -22px rgba(0,0,0,.55); }
.book-cover{ object-fit:cover; display:block; }
.book-cover-ph{ display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:.5rem;
  padding:1.6rem; color:#fff; background:linear-gradient(150deg,#161210,#3a322c); position:relative; overflow:hidden; }
.book-cover-ph::before{ content:""; position:absolute; left:9px; top:0; bottom:0; width:6px; background:rgba(255,255,255,.07); }
.book-cover-ph .bk-bar{ width:38px; height:4px; background:var(--accent); margin-bottom:.4rem; }
.book-cover-ph .bk-title{ font-family:var(--font-head); text-transform:uppercase; font-size:1.25rem; line-height:1.08; }
.book-cover-ph .bk-sub{ font-size:.74rem; color:rgba(255,255,255,.72); line-height:1.3; }
.book-cover-ph .bk-note{ font-size:.68rem; color:var(--accent-soft); margin-top:.5rem; }
.book-q{ font-family:var(--font-head); text-transform:uppercase; color:var(--accent-dark); font-size:.82rem; letter-spacing:.06em; }
.book h3{ font-size:1.55rem; margin:.25rem 0 .15rem; }
.book .book-sub{ color:var(--muted); font-style:italic; margin-bottom:1rem; }
.book .relevance{ background:var(--bg-alt); border-left:4px solid var(--accent); padding:1rem 1.2rem; border-radius:0 8px 8px 0; margin:1.1rem 0; }
.book .relevance strong{ color:var(--ink); }
.book .example{ font-size:.95rem; color:var(--ink-soft, var(--text)); }

/* Praxisbeispiel-Box (Landingpages) */
.example-box{ background:#fff; border:1px solid var(--line); border-left:5px solid var(--accent);
  border-radius:var(--radius-card); padding:1.6rem 1.9rem; box-shadow:var(--shadow-sm);
  font-size:1.05rem; line-height:1.65; color:var(--text); }
.example-box strong{ color:var(--ink); }
.landing-actions{ display:flex; flex-wrap:wrap; gap:.9rem; justify-content:center; margin-top:1.9rem; }

/* Warmer Farbton rund um die Beispiel-Box, damit sie nicht „aufgeklebt" wirkt */
.example-section{ background:linear-gradient(180deg,#f4e0d2 0%,#f0e5d9 100%); }
.example-section .example-box{ box-shadow:0 16px 34px -24px rgba(232,95,51,.45); border-color:#f0d4c4; }

/* Landingpage – "Kennen Sie das?"-Karten */
.kennen-card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius-card);
  padding:1.7rem 1.6rem 1.6rem 3rem; position:relative; box-shadow:var(--shadow-sm); }
.kennen-card::before{ content:"\201E"; font-family:var(--font-head); font-weight:700; font-size:3rem;
  color:var(--accent); position:absolute; top:1.5rem; left:1rem; line-height:.5; }
.kennen-card p{ margin:0; color:var(--ink); font-size:1.05rem; font-style:italic; }
/* Landingpage – "Wie Coaching hilft"-Karten mit Nummer */
.help-card{ border-top:4px solid var(--accent); }
.help-card .help-num{ display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px;
  background:var(--accent); color:#fff; font-family:var(--font-head); font-weight:700; font-size:1.2rem;
  border-radius:50%; margin-bottom:.7rem; }
.book-buy{ margin-top:1.2rem; }
.book-buy .shops{ font-size:.92rem; color:var(--muted); margin:.4rem 0 .8rem; }
.book-actions{ display:flex; flex-wrap:wrap; gap:.7rem; }

/* "Erkennen Sie sich wieder?" – problembewusste Karten (Kundensicht) */
.recognize{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.2rem; }
.recognize a{ display:block; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-card);
  padding:1.5rem 1.7rem; color:var(--text); transition:border-color .18s, transform .18s, box-shadow .18s; }
.recognize a:hover{ border-color:var(--accent); transform:translateY(-3px); box-shadow:var(--shadow-sm); color:var(--text); }
.recognize .rq{ font-family:var(--font-head); font-size:1.12rem; color:var(--ink); margin-bottom:.25rem; display:block; }
.recognize .ra{ font-size:.95rem; color:var(--muted); display:block; margin-bottom:.5rem; }
.recognize .rgo{ color:var(--accent-dark); font-weight:700; font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; }

@media(max-width:760px){
  .book, .book.reverse{ grid-template-columns:1fr; }
  .book.reverse .book-media{ order:0; }
  .book-cover, .book-cover-ph{ max-width:230px; margin-inline:auto; }
  .recognize{ grid-template-columns:1fr; }
}

/* ==================== BÜCHER-TEASER (Startseite) ==================== */
.books-teaser{ display:grid; grid-template-columns:auto 1fr; gap:2.6rem; align-items:center; }
.bt-covers{ display:flex; }
.bt-covers img{ width:130px; aspect-ratio:2/3; object-fit:cover; border-radius:6px; box-shadow:0 20px 40px -18px rgba(0,0,0,.55); }
.bt-covers img:last-child{ margin-left:-34px; transform:rotate(3deg); }
.bt-text .eyebrow{ margin-bottom:.6rem; }
@media(max-width:760px){ .books-teaser{ grid-template-columns:1fr; text-align:center; } .bt-covers{ justify-content:center; } }

/* ==================== RESPONSIVE ==================== */
@media (max-width:980px){
  .cards-3,.offer-cards,.steps,.post-grid{ grid-template-columns:1fr 1fr; }
  .cards-4,.price-grid{ grid-template-columns:1fr 1fr; }
  .split,.contact-grid,.lm-inner,.reasons{ grid-template-columns:1fr; gap:2.2rem; }
  .split.reverse{ direction:ltr; }
  .offer-cols{ grid-template-columns:1fr 1fr; }
}
@media (max-width:760px){
  .section{ padding:3rem 0; }
  .nav-toggle{ display:flex; flex-direction:column; justify-content:center; gap:5px; width:48px; height:48px;
    background:transparent; border:1px solid var(--ink); cursor:pointer; padding:0 11px; }
  .nav-toggle span{ height:2px; background:var(--ink); transition:.25s; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .nav-list{ position:fixed; inset:80px 0 auto 0; flex-direction:column; align-items:stretch; gap:0; background:var(--bg);
    border-bottom:1px solid var(--line); padding:1rem 1.25rem 1.5rem; box-shadow:var(--shadow); transform:translateY(-150%);
    transition:transform .3s; max-height:calc(100vh - 80px); overflow:auto; }
  .nav-list.open{ transform:translateY(0); }
  .nav-list a{ padding:1rem .5rem; border-bottom:1px solid var(--line); }
  .nav-cta{ margin-top:.8rem; } .nav-cta a{ margin:0; width:100%; }
  .cards-3,.cards-4,.offer-cards,.steps,.post-grid,.price-grid,.offer-cols{ grid-template-columns:1fr; }
  .offer{ grid-template-columns:1fr; gap:1rem; padding:1.8rem; }
  .footer-grid{ grid-template-columns:1fr; gap:1.8rem; }
  .cta-inner{ flex-direction:column; align-items:flex-start; }
  .hero{ min-height:auto; } .hero-content{ padding:5rem 0; }
  .hero-media::after{ background:linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.75)); }
}
@media (prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; scroll-behavior:auto!important; } }
