/*
Theme Name: JaZZ Tierfreunde
Theme URI: https://jazztierfreunde.de
Author: JaZZ Tierfreu(n)de e.V.
Description: Eigenes Theme für den Tierschutzverein JaZZ Tierfreu(n)de e.V. – warmes, freundliches Design in der JaZZ-Markenfarbe Lila mit Bernstein-Akzent. Klassisches Theme mit Hero, Projektkarten, Spenden-Bereich und barrierearmer Navigation.
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: tierfreunde
*/

/* ============================================================
   0. Design-Tokens
   ============================================================ */
:root{
  --tf-purple:#5A326E;        /* Markenfarbe (aus Logo) */
  --tf-purple-700:#4A2A5E;
  --tf-purple-800:#3A2049;
  --tf-purple-900:#2C1738;    /* Footer / dunkle Bänder */
  --tf-purple-300:#9B7BB0;
  --tf-purple-100:#EEE7F2;    /* sehr helle Lila-Fläche */
  --tf-lilac:#F4EFF7;

  --tf-amber:#E79B33;         /* warmer Akzent / Spenden */
  --tf-amber-600:#CC8221;
  --tf-amber-100:#FBEFD9;

  --tf-green:#4E9D7E;         /* "nachhaltig" – sparsam */
  --tf-green-100:#E4F1EB;

  --tf-cream:#FBF8F4;         /* warmer Seitenhintergrund */
  --tf-white:#ffffff;
  --tf-ink:#2C2433;           /* Fließtext */
  --tf-muted:#6A6374;         /* sekundärer Text */
  --tf-line:#E9E2EE;          /* Trennlinien */

  --tf-radius:18px;
  --tf-radius-sm:12px;
  --tf-radius-lg:26px;
  --tf-shadow:0 14px 40px -18px rgba(58,32,73,.45);
  --tf-shadow-sm:0 6px 20px -10px rgba(58,32,73,.35);
  --tf-maxw:1180px;
  --tf-gutter:clamp(18px,4vw,40px);

  --tf-head:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --tf-body:'Nunito Sans','Nunito',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* ============================================================
   1. Reset & Basis
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--tf-body);
  font-size:18px;
  line-height:1.7;
  color:var(--tf-ink);
  background:var(--tf-cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  overflow-wrap:break-word;
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
#tf-main{flex:1 0 auto}
.tf-footer{flex-shrink:0}
img{max-width:100%;height:auto;display:block}
a{color:var(--tf-purple);text-underline-offset:3px}
a:hover{color:var(--tf-purple-700)}
h1,h2,h3,h4{font-family:var(--tf-head);font-weight:700;line-height:1.18;color:var(--tf-purple-900);margin:0 0 .5em}
h1{font-size:clamp(2rem,4.2vw,3.1rem);letter-spacing:-.5px}
h2{font-size:clamp(1.55rem,3vw,2.25rem);letter-spacing:-.3px}
h3{font-size:clamp(1.2rem,2vw,1.45rem)}
p{margin:0 0 1.1em}
ul,ol{margin:0 0 1.1em;padding-left:1.3em}
li{margin:.35em 0}
hr{border:0;border-top:1px solid var(--tf-line);margin:2em 0}
strong{font-weight:700;color:var(--tf-purple-800)}
:focus-visible{outline:3px solid var(--tf-purple);outline-offset:3px;border-radius:6px}
.tf-section--purple :focus-visible,.tf-footer :focus-visible,.tf-pagehero :focus-visible,.tf-project-head :focus-visible{outline-color:#fff}
.tf-cta :focus-visible{outline-color:var(--tf-purple-900)}

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

/* ============================================================
   2. Layout-Helfer
   ============================================================ */
.tf-container{width:100%;max-width:var(--tf-maxw);margin-inline:auto;padding-inline:var(--tf-gutter)}
.tf-narrow{max-width:820px;margin-inline:auto}
.tf-section{padding:clamp(48px,7vw,92px) 0}
.tf-section--tint{background:var(--tf-lilac)}
.tf-section--purple{background:linear-gradient(160deg,var(--tf-purple),var(--tf-purple-800));color:#fff}
.tf-section--purple h1,.tf-section--purple h2,.tf-section--purple h3{color:#fff}
.tf-section--cream{background:var(--tf-cream)}
.tf-center{text-align:center}

.tf-kicker{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--tf-head);font-weight:600;font-size:.82rem;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--tf-purple);
  background:var(--tf-purple-100);padding:.45em 1em;border-radius:999px;margin-bottom:1rem;
}
.tf-section--purple .tf-kicker{background:rgba(255,255,255,.16);color:#fff}
.tf-lead{font-size:1.18rem;color:var(--tf-muted);max-width:62ch}
.tf-center .tf-lead{margin-inline:auto}
.tf-section--purple .tf-lead{color:rgba(255,255,255,.9)}

/* ============================================================
   3. Buttons
   ============================================================ */
.tf-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--tf-head);font-weight:600;font-size:1rem;line-height:1;
  padding:.92em 1.7em;border-radius:999px;border:2px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
}
.tf-btn svg{width:1.1em;height:1.1em}
.tf-btn--primary{background:var(--tf-purple);color:#fff}
.tf-btn--primary:hover{background:var(--tf-purple-700);color:#fff;transform:translateY(-2px);box-shadow:var(--tf-shadow-sm)}
.tf-btn--donate{background:var(--tf-amber);color:#3a2410}
.tf-btn--donate:hover{background:var(--tf-amber-600);color:#3a2410;transform:translateY(-2px);box-shadow:0 10px 26px -10px rgba(231,155,51,.7)}
.tf-btn--ghost{background:transparent;color:var(--tf-purple);border-color:var(--tf-purple-300)}
.tf-btn--ghost:hover{background:var(--tf-purple);color:#fff;border-color:var(--tf-purple)}
.tf-btn--white{background:#fff;color:var(--tf-purple)}
.tf-btn--white:hover{background:var(--tf-amber);color:#3a2410;transform:translateY(-2px)}
.tf-btn--lg{font-size:1.08rem;padding:1.05em 2.1em}
.tf-btn-row{display:flex;flex-wrap:wrap;gap:14px}
.tf-center .tf-btn-row{justify-content:center}

/* ============================================================
   4. Header
   ============================================================ */
.tf-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--tf-line);transition:box-shadow .25s ease,padding .25s ease}
.tf-header.is-scrolled{box-shadow:0 8px 30px -16px rgba(58,32,73,.4)}
.tf-headbar{display:flex;align-items:center;gap:20px;min-height:84px;padding-block:8px;transition:min-height .25s ease;max-width:1320px}
.tf-header.is-scrolled .tf-headbar{min-height:68px}
.tf-logo{display:flex;align-items:center;gap:12px;text-decoration:none;flex:0 0 auto}
.tf-logo img{height:60px;width:auto;transition:height .25s ease}
.tf-header.is-scrolled .tf-logo img{height:48px}
.tf-logo-text{display:flex;flex-direction:column;line-height:1.1}
.tf-logo-text b{font-family:var(--tf-head);font-weight:700;color:var(--tf-purple-900);font-size:1.05rem}
.tf-logo-text span{font-size:.74rem;color:var(--tf-muted);letter-spacing:.4px}

.tf-nav{margin-left:auto;display:flex;align-items:center;gap:2px}
.tf-nav ul{list-style:none;display:flex;gap:0;margin:0;padding:0}
.tf-nav a{
  font-family:var(--tf-head);font-weight:600;font-size:.93rem;color:var(--tf-purple-900);
  text-decoration:none;padding:.5em .72em;border-radius:999px;transition:background .2s,color .2s;white-space:nowrap;
  display:flex;align-items:center;min-height:44px;
}
.tf-nav a:hover{background:var(--tf-purple-100);color:var(--tf-purple)}
.tf-nav .current-menu-item>a,.tf-nav .current_page_item>a{background:var(--tf-purple);color:#fff}
.tf-header-cta{margin-left:8px;padding:.7em 1.2em;font-size:.92rem}

/* Burger */
.tf-burger{display:none;margin-left:auto;width:48px;height:48px;border:0;background:var(--tf-purple-100);border-radius:14px;cursor:pointer;position:relative}
.tf-burger span{position:absolute;left:13px;right:13px;height:2.5px;background:var(--tf-purple);border-radius:2px;transition:transform .3s,opacity .2s}
.tf-burger span:nth-child(1){top:17px}
.tf-burger span:nth-child(2){top:23px}
.tf-burger span:nth-child(3){top:29px}
.tf-burger.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.tf-burger.is-open span:nth-child(2){opacity:0}
.tf-burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Mobiles Menü */
.tf-mobile-nav{display:none;border-top:1px solid var(--tf-line);background:#fff}
.tf-mobile-nav ul{list-style:none;margin:0;padding:10px var(--tf-gutter) 22px}
.tf-mobile-nav a{display:block;font-family:var(--tf-head);font-weight:600;color:var(--tf-purple-900);text-decoration:none;padding:.85em .4em;border-bottom:1px solid var(--tf-line)}
.tf-mobile-nav a:hover{color:var(--tf-purple)}
.tf-mobile-nav .tf-btn{margin-top:16px;width:100%}
.tf-mobile-nav.is-open{display:block;animation:tfDrop .3s ease}
@keyframes tfDrop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ============================================================
   5. Hero (Startseite)
   ============================================================ */
.tf-hero{position:relative;overflow:hidden;background:linear-gradient(155deg,#fff 0%,var(--tf-lilac) 55%,var(--tf-purple-100) 100%)}
.tf-hero::before,.tf-hero::after{content:"";position:absolute;border-radius:50%;pointer-events:none}
.tf-hero::before{width:520px;height:520px;right:-160px;top:-180px;background:radial-gradient(circle,rgba(231,155,51,.18),transparent 70%)}
.tf-hero::after{width:460px;height:460px;left:-180px;bottom:-200px;background:radial-gradient(circle,rgba(90,50,110,.16),transparent 70%)}
.tf-hero-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,64px);align-items:center;padding:clamp(46px,7vw,86px) 0}
.tf-hero h1{margin-bottom:.35em}
.tf-hero .tf-lead{font-size:1.25rem}
.tf-hero-art{position:relative;display:flex;justify-content:center;align-items:center}
.tf-hero-art .tf-logo-disc{width:min(380px,80%);aspect-ratio:1;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--tf-shadow);padding:10%}
.tf-hero-art .tf-logo-disc img{width:100%}
.tf-hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:1.4rem}
.tf-badge{display:inline-flex;align-items:center;gap:.5em;background:#fff;border:1px solid var(--tf-line);border-radius:999px;padding:.5em 1em;font-weight:600;font-size:.9rem;color:var(--tf-purple-800);box-shadow:var(--tf-shadow-sm)}
.tf-badge b{color:var(--tf-amber-600)}

/* ============================================================
   6. Karten / Grids
   ============================================================ */
.tf-grid{display:grid;gap:26px}
.tf-grid--2{grid-template-columns:repeat(2,1fr)}
.tf-grid--3{grid-template-columns:repeat(3,1fr)}
.tf-grid--4{grid-template-columns:repeat(4,1fr)}

.tf-card{background:#fff;border:1px solid var(--tf-line);border-radius:var(--tf-radius);padding:30px;box-shadow:var(--tf-shadow-sm);transition:transform .2s ease,box-shadow .25s ease}
.tf-card:hover{transform:translateY(-4px);box-shadow:var(--tf-shadow)}
.tf-card h3{margin-top:.2em}
.tf-card p:last-child{margin-bottom:0}
.tf-card-icon{width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:var(--tf-purple-100);color:var(--tf-purple);margin-bottom:18px}
.tf-card-icon svg{width:30px;height:30px}
.tf-card-icon--amber{background:var(--tf-amber-100);color:var(--tf-amber-600)}
.tf-card-icon--green{background:var(--tf-green-100);color:var(--tf-green)}

/* Projektkarten */
.tf-project{background:#fff;border:1px solid var(--tf-line);border-radius:var(--tf-radius);overflow:hidden;box-shadow:var(--tf-shadow-sm);display:flex;flex-direction:column;transition:transform .2s,box-shadow .25s}
.tf-project:hover{transform:translateY(-4px);box-shadow:var(--tf-shadow)}
.tf-project-head{padding:22px 26px;background:linear-gradient(135deg,var(--tf-purple),var(--tf-purple-800));color:#fff}
.tf-project-head h3{color:#fff;margin:0}
.tf-project-head .tf-project-where{font-size:.85rem;opacity:.85;font-weight:600}
.tf-project-body{padding:24px 26px;flex:1;display:flex;flex-direction:column}
.tf-project-body p:last-of-type{margin-bottom:0}
.tf-project-contact{font-size:.92rem;color:var(--tf-muted);margin-top:auto;padding-top:14px}
.tf-project-contact b{color:var(--tf-purple-800)}
.tf-tag-row{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 16px}
.tf-tag{font-size:.78rem;font-weight:700;font-family:var(--tf-head);padding:.32em .8em;border-radius:999px;background:var(--tf-purple-100);color:var(--tf-purple)}
.tf-tag--amber{background:var(--tf-amber-100);color:#8A4B00}
.tf-tag--green{background:var(--tf-green-100);color:#2F6B53}

/* ============================================================
   7. Statistik-Zahlen ("Was wir erreicht haben")
   ============================================================ */
.tf-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.tf-stat{text-align:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--tf-radius);padding:28px 18px}
.tf-section:not(.tf-section--purple) .tf-stat{background:#fff;border:1px solid var(--tf-line);box-shadow:var(--tf-shadow-sm)}
.tf-stat-num{font-family:var(--tf-head);font-weight:800;font-size:clamp(2.2rem,4vw,3rem);line-height:1;color:var(--tf-amber);font-variant-numeric:tabular-nums}
.tf-section:not(.tf-section--purple) .tf-stat-num{color:var(--tf-purple)}
.tf-stat-label{font-weight:600;margin-top:.5em;font-size:.98rem}
.tf-section--purple .tf-stat-label{color:rgba(255,255,255,.92)}

/* ============================================================
   8. Ziele-Liste
   ============================================================ */
.tf-goals{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.tf-goals li{position:relative;background:#fff;border:1px solid var(--tf-line);border-radius:var(--tf-radius-sm);padding:18px 20px 18px 56px;margin:0;box-shadow:var(--tf-shadow-sm);font-size:1rem}
.tf-goals li::before{content:"";position:absolute;left:18px;top:20px;width:24px;height:24px;border-radius:50%;background:var(--tf-amber-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23CC8221' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/14px no-repeat}

/* ============================================================
   9. CTA-Band (Spenden)
   ============================================================ */
.tf-cta{background:linear-gradient(135deg,var(--tf-amber),#f0b35a);border-radius:var(--tf-radius-lg);padding:clamp(34px,5vw,58px);text-align:center;color:#3a2410;position:relative;overflow:hidden}
.tf-cta h2{color:#3a2410}
.tf-cta .tf-lead{color:#3a2410}
.tf-cta .tf-btn-row{justify-content:center;margin-top:1.4rem}

/* IBAN / Spenden-Box */
.tf-iban{display:inline-flex;flex-direction:column;gap:4px;background:#fff;border:2px dashed var(--tf-purple-300);border-radius:var(--tf-radius-sm);padding:16px 22px;margin:4px 0 12px;max-width:100%}
.tf-iban small{font-weight:700;color:var(--tf-muted);font-size:.78rem;letter-spacing:1px;text-transform:uppercase}
.tf-iban b{font-family:var(--tf-head);font-size:1.2rem;color:var(--tf-purple-900);letter-spacing:.5px;word-break:break-word}

/* ============================================================
   10. Kontakt
   ============================================================ */
.tf-contact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.tf-contact-item{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--tf-line);border-radius:var(--tf-radius-sm);padding:18px 20px;box-shadow:var(--tf-shadow-sm)}
.tf-contact-item .tf-ci{flex:0 0 auto;width:44px;height:44px;border-radius:12px;background:var(--tf-purple-100);color:var(--tf-purple);display:flex;align-items:center;justify-content:center}
.tf-contact-item .tf-ci svg{width:22px;height:22px}
.tf-contact-item b{display:block;font-family:var(--tf-head);color:var(--tf-purple-900)}
.tf-contact-item a{font-weight:600}
.tf-contact-item p{margin:0;font-size:.98rem;color:var(--tf-muted)}

/* ============================================================
   11. Instagram-Streifen
   ============================================================ */
.tf-insta{text-align:center}
.tf-insta-handle{font-family:var(--tf-head);font-weight:700;font-size:1.3rem;color:var(--tf-purple)}

/* ============================================================
   12. Seiten-Hero (Unterseiten) + Brotkrumen
   ============================================================ */
.tf-pagehero{background:linear-gradient(160deg,var(--tf-purple),var(--tf-purple-800));color:#fff;padding:clamp(40px,6vw,72px) 0;position:relative;overflow:hidden}
.tf-pagehero::after{content:"";position:absolute;right:-120px;top:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(231,155,51,.22),transparent 70%)}
.tf-pagehero h1{color:#fff;margin:0;position:relative}
.tf-pagehero .tf-lead{color:rgba(255,255,255,.9);margin-top:.6em;position:relative}
.tf-breadcrumbs{font-size:.85rem;color:rgba(255,255,255,.78);margin-bottom:1rem;position:relative}
.tf-breadcrumbs a{color:#fff;text-decoration:none}
.tf-breadcrumbs a:hover{text-decoration:underline}
.tf-breadcrumbs span{margin:0 .5em;opacity:.6}

/* ============================================================
   13. Seiten-Inhalt (Fließtext .tf-content)
   ============================================================ */
.tf-content{font-size:1.06rem}
.tf-content h2{margin-top:1.8em}
.tf-content h2:first-child,.tf-content h3:first-child{margin-top:0}
.tf-content h3{margin-top:1.5em;color:var(--tf-purple)}
.tf-content ul li::marker{color:var(--tf-amber-600)}
.tf-content a{font-weight:600}
.tf-content img{border-radius:var(--tf-radius);margin:1.4em 0;box-shadow:var(--tf-shadow-sm)}
.tf-content blockquote{margin:1.6em 0;padding:18px 26px;border-left:5px solid var(--tf-amber);background:var(--tf-amber-100);border-radius:0 var(--tf-radius-sm) var(--tf-radius-sm) 0;font-size:1.1rem}
.tf-content blockquote p:last-child{margin-bottom:0}
.tf-content table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:.96rem}
.tf-content th,.tf-content td{padding:.7em 1em;border:1px solid var(--tf-line);text-align:left}
.tf-content tr:nth-child(even){background:var(--tf-lilac)}

/* WP-Standardklassen */
.alignleft{float:left;margin:.4em 1.6em 1em 0}
.alignright{float:right;margin:.4em 0 1em 1.6em}
.aligncenter{margin-inline:auto}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.85rem;color:var(--tf-muted);text-align:center}

/* ============================================================
   14. Footer
   ============================================================ */
.tf-footer{background:var(--tf-purple-900);color:rgba(255,255,255,.82);font-size:.97rem}
.tf-footer a{color:rgba(255,255,255,.82);text-decoration:none}
.tf-footer a:hover{color:#fff}
.tf-footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:clamp(44px,6vw,72px) 0 40px}
.tf-footer-brand{display:flex;gap:16px;align-items:flex-start}
.tf-footer-brand .tf-flogo{flex:0 0 auto;width:74px;height:74px;border-radius:18px;background:#fff;display:flex;align-items:center;justify-content:center;padding:8px}
.tf-footer-brand .tf-flogo img{width:100%}
.tf-footer-brand h3{color:#fff;margin:0 0 .3em;font-size:1.15rem}
.tf-footer-brand p{margin:0;color:rgba(255,255,255,.7);font-size:.92rem}
.tf-footer h4{color:#fff;font-size:1rem;margin:0 0 1em;letter-spacing:.3px}
.tf-footer ul{list-style:none;margin:0;padding:0}
.tf-footer ul li{margin:.5em 0}
.tf-fcontact{display:flex;flex-direction:column;gap:.55em}
.tf-fcontact span{display:flex;gap:.6em;align-items:flex-start;color:rgba(255,255,255,.78)}
.tf-fcontact svg{width:18px;height:18px;flex:0 0 auto;margin-top:3px;opacity:.85}
.tf-footer-bottom{border-top:1px solid rgba(255,255,255,.14);padding:20px 0;display:flex;flex-wrap:wrap;gap:12px 24px;justify-content:space-between;align-items:center;font-size:.86rem;color:rgba(255,255,255,.6)}
.tf-footer-bottom nav{display:flex;flex-wrap:wrap;gap:8px 20px}

/* ============================================================
   15. 404
   ============================================================ */
.tf-404{text-align:center;padding:clamp(60px,10vw,120px) 0}
.tf-404 .tf-big{font-family:var(--tf-head);font-weight:800;font-size:clamp(5rem,16vw,10rem);line-height:1;color:var(--tf-purple-100)}

/* ============================================================
   16. Scroll-Reveal & nach-oben
   ============================================================ */
.tf-reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.tf-reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.tf-reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

.tf-top{position:fixed;right:20px;bottom:20px;width:50px;height:50px;border-radius:50%;background:var(--tf-purple);color:#fff;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;z-index:900;box-shadow:var(--tf-shadow)}
.tf-top.is-show{opacity:1;pointer-events:auto}
.tf-top:hover{background:var(--tf-amber);color:#3a2410;transform:translateY(-3px)}
.tf-top svg{width:22px;height:22px}

/* ============================================================
   17. Responsive
   ============================================================ */
@media (max-width:980px){
  .tf-hero-inner{grid-template-columns:1fr;text-align:center}
  .tf-hero .tf-lead{margin-inline:auto}
  .tf-hero-art{order:-1}
  .tf-hero-art .tf-logo-disc{width:min(260px,62%)}
  .tf-hero-badges{justify-content:center}
  .tf-grid--4{grid-template-columns:repeat(2,1fr)}
  .tf-stats{grid-template-columns:repeat(2,1fr)}
  .tf-footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .tf-footer-brand{grid-column:1 / -1}
}
/* Logo-Tagline ab mittleren Breiten ausblenden (auch mobil) */
@media (max-width:1200px){
  .tf-logo-text span{display:none}
}
/* Volle horizontale Navigation erst ab >1200px; darunter Burger-Menü
   (Logo + Nav + Spenden-Button passen erst ab ~1280px komfortabel) */
@media (max-width:1200px){
  .tf-nav,.tf-header-cta{display:none}
  .tf-burger{display:block}
}
@media (max-width:820px){
  .tf-grid--2,.tf-grid--3{grid-template-columns:1fr}
  .tf-goals{grid-template-columns:1fr}
  .tf-contact-grid{grid-template-columns:1fr}
}
@media (max-width:560px){
  body{font-size:17px}
  .tf-grid--4{grid-template-columns:1fr}
  .tf-stats{grid-template-columns:1fr 1fr}
  .tf-footer-top{grid-template-columns:1fr}
  .alignleft,.alignright{float:none;margin:1.2em auto}
  .tf-iban b{font-size:1.05rem;letter-spacing:0}
}

/* Print */
@media print{
  .tf-header,.tf-mobile-nav,.tf-top,.tf-cta,.tf-footer-bottom nav{display:none}
  body{background:#fff;color:#000}
}
