/*
 Theme Name:   Nonprofit Foundation Child
 Theme URI:    https://fv-osradebeulmitte.org
 Description:  Child Theme für Nonprofit Foundation
 Author:       Jens Seidel - J's Webdesign
 Template:     charity-zone
 Version:      1.0
 Text Domain:  nonprofit-foundation-child
*/

@import url("../charity-zone/style.css");
@import url("../nonprofit-foundation/style.css");
/*@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;600;700&display=swap');*/

@font-face {
  font-family: 'Open Sans';
  src: url('fonts/open-sans-v44-latin-regular.woff2') format('woff2');
  font-weight: 400; font-display: swap;
}
@font-face {
  font-family: 'Open Sans';
  src: url('fonts/open-sans-v44-latin-500.woff2') format('woff2');
  font-weight: 500; font-display: swap;
}
@font-face {
  font-family: 'Open Sans';
  src: url('fonts/open-sans-v44-latin-600.woff2') format('woff2');
  font-weight: 600; font-display: swap;
}
@font-face {
  font-family: 'Open Sans';
  src: url('fonts/open-sans-v44-latin-600.woff2') format('woff2');
  font-weight: 700; font-display: swap;
}

/* =============================================================================
   1. DESIGN TOKENS
   ============================================================================= */

:root {
  --fv-teal:        #29AF8A;
  --fv-teal-light:  #d0f0e8;
  --fv-orange:      #ff9f1c;
  --fv-dark:        #0f172a;
  --fv-green:       #29AF8A;
  --fv-white-panel: rgba(255, 255, 255, 0.96);
  --fv-radius-lg:   26px;
  --fv-radius-md:   18px;
  --fv-radius-sm:   16px;
  --fv-shadow-lg:   0 18px 45px rgba(15, 23, 42, 0.12);
  --fv-shadow-md:   0 10px 26px rgba(15, 23, 42, 0.08);
}


/* =============================================================================
   2. BASIS-TYPOGRAFIE & GLOBALE STYLES
   ============================================================================= */

body        { font-family: 'Open Sans', sans-serif; font-weight: 400; }
h1, h2, h3  { font-family: 'Open Sans', sans-serif; font-weight: 700; }
p           { font-weight: 400; }

html { overflow-y: scroll; scrollbar-gutter: stable; }

body.custom-background {
  background: #f7f8fb;
  background-image:
    radial-gradient(1200px circle at top left,  #d8f0ff 0, transparent 60%),
    radial-gradient(900px  circle at bottom right, #ffe7c4 0, transparent 55%);
}

h1.entry-title { display: none; }
.top-info      { margin: 8px 0; display: none; }
.fa-search     { display: none !important; }
.navbar-brand  { display: inline-table; }
.socialmedia   { padding: .75rem 0 .25rem; background: var(--fv-green); }


/* =============================================================================
   3. HEADER & NAVIGATION
   ============================================================================= */

#masthead {
  background:    var(--fv-green);
  border-bottom: none;
  box-shadow:    0 4px 18px rgba(15, 23, 42, .15);
  margin-bottom: 0;
}

.head-menu            { background: var(--fv-green) !important; padding: 0 !important; }
.head-menu .container { max-width: 1200px; }
.head-menu .container .row {
  display:     flex !important;
  align-items: center !important;
  min-height:  52px !important;
  flex-wrap:   wrap !important;
}

.site-logo        { display: flex !important; align-items: center !important; height: auto !important; line-height: 1 !important; }
.custom-logo-link { display: flex !important; align-items: center !important; line-height: 1 !important; }

img.custom-logo {
  display:       block !important;
  border-radius: 50% !important;
  object-fit:    cover !important;
  box-shadow:    none !important;
  background:    transparent !important;
  padding:       0 !important;
}

.navbar-brand .site-title a,
.socialmedia .site-title a { font-size: 1.4rem !important; }

/* ── Desktop ab 1200px ── */
@media (min-width: 1200px) {
  .toggle-nav.mobile-menu { display: none !important; }

  .navbar-brand .site-title a { font-size: 2.2rem !important; }

  .navbar-brand .site-logo img,
  .navbar-brand .custom-logo-link img,
  .navbar-brand img.custom-logo {
    width:         120px !important;
    height:        120px !important;
    max-height:    120px !important;
    max-width:     120px !important;
    min-width:     120px !important;
    border-radius: 50% !important;
    object-fit:    cover !important;
    flex-shrink:   0;
  }

  .navbar-brand {
    position:      relative !important;
    height:        auto !important;
    display:       flex !important;
    align-items:   center;
    gap:           .75rem;
    padding:       .5rem 1.2rem !important;
    background:    transparent !important;
    box-shadow:    none !important;
    margin:        0 !important;
    color:         #fff;
    border-radius: 0 !important;
  }

  .navbar-brand .site-title   { margin: 0; line-height: 1.25; font-size: 1.05rem; font-weight: 700; }
  .navbar-brand .site-title a { color: #fff; text-decoration: none; }
  .head-menu .offset-lg-2     { margin-left: 0 !important; flex: 1; }

  #mySidenav {
    position:       static !important;
    display:        flex !important;
    flex-direction: row !important;
    align-items:    center !important;
    background:     transparent !important;
    width:          auto !important;
    height:         auto !important;
    padding:        0 !important;
    overflow:       visible !important;
    box-shadow:     none !important;
    z-index:        auto !important;
    transform:      none !important;
  }

  #mySidenav .main-navigation,
  #mySidenav nav              { display: flex !important; align-items: center !important; }
  #mySidenav .menu-main-container { display: flex !important; }

  #mySidenav ul#menu-main,
  #mySidenav ul.menu {
    display:        flex !important;
    flex-direction: row !important;
    align-items:    center !important;
    flex-wrap:      nowrap !important;
    gap:            .1rem;
    margin:         0 !important;
    padding:        0 !important;
    list-style:     none !important;
  }

  #mySidenav li { white-space: nowrap !important; display: block !important; }

  #mySidenav li a {
    color:           rgba(255,255,255,.9) !important;
    font-size:       .88rem !important;
    font-weight:     600 !important;
    padding:         .4rem .6rem !important;
    border-radius:   8px !important;
    display:         block !important;
    text-decoration: none !important;
    white-space:     nowrap !important;
  }

  #mySidenav li a:hover,
  #mySidenav li.current-menu-item > a {
    background: rgba(255,255,255,.18) !important;
    color:      #fff !important;
  }
}

