/**
 * FindLake  Haupt-CSS
 * Datei: /wp-content/themes/impreza-child/assets/css/findlake.css
 *
 * Zusammengefhrt aus: findlake.css + findlake-home.css + findlake-forms.css
 *
 * Keine hardcodierten Farben oder Schriften.
 * Alle Werte kommen aus Impreza Theme Options (CSS-Variablen).
 *
 * STRUKTUR:
 *   1.  Eigene Variablen (nur was Impreza nicht hat)
 *   2.  Buttons
 *   3.  Badges & Tags
 *   4.  Lake Card (wiederverwendbar)
 *   5.  Lake Grid
 *   6.  Startseite  Hero
 *   7.  Startseite  Suchleiste
 *   8.  Startseite  Kategorie-Karten
 *   9.  Startseite  Featured Seen
 *   10. Startseite  Section Header
 *   11. Startseite  Promo Banner
 *   12. Archive  Hero & Layout
 *   13. Archive  Filter Sidebar
 *   14. Archive  Sort Bar & Section Labels
 *   15. Single See  Layout & Galerie
 *   16. Single See  Info Tiles, Karte, Fischarten
 *   17. Single See  Amenities, Regeln, Sidebar
 *   18. Formular  See hinzufgen Layout
 *   19. Formular  ACF Styling
 *   20. Formular  Info Sidebar & Erfolgsbox
 *   21. Allgemein  Breadcrumb, Pagination, No Results
 *   22. Responsive
 */

/* 
   1. EIGENE VARIABLEN
    */
:root {
    --fl-green:      #2E7D32;
    --fl-gold:       #F0A500;
    --fl-white:      #ffffff;
    --fl-shadow-lg:  0 8px 32px rgba(0,0,0,.12);
    --fl-radius:     var(--site-border-radius, 5px);
    --fl-radius-lg:  calc(var(--site-border-radius, 5px) * 2);
}

/* 
   2. BUTTONS
    */
.fl-btn {
    display: inline-block;
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    border-radius: var(--fl-radius);
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: opacity .2s, transform .1s;
    line-height: 1;
}
.fl-btn--primary {
    background: var(--color-content-primary);
    color: var(--fl-white);
    padding: 8px 16px;
    font-size: 12px;
}
.fl-btn--primary:hover { opacity: .85; color: var(--fl-white); }

.fl-btn--search {
    background: var(--fl-green);
    color: var(--fl-white);
    padding: 12px 28px;
    font-size: 14px;
    white-space: nowrap;
}
.fl-btn--search:hover { opacity: .9; }

.fl-btn--filter {
    width: 100%;
    padding: 11px;
    background: var(--fl-green);
    color: var(--fl-white);
    font-size: 13px;
    margin-top: 8px;
    border-radius: var(--fl-radius);
    cursor: pointer;
    border: none;
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
}
.fl-btn--cta {
    background: var(--fl-green);
    color: var(--fl-white) !important;
    padding: 14px 20px;
    font-size: 15px;
    text-align: center;
}
.fl-btn--full { display: block; width: 100%; }

.fl-btn--outline {
    background: transparent;
    color: var(--color-content-primary);
    border: 2px solid var(--color-content-primary);
    padding: 8px 16px;
    font-size: 13px;
}
.fl-btn--outline-white {
    background: transparent;
    color: var(--color-header-middle-text);
    border: 2px solid var(--color-header-middle-text-hover);
    opacity: .7;
    padding: 12px 22px;
    font-size: 14px;
    border-radius: var(--fl-radius);
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    text-decoration: none;
    transition: opacity .2s;
}
.fl-btn--outline-white:hover { opacity: 1; color: var(--color-header-middle-text); }

