/* trust in culture impact — modernes, schlankes Stylesheet (kein Framework) */

@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/poppins-400.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;
  src:url('fonts/poppins-600.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:800;font-display:swap;
  src:url('fonts/poppins-800.woff2') format('woff2')}
@font-face{font-family:'Merriweather';font-style:italic;font-weight:400;font-display:swap;
  src:url('fonts/merriweather-italic.woff2') format('woff2')}

:root{
  --pink:#FF356F; --pink-dark:#D33479; --salmon:#FF9A90;
  --ink:#141118; --body:#3d3844; --muted:#6d6775;
  --bg:#ffffff; --bg-soft:#FBF7F8; --line:#f0e4e9;
  --grad:linear-gradient(120deg,#FF356F 0%,#D33479 100%);
  --radius:22px;
  --shadow:0 10px 40px rgba(211,52,121,.10);
  --shadow-lg:0 22px 70px rgba(211,52,121,.16);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Poppins',system-ui,-apple-system,'Segoe UI',sans-serif;
  color:var(--body);background:var(--bg);line-height:1.7;font-size:1.0rem;
  -webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--pink-dark)}
h1,h2,h3{font-weight:800;color:var(--ink);line-height:1.18;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.3rem)}
h3{font-size:1.18rem}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
section{padding:76px 0}
.eyebrow{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--pink-dark);background:rgba(255,53,111,.09);
  border:1px solid rgba(255,53,111,.22);padding:.32em 1em;border-radius:99px;margin-bottom:1.1rem}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.center{text-align:center}
.lead{font-size:1.12rem}
.muted{color:var(--muted)}

/* Skip-Link */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;
  padding:.6em 1.2em;z-index:99;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* Header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.navbar{display:flex;align-items:center;gap:1.4rem;min-height:74px}
.brand img{width:52px;height:52px;border-radius:12px}
.navbar nav{margin-left:auto}
.navbar ul{display:flex;gap:1.5rem;list-style:none;align-items:center}
.navbar nav a{color:var(--ink);text-decoration:none;font-weight:600;font-size:.94rem;
  padding:.35em 0;border-bottom:2px solid transparent;white-space:nowrap}
.navbar nav a:hover{color:var(--pink)}
.navbar nav a[aria-current="page"]{color:var(--pink-dark);border-bottom-color:var(--pink)}
.btn{display:inline-block;background:var(--grad);color:#fff;text-decoration:none;
  font-weight:600;padding:.78em 1.7em;border-radius:99px;border:0;cursor:pointer;
  font-size:.97rem;font-family:inherit;box-shadow:0 8px 24px rgba(255,53,111,.32);
  transition:transform .18s ease,box-shadow .18s ease}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(255,53,111,.42)}
.btn.ghost{background:#fff;color:var(--pink-dark);border:2px solid var(--pink);box-shadow:none}
.btn.small{padding:.55em 1.3em;font-size:.88rem}
.nav-toggle{display:none;margin-left:auto;background:none;border:0;cursor:pointer;padding:.4rem}
.nav-toggle span{display:block;width:26px;height:3px;background:var(--ink);margin:5px 0;border-radius:2px}

/* Sprachumschalter */
.lang-switch{position:relative}
.lang-switch summary{list-style:none;cursor:pointer;font-weight:600;font-size:.94rem;
  color:var(--ink);padding:.35em .2em;user-select:none}
.lang-switch summary::-webkit-details-marker{display:none}
.lang-switch summary::after{content:" ▾";font-size:.75em;color:var(--pink-dark)}
.lang-switch ul{position:absolute;right:0;top:2.2rem;background:#fff;border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--shadow-lg);padding:.5rem;display:flex;
  flex-direction:column;gap:0;min-width:9.5rem;z-index:60}
.lang-switch li{list-style:none}
.lang-switch ul a{display:block;padding:.45em .9em;border-radius:9px;border-bottom:0 !important}
.lang-switch ul a:hover{background:var(--bg-soft)}
.lang-switch ul a[aria-current="true"]{color:var(--pink-dark);font-weight:800}

/* Hero */
.hero{background:
  radial-gradient(1000px 500px at 85% -10%,rgba(255,154,144,.25),transparent 60%),
  radial-gradient(800px 420px at -10% 20%,rgba(255,53,111,.10),transparent 55%),var(--bg);
  padding:86px 0 90px}
.hero .cols{display:grid;grid-template-columns:1.05fr .95fr;gap:3.2rem;align-items:center}
.hero-img img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}
.checks{list-style:none;margin:1.6rem 0 2rem}
.checks li{padding-left:2.2rem;position:relative;margin:.65rem 0;font-weight:600;color:var(--ink)}
.checks li::before{content:"";position:absolute;left:0;top:.34em;width:1.35em;height:1.35em;
  border-radius:50%;background:var(--grad);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/70% no-repeat, linear-gradient(#000,#000);
  -webkit-mask-composite:destination-out;mask-composite:exclude}
.checks li.sum{font-size:1.15rem;color:var(--pink-dark)}
.checks li.sum::before{background:var(--salmon)}
.cta-row{display:flex;gap:1rem;flex-wrap:wrap}

/* Karten */
.cards{display:grid;gap:1.6rem;margin-top:2.6rem}
.cards.three{grid-template-columns:repeat(3,1fr)}
.cards.two{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.8rem;box-shadow:var(--shadow);transition:transform .22s ease,box-shadow .22s ease}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.card img.icon{width:118px;height:118px;object-fit:contain;margin:0 auto 1.2rem}
.card h3{margin-bottom:.55rem}
.card .tag{font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--pink-dark);margin-bottom:.4rem}

