/*
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-purple-150:#E3D6EC;
  --tf-amber-150:#F6E0B8;
  --tf-green-150:#D4E9DF;

  --tf-cream:#FAF4EC;         /* 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 22px 50px -22px rgba(58,32,73,.30), 0 4px 12px -4px rgba(58,32,73,.12);
  --tf-shadow-sm:0 10px 30px -14px rgba(58,32,73,.22), 0 2px 6px -2px rgba(58,32,73,.10);
  --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.62;
  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;text-wrap:balance}
h1{font-size:clamp(2rem,4.2vw,3.1rem);letter-spacing:-.5px;line-height:1.1}
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-color:var(--tf-lilac);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160' viewBox='0 0 160 160'%3E%3Cg fill='none' stroke='%235A326E' stroke-width='2' opacity='0.035'%3E%3Cellipse cx='80' cy='92' rx='15' ry='18'/%3E%3Ccircle cx='58' cy='60' r='7'/%3E%3Ccircle cx='80' cy='52' r='7'/%3E%3Ccircle cx='102' cy='60' r='7'/%3E%3Ccircle cx='112' cy='80' r='6'/%3E%3C/g%3E%3C/svg%3E");background-repeat:repeat;background-size:160px}
.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}
/* Abstands-Feintuning einzelner Sektionen */
.tf-tight-top{padding-top:clamp(12px,2vw,26px)}
.tf-tight-bottom{padding-bottom:clamp(12px,2vw,26px)}