.fl-btn--gold {
    background: var(--fl-gold);
    color: #7a4e00;
    padding: 12px 22px;
    font-size: 14px;
    border-radius: var(--fl-radius);
    font-family: var(--h2-font-family, inherit);
    font-weight: 800;
    text-decoration: none;
    border: none;
    transition: opacity .2s;
}
.fl-btn--gold:hover { opacity: .9; color: #7a4e00; }

/* 
   3. BADGES & TAGS
    */
.fl-badge {
    position: absolute;
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: .5px;
    z-index: 2;
}
.fl-badge--promoted {
    top: 10px;
    left: 10px;
    background: var(--fl-gold);
    color: #7a4e00;
}
.fl-badge--country {
    bottom: 10px;
    left: 10px;
    background: rgba(0,0,0,.55);
    color: var(--fl-white);
    backdrop-filter: blur(4px);
    border-radius: var(--fl-radius);
    text-transform: none;
    font-weight: 600;
}

.fl-tag {
    font-size: 11px;
    font-weight: 600;
    padding: 3px 10px;
    border-radius: 12px;
    font-family: var(--h2-font-family, inherit);
}
.fl-tag--size {
    background: var(--color-content-primary-faded);
    color: var(--color-content-primary);
}
.fl-tag--type {
    background: rgba(46,125,50,.12);
    color: var(--fl-green);
}

/* 
   4. LAKE CARD
    */
.fl-lake-card {
    background: var(--color-content-bg-alt);
    border-radius: var(--fl-radius-lg);
    border: 1px solid var(--color-content-border);
    overflow: hidden;
    transition: transform .2s ease, box-shadow .2s ease;
    display: flex;
    flex-direction: column;
}
.fl-lake-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--fl-shadow-lg);
}
.fl-lake-card--promoted {
    border-color: var(--fl-gold);
    box-shadow: 0 4px 16px rgba(240,165,0,.2);
}

.fl-lake-card__image {
    position: relative;
    height: 200px;
    overflow: hidden;
}
.fl-lake-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}
.fl-lake-card:hover .fl-lake-card__image img { transform: scale(1.04); }

.fl-lake-card__image--placeholder {
    width: 100%;
    height: 100%;
    background: var(--color-header-middle-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    opacity: .6;
}

.fl-lake-card__body {
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.fl-lake-card__title {
    font-size: 17px;
    font-weight: var(--h2-font-weight, 700);
    color: var(--color-content-heading);
    margin: 0 0 8px;
    font-family: var(--h2-font-family, inherit);
}
.fl-lake-card__title a { color: inherit; text-decoration: none; }
.fl-lake-card__title a:hover { color: var(--color-content-primary); }

.fl-lake-card__tags {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.fl-lake-card__excerpt {
    color: var(--color-content-faded);
    font-size: 13px;
    line-height: 1.6;
    margin-bottom: 14px;
    flex: 1;
}
.fl-lake-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
}
.fl-lake-card__price {
    font-weight: 700;
    font-size: 15px;
    color: var(--color-content-heading);
    font-family: var(--h2-font-family, inherit);
}
.fl-lake-card__price span {
    font-weight: 400;
    font-size: 12px;
    color: var(--color-content-faded);
}

/* 
   5. LAKE GRID
    */
.fl-lake-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-bottom: 16px;
}

/* 
   6. STARTSEITE  HERO
    */
.fl-hero-row {
    background: var(--color-header-middle-bg) !important;
    padding: 80px 0 100px !important;
    position: relative;
    overflow: visible !important;
    text-align: center;
}
.fl-hero-row h1 {
    font-family: var(--h1-font-family, inherit) !important;
    font-weight: var(--h1-font-weight, 700) !important;
    color: var(--color-header-middle-text) !important;
    margin-bottom: 14px;
    line-height: 1.2;
}
.fl-hero-subtitle {
    color: var(--color-header-middle-text) !important;
    opacity: .75;
    font-size: 18px;
    margin-bottom: 36px;
}
.fl-hero-row--sm {
    padding: 48px 0 !important;
}
.fl-hero-row__inner {
    max-width: var(--site-canvas-width, 1300px);
    margin: 0 auto;
    padding: 0 32px;
}

/* 
   7. STARTSEITE  SUCHLEISTE
    */
.fl-search-bar {
    background: var(--fl-white);
    border-radius: var(--fl-radius-lg);
    padding: 8px;
    display: flex;
    gap: 8px;
    align-items: center;
    max-width: 720px;
    margin: 0 auto;
    box-shadow: var(--fl-shadow-lg);
}
.fl-search-bar__select {
    flex: 1;
    padding: 0px;
    border: none;
    outline: none;
    font-size: 14px;
    color: var(--color-content-text);
    background: transparent;
    min-width: 150px;
    cursor: pointer;
}
.fl-search-bar__divider {
    width: 1px;
    height: 32px;
    background: var(--color-content-border);
    opacity: .3;
    flex-shrink: 0;
}

/* 
   8. STARTSEITE  KATEGORIE-KARTEN
    */
.fl-cat-section-row {
    position: relative;
    z-index: 10;
}
.fl-cat-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-top: -60px;
    position: relative;
    z-index: 10;
    padding: 0 16px;
}
.fl-cat-card {
    background: var(--fl-white);
    border-radius: var(--fl-radius-lg);
    border: 1px solid var(--color-content-border);
    text-decoration: none;
    text-align: center;
    overflow: hidden;
    transition: transform .25s, box-shadow .25s;
    box-shadow: 0 8px 24px rgba(0,0,0,.15);
}
.fl-cat-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0,0,0,.2);
    border-color: var(--color-content-primary);
}
.fl-cat-card__image {
    height: 110px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: transform .3s ease;
    overflow: hidden;
}
.fl-cat-card:hover .fl-cat-card__image { transform: scale(1.06); }
.fl-cat-card__label {
    padding: 14px 8px;
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-heading);
}

