/* ===========================================================
   Steffani König — Neuro-Mindset & Neuausrichtung
   Personal Authority Brand
   Palette: warm oat ground, deep aubergine ink, garnet accent
   Type: Fraunces (display, italic-forward) + Hanken Grotesk (body)
   =========================================================== */

:root {
  --paper:      #F4EDE6;   /* warm oat */
  --paper-2:    #EBE0D7;   /* deeper oat for cards */
  --ink:        #2B2230;   /* deep aubergine charcoal */
  --slate:      #6E6068;   /* muted mauve-grey */
  --line:       #DFD2C8;   /* warm hairline */
  --accent:     #A93149;   /* garnet */
  --accent-deep:#8A2239;   /* darker garnet */
  --accent-soft:#F3DBDF;   /* garnet tint bg */
  --max:        1180px;
  --read:       740px;
  --ease:       cubic-bezier(.22,.61,.36,1);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  font-size: 17px;
  line-height: 1.68;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
::selection { background: var(--accent); color: #fff; }

.wrap { width: 100%; max-width: var(--max); margin: 0 auto; padding: 0 28px; }
.read { max-width: var(--read); }

.eyebrow {
  font-size: 12px; letter-spacing: .24em; text-transform: uppercase;
  font-weight: 600; color: var(--accent); margin: 0 0 20px;
}

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 88%, transparent);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--line);
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand {
  font-family: "Fraunces", Georgia, serif; font-weight: 600; font-size: 21px;
  letter-spacing: -.01em; text-decoration: none; color: var(--ink);
}
.brand .mark { color: var(--accent); font-style: italic; }
.nav { display: flex; align-items: center; gap: 28px; }
.nav a { text-decoration: none; font-size: 14.5px; font-weight: 500; color: var(--slate); transition: color .2s var(--ease); }
.nav a:hover, .nav a:focus-visible { color: var(--ink); }
.nav .nav-cta { color: var(--ink); border-bottom: 1.5px solid var(--accent); padding-bottom: 2px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .6ch;
  font-family: inherit; font-size: 15px; font-weight: 600;
  text-decoration: none; cursor: pointer; padding: 14px 24px;
  border-radius: 999px; border: 1px solid var(--accent);
  background: var(--accent); color: #fff;
  transition: background .22s var(--ease), transform .22s var(--ease);
}
.btn:hover { background: var(--accent-deep); transform: translateY(-1px); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn .arrow { transition: transform .22s var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

/* ---------- Hero ---------- */
.hero { padding: 88px 0 84px; border-bottom: 1px solid var(--line); }
.hero-grid { display: grid; grid-template-columns: 1.18fr .82fr; gap: 60px; align-items: center; }
.hero h1 {
  font-family: "Fraunces", Georgia, serif; font-weight: 460;
  font-size: clamp(40px, 5.6vw, 68px); line-height: 1.04;
  letter-spacing: -.022em; margin: 0 0 26px;
}
.hero h1 em { font-style: italic; color: var(--accent); }
.hero .lead { font-size: clamp(18px, 2vw, 20px); color: var(--slate); max-width: 46ch; margin: 0 0 34px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero-actions .sub { font-size: 14px; color: var(--slate); }

/* portrait placeholder */
.portrait {
  position: relative; aspect-ratio: 4/5; border-radius: 4px;
  background:
    radial-gradient(120% 90% at 70% 10%, var(--accent-soft), transparent 60%),
    var(--paper-2);
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.portrait::after {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(135deg, transparent 0 18px, rgba(169,49,73,.04) 18px 19px);
}
.portrait .ph-label {
  position: relative; text-align: center; color: var(--slate);
  font-size: 13px; line-height: 1.5; padding: 0 22px;
}
.portrait .ph-label strong { display: block; color: var(--ink); font-weight: 600; margin-bottom: 4px; font-size: 14px; }

/* ---------- Section base ---------- */
.block { padding: 88px 0; border-bottom: 1px solid var(--line); }
.block-head { max-width: 60ch; margin-bottom: 48px; }
.block-head h2 {
  font-family: "Fraunces", Georgia, serif; font-weight: 470;
  font-size: clamp(28px, 4vw, 42px); line-height: 1.08;
  letter-spacing: -.018em; margin: 0 0 16px;
}
.block-head h2 em { font-style: italic; color: var(--accent); }
.block-head p { color: var(--slate); font-size: 18px; margin: 0; }

/* qualifier list — "erkennst du dich wieder" */
.qual { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 4px; overflow: hidden; }
.qual .item { background: var(--paper); padding: 30px 30px; display: flex; gap: 16px; align-items: flex-start; }
.qual .item .dot { flex: none; width: 9px; height: 9px; border-radius: 999px; background: var(--accent); margin-top: 10px; }
.qual .item p { margin: 0; font-size: 17px; }
.qual .item p strong { font-weight: 600; }

/* method pillars */
.pillars { display: grid; grid-template-columns: repeat(5, 1fr); gap: 26px; }
.pillar .num {
  font-family: "Fraunces", Georgia, serif; font-style: italic;
  font-size: 17px; color: var(--accent); font-weight: 500;
  display: block; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--line);
}
.pillar h3 { font-size: 17px; margin: 0 0 8px; letter-spacing: -.005em; }
.pillar p { margin: 0; color: var(--slate); font-size: 14.5px; line-height: 1.55; }

/* about */
.about { display: grid; grid-template-columns: .85fr 1.15fr; gap: 60px; align-items: start; }
.about .portrait { aspect-ratio: 3/4; }
.about .eyebrow { margin-bottom: 16px; }
.about h2 {
  font-family: "Fraunces", Georgia, serif; font-weight: 470;
  font-size: clamp(26px, 3.4vw, 36px); line-height: 1.12;
  letter-spacing: -.015em; margin: 0 0 22px;
}
.about p { color: var(--ink); margin: 0 0 16px; }
.about p.muted { color: var(--slate); }
.about .signature {
  font-family: "Fraunces", Georgia, serif; font-style: italic;
  font-size: 22px; color: var(--accent); margin-top: 26px;
}

/* testimonial / authority quote */
.quote-strip { background: var(--ink); color: var(--paper); border-bottom: 1px solid var(--line); }
.quote-strip .wrap { padding: 78px 28px; max-width: 900px; text-align: center; }
.quote-strip .eyebrow { color: var(--accent-soft); }
.quote-strip blockquote {
  font-family: "Fraunces", Georgia, serif; font-weight: 440; font-style: italic;
  font-size: clamp(23px, 3.2vw, 33px); line-height: 1.28; letter-spacing: -.01em;
  margin: 0 0 22px;
}
.quote-strip cite { font-style: normal; font-size: 15px; color: rgba(244,237,230,.7); letter-spacing: .02em; }

/* contact */
.contact { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.contact h2 {
  font-family: "Fraunces", Georgia, serif; font-weight: 460;
  font-size: clamp(30px, 4.4vw, 46px); line-height: 1.07;
  letter-spacing: -.02em; margin: 0 0 20px;
}
.contact h2 em { font-style: italic; color: var(--accent); }
.contact .lead { color: var(--slate); font-size: 18px; margin: 0 0 28px; }
.contact-card { background: var(--ink); color: var(--paper); padding: 40px 36px; border-radius: 6px; }
.contact-card .row { border-top: 1px solid rgba(244,237,230,.16); padding: 16px 0; }
.contact-card .row:first-of-type { border-top: 0; }
.contact-card .label { font-size: 12px; letter-spacing: .18em; text-transform: uppercase; color: rgba(244,237,230,.55); margin-bottom: 4px; }
.contact-card a { color: var(--paper); text-decoration: none; font-size: 18px; border-bottom: 1px solid rgba(244,237,230,.3); padding-bottom: 1px; word-break: break-word; }
.contact-card a:hover { border-color: var(--paper); }

/* ---------- Footer ---------- */
.site-footer { padding: 56px 0 40px; }
.footer-grid { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; flex-wrap: wrap; }
.footer-brand { font-family: "Fraunces", Georgia, serif; font-size: 19px; }
.footer-brand .mark { color: var(--accent); font-style: italic; }
.footer-links { display: flex; gap: 26px; flex-wrap: wrap; }
.footer-links a { color: var(--slate); text-decoration: none; font-size: 14.5px; transition: color .2s var(--ease); }
.footer-links a:hover { color: var(--ink); }
.footer-legal { margin-top: 30px; padding-top: 22px; border-top: 1px solid var(--line); font-size: 13px; color: var(--slate); display:flex; justify-content: space-between; gap:16px; flex-wrap: wrap; }

/* ---------- Legal / content pages ---------- */
.legal { padding: 72px 0 40px; }
.legal .eyebrow { margin-bottom: 14px; }
.legal h1 { font-family: "Fraunces", Georgia, serif; font-weight: 470; font-size: clamp(34px, 5vw, 52px); letter-spacing: -.02em; line-height: 1.05; margin: 0 0 16px; }
.legal .updated { color: var(--slate); font-size: 14px; margin: 0 0 8px; }
.legal .notice { margin: 26px 0 8px; padding: 18px 20px; background: var(--accent-soft); border-left: 3px solid var(--accent); font-size: 14.5px; color: var(--ink); border-radius: 2px; }
.legal .notice strong { color: var(--ink); }
.legal h2 { font-family: "Fraunces", Georgia, serif; font-weight: 520; font-size: 24px; letter-spacing: -.01em; margin: 48px 0 14px; }
.legal h3 { font-size: 17px; margin: 26px 0 8px; }
.legal p { margin: 0 0 16px; }
.legal ul { margin: 0 0 16px; padding-left: 20px; }
.legal li { margin-bottom: 7px; }
.legal a.inline { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.legal .ph { background: #fbf3df; color: #7a5a14; padding: 1px 6px; border-radius: 3px; font-weight: 500; font-size: .94em; white-space: nowrap; }
.back-link { display:inline-flex; align-items:center; gap:.5ch; margin-top: 40px; font-size: 15px; color: var(--accent); text-decoration: none; font-weight: 600; }
.back-link:hover { text-decoration: underline; text-underline-offset: 3px; }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 940px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero .portrait { max-width: 380px; }
  .pillars { grid-template-columns: repeat(2, 1fr); gap: 24px 28px; }
  .about { grid-template-columns: 1fr; gap: 32px; }
  .about .portrait { max-width: 360px; }
}
@media (max-width: 720px) {
  body { font-size: 16px; }
  .qual { grid-template-columns: 1fr; }
  .contact { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 560px) {
  .wrap { padding: 0 20px; }
  .nav { gap: 16px; }
  .nav .nav-link { display: none; }
  .hero { padding: 56px 0 56px; }
  .pillars { grid-template-columns: 1fr; }
  .footer-legal { flex-direction: column; }
}
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .btn:hover { transform: none; }
}