.tf-kicker{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--tf-head);font-weight:700;font-size:.76rem;letter-spacing:.09em;
  text-transform:uppercase;color:var(--tf-purple);
  background:var(--tf-purple-100);padding:.45em 1em;border-radius:999px;margin-bottom:1rem;
}
.tf-kicker svg{width:1.45em;height:1.45em;flex:0 0 auto}
.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;line-height:1.55}
.tf-center .tf-lead{margin-inline:auto}
.tf-section--purple .tf-lead{color:rgba(255,255,255,.9)}
.tf-content,.tf-content p,.tf-card p,.tf-lead{-webkit-hyphens:auto;hyphens:auto;hyphenate-limit-chars:6 3 3}
.tf-center h2::after{content:'';display:block;width:54px;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--tf-amber),var(--tf-purple));margin:.55em auto 0}
.tf-section--purple .tf-center h2::after{background:linear-gradient(90deg,var(--tf-amber),#fff)}
.tf-cta .tf-center h2::after,.tf-cta h2::after{content:none}

/* ============================================================
   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;box-shadow:0 12px 26px -14px rgba(90,50,110,.55)}
.tf-btn--primary:hover{background:var(--tf-purple-700);color:#fff;transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(90,50,110,.6)}
.tf-btn--donate{background:var(--tf-amber);color:#3a2410;box-shadow:0 12px 24px -12px rgba(231,155,51,.65)}
.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(56px,8vw,104px) 0}
.tf-hero h1{margin-bottom:.35em}
.tf-hero .tf-lead{font-size:1.25rem;line-height:1.5}
.tf-hero-art{position:relative;display:flex;justify-content:center;align-items:center;align-self:stretch}
.tf-hero-art .tf-logo-disc{width:min(420px,90%);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 svg{width:1.05em;height:1.05em;flex:0 0 auto;color:var(--tf-purple)}
.tf-badge b{color:var(--tf-amber-600)}

/* ============================================================
   6. Karten / Grids
   ============================================================ */
.tf-grid{display:grid;gap:clamp(22px,2vw,30px)}
.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-top:3px solid var(--tf-amber);border-radius:var(--tf-radius);padding:30px;box-shadow:0 10px 30px -16px rgba(58,32,73,.22);transition:transform .2s ease,box-shadow .25s ease,border-color .25s ease}
.tf-card:hover{transform:translateY(-4px);border-top-color:var(--tf-purple);box-shadow:0 20px 46px -20px rgba(90,50,110,.32)}
.tf-card h3{margin-top:.2em}
.tf-card p:last-child{margin-bottom:0}
.tf-card-icon{width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--tf-purple-100),var(--tf-purple-150));color:var(--tf-purple);margin-bottom:16px}
.tf-card-icon svg{width:26px;height:26px}
.tf-card-icon--amber{background:linear-gradient(145deg,var(--tf-amber-100),var(--tf-amber-150));color:var(--tf-amber-600)}
.tf-card-icon--green{background:linear-gradient(145deg,var(--tf-green-100),var(--tf-green-150));color:var(--tf-green)}
/* Empty-State + Bald-Pille */
.tf-empty{background:linear-gradient(160deg,#fff 0%,var(--tf-lilac) 100%);border:1px dashed var(--tf-purple-300);border-radius:var(--tf-radius);padding:clamp(34px,5vw,52px);text-align:center;box-shadow:var(--tf-shadow-sm)}
.tf-empty .tf-card-icon{width:64px;height:64px;margin:0 auto 18px;background:var(--tf-purple-100);color:var(--tf-purple);border-radius:18px}
.tf-empty .tf-card-icon svg{width:30px;height:30px}
.tf-empty h3{color:var(--tf-purple-800)}
.tf-empty p,.tf-empty em{color:var(--tf-purple-800);font-style:italic;font-size:1.06rem;max-width:48ch;margin-inline:auto}
.tf-soon{display:inline-flex;align-items:center;gap:.4em;font-family:var(--tf-head);font-weight:600;font-size:.74rem;letter-spacing:.4px;text-transform:uppercase;color:var(--tf-amber-600);background:var(--tf-amber-100);padding:.32em .8em;border-radius:999px;font-style:normal;line-height:1.2}
/* Gedenk-Beitrag (stille Begleiter) */
.tf-memorial{display:grid;grid-template-columns:300px 1fr;gap:0;max-width:920px;margin-inline:auto;background:#fff;border:1px solid var(--tf-line);border-top:3px solid var(--tf-amber);border-radius:var(--tf-radius);overflow:hidden;box-shadow:var(--tf-shadow-sm);text-align:left}
.tf-memorial>figure{margin:0;display:flex}
.tf-memorial img{width:100%;height:100%;min-height:300px;object-fit:cover;object-position:center;display:block}
.tf-memorial-body{padding:clamp(24px,3vw,36px)}
.tf-memorial-body h3{margin:.1em 0 .15em}
.tf-memorial-date{display:inline-flex;align-items:center;gap:.45em;font-family:var(--tf-head);font-weight:600;font-size:.78rem;color:var(--tf-purple);background:var(--tf-purple-100);padding:.35em .9em;border-radius:999px;margin-bottom:.9em}
.tf-memorial-date svg{width:1.05em;height:1.05em;flex:0 0 auto}
.tf-memorial-sub{color:var(--tf-amber-600);font-weight:600;font-style:italic;margin:0 0 1em}
.tf-memorial-body p:last-child{margin-bottom:0}
.tf-memorial+.tf-memorial{margin-top:clamp(22px,3vw,32px)}
.tf-memorial--flip{grid-template-columns:1fr 300px}
.tf-memorial--flip>figure{order:2}
@media(max-width:680px){.tf-memorial{grid-template-columns:1fr}.tf-memorial img{min-height:240px;max-height:340px}.tf-memorial--flip>figure{order:-1}}
/* Ausführliche Tiergeschichte mit Galerie */
.tf-story{max-width:920px;margin-inline:auto;background:#fff;border:1px solid var(--tf-line);border-top:3px solid var(--tf-amber);border-radius:var(--tf-radius);box-shadow:var(--tf-shadow-sm);overflow:hidden;text-align:left}
.tf-story-body{padding:clamp(26px,3.5vw,42px)}
.tf-story-body h3{font-size:clamp(1.45rem,2.6vw,1.9rem);margin:.15em 0 .55em}
.tf-story-body h4{color:var(--tf-purple);font-family:var(--tf-head);font-size:1.18rem;margin:1.5em 0 .35em}
.tf-story-body p{font-size:1.04rem}
.tf-story-sub{color:var(--tf-amber-600);font-weight:600;font-size:.82rem;letter-spacing:1px;text-transform:uppercase;font-family:var(--tf-head);margin:0 0 1em}
.tf-story-outro{font-family:var(--tf-head);font-weight:600;color:var(--tf-purple);font-size:1.1rem;border-left:4px solid var(--tf-amber);padding-left:16px;margin-top:1.4em}
.tf-story-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:1.4em}
.tf-story-gallery figure{margin:0}
.tf-story-gallery img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center;border-radius:var(--tf-radius-sm);display:block;box-shadow:var(--tf-shadow-sm)}
.tf-story-gallery--sq img{aspect-ratio:1}
.tf-story-gallery figcaption{font-size:.8rem;color:var(--tf-muted);margin-top:.45em;line-height:1.35}
@media(max-width:680px){.tf-story-gallery{grid-template-columns:1fr;max-width:360px;margin-inline:auto}}
.tf-story--single{border-top:3px solid var(--tf-amber)}

/* Foto mit Zitat-Overlay (z.B. Cooper auf der Über-uns-Seite) */
.tf-quote-img{position:relative;margin:0;border-radius:var(--tf-radius);overflow:hidden;box-shadow:var(--tf-shadow)}
.tf-quote-img img{display:block;width:100%;height:100%;object-fit:cover}
.tf-quote-img .tf-quote-text{position:absolute;left:0;right:0;bottom:0;padding:70px 16px 18px;background:linear-gradient(180deg,transparent,rgba(24,12,30,.85));color:#fff;font-family:var(--tf-head);font-weight:700;font-size:clamp(.92rem,1.3vw,1.1rem);line-height:1.35;text-align:center;text-shadow:0 2px 8px rgba(0,0,0,.55)}

/* Tiergeschichten-Kacheln (Übersichtsraster) */
.tf-story-card{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--tf-line);border-radius:var(--tf-radius);overflow:hidden;box-shadow:var(--tf-shadow-sm);text-decoration:none;color:inherit;transition:transform .2s ease,box-shadow .25s ease}
.tf-story-card:hover{transform:translateY(-5px);box-shadow:var(--tf-shadow);color:inherit}
.tf-story-card__media{aspect-ratio:4/3;overflow:hidden;background:var(--tf-purple-100)}
.tf-story-card__media img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;transition:transform .4s ease}
.tf-story-card:hover .tf-story-card__media img{transform:scale(1.06)}
.tf-story-card__media--placeholder{display:flex;align-items:center;justify-content:center}
.tf-story-card__media--placeholder svg{width:56px;height:56px;color:#fff;opacity:.9}
.tf-story-card__badge{position:absolute;top:14px;right:14px;z-index:2}
.tf-story-card__body{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.tf-story-card h3{margin:.05em 0 .4em;font-size:1.28rem}
.tf-story-card__body p{color:var(--tf-muted);font-size:.96rem;margin-bottom:.9em;flex:1}
.tf-story-card__cta{display:inline-flex;align-items:center;gap:.4em;font-family:var(--tf-head);font-weight:600;color:var(--tf-purple);font-size:.95rem;margin-top:auto}
.tf-story-card__cta svg{width:1em;height:1em;transition:transform .2s ease}
.tf-story-card:hover .tf-story-card__cta svg{transform:translateX(4px)}
.tf-soon--memorial{color:var(--tf-purple);background:var(--tf-purple-100)}
.tf-soon--memorial svg{width:1.1em;height:1.1em}
.tf-stories-grid--memorial .tf-story-card{border-top:3px solid var(--tf-purple-300)}
.tf-story-card--more{background:var(--tf-purple-100);border-style:dashed}
.tf-story-card--more .tf-story-card__body{padding:30px 26px}
.tf-story-card--more .tf-story-card__cta{color:var(--tf-purple-800)}

/* Featured-Projekt/Beitrag (Foto + Text nebeneinander, Foto unbeschnitten) */
.tf-feature{display:grid;grid-template-columns:minmax(300px,400px) 1fr;gap:clamp(24px,3vw,40px);align-items:start;max-width:1000px;margin-inline:auto;background:#fff;border:1px solid var(--tf-line);border-top:3px solid var(--tf-amber);border-radius:var(--tf-radius);box-shadow:var(--tf-shadow-sm);padding:clamp(22px,3vw,34px);text-align:left}
.tf-feature>figure{margin:0;position:sticky;top:100px}
.tf-feature img{width:100%;height:auto;border-radius:var(--tf-radius-sm);display:block;box-shadow:var(--tf-shadow-sm)}
.tf-feature figcaption{font-size:.8rem;color:var(--tf-muted);margin-top:.5em;text-align:center}
.tf-feature h3{font-size:clamp(1.4rem,2.4vw,1.8rem);margin:.1em 0 .15em}
.tf-feature-sub{color:var(--tf-amber-600);font-weight:600;margin:0 0 1em}
.tf-feature p{font-size:1.03rem}
.tf-facts{display:flex;flex-wrap:wrap;gap:8px;margin:1.2em 0}
.tf-facts span{display:inline-flex;align-items:center;gap:.4em;font-size:.85rem;font-weight:600;color:var(--tf-purple);background:var(--tf-purple-100);padding:.4em .85em;border-radius:999px}
@media(max-width:760px){.tf-feature{grid-template-columns:1fr}.tf-feature>figure{position:static;max-width:420px;margin-inline:auto}}

/* 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,border-color .2s}
.tf-project:hover{transform:translateY(-3px);border-color:var(--tf-purple-300);box-shadow:0 16px 44px -18px rgba(58,32,73,.5),0 0 0 3px var(--tf-purple-100)}
.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{display:inline-block;white-space:nowrap;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:clamp(20px,1.8vw,28px)}
.tf-stat{text-align:center;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);border-radius:var(--tf-radius);padding:28px 18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 18px 40px -26px rgba(0,0,0,.5)}
.tf-section:not(.tf-section--purple) .tf-stat{background:#fff;border:1px solid var(--tf-line);border-top:3px solid var(--tf-amber);box-shadow:0 16px 38px -20px rgba(58,32,73,.28)}
.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;letter-spacing:-.5px}
.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;line-height:1.3}
.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:radial-gradient(120% 140% at 0% 0%,#F2B45C 0%,var(--tf-amber) 45%,var(--tf-amber-600) 100%);border:1px solid rgba(255,255,255,.35);box-shadow:0 30px 60px -28px rgba(204,130,33,.6);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:clamp(20px,3vw,32px)}
.tf-cta-media{display:flex;flex-wrap:wrap;gap:clamp(18px,2.5vw,28px);justify-content:center;align-items:center;margin-top:clamp(18px,3vw,30px)}

/* IBAN / Spenden-Box */
.tf-iban{display:inline-flex;flex-direction:column;gap:4px;background:#fff;border:1px solid var(--tf-line);border-radius:var(--tf-radius-sm);padding:20px 26px;margin:4px 0 12px;max-width:100%;box-shadow:var(--tf-shadow-sm)}
.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.28rem;color:var(--tf-purple-900);letter-spacing:1px;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::before{content:"";position:absolute;left:-140px;bottom:-160px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(231,155,51,.10),transparent 70%);pointer-events:none}
.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;line-height:1.68}
.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}
  .tf-hero .tf-btn-row{gap:12px}
  .tf-hero .tf-btn-row .tf-btn{width:100%}
  .tf-card{padding:22px 20px}
  .tf-project-head{padding:20px 18px}
  .tf-project-body{padding:22px 18px}
  .tf-lead{font-size:1.05rem;line-height:1.6}
  .tf-hero .tf-lead{font-size:1.08rem}
  .tf-cta{border-radius:var(--tf-radius);padding:28px 18px}
  .tf-iban{padding:14px 16px}
  .tf-footer-bottom{justify-content:center;text-align:center;gap:16px}
  .tf-footer-bottom nav{justify-content:center;column-gap:18px;row-gap:10px}
}

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