/* 
   9. STARTSEITE  FEATURED SEEN GRID
    */
.fl-featured-grid { display: grid; gap: 24px; }
.fl-featured-grid--2 { grid-template-columns: repeat(2, 1fr); }
.fl-featured-grid--3 { grid-template-columns: repeat(3, 1fr); }
.fl-featured-grid--4 { grid-template-columns: repeat(4, 1fr); }

/* 
   10. STARTSEITE  SECTION HEADER
    */
.fl-section-header { margin-bottom: 24px; overflow: hidden; }
.fl-section-header h2 {
    font-family: var(--h2-font-family, inherit);
    font-weight: var(--h2-font-weight, 700);
    color: var(--color-content-heading);
    margin-bottom: 6px;
}
.fl-section-header p { color: var(--color-content-faded); font-size: 15px; }
.fl-section-header__link {
    float: right;
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-primary);
    text-decoration: none;
    margin-top: 6px;
}
.fl-section-header__link:hover { text-decoration: underline; }

/* 
   11. STARTSEITE  PROMO BANNER
    */
.fl-promo-banner {
    background: var(--color-header-middle-bg);
    border-radius: var(--fl-radius-lg);
    padding: 48px 40px;
    margin: 20px 0;
}
.fl-promo-banner__content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}
.fl-promo-banner__text h2 {
    font-family: var(--h2-font-family, inherit);
    font-weight: var(--h2-font-weight, 700);
    color: var(--color-header-middle-text);
    margin-bottom: 8px;
}
.fl-promo-banner__text p {
    color: var(--color-header-middle-text);
    opacity: .8;
    font-size: 15px;
    max-width: 480px;
}
.fl-promo-banner__actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* 
   12. ARCHIVE  HERO & LAYOUT
    */
.fl-archive__hero {
    background: var(--color-header-middle-bg);
    padding: 120px 32px 40px;
	background-image: url(/wp-content/uploads/2026/05/header_find_lake.webp);
    background-repeat: no-repeat;
	min-height: 600px !important;
    background-position: center center;
    background-size: cover;
}
.fl-archive__hero-inner {
    max-width: var(--site-canvas-width, 1300px);
    margin: 0 auto;
}
.fl-archive__title {
    font-family: var(--h1-font-family, inherit);
    font-size: var(--h2-font-size, 30px);
    font-weight: var(--h1-font-weight, 700);
    color: var(--color-header-middle-text);
    margin: 10px 0 8px;
}
.fl-archive__subtitle {
    color: var(--color-header-middle-text);
    opacity: .75;
    font-size: 15px;
    margin-bottom: 24px;
}
.fl-archive__content {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 24px;
    padding: 28px 32px;
    max-width: var(--site-canvas-width, 1300px);
    margin: 0 auto;
}

/* 
   13. ARCHIVE  FILTER SIDEBAR
    */
.fl-filter-sidebar {
    background: var(--color-content-bg-alt);
    border-radius: var(--fl-radius-lg);
    border: 1px solid var(--color-content-border);
    padding: 20px;
    height: fit-content;
    position: sticky;
    top: 20px;
}
.fl-filter-sidebar__title {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 15px;
    color: var(--color-content-heading);
    margin-bottom: 16px;
}
.fl-filter-section { margin-bottom: 20px; }
.fl-filter-section__label {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-text);
    margin-bottom: 10px;
}
.fl-filter-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 0;
    font-size: 13px;
    color: var(--color-content-text);
    cursor: pointer;
}
.fl-filter-option input { accent-color: var(--color-content-primary); }
.fl-filter-option__count { color: var(--color-content-faded); font-size: 11px; }
.fl-filter-reset {
    display: block;
    text-align: center;
    color: var(--color-content-faded);
    font-size: 12px;
    margin-top: 6px;
    text-decoration: none;
}