/* Formel */
.formel{background:var(--bg-soft)}
.formel-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:1.6rem;align-items:stretch;margin-top:2.4rem}
.formel-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem;box-shadow:var(--shadow);text-align:center}
.formel-card h3{font-size:1.5rem;margin-bottom:1rem}
.formel-card ul{list-style:none}
.formel-card li{font-style:italic;color:var(--body);padding:.42em 0;border-top:1px dashed var(--line)}
.formel-card li:first-child{border-top:0}
.formel-x{display:flex;align-items:center;justify-content:center;font-size:2.4rem;
  font-weight:800;color:var(--pink)}
.formel-note{margin-top:2.4rem;text-align:center}
.formel-note strong{color:var(--ink)}

/* Zitat */
.quote{background:linear-gradient(120deg,#1c1522,#3a1a2c);color:#fff}
.quote .cols{display:grid;grid-template-columns:auto 1fr;gap:2.6rem;align-items:center}
.quote img{width:168px;height:168px;border-radius:50%;object-fit:cover;
  border:4px solid rgba(255,255,255,.25)}
.quote blockquote{font-family:'Merriweather',Georgia,serif;font-style:italic;
  font-size:clamp(1.2rem,2.6vw,1.65rem);line-height:1.55}
.quote figcaption{margin-top:1.1rem;color:var(--salmon);font-weight:600}

/* Countdown / Buch — Buchfoto als Sektionshintergrund wie im Original */
.buch{background:#d9d9d9 url('img/bg-hero.jpg') no-repeat right center/cover;
  text-align:left;padding:110px 0}
.buch-content{max-width:620px}
.buch-mobile{display:none}
.countdown{display:flex;gap:1.1rem;justify-content:flex-start;margin:2.2rem 0;flex-wrap:wrap}
.cd-box{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:18px;
  min-width:104px;padding:1rem .6rem;text-align:center;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.cd-box b{display:block;font-size:2.3rem;font-weight:800;line-height:1.1;
  font-variant-numeric:tabular-nums;color:var(--pink-dark)}
.cd-box span{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
@media(max-width:920px){
  .buch{background-image:none;background:#e9e7e5;padding:56px 0}
  .buch-mobile{display:block;max-width:400px;margin:2.2rem auto 0;border-radius:18px;
    box-shadow:0 14px 40px rgba(0,0,0,.18)}
}

/* Formulare */
form.ml{max-width:640px;margin:2rem auto 0;text-align:left}
.buch form.ml{margin-left:0}
.field{margin-bottom:1rem}
.field input,.field textarea{width:100%;padding:.95em 1.2em;border-radius:14px;
  border:1px solid var(--line);font:inherit;color:var(--ink);background:#fff}
.field input:focus,.field textarea:focus{outline:3px solid rgba(255,53,111,.35)}
.field textarea{min-height:140px;resize:vertical}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.92rem;margin:1rem 0 1.4rem}
.consent input{width:1.25em;height:1.25em;margin-top:.22em;accent-color:var(--pink-dark)}
.buch .center{text-align:left}
.form-note{font-size:.85rem;opacity:.85;margin-top:.6rem}
.form-success{display:none;margin:2rem auto 0;max-width:640px;background:#fff;
  color:var(--ink);border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow)}
.form-success.show{display:block}
.mail-hint{display:none;margin-top:1rem;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:.9rem 1.2rem;font-size:.92rem;box-shadow:var(--shadow)}
.mail-hint.show{display:block}

/* Schritte */
.steps{counter-reset:step}
.steps .card{position:relative;padding-top:3.4rem;text-align:center}
.steps .card::before{counter-increment:step;content:counter(step);
  position:absolute;top:-24px;left:50%;transform:translateX(-50%);
  width:48px;height:48px;border-radius:50%;background:var(--grad);color:#fff;
  font-weight:800;font-size:1.25rem;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 20px rgba(255,53,111,.35)}
.steps .card img{border-radius:14px;max-height:320px;object-fit:contain;margin:0 auto}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:16px;
  margin-top:1rem;box-shadow:var(--shadow);overflow:hidden}
.faq summary{cursor:pointer;font-weight:600;color:var(--ink);padding:1.15rem 1.4rem;
  list-style:none;position:relative;padding-right:3rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:1.3rem;top:50%;
  transform:translateY(-50%);font-size:1.5rem;font-weight:400;color:var(--pink)}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 1.4rem 1.2rem}

/* Workshops */
.ws-card{display:flex;flex-direction:column}
.ws-card .price{margin-top:auto;padding-top:1.2rem;font-weight:800;color:var(--pink-dark);font-size:1.25rem}
.ws-card .price small{display:block;font-weight:400;color:var(--muted);font-size:.82rem;line-height:1.5}
.ws-card ul{margin:.4rem 0 .9rem 1.2rem}
.ws-card h4{color:var(--pink-dark);font-size:.85rem;letter-spacing:.1em;
  text-transform:uppercase;margin:1.1rem 0 .2rem}
.kpis{display:flex;gap:1rem;flex-wrap:wrap;margin:.6rem 0}
.kpi{background:rgba(255,53,111,.08);border:1px solid rgba(255,53,111,.2);
  border-radius:14px;padding:.6rem 1rem;font-weight:600;color:var(--pink-dark)}

/* Split-Layout */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}

/* Footer */
footer.site{background:var(--ink);color:#cfc8d4;padding:56px 0 40px;font-size:.95rem}
footer.site .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem}
footer.site h3{color:#fff;font-size:1rem;margin-bottom:.8rem}
footer.site a{color:var(--salmon);text-decoration:none}
footer.site a:hover{text-decoration:underline}
footer.site ul{list-style:none}
footer.site li{margin:.35rem 0}
footer.site img.logo{width:56px;border-radius:12px;margin-bottom:1rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2.5rem;
  padding-top:1.4rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem}
.li-badge{display:inline-flex;align-items:center;gap:.5rem;font-weight:600}
.li-badge svg{width:22px;height:22px;fill:var(--salmon)}

/* Reveal-Animation (nur wenn JS aktiv; ohne JS ist alles sichtbar) */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}
@media print{.js .reveal{opacity:1;transform:none}}

/* Rechtsseiten — hängende Nummerierung wie auf tf-impact.com */
.legal{max-width:860px}
.legal h2{margin-top:2.6rem;font-size:1.45rem}
.legal h3{margin-top:1.6rem;margin-left:3.4rem}
.legal p{margin-top:.8rem;margin-left:3.4rem}
.legal ul,.legal ol{margin:.6rem 0 .6rem 4.8rem}
.legal li{margin:.3rem 0}
.legal .hang{position:relative}
.legal .hang-num{position:absolute;left:-3.4rem;top:0;width:2.9rem;font-weight:600;color:var(--pink-dark)}
.legal h2 .hang-num{font-weight:800;color:inherit;top:auto}
.legal h1,.legal h2,.legal .eyebrow{margin-left:0}
.legal h2.hang{padding-left:3.4rem}
.legal h2 .hang-num{left:0}
.legal table{width:calc(100% - 3.4rem);margin:1.2rem 0 1.2rem 3.4rem;border-collapse:collapse;font-size:.94rem}
.legal th,.legal td{border:1px solid var(--line);padding:.7em .9em;text-align:left;vertical-align:top}
.legal th{background:var(--bg-soft);color:var(--ink)}
.legal .stand{margin-top:2.4rem;color:var(--muted);font-size:.9rem}
.legal.simple p,.legal.simple ul{margin-left:0}
.legal.simple ul{margin-left:1.5rem}
@media(max-width:640px){
  .legal p,.legal h3{margin-left:2.5rem}
  .legal ul,.legal ol{margin-left:3.6rem}
  .legal .hang-num{left:-2.5rem;width:2.2rem;font-size:.85em;top:.15em}
  .legal h2.hang{padding-left:2.5rem}
  .legal h2 .hang-num{left:0;top:auto;font-size:inherit}
  .legal table{width:calc(100% - 2.5rem);margin-left:2.5rem}
  .legal.simple p{margin-left:0}
  .legal.simple ul{margin-left:1.5rem}
}

/* Responsive */
@media(max-width:1120px){
  .navbar > nav > ul{display:none;position:absolute;top:74px;left:0;right:0;background:#fff;
    flex-direction:column;padding:1.2rem 22px 1.6rem;gap:1.1rem;border-bottom:1px solid var(--line);
    box-shadow:0 18px 40px rgba(0,0,0,.08)}
  .navbar > nav > ul.open{display:flex}
  .nav-toggle{display:block}
  .lang-switch ul{position:static;box-shadow:none;border:0;padding:0;flex-direction:row;gap:.4rem}
}
@media(max-width:920px){
  .hero .cols,.split,.quote .cols{grid-template-columns:1fr}
  .cards.three,.cards.two{grid-template-columns:1fr}
  .formel-grid{grid-template-columns:1fr}
  .formel-x{transform:rotate(90deg)}
  footer.site .cols{grid-template-columns:1fr}
  .hero{padding:56px 0 64px}
  section{padding:56px 0}
}