/* ── Mobile/Tablet bis 1199px ── */
@media (max-width: 1199px) {
  #masthead .socialmedia {
    display:    block !important;
    padding:    .25rem 0 !important;
    background: var(--fv-green) !important;
  }

  #masthead .socialmedia .navbar-brand {
    display:        flex !important;
    flex-direction: row !important;
    align-items:    center !important;
    width:          auto !important;
    max-width:      75vw !important;
    background:     transparent !important;
    border-radius:  0 !important;
    gap:            .5rem !important;
    padding:        .25rem .6rem !important;
    height:         auto !important;
    min-height:     0 !important;
  }

  #masthead .socialmedia .navbar-brand img {
    width:         40px !important;
    height:        40px !important;
    min-width:     40px !important;
    max-width:     40px !important;
    max-height:    40px !important;
    border-radius: 50% !important;
    object-fit:    cover !important;
    flex-shrink:   0 !important;
    margin:        0 !important;
  }

  #masthead .socialmedia .navbar-brand .site-title {
    margin:    0 !important;
    flex:      1 !important;
    min-width: 0 !important;
  }

  #masthead .socialmedia .navbar-brand .site-title a {
    font-size:     clamp(.85rem, 4.5vw, 1.2rem) !important;
    color:         #fff !important;
    white-space:   nowrap !important;
    text-overflow: ellipsis !important;
    display:       block !important;
    line-height:   1.3 !important;
  }

  #masthead .head-menu {
    background: var(--fv-green) !important;
    padding:    0 !important;
    box-shadow: none !important;
  }

  #masthead .head-menu .container .row { min-height: auto !important; }

  #masthead .head-menu .offset-lg-4 { margin-left: 85% !important; }

  #masthead .head-menu .fv-sticky-brand,
  #masthead .head-menu .donate-btn,
  #masthead .head-menu .col-lg-2 { display: none !important; }

  #masthead .head-menu #mySidenav:not(.show) { display: none !important; }

  #masthead .head-menu .toggle-nav.mobile-menu {
    display:   block !important;
    position:  static !important;
    transform: none !important;
  }

  #masthead .head-menu .toggle-nav.mobile-menu button {
    background:  transparent !important;
    border:      none !important;
    color:       #fff !important;
    font-size:   1.3rem !important;
    padding:     .3rem .6rem !important;
    cursor:      pointer !important;
    line-height: 1 !important;
    display:     block !important;
  }

  .fv-sticky-brand { display: none !important; }

  #masthead {
    position:       relative !important;
    margin-bottom:  0 !important;
    padding-bottom: 0 !important;
  }

  #mySidenav      { background: var(--fv-green) !important; }
  #mySidenav li a { color: #fff !important; }
}

/* ── Sticky Brand ── */
.fv-sticky-brand {
  display:        flex;
  align-items:    center;
  gap:            .5rem;
  opacity:        0;
  transform:      translateX(-10px);
  transition:     opacity .25s ease, transform .25s ease;
  margin-right:   auto;
  pointer-events: none;
  flex-shrink:    0;
  order:          0;
}

.fv-is-scrolled .fv-sticky-brand {
  opacity:        1;
  transform:      translateX(0);
  pointer-events: auto;
}