/* 
   14. ARCHIVE  SORT BAR & SECTION LABELS
    */
.fl-sort-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 10px;
}
.fl-sort-bar__count {
    font-size: 14px;
    color: var(--color-content-text);
    font-family: var(--h2-font-family, inherit);
}
.fl-sort-bar__count strong { color: var(--color-content-primary); }

.fl-results-section-label {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.fl-results-section-label--promoted      { color: var(--fl-gold); }
.fl-results-section-label--promoted-rest { color: var(--fl-gold); opacity: .7; }
.fl-results-section-label--free          { color: var(--color-content-faded); }

/* 
   15. SINGLE SEE  LAYOUT & GALERIE
    */
.fl-single__wrapper {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 32px;
    padding: 28px 32px;
    max-width: var(--site-canvas-width, 1300px);
    margin: 0 auto;
}
.fl-section-title {
    font-family: var(--h2-font-family, inherit);
    font-size: 18px;
    font-weight: var(--h2-font-weight, 700);
    color: var(--color-content-heading);
    margin: 28px 0 14px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--color-content-primary-faded);
}
.fl-gallery__main-img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    border-radius: var(--fl-radius-lg);
    display: block;
}
.fl-gallery__thumbs {
    display: flex;
    gap: 8px;
    margin-top: 8px;
    overflow-x: auto;
}
.fl-gallery__thumb {
    flex-shrink: 0;
    width: 100px;
    height: 70px;
    border-radius: var(--fl-radius);
    overflow: hidden;
    cursor: pointer;
    opacity: .75;
    transition: opacity .2s;
}
.fl-gallery__thumb:hover { opacity: 1; }
.fl-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* 
   16. SINGLE SEE  INFO TILES, KARTE, FISCHARTEN
    */
.fl-info-tiles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin: 20px 0;
}
.fl-info-tile {
    background: var(--color-content-bg);
    border-radius: var(--fl-radius);
    padding: 14px 16px;
    text-align: center;
}
.fl-info-tile__icon { font-size: 24px; display: block; margin-bottom: 4px; }
.fl-info-tile__label { font-size: 11px; color: var(--color-content-faded); margin-bottom: 4px; }
.fl-info-tile__value {
    font-weight: 700;
    font-size: 14px;
    color: var(--color-content-heading);
    font-family: var(--h2-font-family, inherit);
}

.fl-map__embed {
    width: 100%;
    height: 320px;
    border-radius: var(--fl-radius-lg);
    background: var(--color-content-bg);
    border: 1px solid var(--color-content-border);
    margin-bottom: 10px;
}
.fl-map__address { font-size: 13px; color: var(--color-content-faded); margin-bottom: 12px; }

.fl-fish-species__grid { display: flex; flex-wrap: wrap; gap: 10px; }
.fl-fish-species__item {
    background: var(--color-content-primary-faded);
    color: var(--color-content-primary);
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    font-family: var(--h2-font-family, inherit);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* 
   17. SINGLE SEE  AMENITIES, REGELN, SIDEBAR
    */
.fl-amenities__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.fl-amenity-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--color-content-text);
    padding: 8px 12px;
    background: var(--color-content-bg);
    border-radius: var(--fl-radius);
}
.fl-amenity-item__icon { font-size: 20px; }

.fl-rules__content {
    background: rgba(240,165,0,.08);
    border-left: 4px solid var(--fl-gold);
    padding: 16px 20px;
    border-radius: 0 var(--fl-radius) var(--fl-radius) 0;
    font-size: 14px;
    line-height: 1.7;
    color: var(--color-content-text);
}

.fl-sidebar-box {
    background: var(--color-content-bg-alt);
    border: 1px solid var(--color-content-border);
    border-radius: var(--fl-radius-lg);
    padding: 18px 20px;
    margin-bottom: 16px;
}
.fl-sidebar-box__title {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-heading);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 14px;
}
.fl-sidebar-box--prices { border-color: var(--color-content-primary); }

.fl-price-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: 1px solid var(--color-content-border);
    font-size: 14px;
    color: var(--color-content-text);
}
.fl-price-row:last-child { border-bottom: none; }
.fl-price-row strong {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 16px;
    color: var(--color-content-primary);
}
.fl-price-row__na { color: var(--color-content-faded); font-size: 13px; }

