@font-face {
  font-family:"Archivo Black";
  font-style:normal; font-weight:900; font-display:swap;
  src:url("../fonts/archivo-black.woff2") format("woff2");
}
/* ===== KLINIKFUCHS homepage — design tokens ===== */
:root {
  --orange:#F47C20; --black:#141414; --cream:#FBF4E6; --teal:#1B8A7A;
  --ink:#1a1a1a; --muted:#6b6b6b; --line:#f0f0f0;
  --maxw:1140px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --display:"Archivo Black","Arial Black",var(--font);
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family:var(--font); color:var(--ink); background:#fff; line-height:1.5; }
img { max-width:100%; display:block; }
a { color:inherit; }
.container { max-width:var(--maxw); margin:0 auto; }

/* ===== logo wordmark ===== */
.kf-logo { display:inline-flex; font-family:var(--display); font-weight:900;
  letter-spacing:-.5px; line-height:1; border-radius:8px; overflow:hidden; text-decoration:none; }
.kf-logo .klinik { background:#fff; color:var(--black); padding:7px 9px; }
.kf-logo .fuchs  { background:var(--orange); color:#fff; padding:7px 9px; }
.kf-logo-stack { display:inline-flex; flex-direction:column; align-items:center; gap:7px;
  font-family:var(--display); font-weight:900; letter-spacing:-1px; line-height:.95; }
.kf-logo-stack .klinik { color:var(--black); }
.kf-logo-stack .fuchs  { background:var(--orange); color:#fff; padding:5px 18px; border-radius:40px; }

/* ===== buttons ===== */
.kf-store { display:inline-flex; align-items:center; gap:7px; padding:12px 18px; border-radius:12px;
  font-size:14px; font-weight:700; text-decoration:none; }
.kf-store.primary { background:var(--black); color:#fff; }
.kf-store.ghost { background:#fff; color:var(--black); border:1.5px solid #d8d8d8; }
.kf-label { font-size:11px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; color:var(--orange); margin:0 0 14px; }

/* ===== nav ===== */
.kf-nav { display:flex; align-items:center; justify-content:space-between; padding:18px 36px; border-bottom:1px solid var(--line); }
.kf-navlinks { display:flex; gap:26px; align-items:center; font-size:14px; font-weight:600; color:#333; }
.kf-navlinks a { text-decoration:none; }
.kf-lang { border:1px solid #ddd; border-radius:8px; padding:5px 10px; font-size:13px; font-weight:700; text-decoration:none; }
.kf-navcta { background:var(--orange); color:#fff !important; padding:10px 18px; border-radius:10px; font-weight:700; font-size:14px; text-decoration:none; }
.kf-burger { display:none; background:none; border:0; font-size:24px; cursor:pointer; }

/* ===== hero ===== */
.kf-hero { background:linear-gradient(180deg,var(--cream),#fff); padding:60px 36px 50px; text-align:center; }
.kf-hero .kf-logo-stack { margin:0 auto 22px; }
.kf-badge { display:inline-block; font-size:12px; font-weight:800; letter-spacing:.4px; text-transform:uppercase;
  background:#fff; border:1px solid #f0d8bf; color:var(--orange); padding:7px 14px; border-radius:30px; margin-bottom:22px; }
.kf-h1 { font-size:46px; line-height:1.05; font-weight:800; margin:0 auto 18px; letter-spacing:-1.2px; color:var(--ink); max-width:16ch; }
.kf-hsub { font-size:18px; color:var(--muted); line-height:1.5; margin:0 auto 28px; max-width:50ch; }
.kf-cta { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.kf-devices { display:flex; align-items:flex-end; justify-content:center; gap:18px; margin-top:46px; }
.kf-shotimg { border-radius:26px; box-shadow:0 22px 50px rgba(0,0,0,.20); width:150px; }
.kf-shotimg.big { width:180px; z-index:2; position:relative; }

/* ===== audience strip ===== */
.kf-aud { padding:22px 36px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); text-align:center; }
.kf-aud .lbl { font-size:12px; color:#999; font-weight:700; letter-spacing:.5px; margin-bottom:12px; }
.kf-aud .row { display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.kf-aud .pill { font-size:13px; font-weight:600; color:#555; background:#faf7f1; border:1px solid #eee; border-radius:30px; padding:8px 16px; }

/* ===== sections ===== */
.kf-sec { padding:58px 36px; }
.kf-sec.alt { background:#fbfaf8; }
.kf-center { text-align:center; max-width:620px; margin:0 auto 8px; }
.kf-title { font-size:32px; font-weight:800; letter-spacing:-.6px; margin:0 0 12px; color:var(--ink); }
.kf-lead { font-size:16px; color:var(--muted); line-height:1.55; margin:0; }

/* ===== how-it-works rows ===== */
.kf-row { display:grid; grid-template-columns:210px 1fr; gap:40px; align-items:center; max-width:940px; margin:46px auto 0; }
.kf-row.rev { grid-template-columns:1fr 210px; }
.kf-shotwrap { display:flex; justify-content:center; }
.kf-shot { width:190px; aspect-ratio:9/18; border-radius:22px; border:1px solid #ececec; background:#fff;
  box-shadow:0 16px 40px rgba(0,0,0,.10); display:flex; align-items:center; justify-content:center; overflow:hidden;
  font-size:13px; color:#bbb; text-align:center; padding:0; }
.kf-shot img { width:100%; height:100%; object-fit:cover; }
.kf-step { font-size:12px; font-weight:800; color:var(--orange); letter-spacing:1.2px; }
.kf-row h3 { font-size:24px; margin:10px 0 12px; color:var(--ink); letter-spacing:-.4px; }
.kf-row p { font-size:15.5px; color:var(--muted); margin:0; line-height:1.6; }
.kf-row .tag { display:inline-block; margin-top:12px; margin-right:6px; font-size:12px; background:#fff;
  border:1px solid #e6e6e6; color:#666; border-radius:30px; padding:5px 13px; }
.kf-flist { list-style:none; margin:14px 0 0; padding:0; }
.kf-flist li { position:relative; padding-left:24px; margin-bottom:8px; font-size:14px; color:#555; line-height:1.45; }
.kf-flist li::before { content:"✓"; position:absolute; left:0; top:0; color:var(--teal); font-weight:800; }
.kf-flist li b { color:var(--ink); font-weight:700; }
/* learning techniques grid */
.kf-techgrid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; max-width:1000px; margin:34px auto 0; }
.kf-tech { background:#fff; border:1px solid #eee; border-radius:14px; padding:20px; }
.kf-tech .ic { font-size:24px; margin-bottom:10px; }
.kf-tech b { display:block; font-size:15px; margin-bottom:6px; color:var(--ink); }
.kf-tech p { font-size:13px; color:#666; margin:0; line-height:1.5; }
@media (max-width:860px){ .kf-techgrid { grid-template-columns:1fr; } }

/* ===== module accordion ===== */
details.kf-reiter { max-width:820px; margin:34px auto 0; text-align:center; }
details.kf-reiter > summary { list-style:none; cursor:pointer; display:inline-flex; align-items:center; gap:10px;
  background:var(--black); color:#fff; font-weight:700; font-size:15px; padding:15px 26px; border-radius:13px; }
details.kf-reiter > summary::-webkit-details-marker { display:none; }
details.kf-reiter > summary .chev { transition:transform .2s; }
details.kf-reiter[open] > summary .chev { transform:rotate(180deg); }
.kf-modgrid { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:26px; }
.kf-mod { border:1px solid #eee; border-radius:14px; padding:18px 10px; text-align:center; background:#fff; }
.kf-mod .ic { width:42px; height:42px; border-radius:12px; margin:0 auto 10px; display:flex; align-items:center;
  justify-content:center; font-size:20px; background:var(--cream); }
.kf-mod b { font-size:13px; display:block; color:var(--ink); }
.kf-mod span { font-size:11px; color:#999; }

/* ===== final cta ===== */
.kf-final { background:var(--orange); color:#fff; text-align:center; padding:60px 36px; }
.kf-final h3 { color:#fff; font-size:32px; margin:0 0 10px; letter-spacing:-.5px; }
.kf-final p { opacity:.92; font-size:16px; margin:0 0 24px; }
.kf-final .kf-store.primary { background:#fff; color:var(--black); }
.kf-final .kf-store.ghost { border-color:rgba(255,255,255,.7); color:#fff; background:transparent; }

/* ===== footer ===== */
.kf-foot { background:var(--black); color:#aaa; padding:44px 36px 26px; }
.kf-foot-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:24px; padding-bottom:28px; border-bottom:1px solid #2a2a2a; max-width:var(--maxw); margin:0 auto; }
.kf-foot .kf-logo .klinik { background:transparent; color:#fff; padding-left:0; }
.kf-foot h5 { color:#fff; font-size:13px; margin:0 0 10px; }
.kf-foot a { display:block; color:#aaa; margin-bottom:7px; text-decoration:none; font-size:13px; }
.kf-foot .badges { display:flex; gap:8px; margin-top:12px; }
.kf-foot .badge { font-size:11px; font-weight:700; border:1px solid #3a3a3a; border-radius:8px; padding:7px 10px; color:#ddd; text-decoration:none; }
.kf-foot-bot { display:flex; justify-content:space-between; align-items:center; padding-top:18px; font-size:12px; color:#777; flex-wrap:wrap; gap:10px; max-width:var(--maxw); margin:0 auto; }
.kf-foot-bot .social { display:flex; gap:12px; }
.kf-foot-bot .social a { width:28px; height:28px; border:1px solid #3a3a3a; border-radius:50%; display:flex; align-items:center; justify-content:center; text-decoration:none; }
.kf-foot-lang { border:1px solid #3a3a3a; border-radius:8px; padding:5px 10px; color:#ddd; text-decoration:none; }

/* ===== legal pages ===== */
.kf-legal { max-width:760px; margin:0 auto; padding:50px 24px 80px; }
.kf-legal h1 { font-size:32px; letter-spacing:-.5px; }
.kf-legal h2 { font-size:20px; margin-top:32px; }
.kf-legal h3 { font-size:16px; margin-top:22px; }
.kf-legal p, .kf-legal li { color:#333; font-size:15px; line-height:1.65; }
.kf-legal code { background:#f3f3f3; border-radius:4px; padding:1px 5px; font-size:13px; }
.kf-legal table { width:100%; border-collapse:collapse; margin:14px 0; font-size:13.5px; }
.kf-legal th, .kf-legal td { border:1px solid #e5e5e5; padding:8px 10px; text-align:left; vertical-align:top; }
.kf-legal th { background:#faf7f1; font-weight:700; }

/* ===== responsive ===== */
@media (max-width:860px) {
  .kf-nav { padding:14px 18px; }
  .kf-navlinks { display:none; }
  .kf-navlinks.open { display:flex; position:absolute; top:60px; left:0; right:0; background:#fff;
    flex-direction:column; gap:16px; padding:18px; border-bottom:1px solid var(--line); z-index:20; }
  .kf-burger { display:block; }
  .kf-h1 { font-size:32px; }
  .kf-hsub { font-size:16px; }
  .kf-sec { padding:40px 20px; }
  .kf-modgrid { grid-template-columns:repeat(2,1fr); }
  .kf-foot-top { grid-template-columns:1fr 1fr; }
  .kf-devices { gap:10px; }
  .kf-shotimg { width:110px; } .kf-shotimg.big { width:132px; }
}

/* how-it-works rows: stack only on real phones, screenshot above text */
@media (max-width:640px) {
  .kf-row, .kf-row.rev { grid-template-columns:1fr; gap:16px; }
  .kf-row .kf-shotwrap { order:-1; }
}

/* legal/support pages: keep the single back-home nav link visible on mobile */
.kf-navlinks--inline { display:flex !important; position:static !important; flex-direction:row !important; padding:0 !important; border:0 !important; background:none !important; }