.fv-sticky-brand a   { display: flex; align-items: center; text-decoration: none; }
.fv-sticky-title     { color: #fff; font-size: .88rem; font-weight: 700; white-space: nowrap; }
.fv-sticky-brand img { width: 32px !important; height: 32px !important; min-width: 32px !important; border-radius: 50% !important; object-fit: cover !important; }

/* ── Bottom Navigation ── */
.fv-bottom-nav {
  display:        none;
  position:       fixed;
  bottom:         0; left: 0; right: 0;
  z-index:        999;
  background:     white;
  border-top:     1px solid rgba(15,23,42,.08);
  box-shadow:     0 -4px 20px rgba(15,23,42,.08);
  padding-bottom: env(safe-area-inset-bottom);
}
.fv-bottom-nav-item {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; padding: 10px 4px 12px;
  gap: 3px; text-decoration: none;
}
.fv-bottom-nav-icon  { font-size: 18px; line-height: 1; }
.fv-bottom-nav-label { font-size: 9px; font-weight: 600; color: #9ca3af; text-transform: uppercase; letter-spacing: .04em; }
.fv-bottom-nav-item.active .fv-bottom-nav-label { color: var(--fv-teal); }

@media (max-width: 768px) {
  .fv-bottom-nav { display: flex; }
  body           { padding-bottom: 65px; }
}


/* =============================================================================
   4. STARTSEITE – LAYOUT & PANEL
   ============================================================================= */

.home #skip-content .container          { padding-top: 2.5rem; padding-bottom: 3rem; }
.home #primary                          { background: transparent; border-radius: 0; box-shadow: none; padding: 0; }
.home .site-main > article              { max-width: 100%; margin: 0; padding: 0; background: transparent; box-shadow: none; }
.home #primary > .site-main             { display: flex; flex-direction: column; gap: 2.4rem; }
.home .entry-content                    { font-family: 'Open Sans', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.home .entry-content p                  { font-size: 1rem; line-height: 1.7; margin-bottom: .9rem; }
.home .entry-content a, .fv-card a      { color: var(--fv-teal); }
.fv-card a:hover                        { text-decoration: underline; }


/* =============================================================================
   5. HERO-BEREICH
   ============================================================================= */

.fv-hero {
  position: relative; border-radius: var(--fv-radius-lg);
  overflow: hidden; min-height: 280px; margin-bottom: 2.2rem;
  background-size: cover; background-position: center;
}

.fv-hero::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(41,175,138,.75), rgba(255,159,28,.65));
}

.fv-hero-inner--split { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 2rem; }
.fv-hero-text         { min-width: 0; }
.fv-hero-image        { display: flex; align-items: center; justify-content: center; }

.fv-hero-logo {
  width: clamp(150px, 22vw, 260px); height: auto;
  border-radius: 16px; background: transparent;
  padding: 0; box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

.fv-hero-inner {
  background: rgba(255,255,255,.88); border-radius: 20px;
  padding: clamp(1.8rem, 3vw, 2.4rem); color: var(--fv-dark);
}
.fv-hero-inner h1       { margin: .6rem 0 1.1rem; font-size: clamp(2rem, 1.3rem + 2vw, 2.8rem); line-height: 1.15; color: var(--fv-dark); }
.fv-hero-inner p        { color: var(--fv-dark); }
.fv-hero-inner strong,
.fv-hero-inner a        { color: var(--fv-orange); text-decoration: none; }
.fv-hero-actions        { margin-top: 1.4rem; display: flex; flex-wrap: wrap; gap: .75rem; }

.fv-hero-badge {
  display: inline-block; padding: .35rem 1rem; border-radius: 999px;
  background: rgba(0,0,0,0.35); color: #fff; font-size: .8rem; font-weight: 600;
  letter-spacing: .04em; text-transform: uppercase;
  backdrop-filter: blur(3px); text-shadow: 0 1px 2px rgba(0,0,0,.45);
}

@media (max-width: 768px) {
  .fv-hero {
    border-radius: 0 !important; margin-left: -1rem !important;
    margin-right: -1rem !important; min-height: 420px !important; margin-bottom: 0 !important;
  }
  .fv-hero-inner {
    background: rgba(0,0,0,.45) !important; border-radius: 0 !important;
    margin: 0 !important; padding: 1.5rem 1.2rem !important; color: #fff !important;
  }
  .fv-hero-inner h1,
  .fv-hero-inner p        { color: #fff !important; }
  .fv-hero-inner strong,
  .fv-hero-inner a        { color: #ffe2a0 !important; }
  .fv-hero-inner--split   { grid-template-columns: 1fr !important; text-align: center !important; }
  .fv-hero-logo           { margin: 0 auto 1rem !important; width: 120px !important; order: -1 !important; }
  .fv-hero-actions        { justify-content: center !important; }
  .fv-btn-primary-link    { background: #fff !important; color: var(--fv-teal) !important; }
  .fv-btn-outline-link    { border-color: #fff !important; color: #fff !important; }
}


/* =============================================================================
   6. BUTTONS
   ============================================================================= */

.fv-btn-primary .wp-block-button__link         { background: var(--fv-teal); border-color: var(--fv-teal); color: #fff; }
.fv-btn-primary .wp-block-button__link:hover   { background: #23c99a; }
.fv-btn-outline .wp-block-button__link         { background: transparent; border-color: #fff; color: #fff; }
.fv-btn-outline .wp-block-button__link:hover   { background: rgba(255,255,255,.25); }

.fv-btn-primary-link,
.fv-btn-outline-link {
  display: inline-block; padding: .65rem 1.6rem; border-radius: 999px;
  font-size: .95rem; font-weight: 600;
  text-decoration: none !important;
  transition: transform .15s, box-shadow .15s, background .15s;
}

.fv-btn-primary-link { background: var(--fv-teal); color: #fff !important; box-shadow: 0 4px 14px rgba(41,175,138,.35); }
.fv-btn-primary-link:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(41,175,138,.45); background: #23c99a; }
.fv-btn-outline-link { background: transparent; color: var(--fv-teal) !important; border: 2px solid var(--fv-teal); }
.fv-btn-outline-link:hover { background: var(--fv-teal); color: #fff !important; transform: translateY(-2px); }

a.fv-contact-btn   { background: var(--fv-teal) !important; color: #fff !important; text-decoration: none !important; border-color: var(--fv-teal) !important; }
.fv-cta-btn--white { background: #fff !important; color: var(--fv-teal) !important; text-decoration: none !important; border: none !important; }
.fv-cta-btn--ghost { background: rgba(255,255,255,.18) !important; color: #fff !important; border: 1.5px solid rgba(255,255,255,.5) !important; text-decoration: none !important; }


/* =============================================================================
   7. SEKTIONEN & KACHELN (Startseite)
   ============================================================================= */

.fv-section-wrap {
  padding: 1.6rem 1.4rem; border-radius: var(--fv-radius-md);
  background: linear-gradient(135deg, rgba(0,184,176,.04), rgba(255,159,28,.03));
  border: 1px solid rgba(15,23,42,.04);
}
.fv-section-wrap > * + *  { margin-top: 1.5rem; }
.fv-section-title         { font-size: 1.2rem; font-weight: 700; margin: 0 0 .75rem; display: inline-flex; align-items: center; gap: .4rem; }
.fv-section-title::after  { content: ""; height: 3px; width: 42px; border-radius: 999px; background: var(--fv-orange); }
.fv-section-title-top     { font-size: 1.45rem; font-weight: 700; margin-bottom: 0.8rem; display: inline-flex; align-items: center; gap: .4rem; }

.fv-stats-strip           { display: flex; border-bottom: 1px solid rgba(15,23,42,.06); margin-bottom: 1.5rem; }
.fv-stat-item             { flex: 1; text-align: center; padding: 1rem .5rem; border-right: 1px solid rgba(15,23,42,.06); }
.fv-stat-item:last-child  { border-right: none; }
.fv-stat-num              { display: block; font-size: 1.6rem; font-weight: 700; color: var(--fv-teal); line-height: 1; margin-bottom: .25rem; }
.fv-stat-label            { font-size: .72rem; color: #6b7280; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }

.fv-impact-intro          { font-size: 1.05rem; line-height: 1.75; color: #374151; max-width: 820px; margin: 0 0 2rem; }
.fv-impact-intro a        { color: var(--fv-teal); text-decoration: underline; text-underline-offset: .18em; }

.fv-cards-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.4rem; }

.fv-card {
  position: relative; background: #fff; border-radius: var(--fv-radius-md);
  padding: 1.8rem 1.6rem; box-shadow: var(--fv-shadow-md);
  display: flex; flex-direction: column; gap: .6rem;
  overflow: hidden; transition: transform .18s ease-out, box-shadow .18s ease-out;
  border-top: 3px solid var(--fv-teal);
}
.fv-card:hover    { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(15,23,42,.14); }
.fv-card-icon     { font-size: 2rem; line-height: 1; margin-bottom: .2rem; }
.fv-card-title    { font-size: 1.05rem; font-weight: 700; color: var(--fv-dark); margin: 0; }
.fv-card-text     { font-size: .95rem; line-height: 1.65; color: #4b5563; margin: 0; flex: 1; }
.fv-card-btn {
  align-self: flex-start; margin-top: .4rem; padding: .45rem 1.1rem;
  border-radius: 999px; background: var(--fv-teal);
  color: #fff !important; font-size: .88rem; font-weight: 600;
  text-decoration: none !important; transition: filter .15s, transform .15s; white-space: nowrap;
}
.fv-card-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }

@media (max-width: 600px) {
  .fv-cards-grid { grid-template-columns: 1fr; }
  .fv-card       { flex-direction: column !important; align-items: flex-start !important; padding: 1.4rem 1.2rem; }
  .fv-card-icon  { font-size: 1.8rem; flex-shrink: 0; margin-top: 0; }
  .fv-card-btn   { align-self: flex-start; margin-top: .6rem; width: auto !important; display: inline-block !important; }
}

.fv-feature-columns .wp-block-column { background: #fff; border-radius: var(--fv-radius-md); padding: 1.6rem 1.8rem; box-shadow: 0 8px 22px rgba(15,23,42,.10); }
.fv-feature-columns { margin-bottom: 2.5rem; }

.fv-feature-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; margin-top: 1.5rem; }
.fv-feature-card  { position: relative; border-radius: var(--fv-radius-md); overflow: hidden; min-height: 220px; background-size: cover; background-position: center; box-shadow: 0 10px 26px rgba(15,23,42,.1); }
.fv-feature-card::before  { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(41,175,138,.65), rgba(255,159,28,.45)); }
.fv-feature-card-content  { position: relative; padding: 1.4rem 1.5rem; color: #fff; display: flex; flex-direction: column; justify-content: flex-end; min-height: 220px; }
.fv-feature-card-content h2 { margin: 0 0 .4rem; font-size: 1.2rem; }
.fv-feature-card-content a  { margin-top: .5rem; font-weight: 600; color: #fff; text-decoration: underline; text-underline-offset: .18em; }

@media (max-width: 768px) {
  .fv-section-wrap  { padding: 1.3rem 1.1rem; }
  .fv-section-title { font-size: 1.05rem; }
}
@media (max-width: 480px) {
  .fv-feature-card,
  .fv-feature-card-content { min-height: 180px; }
}


/* =============================================================================
   8. UNTERSEITEN – PANEL-LAYOUT
   ============================================================================= */

.page:not(.home) #skip-content .container { padding: 3rem 0 3.5rem; }
.page:not(.home) #primary                 { background: transparent; border-radius: 0; box-shadow: none; }
.page:not(.home) .entry-header            { margin-bottom: 1.4rem; }
.page:not(.home) .entry-title             { font-size: clamp(1.9rem, 1.2rem + 1.5vw, 2.4rem); line-height: 1.1; margin: 0 0 .3rem; }
.page:not(.home) .entry-content p         { font-size: 1rem; line-height: 1.7; margin-bottom: .9rem; }

.page:not(.home) .entry-content a:not(.fv-contact-btn):not(.fv-cta-btn):not(.fv-cta-btn--white):not(.fv-cta-btn--ghost):not(.fv-card-btn):not(.fv-support-btn):not(.fv-contact-mail-btn):not(.fv-contact-doc-link) {
  color: var(--fv-teal);
  text-decoration: underline;
  text-decoration-thickness: .12em;
  text-underline-offset: .18em;
}


/* =============================================================================
   9. KONTAKTSEITE (alt)
   ============================================================================= */

.page-id-37 .entry-content { margin-top: 1.5rem; }
.fv-contact-grid           { display: grid; gap: 1.4rem; }

@media (min-width: 768px) {
  .fv-contact-grid                       { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .fv-contact-grid .fv-contact-highlight { grid-column: 1 / -1; }
}

.fv-contact-card {
  position: relative; background: #fff; border-radius: var(--fv-radius-sm);
  padding: 1.2rem 1.3rem 1.3rem; box-shadow: var(--fv-shadow-md);
  display: flex; flex-direction: column; gap: .4rem;
  transition: transform .18s ease-out, box-shadow .18s ease-out; overflow: hidden;
}
.fv-contact-card::before       { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(41,175,138,.08), rgba(255,159,28,.12)); opacity: 0; pointer-events: none; transition: opacity .18s ease-out; }
.fv-contact-card:hover         { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(15,23,42,.16); }
.fv-contact-card:hover::before { opacity: 1; }

.fv-contact-icon {
  width: 40px !important; height: 40px !important; min-width: 40px !important; min-height: 40px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  border-radius: 999px !important; background: var(--fv-teal-light) !important;
  font-size: 1.2rem; flex-shrink: 0; margin-bottom: .5rem;
}
.fv-contact-card:nth-child(1) .fv-contact-icon::before { content: "✉️"; }
.fv-contact-card:nth-child(2) .fv-contact-icon::before { content: "📮"; }
.fv-contact-card:nth-child(3) .fv-contact-icon::before { content: "📄"; }

.fv-contact-card h2   { font-size: 1.1rem; margin: 0 0 .2rem; }
.fv-contact-btn       { align-self: flex-start; margin-top: .4rem; padding: .45rem .9rem; border-radius: 999px; border: 1px solid var(--fv-teal); background: var(--fv-teal); color: #fff !important; font-size: .9rem; font-weight: 600; text-decoration: none !important; }
.fv-contact-btn:hover { background: #23c99a; }


/* =============================================================================
   10. PROJEKTE-SEITE
   ============================================================================= */
.blog h1.page-title.screen-reader-text,
.blog .page-title { display: none !important; }
.fv-projekte-intro {
  background:    linear-gradient(135deg, var(--fv-teal), #1d9470);
  border-radius: var(--fv-radius-lg);
  padding:       2.5rem 2rem;
  margin-bottom: 2rem;
  color:         #fff;
}
.fv-projekte-titel {
  color:       #fff;
  font-size:   clamp(1.8rem, 3vw, 2.4rem);
  margin:      0 0 .75rem;
  display:     block !important;
}
.fv-projekte-intro p {
  color:     rgba(255,255,255,.9);
  font-size: 1.05rem;
  margin:    0;
}
	
.blog #skip-content .container { padding: 3rem 0 3.5rem; }
.blog #primary                 { background: var(--fv-white-panel); border-radius: var(--fv-radius-lg); box-shadow: var(--fv-shadow-lg); padding: 2.2rem min(3vw, 3rem); }
.blog #secondary .sidebar      { background: rgba(255,255,255,.92); border-radius: 20px; box-shadow: 0 14px 36px rgba(15,23,42,.1); padding: 1.4rem 1.3rem; }
.blog #primary .row > header   { width: 100%; margin-bottom: 1.5rem; }

.blog h1.page-title.screen-reader-text { position: static; width: auto; height: auto; clip: auto; clip-path: none; margin: 0 0 .5rem; padding: 0; overflow: visible; font-size: clamp(1.9rem, 1.3rem + 1.3vw, 2.3rem); line-height: 1.15; font-weight: 700; color: var(--fv-dark); }
.blog h1.page-title.screen-reader-text::after { content: ""; display: block; margin-top: .5rem; width: 60px; height: 4px; border-radius: 999px; background: linear-gradient(90deg, var(--fv-teal), var(--fv-orange)); }

.blog .page-title        { font-size: clamp(1.9rem, 1.3rem + 1.3vw, 2.3rem); font-weight: 700; color: var(--fv-dark); margin: 0 0 .5rem; }
.blog .row.content-area  { display: flex; flex-wrap: wrap; }
.blog .col-lg-4.col-md-8 { display: flex; flex-direction: column; margin-bottom: 1.8rem; }

.blog .article-box { position: relative; background: #fff; border-radius: 20px; overflow: hidden; box-shadow: 0 12px 32px rgba(15,23,42,.1); margin-bottom: 1.8rem; display: flex; flex-direction: column; height: 100%; transition: transform .18s ease-out, box-shadow .18s ease-out; flex: 1; }
.blog .article-box::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at top left, rgba(41,175,138,.16), transparent 55%), radial-gradient(circle at bottom right, rgba(255,159,28,.16), transparent 55%); opacity: 0; transition: opacity .18s ease-out; pointer-events: none; }
.blog .article-box:hover         { transform: translateY(-4px); box-shadow: 0 18px 42px rgba(15,23,42,.18); }
.blog .article-box:hover::before { opacity: 1; }

.blog .article-box > img,
.blog .article-box .attachment-post-thumbnail { display: block !important; width: 100% !important; height: 220px !important; object-fit: cover !important; object-position: center !important; }

.blog .article-box .post-summery   { position: relative; padding: 1.2rem 1.3rem 1.3rem; z-index: 1; flex: 1 1 auto; }
.blog .article-box .meta-info-box  { padding: .7rem 1.3rem 0; font-size: .78rem !important; color: #9ca3af !important; }
.blog .article-box .entry-title    { font-size: 1.15rem !important; font-weight: 700 !important; margin: 0 0 .6rem !important; line-height: 1.3 !important; }
.blog .article-box .entry-title a  { color: var(--fv-dark); text-decoration: none; }
.blog .article-box .entry-title a:hover { color: var(--fv-teal); }
.blog .article-box .post-summery p { font-size: .92rem !important; line-height: 1.65 !important; color: #4b5563 !important; margin-bottom: .8rem; }

.blog .article-box .btn-text { display: inline-flex; align-items: center; gap: .35rem; padding: .4rem .9rem; border-radius: 999px; border: 1px solid var(--fv-teal); background: var(--fv-teal); color: #fff; font-size: 0; font-weight: 600; text-decoration: none; }
.blog .article-box .btn-text::before { content: "Mehr lesen"; font-size: .86rem; }
.blog .article-box .btn-text::after { content: "\203A"; font-size: 1rem; }
.blog .article-box .btn-text:hover   { background: var(--fv-orange); border-color: var(--fv-orange); color: #000; }
.blog #secondary:empty { display: none; }

@media (max-width: 767px) {
  .blog #primary { padding: 1.6rem 1.2rem; }
  .blog .article-box > img,
  .blog .article-box .attachment-post-thumbnail { height: 180px !important; }
}

/* =============================================================================
   20. PROJEKT-EINZELSEITE
   ============================================================================= */

.single .entry-header {
  position:      relative;
  border-radius: var(--fv-radius-lg);
  overflow:      hidden;
  margin-bottom: 1.5rem;
  min-height:    300px;
  display:       flex;
  align-items:   flex-end;
  padding:       0;
}

/* Bild als Hintergrund */
.single .entry-header img {
  position:   absolute;
  inset:      0;
  width:      100%;
  height:     100%;
  object-fit: cover;
  z-index:    0;
}

/* Dunkler Overlay */
.single .entry-header::after {
  content:  '';
  position: absolute;
  inset:    0;
  background: linear-gradient(to top, rgba(15,23,42,.75), rgba(15,23,42,.15));
  z-index:  1;
}

/* Titel über dem Bild */
.single .entry-title {
  position:    relative;
  z-index:     2;
  display:     block !important;
  color:       #fff !important;
  font-size:   clamp(1.6rem, 3vw, 2.4rem) !important;
  margin:      0 !important;
  padding:     1.5rem 1.8rem !important;
  line-height: 1.2 !important;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
}

/* Bilder im Inhalt */
.single .entry-content img {
  border-radius: var(--fv-radius-md);
  box-shadow:    var(--fv-shadow-md);
  max-width:     100%;
  height:        auto;
}

/* Sidebar-Button */
.single .sidebar .btn,
.single .sidebar a {
  background:    var(--fv-teal) !important;
  border-color:  var(--fv-teal) !important;
  border-radius: 999px !important;
  color:         #fff !important;
}

@media (max-width: 600px) {
  .single .entry-header { min-height: 220px; }
}

/* =============================================================================
   11. FOOTER
   ============================================================================= */

#colophon                   { background: var(--fv-green); }
#colophon a,
#colophon a:visited         { color: #fff !important; text-decoration: none !important; }
#colophon a:hover           { color: var(--fv-orange) !important; }


/* =============================================================================
   12. DIVERSES
   ============================================================================= */

.fv-section-title + p strong { display: block; margin-top: 0.2rem; margin-bottom: 0.8rem; }
.fv-download-list a,
.wp-block-group p a          { display: inline-block; margin: 0.15rem 0; }


/* =============================================================================
   13. WER WIR SIND – SEITE
   ============================================================================= */

.fv-about-hero {
  position: relative; min-height: 260px;
  background: linear-gradient(135deg, rgba(41,175,138,.82), rgba(255,159,28,.6)), url('https://fv-osradebeulmitte.org/wp-content/uploads/2025/09/Oberschule-Radebeul-Mitte-Wasastrasse-1024x683.jpg') center/cover no-repeat;
  border-radius: var(--fv-radius-lg); display: flex; align-items: flex-end; padding: 2rem; margin-bottom: 1.5rem;
}
.fv-about-hero-inner    { background: rgba(255,255,255,.88); border-radius: 16px; padding: 1.4rem 1.8rem; max-width: 520px; }
.fv-about-hero-inner h1 { font-size: clamp(1.6rem, 3vw, 2.2rem); color: var(--fv-dark); margin: .4rem 0 .5rem; line-height: 1.15; }
.fv-about-hero-inner p  { font-size: .95rem; color: #4b5563; line-height: 1.65; margin: 0; }

.fv-numbers              { display: grid; grid-template-columns: repeat(3, 1fr); margin-bottom: 1.5rem; border-radius: var(--fv-radius-md); overflow: hidden; border: 1px solid rgba(15,23,42,.06); background: #fff; }
.fv-number-card          { padding: 1.5rem 1rem; text-align: center; border-right: 1px solid rgba(15,23,42,.06); transition: background .2s; }
.fv-number-card:last-child { border-right: none; }
.fv-number-card:hover    { background: rgba(41,175,138,.04); }
.fv-number-val           { display: block; font-size: 2rem; font-weight: 700; color: var(--fv-teal); line-height: 1; margin-bottom: .3rem; }
.fv-number-label         { font-size: .78rem; color: #6b7280; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }

.fv-mission              { display: flex; gap: 1.2rem; background: linear-gradient(135deg, rgba(41,175,138,.06), rgba(255,159,28,.04)); border: 1px solid rgba(41,175,138,.18); border-radius: var(--fv-radius-md); padding: 1.5rem 1.8rem; margin-bottom: 1.5rem; }
.fv-mission-bar          { width: 4px; border-radius: 999px; background: linear-gradient(180deg, var(--fv-teal), var(--fv-orange)); flex-shrink: 0; }
.fv-mission-text h2      { font-size: 1rem; color: var(--fv-teal); font-weight: 700; margin-bottom: .5rem; }
.fv-mission-text p       { font-size: .95rem; color: #374151; line-height: 1.7; margin: 0; }

.fv-school-img           { width: 100%; height: 220px; object-fit: cover; border-radius: var(--fv-radius-md); display: block; margin-bottom: 1.5rem; }
.fv-about-section        { margin-bottom: 1.5rem; }

.fv-team-grid  { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: .9rem; margin-top: 1rem; }
.fv-team-card  { background: #fff; border-radius: 12px; padding: 1rem 1.1rem; border-left: 3px solid var(--fv-teal); box-shadow: 0 4px 14px rgba(15,23,42,.07); display: flex; flex-direction: column; gap: .2rem; transition: transform .18s, box-shadow .18s; }
.fv-team-card:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(15,23,42,.12); }
.fv-team-role  { font-size: .72rem; font-weight: 700; color: var(--fv-teal); text-transform: uppercase; letter-spacing: .06em; }
.fv-team-name  { font-size: .92rem; font-weight: 700; color: var(--fv-dark); }
.fv-team-mail  { font-size: .78rem; color: #6b7280; text-decoration: none; margin-top: .1rem; }
.fv-team-mail:hover { color: var(--fv-teal); text-decoration: underline; }

.fv-cta-box     { background: linear-gradient(135deg, var(--fv-teal), #1d9470); border-radius: var(--fv-radius-md); padding: 1.8rem 2rem; display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; flex-wrap: wrap; }
.fv-cta-text h3 { color: #fff; font-size: 1.05rem; margin-bottom: .3rem; }
.fv-cta-text p  { color: rgba(255,255,255,.85); font-size: .88rem; margin: 0; }
.fv-cta-buttons { display: flex; gap: .7rem; flex-wrap: wrap; }
.fv-cta-btn     { padding: .5rem 1.3rem; border-radius: 999px; font-size: .88rem; font-weight: 700; text-decoration: none; transition: transform .15s, box-shadow .15s; display: inline-block; }
.fv-cta-btn:hover  { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,.2); }
.fv-cta-btn--white { background: #fff !important; color: var(--fv-teal) !important; }
.fv-cta-btn--ghost { background: rgba(255,255,255,.18) !important; color: #fff !important; border: 1.5px solid rgba(255,255,255,.5) !important; }

@media (max-width: 600px) {
  .fv-numbers          { grid-template-columns: 1fr; }
  .fv-number-card      { border-right: none; border-bottom: 1px solid rgba(15,23,42,.06); }
  .fv-cta-box          { flex-direction: column; text-align: center; }
  .fv-cta-buttons      { justify-content: center; }
  .fv-about-hero       { padding: 1.2rem; }
  .fv-about-hero-inner { max-width: 100%; }
}


/* =============================================================================
   14. UNTERSTÜTZEN – SEITE
   ============================================================================= */

.fv-support-hero { background: linear-gradient(135deg, var(--fv-teal), #1d9470); border-radius: var(--fv-radius-lg); padding: 2.5rem 2rem; margin-bottom: 2rem; color: #fff; }
.fv-support-hero h1 { color: #fff; font-size: clamp(1.8rem, 3vw, 2.4rem); margin: .5rem 0 .75rem; }
.fv-support-hero p  { color: rgba(255,255,255,.9); font-size: 1.05rem; margin: 0; }

.fv-support-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.4rem; margin-bottom: 1.5rem; }

.fv-support-card { background: #fff; border-radius: var(--fv-radius-md); padding: 1.8rem 1.6rem; box-shadow: var(--fv-shadow-md); display: flex; flex-direction: column; gap: .75rem; border-top: 3px solid var(--fv-teal); transition: transform .18s ease-out, box-shadow .18s ease-out; }
.fv-support-card:hover    { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(15,23,42,.14); }
.fv-support-card--primary { border-top-color: var(--fv-orange); }
.fv-support-icon          { font-size: 2.2rem; line-height: 1; }
.fv-support-card h2       { font-size: 1.2rem; color: var(--fv-dark); margin: 0; }
.fv-support-card p        { font-size: .95rem; line-height: 1.65; color: #4b5563; margin: 0; }
.fv-support-card a        { color: var(--fv-teal); }
.fv-support-price         { font-size: 1.1rem !important; color: var(--fv-dark) !important; }
.fv-support-price strong  { color: var(--fv-orange); font-size: 1.4rem; }

.fv-support-list    { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .35rem; }
.fv-support-list li { font-size: .9rem; color: #374151; }

.fv-support-btn { display: inline-flex; align-items: center; gap: .4rem; margin-top: auto; padding: .6rem 1.3rem; border-radius: 999px; background: var(--fv-teal); color: #fff !important; font-size: .9rem; font-weight: 700; text-decoration: none !important; transition: background .15s, transform .15s; align-self: flex-start; }
.fv-support-btn:hover            { background: #23c99a; transform: translateY(-1px); }
.fv-support-btn--secondary       { background: var(--fv-orange); color: #000 !important; }
.fv-support-btn--secondary:hover { background: #ffb84f; }
.fv-support-link                 { font-size: .85rem; color: var(--fv-teal) !important; text-decoration: none !important; margin-top: -.25rem; }
.fv-support-link:hover           { text-decoration: underline !important; }

.fv-iban-box   { background: #f8fffe; border: 1px solid var(--fv-teal-light); border-radius: 12px; padding: 1rem 1.1rem; display: flex; flex-direction: column; gap: .5rem; margin-top: .25rem; }
.fv-iban-row   { display: flex; gap: .75rem; align-items: baseline; flex-wrap: wrap; }
.fv-iban-label { font-size: .75rem; font-weight: 700; color: var(--fv-teal); text-transform: uppercase; letter-spacing: .04em; min-width: 70px; }
.fv-iban-value { font-size: .9rem; color: var(--fv-dark); }
.fv-iban-mono  { font-family: monospace; font-size: .88rem; letter-spacing: .05em; }

.fv-support-steps     { display: flex; gap: .5rem; flex-wrap: wrap; }
.fv-support-step      { display: flex; align-items: center; gap: .35rem; font-size: .85rem; color: #374151; background: #f1f5f9; padding: .3rem .7rem; border-radius: 999px; }
.fv-support-step span { background: var(--fv-teal); color: #fff; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .75rem; font-weight: 700; flex-shrink: 0; }

.fv-support-thanks      { display: flex; align-items: center; gap: 1rem; background: linear-gradient(135deg, rgba(41,175,138,.08), rgba(255,159,28,.06)); border: 1px solid rgba(41,175,138,.2); border-radius: var(--fv-radius-md); padding: 1.2rem 1.5rem; }
.fv-support-thanks span { font-size: 1.8rem; flex-shrink: 0; }
.fv-support-thanks p    { font-size: 1rem; color: var(--fv-dark); font-weight: 600; margin: 0; }

@media (max-width: 600px) {
  .fv-support-hero  { padding: 1.5rem 1.2rem; }
  .fv-support-grid  { grid-template-columns: 1fr; }
  .fv-support-steps { flex-direction: column; }
}


/* =============================================================================
   15. DANKE – SEITE
   ============================================================================= */

.fv-thanks-hero      { background: linear-gradient(135deg, var(--fv-teal), #1d9470); border-radius: var(--fv-radius-lg); padding: 2.5rem 2rem; margin-bottom: 2rem; text-align: center; color: #fff; }
.fv-thanks-hero-icon { font-size: 3rem; margin-bottom: .75rem; }
.fv-thanks-hero h1   { color: #fff; font-size: clamp(1.8rem, 3vw, 2.4rem); margin: 0 0 .75rem; }
.fv-thanks-hero p    { color: rgba(255,255,255,.9); font-size: 1.05rem; max-width: 600px; margin: 0 auto; }
.fv-thanks-section   { margin-bottom: 2rem; }
.fv-thanks-intro     { font-size: 1rem; color: #4b5563; margin: 0 0 1.5rem; }

.fv-sponsors-grid     { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1.2rem; }
.fv-sponsor-card      { background: #fff; border-radius: var(--fv-radius-md); padding: 2rem 1.5rem; min-height: 140px; box-shadow: var(--fv-shadow-md); display: flex; align-items: center; justify-content: center; transition: transform .18s ease-out, box-shadow .18s ease-out; border: 1px solid rgba(15,23,42,.06); }
.fv-sponsor-card:hover     { transform: translateY(-3px); box-shadow: 0 12px 30px rgba(15,23,42,.12); }
.fv-sponsor-card img       { max-width: 100%; max-height: 120px; width: auto; height: auto; object-fit: contain; filter: grayscale(20%); transition: filter .18s; }
.fv-sponsor-card:hover img { filter: grayscale(0%); }

.fv-thanks-cta         { background: linear-gradient(135deg, var(--fv-teal), #1d9470); border-radius: var(--fv-radius-md); padding: 1.8rem 2rem; display: flex; align-items: center; justify-content: space-between; gap: 1.2rem; flex-wrap: wrap; }
.fv-thanks-cta-text h3 { color: #fff; font-size: 1.05rem; margin-bottom: .3rem; }
.fv-thanks-cta-text p  { color: rgba(255,255,255,.85); font-size: .88rem; margin: 0; }

@media (max-width: 600px) {
  .fv-thanks-hero   { padding: 1.5rem 1.2rem; }
  .fv-sponsors-grid { grid-template-columns: repeat(2, 1fr); }
  .fv-thanks-cta    { flex-direction: column; text-align: center; }
}


/* =============================================================================
   16. KONTAKT – SEITE (neu)
   ============================================================================= */

.fv-contact-hero    { background: linear-gradient(135deg, var(--fv-teal), #1d9470); border-radius: var(--fv-radius-lg); padding: 2.5rem 2rem; margin-bottom: 2rem; color: #fff; }
.fv-contact-hero h1 { color: #fff; font-size: clamp(1.8rem, 3vw, 2.4rem); margin: .5rem 0 .75rem; }
.fv-contact-hero p  { color: rgba(255,255,255,.9); font-size: 1.05rem; margin: 0; }

.fv-contact-grid-new { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }

.fv-contact-card-new { background: #fff; border-radius: var(--fv-radius-md); padding: 1.8rem 1.6rem; box-shadow: var(--fv-shadow-md); display: flex; flex-direction: column; gap: .75rem; border-top: 3px solid var(--fv-teal); transition: transform .18s ease-out, box-shadow .18s ease-out; }
.fv-contact-card-new:hover { transform: translateY(-3px); box-shadow: 0 18px 40px rgba(15,23,42,.14); }
.fv-contact-card-new--full { grid-column: 1 / -1; }
.fv-contact-icon-new       { font-size: 2rem; line-height: 1; }
.fv-contact-card-new h2    { font-size: 1.15rem; color: var(--fv-dark); margin: 0; }
.fv-contact-card-new p     { font-size: .95rem; color: #4b5563; margin: 0; line-height: 1.65; }

.fv-contact-mail-btn { display: inline-flex; align-items: center; gap: .4rem; padding: .6rem 1.2rem; border-radius: 999px; background: var(--fv-teal-light); color: var(--fv-teal) !important; font-size: .9rem; font-weight: 700; text-decoration: none !important; transition: background .15s; align-self: flex-start; margin-top: auto; word-break: break-all; }
.fv-contact-mail-btn:hover { background: #b8e8d8; }

.fv-contact-address { display: flex; flex-direction: column; gap: .2rem; background: #f8fffe; border: 1px solid var(--fv-teal-light); border-radius: 12px; padding: 1rem 1.1rem; font-size: .95rem; color: var(--fv-dark); margin-top: auto; }

.fv-contact-docs       { display: flex; flex-direction: column; gap: .75rem; }
.fv-contact-doc-link   { display: flex; align-items: center; gap: 1rem; padding: 1rem 1.2rem; border-radius: 12px; background: #f8fffe; border: 1px solid var(--fv-teal-light); text-decoration: none !important; transition: background .15s, transform .15s; }
.fv-contact-doc-link:hover { background: var(--fv-teal-light); transform: translateX(3px); }
.fv-doc-icon           { font-size: 1.6rem; flex-shrink: 0; }
.fv-doc-info           { flex: 1; display: flex; flex-direction: column; gap: .1rem; }
.fv-doc-info strong    { font-size: .95rem; color: var(--fv-dark); }
.fv-doc-info small     { font-size: .8rem; color: #6b7280; }
.fv-doc-arrow          { font-size: 1.1rem; color: var(--fv-teal); font-weight: 700; }

.fv-contact-cta-inline   { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; background: linear-gradient(135deg, rgba(41,175,138,.08), rgba(255,159,28,.06)); border: 1px solid rgba(41,175,138,.2); border-radius: 12px; padding: 1.1rem 1.3rem; margin-top: .5rem; }
.fv-contact-cta-inline p { font-size: .95rem; color: var(--fv-dark); margin: 0; font-weight: 600; }

@media (max-width: 600px) {
  .fv-contact-grid-new       { grid-template-columns: 1fr; }
  .fv-contact-card-new--full { grid-column: 1; }
  .fv-contact-hero           { padding: 1.5rem 1.2rem; }
  .fv-contact-cta-inline     { flex-direction: column; }
}


/* =============================================================================
   17. IMPRESSUM
   ============================================================================= */

.fv-legal-hero    { background: linear-gradient(135deg, var(--fv-teal), #1d9470); border-radius: var(--fv-radius-lg); padding: 2rem 2rem 1.8rem; margin-bottom: 2rem; color: #fff; }
.fv-legal-hero h1 { color: #fff; font-size: clamp(1.6rem, 3vw, 2.2rem); margin: .4rem 0 0; }

.fv-legal-grid        { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.2rem; }
.fv-legal-card        { background: #fff; border-radius: var(--fv-radius-md); padding: 1.6rem; box-shadow: var(--fv-shadow-md); display: flex; flex-direction: column; gap: .75rem; border-top: 3px solid var(--fv-teal); }
.fv-legal-card--main  { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: 2rem; }
.fv-legal-icon        { font-size: 1.8rem; line-height: 1; flex-shrink: 0; }
.fv-legal-card h2     { font-size: 1rem; color: var(--fv-teal); font-weight: 700; margin: 0; text-transform: uppercase; letter-spacing: .04em; }
.fv-legal-address     { display: flex; flex-direction: column; gap: .2rem; font-size: .95rem; color: var(--fv-dark); line-height: 1.6; }
.fv-legal-address a   { color: var(--fv-teal) !important; text-decoration: none !important; }
.fv-legal-address a:hover { text-decoration: underline !important; }
.fv-legal-logo img    { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }

@media (max-width: 600px) {
  .fv-legal-grid       { grid-template-columns: 1fr; }
  .fv-legal-card--main { flex-direction: column; grid-column: 1; }
}


/* =============================================================================
   18. PRIVATE UNTERSTÜTZER – Testimonials
   ============================================================================= */

.fv-thanks-private        { margin-top: 2rem; margin-bottom: 1.5rem; }

.fv-testimonials-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:                   1.2rem;
  margin-top:            1rem;
}

.fv-testimonial-card {
  background:     #fff;
  border-radius:  var(--fv-radius-md);
  padding:        1.6rem 1.8rem;
  box-shadow:     var(--fv-shadow-md);
  display:        flex;
  flex-direction: column;
  gap:            .75rem;
  border-left:    4px solid var(--fv-teal);
  transition:     transform .18s ease-out, box-shadow .18s ease-out;
}
.fv-testimonial-card:hover { transform: translateY(-3px); box-shadow: 0 14px 36px rgba(15,23,42,.12); }
.fv-testimonial-quote      { font-size: 1.8rem; line-height: 1; }
.fv-testimonial-text       { font-size: 1rem; line-height: 1.7; color: #374151; margin: 0; font-style: italic; flex: 1; }
.fv-testimonial-author     { display: flex; align-items: center; gap: .75rem; padding-top: .5rem; border-top: 1px solid rgba(15,23,42,.06); }
.fv-testimonial-name       { font-size: .9rem; font-weight: 700; color: var(--fv-dark); }
.fv-testimonial-date       { font-size: .8rem; color: #9ca3af; margin-left: auto; }

@media (max-width: 600px) {
  .fv-testimonials-grid { grid-template-columns: 1fr; }
}


/* =============================================================================
   19. WER WIR SIND – Timeline & Fotos
   ============================================================================= */

.fv-about-photo            { text-align: center; margin: 1.5rem 0; }
.fv-about-photo img        { border-radius: var(--fv-radius-md); max-width: 320px; width: 100%; height: auto; box-shadow: var(--fv-shadow-md); }
.fv-about-photo--small img { max-width: 180px; }
.fv-about-photo p          { font-size: .85rem; color: #6b7280; margin-top: .5rem; font-style: italic; }

/* ── Timeline ── */
.fv-timeline {
  position:     relative;
  padding-left: 1.8rem;
  margin-top:   1rem;
}
.fv-timeline::before {
  content:       '';
  position:      absolute;
  left:          .55rem;
  top:           0; bottom: 0;
  width:         2px;
  background:    linear-gradient(180deg, var(--fv-teal), var(--fv-orange));
  border-radius: 999px;
}

.fv-timeline-item {
  position:      relative;
  margin-bottom: 1.2rem;
  display:       flex;
  gap:           1rem;
  align-items:   flex-start;
}
.fv-timeline-item::before {
  content:       '';
  position:      absolute;
  left:          -1.26rem;
  top:           .35rem;
  width:         10px; height: 10px;
  border-radius: 50%;
  background:    var(--fv-teal);
  border:        2px solid #fff;
  box-shadow:    0 0 0 2px var(--fv-teal);
}
.fv-timeline-item--highlight::before {
  background: var(--fv-orange);
  box-shadow: 0 0 0 2px var(--fv-orange);
}

.fv-timeline-date {
  font-size:   .8rem;
  font-weight: 700;
  color:       var(--fv-teal);
  white-space: nowrap;
  min-width:   70px;
  padding-top: .15rem;
}
.fv-timeline-item--highlight .fv-timeline-date { color: var(--fv-orange); }

.fv-timeline-content { font-size: .92rem; color: #374151; line-height: 1.6; }

/* ── Bild im Timeline-Eintrag ── */
.fv-timeline-figure {
  margin:  .75rem 0 0 0;
  display: block;
}

.fv-timeline-figure img {
  width:         220px !important;
  height:        auto !important;
  object-fit:    cover !important;
  border-radius: var(--fv-radius-sm);
  box-shadow:    var(--fv-shadow-md);
  display:       block;
}

.fv-timeline-figure figcaption {
  font-size:  .78rem;
  color:      #9ca3af;
  font-style: italic;
  margin-top: .4rem;
  max-width:  220px;
}

@media (max-width: 600px) {
  .fv-timeline              { padding-left: 1.4rem; }
  .fv-timeline-item         { flex-direction: column; gap: .2rem; }
  .fv-timeline-date         { min-width: auto; }
  .fv-timeline-figure img   { width: 100% !important; max-width: 220px !important; }
}
/* Abstand oben + weißer Hintergrund für Einzelseite */
.single #skip-content {
  background: #fff;
}

.single #primary {
  background:    #fff;
  border-radius: var(--fv-radius-lg);
  box-shadow:    var(--fv-shadow-md);
  padding:       1.5rem;
  margin-top:    2rem;
}