.fl-contact-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 0;
    font-size: 14px;
    color: var(--color-content-text);
    text-decoration: none;
    border-bottom: 1px solid var(--color-content-border);
    transition: color .2s;
}
.fl-contact-link:last-child { border-bottom: none; }
.fl-contact-link:hover { color: var(--color-content-primary); }
.fl-contact-link--whatsapp { color: #25D366; }

/* 
   18. FORMULAR  SEE HINZUFGEN LAYOUT
    */
.fl-add-lake__wrapper {
    max-width: var(--site-canvas-width, 1300px);
    margin: 0 auto;
    padding: 40px 32px 60px;
}
.fl-add-lake__layout {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 32px;
    align-items: start;
}
.fl-add-lake__form {
    background: var(--color-content-bg-alt);
    border: 1px solid var(--color-content-border);
    border-radius: var(--fl-radius-lg);
    padding: 32px;
}

/* 
   19. FORMULAR  ACF STYLING
    */
.fl-add-lake__form .acf-form-fields .acf-field { margin-bottom: 20px; }

.fl-add-lake__form .acf-label label {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-heading);
    margin-bottom: 6px;
    display: block;
}
.fl-add-lake__form .acf-label .description {
    color: var(--color-content-faded);
    font-size: 12px;
    font-weight: 400;
    margin-top: 2px;
}
.fl-add-lake__form input[type="text"],
.fl-add-lake__form input[type="email"],
.fl-add-lake__form input[type="url"],
.fl-add-lake__form input[type="number"],
.fl-add-lake__form textarea,
.fl-add-lake__form select {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--color-content-border);
    border-radius: var(--fl-radius);
    font-size: 14px;
    color: var(--color-content-text);
    background: var(--fl-white);
    transition: border-color .2s;
    font-family: inherit;
}
.fl-add-lake__form input:focus,
.fl-add-lake__form textarea:focus,
.fl-add-lake__form select:focus {
    outline: none;
    border-color: var(--color-content-primary);
    box-shadow: 0 0 0 3px var(--color-content-primary-faded);
}
.fl-add-lake__form textarea { min-height: 120px; resize: vertical; }

.fl-add-lake__form .acf-tab-wrap .acf-tab-button {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 12px;
    color: var(--color-content-text);
    border-color: var(--color-content-border);
}
.fl-add-lake__form .acf-tab-wrap .acf-tab-button.active {
    color: var(--color-content-primary);
    border-color: var(--color-content-primary);
    background: var(--color-content-primary-faded);
}
.fl-add-lake__form .acf-checkbox-list li label,
.fl-add-lake__form .acf-true-false label {
    font-size: 13px;
    color: var(--color-content-text);
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}
.fl-add-lake__form .acf-required { color: var(--color-content-primary); }

.fl-add-lake__form .acf-error-message {
    background: rgba(216,70,57,.1);
    border-left: 3px solid #D84639;
    padding: 10px 14px;
    border-radius: 0 var(--fl-radius) var(--fl-radius) 0;
    font-size: 13px;
    color: #D84639;
    margin-bottom: 16px;
}
.fl-add-lake__form .acf-field.acf-error input,
.fl-add-lake__form .acf-field.acf-error select,
.fl-add-lake__form .acf-field.acf-error textarea { border-color: #D84639; }

.fl-add-lake__form .acf-gallery {
    border: 2px dashed var(--color-content-border);
    border-radius: var(--fl-radius-lg);
    padding: 20px;
    background: var(--color-content-bg);
}
.fl-add-lake__form .acf-form-submit {
    margin-top: 28px;
    padding-top: 20px;
    border-top: 1px solid var(--color-content-border);
}
.fl-add-lake__form .acf-form-submit input[type="submit"],
.fl-add-lake__form .acf-form-submit button {
    background: var(--fl-green);
    color: var(--fl-white);
    border: none;
    padding: 14px 32px;
    border-radius: var(--fl-radius);
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 15px;
    cursor: pointer;
    transition: opacity .2s;
    width: 100%;
}
.fl-add-lake__form .acf-form-submit input[type="submit"]:hover { opacity: .9; }
.fl-add-lake__form .acf-field-post-title input,
.fl-add-lake__form .acf-field-post-content textarea { font-size: 15px; }

/* 
   20. FORMULAR  INFO SIDEBAR & ERFOLGSBOX
    */
.fl-add-lake__info { display: flex; flex-direction: column; gap: 16px; }

.fl-info-box {
    background: var(--color-content-bg-alt);
    border: 1px solid var(--color-content-border);
    border-radius: var(--fl-radius-lg);
    padding: 18px 20px;
}
.fl-info-box__title {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 14px;
    color: var(--color-content-heading);
    margin-bottom: 8px;
}
.fl-info-box p {
    font-size: 13px;
    color: var(--color-content-faded);
    line-height: 1.6;
    margin: 0;
}
.fl-info-box--promo {
    border-color: var(--fl-gold);
    background: rgba(240,165,0,.06);
}
.fl-info-box--promo .fl-info-box__title { color: #7a4e00; }

.fl-success-box {
    max-width: 560px;
    margin: 0 auto;
    text-align: center;
    background: var(--color-content-bg-alt);
    border: 1px solid var(--color-content-border);
    border-top: 4px solid var(--fl-green);
    border-radius: var(--fl-radius-lg);
    padding: 48px 40px;
}
.fl-success-box__icon { font-size: 48px; margin-bottom: 16px; }
.fl-success-box h2 {
    font-family: var(--h2-font-family, inherit);
    font-weight: var(--h2-font-weight, 700);
    color: var(--color-content-heading);
    margin-bottom: 12px;
}
.fl-success-box p { color: var(--color-content-text); font-size: 15px; line-height: 1.6; }

/* 
   21. ALLGEMEIN  BREADCRUMB, PAGINATION, NO RESULTS
    */
.fl-breadcrumb {
    color: var(--color-header-middle-text);
    opacity: .7;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.fl-breadcrumb a { color: var(--color-header-middle-text); opacity: .8; text-decoration: none; }
.fl-breadcrumb a:hover { opacity: 1; }
.fl-breadcrumb-bar {
    background: var(--color-header-middle-bg);
    padding: 12px 32px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.fl-no-results {
    text-align: center;
    padding: 60px 20px;
    color: var(--color-content-faded);
}
.fl-pagination {
    margin: 32px 0;
    display: flex;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
}
.fl-pagination .page-numbers {
    padding: 8px 14px;
    border: 1px solid var(--color-content-border);
    border-radius: var(--fl-radius);
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-heading);
    text-decoration: none;
    transition: background .2s;
}
.fl-pagination .page-numbers.current {
    background: var(--color-content-primary);
    color: var(--fl-white);
    border-color: var(--color-content-primary);
}
.fl-pagination .page-numbers:hover:not(.current) { background: var(--color-content-bg); }

/* 
   22. RESPONSIVE
    */
@media (max-width: 1024px) {
    .fl-lake-grid          { grid-template-columns: repeat(2, 1fr); }
    .fl-featured-grid--3,
    .fl-featured-grid--4   { grid-template-columns: repeat(2, 1fr); }
    .fl-single__wrapper    { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
    .fl-add-lake__layout   { grid-template-columns: 1fr; }
    .fl-add-lake__info     { order: -1; }
}
@media (max-width: 768px) {
    .fl-archive__content   { grid-template-columns: 1fr; }
    .fl-filter-sidebar     { order: 2; }
}
@media (max-width: 640px) {
    .fl-lake-grid,
    .fl-featured-grid--3,
    .fl-featured-grid--4,
    .fl-featured-grid--2   { grid-template-columns: 1fr; }
    .fl-cat-grid           { grid-template-columns: repeat(3, 1fr); }
    .fl-hero-row h1        { font-size: 28px !important; }
    .fl-promo-banner       { padding: 32px 20px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   23. AMENITY BADGES (Lake Card & Single)
   ═══════════════════════════════════════════════════════════════════════════ */
.fl-lake-card__amenities {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 12px;
}
.fl-amenity-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--color-content-bg);
    border: 1px solid var(--color-content-border);
    border-radius: 20px;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-content-text);
    white-space: nowrap;
    font-family: var(--h2-font-family, inherit);
}
.fl-amenity-badge--more {
    background: var(--color-content-primary-faded);
    color: var(--color-content-primary);
    border-color: var(--color-content-primary-faded);
}

/* Amenity Grid auf der Single-Seite */
.fl-amenities-section {
    margin: 24px 0;
}
.fl-amenities-group {
    margin-bottom: 20px;
}
.fl-amenities-group__title {
    font-family: var(--h2-font-family, inherit);
    font-weight: 700;
    font-size: 13px;
    color: var(--color-content-heading);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--color-content-border);
}
.fl-amenities-group__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.fl-amenity-item-lg {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--color-content-bg);
    border: 1px solid var(--color-content-border);
    border-radius: var(--fl-radius);
    padding: 7px 14px;
    font-size: 13px;
    color: var(--color-content-text);
    font-family: var(--h2-font-family, inherit);
    font-weight: 600;
}
.fl-amenity-item-lg--no {
    opacity: .5;
    text-decoration: line-through;
}
.fl-amenity-item-lg--rule {
    background: rgba(216,70,57,.06);
    border-color: rgba(216,70,57,.2);
    color: #c0392b;
}

/* ═══════════════════════════════════════════════════════════════════════════
   24. TYPEN-SELEKTOR (Universelles Eintrags-Formular)
   ═══════════════════════════════════════════════════════════════════════════ */
.fl-type-selector {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 28px;
}
.fl-type-selector__btn {
    display: inline-block;
    padding: 9px 22px;
    border-radius: 30px;
    border: 2px solid rgba(255,255,255,0.45);
    color: rgba(255,255,255,0.85);
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    font-family: var(--h2-font-family, inherit);
    line-height: 1;
    transition: background 0.18s, color 0.18s, border-color 0.18s;
    white-space: nowrap;
}
.fl-type-selector__btn:hover {
    background: rgba(255,255,255,0.15);
    border-color: rgba(255,255,255,0.75);
    color: #fff;
    text-decoration: none;
}
.fl-type-selector__btn--active {
    background: #fff;
    border-color: #fff;
    color: var(--color-content-primary, #2a6496);
    pointer-events: none;
}
@media (max-width: 640px) {
    .fl-type-selector {
        gap: 8px;
    }
    .fl-type-selector__btn {
        padding: 8px 16px;
        font-size: 13px;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   25. SHOP & BRANDS (Badge, Buttons – aus style.css übernommen)
   ═══════════════════════════════════════════════════════════════════════════ */
.fl-biz-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: var(--site-border-radius);
    font-size: 13px;
    font-weight: 600;
    color: #fff;
    background: var(--color-content-primary);
}
.fl-biz-badge.is-brand {
    background: var(--color-header-middle-bg);
}
.fl-biz-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
}
/* Single-Dash-Varianten für functions.php-Kompatibilität */
.fl-btn-primary {
    background: var(--color-content-primary);
    color: #fff;
    padding: 10px 18px;
    font-size: 14px;
}
.fl-btn-primary:hover { opacity: .9; color: #fff; }
.fl-btn-shop {
    background: var(--color-header-middle-bg);
    color: #fff;
    padding: 10px 18px;
    font-size: 14px;
}
.fl-btn-shop:hover { opacity: .9; color: #fff; }

/* ═══════════════════════════════════════════════════════════════════════════
   26. ANGELTYP-CARDS (aus style.css übernommen)
   ═══════════════════════════════════════════════════════════════════════════ */
.fl-angeltyp-cards {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    max-width: var(--site-canvas-width);
    margin: 30px auto;
    padding: 0 20px;
}
.fl-angeltyp-card {
    position: relative;
    flex: 1 1 320px;
    min-height: 240px;
    border-radius: var(--site-border-radius);
    overflow: hidden;
    background-size: cover;
    background-position: center;
    text-decoration: none;
    display: flex;
    align-items: flex-end;
}
.fl-angeltyp-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(6,62,84,0) 30%, rgba(6,62,84,.85) 100%);
}
.fl-angeltyp-inner {
    position: relative;
    z-index: 1;
    padding: 24px;
    color: #fff;
    width: 100%;
}
.fl-angeltyp-inner h3 {
    color: #fff;
    margin: 0 0 6px;
    font-family: var(--h2-font-family);
}
.fl-angeltyp-inner p {
    color: #fff;
    opacity: .9;
    margin: 0 0 14px;
}
.fl-angeltyp-card.is-active {
    outline: 3px solid var(--color-content-primary);
}
.fl-angeltyp-card .fl-btn {
    display: inline-block;
    padding: 10px 18px;
    border-radius: var(--site-border-radius);
    font-weight: 600;
    background: var(--color-content-primary);
    color: #fff;
}
.fl-angeltyp-card:hover .fl-btn { opacity: .9; }
