/* ===== ErsteHilfeFinder – Design System ===== */
/* Google Fonts loaded via <link> in index.html head for non-blocking rendering */

:root {
  --blue-900: #0B3D6B;
  --blue-700: #0B5394;
  --blue-600: #1565C0;
  --blue-500: #1A73B5;
  --blue-400: #3D8ECF;
  --blue-100: #DCEEFB;
  --blue-50: #EFF7FF;
  --green-600: #1E8E4E;
  --green-500: #27AE60;
  --green-400: #2ECC71;
  --green-100: #D5F5E3;
  --green-50: #EAFAF1;
  --dark: #1B2A4A;
  --dark-700: #2C3E5A;
  --gray-600: #5A6B7F;
  --gray-500: #5F7282;
  --gray-400: #9BADBF;
  --gray-300: #C8D6E0;
  --gray-200: #E2EAF0;
  --gray-100: #F0F4F8;
  --gray-50: #F8FBFF;
  --white: #FFFFFF;
  --star: #F5A623;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --shadow-sm: 0 1px 3px rgba(11,61,107,0.06), 0 1px 2px rgba(11,61,107,0.04);
  --shadow-md: 0 4px 12px rgba(11,61,107,0.08), 0 2px 4px rgba(11,61,107,0.04);
  --shadow-lg: 0 10px 30px rgba(11,61,107,0.10), 0 4px 8px rgba(11,61,107,0.05);
  --shadow-xl: 0 20px 50px rgba(11,61,107,0.12);
  --transition: 0.25s cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; text-size-adjust: 100%; overflow-x: hidden; }

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 16px;
  color: var(--dark);
  background: var(--white);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
button { cursor: pointer; border: none; background: none; font-family: inherit; touch-action: manipulation; }
input, select, textarea { font-family: inherit; font-size: inherit; }
a { touch-action: manipulation; }
ul { list-style: none; }

/* ===== Utility Classes ===== */
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.section { padding: 80px 0; }
.section-sm { padding: 60px 0; }

.text-center { text-align: center; }
.text-blue { color: var(--blue-700); }
.text-green { color: var(--green-500); }
.text-gray { color: var(--gray-500); }
.text-dark { color: var(--dark); }
.text-white { color: var(--white); }

.bg-white { background: var(--white); }
.bg-light { background: var(--gray-50); }
.bg-blue-50 { background: var(--blue-50); }
.bg-green-50 { background: var(--green-50); }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 28px; border-radius: var(--radius-sm); font-weight: 600;
  font-size: 15px; transition: all var(--transition); white-space: nowrap;
  min-height: 48px;
}
.btn-primary {
  background: linear-gradient(135deg, var(--blue-600), var(--blue-700));
  color: var(--white); box-shadow: 0 4px 14px rgba(11,83,148,0.35);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(11,83,148,0.45); }
.btn-green {
  background: linear-gradient(135deg, var(--green-400), var(--green-600));
  color: var(--white); box-shadow: 0 4px 14px rgba(39,174,96,0.35);
}
.btn-green:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(39,174,96,0.45); }
.btn-outline {
  border: 2px solid var(--blue-500); color: var(--blue-500); background: transparent;
}
.btn-outline:hover { background: var(--blue-500); color: var(--white); }
.btn-sm { padding: 10px 18px; font-size: 14px; min-height: 48px; }
.btn-lg { padding: 16px 36px; font-size: 17px; }

.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 12px; border-radius: 50px; font-size: 12px; font-weight: 600;
}
.badge-blue { background: var(--blue-100); color: var(--blue-700); }
.badge-green { background: var(--green-100); color: var(--green-600); }
.badge-soon {
  background: #FFF3CD; color: #856404; font-size: 10px; padding: 2px 8px;
  animation: badge-pulse 2s ease-in-out infinite;
}
.badge-urgency {
  background: #FDECEA; color: #C0392B; font-size: 11px; font-weight: 700;
}
.badge-spots {
  background: var(--green-100); color: var(--green-600); font-size: 11px;
}
@keyframes badge-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}

.card {
  background: var(--white); border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm); border: 1px solid var(--gray-200);
  transition: all var(--transition); overflow: hidden;
}
.card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--blue-400); }

h1 { font-size: clamp(28px, 5vw, 48px); font-weight: 800; line-height: 1.15; }
h2 { font-size: clamp(24px, 3.5vw, 36px); font-weight: 700; line-height: 1.2; }
h3 { font-size: clamp(18px, 2vw, 22px); font-weight: 600; line-height: 1.3; }

/* ===== Header ===== */
.header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: rgba(255,255,255,0.97); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--gray-200); transition: box-shadow var(--transition);
}
.header.scrolled { box-shadow: var(--shadow-md); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 68px; max-width: 1200px; margin: 0 auto; padding: 0 20px;
}
.logo { display: flex; align-items: center; gap: 10px; }
.logo svg { width: 36px; height: 36px; }
.logo-text { font-size: 20px; font-weight: 700; color: var(--dark); }
.logo-text span { color: var(--blue-600); }
.footer .logo-text span { color: #90caf9; }

.nav { display: flex; align-items: center; gap: 28px; }
.nav a {
  font-size: 14px; font-weight: 500; color: var(--gray-600);
  transition: color var(--transition); position: relative;
  padding: 12px 4px; min-height: 48px; display: inline-flex; align-items: center;
}
.nav a:hover, .nav a.active { color: var(--blue-600); }
.nav a.active::after {
  content: ''; position: absolute; bottom: -4px; left: 0; right: 0;
  height: 2px; background: var(--blue-600); border-radius: 2px;
}
.nav-cta {
  background: var(--blue-600) !important; color: var(--white) !important;
  padding: 8px 20px !important; border-radius: var(--radius-sm) !important;
  font-weight: 600 !important;
}
.nav-cta:hover { background: var(--blue-700) !important; }
.nav-cta.active::after { display: none !important; }

.mobile-toggle { display: none; width: 40px; height: 40px; align-items: center; justify-content: center; border-radius: var(--radius-sm); }
.mobile-toggle svg { width: 24px; height: 24px; color: var(--dark); }
.mobile-menu {
  display: none; position: absolute; top: 68px; left: 0; right: 0;
  background: var(--white); border-bottom: 1px solid var(--gray-200);
  padding: 16px 20px; box-shadow: var(--shadow-md);
}
.mobile-menu.open { display: block; }
.mobile-menu a {
  display: block; padding: 14px 0; font-size: 15px; font-weight: 500;
  color: var(--gray-600); border-bottom: 1px solid var(--gray-100);
}
.mobile-menu a:last-child { border-bottom: none; }
.mobile-menu a.active { color: var(--blue-600); }
.mobile-menu-cta {
  margin-top: 8px; background: var(--blue-600) !important;
  color: var(--white) !important; border-radius: var(--radius-sm);
  text-align: center; font-weight: 600 !important;
  border-bottom: none !important; padding: 14px !important;
}

@media (max-width: 768px) {
  .nav { display: none; }
  .mobile-toggle { display: flex; }
}

/* ===== Hero ===== */
.hero {
  position: relative; min-height: 640px; display: flex; align-items: center;
  justify-content: center; padding: 100px 20px 80px; overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: #0B3D6B;
}
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(135deg, rgba(11,61,107,0.88) 0%, rgba(11,83,148,0.82) 40%, rgba(26,115,181,0.75) 100%);
}
.hero::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 120px;
  background: linear-gradient(to top, var(--white), transparent); z-index: 2;
}
.hero-content { position: relative; z-index: 3; text-align: center; max-width: 800px; }
.hero h1 { color: var(--white); margin-bottom: 16px; text-shadow: 0 2px 20px rgba(0,0,0,0.2); }
.hero p { color: rgba(255,255,255,0.9); font-size: clamp(16px, 2vw, 20px); margin-bottom: 36px; }

.search-box {
  background: var(--white); border-radius: var(--radius-lg); padding: 8px;
  box-shadow: var(--shadow-xl); display: flex; flex-wrap: wrap; gap: 8px; max-width: 860px; margin: 0 auto;
}
.search-box input, .search-box select {
  flex: 1; padding: 14px 18px; border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm); background: var(--gray-50);
  font-size: 14px; color: var(--dark); outline: none; min-width: 0;
  transition: border-color var(--transition);
}
.search-box input:focus, .search-box select:focus { border-color: var(--blue-400); }
.search-box select.error-shake, .search-box input.error-shake { border-color: var(--red-500, #ef4444); }
.search-box .btn { flex-shrink: 0; }
.search-date-wrap { position: relative; flex: 1; min-width: 0; display: flex; align-items: center; }
.search-date-wrap input[type="date"] { width: 100%; padding-right: 60px; }
.search-date-label {
  position: absolute; right: 10px; font-size: 11px; color: var(--gray-400);
  pointer-events: none; white-space: nowrap;
}

@media (max-width: 640px) {
  .search-box { flex-direction: column; }
  .search-box input, .search-box select { font-size: 16px; } /* prevent iOS zoom */
  .search-date-wrap input[type="date"] { font-size: 16px; }
  .hero { min-height: 520px; padding: 90px 16px 60px; }
}

/* ===== Category Tiles ===== */
.categories-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px;
}
.cat-tile {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 28px 16px; border-radius: var(--radius-md); background: var(--white);
  border: 1.5px solid var(--gray-200); cursor: pointer; transition: all 0.2s ease;
  min-height: 44px; text-decoration: none;
}
.cat-tile:hover {
  border-color: var(--cat-icon, var(--blue-400));
  box-shadow: 0 8px 24px rgba(0,0,0,0.09);
  transform: translateY(-4px);
}
.cat-tile-icon {
  width: 60px; height: 60px; border-radius: 16px; display: flex;
  align-items: center; justify-content: center;
  background: var(--cat-bg, var(--blue-50));
  transition: background 0.2s ease, transform 0.2s ease;
}
.cat-tile:hover .cat-tile-icon {
  background: var(--cat-hover, var(--blue-100));
  transform: scale(1.08);
}
.cat-tile-icon svg { width: 30px; height: 30px; color: var(--cat-icon, var(--blue-600)); }
.cat-tile span { font-size: 13px; font-weight: 600; color: var(--dark); text-align: center; line-height: 1.3; }

@media (max-width: 900px) { .categories-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .categories-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) {
  .categories-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .cat-tile { padding: 16px 8px; gap: 8px; }
  .cat-tile-icon { width: 44px; height: 44px; }
  .cat-tile-icon svg { width: 22px; height: 22px; }
}

/* ===== Stats ===== */
.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.stat-item { text-align: center; padding: 24px; }
.stat-num { font-size: clamp(28px, 4vw, 40px); font-weight: 800; color: var(--blue-600); }
.stat-label { font-size: 14px; color: var(--gray-500); margin-top: 4px; }

@media (max-width: 640px) { .stats-row { grid-template-columns: repeat(2, 1fr); } }

/* ===== How It Works ===== */
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; position: relative; }
.step-card { text-align: center; position: relative; }
.step-num {
  width: 60px; height: 60px; border-radius: 50%; margin: 0 auto 20px;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 800; color: var(--white);
  background: linear-gradient(135deg, var(--blue-500), var(--blue-700));
  box-shadow: 0 4px 14px rgba(11,83,148,0.3);
}
.step-card h3 { margin-bottom: 8px; }
.step-card p { color: var(--gray-500); font-size: 14px; }

@media (max-width: 640px) { .steps-grid { grid-template-columns: 1fr; gap: 32px; } }

/* ===== Trust Badges ===== */
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.trust-item {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  padding: 32px 20px; border-radius: var(--radius-md); background: var(--white);
  border: 1px solid var(--gray-200); transition: all var(--transition);
}
.trust-item:hover { border-color: var(--green-400); box-shadow: var(--shadow-md); }
.trust-icon {
  width: 52px; height: 52px; border-radius: 50%; display: flex;
  align-items: center; justify-content: center; background: var(--green-50);
}
.trust-icon svg { width: 24px; height: 24px; color: var(--green-500); }
.trust-item h3 { font-size: 15px; text-align: center; }
.trust-item p { font-size: 13px; color: var(--gray-500); text-align: center; }

@media (max-width: 768px) { .trust-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .trust-grid { grid-template-columns: 1fr; } }

/* ===== Provider Cards (Listing) ===== */
.listing-layout { display: grid; grid-template-columns: 280px 1fr; gap: 32px; }
.filters-panel {
  position: sticky; top: 88px; align-self: start;
  background: var(--white); border-radius: var(--radius-md);
  border: 1px solid var(--gray-200); padding: 24px;
}
.filter-group { margin-bottom: 20px; }
.filter-group:last-child { margin-bottom: 0; }
.filter-group label { display: block; font-size: 13px; font-weight: 600; color: var(--dark); margin-bottom: 8px; }
.filter-group input, .filter-group select {
  width: 100%; padding: 10px 14px; border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm); background: var(--gray-50); font-size: 16px;
  outline: none; transition: border-color var(--transition);
  box-sizing: border-box; -webkit-appearance: none; appearance: none; min-height: 48px;
}
.filter-group input:focus, .filter-group select:focus { border-color: var(--blue-400); }

.provider-list { display: flex; flex-direction: column; gap: 16px; }
.provider-card {
  display: grid; grid-template-columns: 1fr; gap: 0;
  background: var(--white); border-radius: var(--radius-md);
  border: 1px solid var(--gray-200); transition: all var(--transition);
  overflow: hidden;
}
.provider-card:hover { border-color: var(--blue-400); box-shadow: var(--shadow-md); }
.provider-card.featured { border-color: var(--green-400); background: var(--green-50); }
.provider-card-body {
  display: grid; grid-template-columns: 1fr auto; gap: 16px;
  padding: 16px 20px; align-items: center;
}
.provider-logo {
  width: 80px; height: 80px; border-radius: var(--radius-sm);
  background: var(--blue-50); display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 800; color: var(--blue-600);
}
.provider-info h3 { margin-bottom: 4px; }
.provider-name-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.provider-meta { display: flex; flex-wrap: wrap; gap: 12px; color: var(--gray-500); font-size: 13px; margin-bottom: 8px; }
.provider-meta svg { width: 14px; height: 14px; flex-shrink: 0; }
.provider-meta span { display: inline-flex; align-items: center; gap: 4px; }
.provider-stars { display: flex; gap: 2px; }
.provider-stars svg { width: 14px; height: 14px; color: var(--star); }
.provider-price { font-size: 20px; font-weight: 700; color: var(--blue-700); }
.provider-price small { font-size: 13px; font-weight: 400; color: var(--gray-500); display: block; }
.provider-actions { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; }

@media (max-width: 900px) {
  .listing-layout { grid-template-columns: 1fr; }
  .filters-panel { position: static; }
}
@media (max-width: 640px) {
  .provider-card-body { grid-template-columns: 1fr; gap: 12px; padding: 14px; }
  .provider-actions { display: flex; flex-direction: row; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
  .provider-price { font-size: 17px; }
}

/* ===== Results Hero ===== */
.results-hero {
  background: linear-gradient(135deg, var(--blue-900), var(--blue-700));
  padding: 80px 20px 28px; color: white;
}
@media (max-width: 640px) {
  .results-hero { padding: 72px 16px 20px; }
}

/* ===== Detail Page ===== */
.detail-hero {
  background: linear-gradient(135deg, var(--blue-900), var(--blue-700));
  padding: 100px 20px 48px; color: var(--white);
}
.detail-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 32px; margin-top: -40px; position: relative; z-index: 2; }
.detail-main { background: var(--white); border-radius: var(--radius-md); padding: 32px; box-shadow: var(--shadow-md); border: 1px solid var(--gray-200); }
.detail-sidebar { display: flex; flex-direction: column; gap: 20px; }
.detail-sidebar .card { padding: 24px; }
.course-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin-top: 12px; border-radius: var(--radius-sm); }
.course-table { width: 100%; border-collapse: collapse; }
.course-table th, .course-table td { padding: 12px 16px; text-align: left; font-size: 14px; border-bottom: 1px solid var(--gray-100); white-space: nowrap; }
.course-table th { font-weight: 600; color: var(--dark); background: var(--gray-50); }
@media (max-width: 640px) {
  .course-table-wrap { overflow-x: visible; }
  .course-table { display: block; }
  .course-table thead { display: none; }
  .course-table tbody { display: flex; flex-direction: column; gap: 10px; }
  .course-table tr {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto auto;
    align-items: center;
    gap: 2px 10px;
    padding: 14px 16px;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-sm);
    background: var(--white);
  }
  .course-table tr:last-child { border-bottom: 1px solid var(--gray-200); }
  /* Kursname – volle Breite oben */
  .course-table td:nth-child(1) { grid-column: 1 / -1; font-weight: 600; font-size: 14px; border: none; padding: 0; white-space: normal; }
  /* Datum */
  .course-table td:nth-child(2) { grid-column: 1; font-size: 13px; color: var(--gray-500); border: none; padding: 0; white-space: normal; }
  /* Uhrzeit – versteckt */
  .course-table td:nth-child(3) { display: none; }
  /* Preis */
  .course-table td:nth-child(4) { grid-column: 2; grid-row: 2; font-weight: 700; font-size: 14px; color: var(--blue-700); border: none; padding: 0; white-space: normal; text-align: right; }
  /* Plätze – versteckt */
  .course-table td:nth-child(5) { display: none; }
  /* Buchen-Button – volle Breite unten */
  .course-table td:nth-child(6) { grid-column: 1 / -1; border: none; padding: 10px 0 0; }
  .course-table td:nth-child(6) .btn { width: 100%; text-align: center; justify-content: center; }
}
.review-card { padding: 16px; border: 1px solid var(--gray-100); border-radius: var(--radius-sm); margin-top: 12px; }
.review-card .stars { display: flex; gap: 2px; margin-bottom: 8px; }
.review-card .stars svg { width: 14px; height: 14px; color: var(--star); }
.review-card p { font-size: 14px; color: var(--gray-600); }
.review-card .reviewer { font-size: 13px; font-weight: 600; color: var(--dark); margin-top: 8px; }

.map-placeholder {
  width: 100%; height: 200px; border-radius: var(--radius-sm);
  background: var(--gray-100); display: flex; align-items: center;
  justify-content: center; color: var(--gray-400); font-size: 14px;
  border: 1px solid var(--gray-200);
}

@media (max-width: 768px) {
  .detail-grid { grid-template-columns: 1fr; margin-top: 24px; width: 100%; }
  .detail-hero { padding: 88px 16px 40px; }
  .detail-main { overflow: hidden; word-break: break-word; overflow-wrap: break-word; }
  .detail-sidebar { width: 100%; max-width: 100%; }
  .detail-sidebar .card { width: 100%; max-width: 100%; box-sizing: border-box; }
}
@media (max-width: 480px) {
  .detail-main { padding: 20px 16px; }
  .detail-sidebar .card { padding: 16px; }
}

/* ===== About / How It Works Page ===== */
.about-hero {
  background: linear-gradient(135deg, var(--blue-50), var(--green-50));
  padding: 100px 20px 60px; text-align: center;
}

/* ===== B2B Page ===== */
.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.pricing-card {
  background: var(--white); border-radius: var(--radius-md); padding: 32px;
  border: 2px solid var(--gray-200); text-align: center; transition: all var(--transition);
}
.pricing-card.popular { border-color: var(--blue-500); position: relative; }
.pricing-card.popular::before {
  content: 'Beliebt'; position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  background: var(--blue-600); color: var(--white); padding: 4px 20px;
  border-radius: 50px; font-size: 12px; font-weight: 700;
}
.pricing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.pricing-card h3 { margin-bottom: 8px; }
.pricing-amount { font-size: 40px; font-weight: 800; color: var(--blue-700); margin: 16px 0; }
.pricing-amount small { font-size: 16px; font-weight: 400; color: var(--gray-500); }
.pricing-features { text-align: left; margin: 20px 0; }
.pricing-features li { padding: 8px 0; font-size: 14px; color: var(--gray-600); display: flex; align-items: center; gap: 8px; }
.pricing-features li svg { width: 18px; height: 18px; color: var(--green-500); flex-shrink: 0; }
.pricing-feature-no { color: var(--gray-400) !important; }

@media (max-width: 768px) { .pricing-grid { grid-template-columns: 1fr; } }

/* ===== Forms ===== */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group.full { grid-column: 1 / -1; }
.form-group label { font-size: 13px; font-weight: 600; color: var(--dark); }
.form-group input, .form-group select, .form-group textarea {
  padding: 12px 16px; border: 1px solid var(--gray-200); border-radius: var(--radius-sm);
  background: var(--gray-50); font-size: 16px; outline: none;
  transition: border-color var(--transition); min-height: 48px;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--blue-400); background: var(--white); }
.form-group textarea { min-height: 120px; resize: vertical; }

@media (max-width: 640px) { .form-grid { grid-template-columns: 1fr; } }

.inline-error {
  display: block; font-size: 12px; color: var(--red-500, #ef4444);
  margin-top: 4px; font-weight: 500;
}

/* ===== CTA Banner ===== */
.cta-banner {
  background: linear-gradient(135deg, var(--blue-900), var(--blue-600));
  padding: 80px 20px; text-align: center; position: relative; overflow: hidden;
}
.cta-banner::before {
  content: ''; position: absolute; top: -50%; right: -20%; width: 500px; height: 500px;
  border-radius: 50%; background: rgba(39,174,96,0.12);
}
.cta-banner h2 { color: var(--white); margin-bottom: 12px; }
.cta-banner p { color: rgba(255,255,255,0.8); font-size: 18px; margin-bottom: 28px; }

/* ===== Testimonials ===== */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.testimonial-card {
  background: var(--white); border-radius: var(--radius-md); padding: 28px;
  border: 1px solid var(--gray-200); position: relative;
}
.testimonial-card .quote-icon { position: absolute; top: 16px; right: 20px; color: var(--blue-100); }
.testimonial-card .stars { display: flex; gap: 2px; margin-bottom: 12px; }
.testimonial-card .stars svg { width: 16px; height: 16px; color: var(--star); }
.testimonial-card p { font-size: 14px; color: var(--gray-600); line-height: 1.7; margin-bottom: 16px; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.testimonial-avatar {
  width: 40px; height: 40px; border-radius: 50%; display: flex;
  align-items: center; justify-content: center; font-size: 14px; font-weight: 700;
}
.testimonial-name { font-size: 14px; font-weight: 600; color: var(--dark); }
.testimonial-loc { font-size: 12px; color: var(--gray-500); }

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

/* ===== FAQ ===== */
.faq-item { border: 1px solid var(--gray-200); border-radius: var(--radius-sm); margin-bottom: 8px; overflow: hidden; }
.faq-btn {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; font-size: 15px; font-weight: 600; color: var(--dark);
  background: var(--white); transition: background var(--transition); gap: 12px;
}
.faq-q { flex: 1; text-align: center; }
.faq-btn:hover { background: var(--gray-50); }
.faq-btn svg { width: 20px; height: 20px; color: var(--gray-400); transition: transform var(--transition); flex-shrink: 0; }
.faq-btn.open svg { transform: rotate(180deg); }
.faq-answer { padding: 0 20px 16px; font-size: 14px; color: var(--gray-600); line-height: 1.7; display: none; }
.faq-answer.open { display: block; }

/* ===== Footer ===== */
.footer { background: var(--dark); color: rgba(255,255,255,0.6); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; padding: 60px 0; }
.footer h4, .footer-heading { color: var(--white); font-size: 15px; font-weight: 700; margin-bottom: 16px; }
.footer p { font-size: 13px; line-height: 1.7; }
.footer ul li { margin-bottom: 4px; }
.footer ul a { font-size: 13px; transition: color var(--transition); display: inline-block; padding: 6px 0; }
.footer ul a:hover { color: var(--white); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 20px 0; display: flex; align-items: center;
  justify-content: space-between; font-size: 12px;
}
.footer-social { display: flex; gap: 10px; }
.footer-social a {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,0.08); display: flex;
  align-items: center; justify-content: center; transition: all var(--transition);
}
.footer-social a:hover { background: var(--blue-600); }
.footer-social svg { width: 16px; height: 16px; fill: currentColor; }

@media (max-width: 768px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-bottom { flex-direction: column; gap: 12px; }
}
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }

/* ===== Legal Pages ===== */
.legal-content { max-width: 800px; margin: 0 auto; }
.legal-content h2 { font-size: 22px; margin: 32px 0 12px; }
.legal-content h3 { font-size: 18px; margin: 24px 0 8px; }
.legal-content p { font-size: 14px; color: var(--gray-600); margin-bottom: 12px; line-height: 1.8; }
.legal-content ul { padding-left: 20px; margin-bottom: 12px; }
.legal-content ul li { font-size: 14px; color: var(--gray-600); margin-bottom: 6px; list-style: disc; }

/* ===== Scroll To Top ===== */
.scroll-top {
  position: fixed; bottom: 24px; right: 24px; z-index: 90;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--blue-600); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md); opacity: 0; pointer-events: none;
  transition: all var(--transition);
}
.scroll-top.visible { opacity: 1; pointer-events: auto; }
.scroll-top:hover { background: var(--blue-700); transform: translateY(-2px); }
.scroll-top svg { width: 20px; height: 20px; }

/* ===== Page Transitions ===== */
#app { min-height: calc(100vh - 68px); padding-top: 68px; }
.page-enter { animation: fadeIn 0.3s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

/* ===== Scroll Reveal ===== */
.reveal {
  opacity: 0; transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(.4,0,.2,1), transform 0.7s cubic-bezier(.4,0,.2,1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }

/* ===== Cookie Banner ===== */
.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 200;
  background: var(--dark); color: rgba(255,255,255,0.85);
  padding: 20px; display: none;
  animation: slideUp 0.4s ease;
}
.cookie-banner.show { display: block; }
.cookie-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  flex-wrap: wrap;
}
.cookie-inner p { font-size: 13px; line-height: 1.6; flex: 1; min-width: 280px; }
.cookie-inner p a { color: #93c5fd; text-decoration: underline; }
.cookie-actions { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-accept {
  padding: 10px 24px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 600;
  background: #166534; color: white; border: none; cursor: pointer;
  transition: background var(--transition);
}
.cookie-accept:hover { background: #145a30; }
.cookie-settings {
  padding: 10px 24px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 600;
  background: transparent; color: rgba(255,255,255,0.7); border: 1px solid rgba(255,255,255,0.2);
  cursor: pointer; transition: all var(--transition);
}
.cookie-settings:hover { border-color: rgba(255,255,255,0.5); color: white; }
@keyframes slideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }

@media (max-width: 640px) {
  .cookie-inner { flex-direction: column; text-align: center; }
  .cookie-actions { width: 100%; justify-content: center; }
}

/* ===== Breadcrumbs ===== */
.breadcrumb {
  display: flex; align-items: center; gap: 8px; font-size: 13px;
  color: rgba(255,255,255,0.6); margin-bottom: 12px; flex-wrap: wrap;
}
.breadcrumb a { color: rgba(255,255,255,0.6); cursor: pointer; transition: color var(--transition); }
.breadcrumb a:hover { color: rgba(255,255,255,0.9); }
.breadcrumb .sep { color: rgba(255,255,255,0.3); }
.breadcrumb .current { color: white; font-weight: 500; }

.breadcrumb-light {
  display: flex; align-items: center; gap: 8px; font-size: 13px;
  color: var(--gray-400); margin-bottom: 12px; flex-wrap: wrap;
}
.breadcrumb-light a { color: var(--gray-500); cursor: pointer; transition: color var(--transition); }
.breadcrumb-light a:hover { color: var(--blue-600); }
.breadcrumb-light .sep { color: var(--gray-300); }
.breadcrumb-light .current { color: var(--dark); font-weight: 500; }

/* ===== Loading Skeleton ===== */
.page-loading {
  display: flex; flex-direction: column; gap: 24px;
  padding: 100px 20px 60px; max-width: 1200px; margin: 0 auto;
}
.skeleton {
  background: linear-gradient(90deg, var(--gray-100) 25%, var(--gray-50) 50%, var(--gray-100) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite ease-in-out;
  border-radius: var(--radius-sm);
}
.skeleton-hero { height: 320px; border-radius: 0; }
.skeleton-title { height: 32px; width: 50%; }
.skeleton-text { height: 16px; width: 80%; }
.skeleton-text-sm { height: 14px; width: 60%; }
.skeleton-card { height: 120px; border-radius: var(--radius-md); }
.skeleton-row { display: flex; gap: 16px; }
.skeleton-row .skeleton { flex: 1; height: 180px; }
@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ===== Skip link & screen-reader ===== */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.skip-link:focus {
  position: fixed; top: 12px; left: 12px; z-index: 10001;
  clip: auto; width: auto; height: auto; margin: 0; padding: 12px 16px;
  overflow: visible; white-space: normal;
  background: var(--blue-700); color: var(--white); border-radius: var(--radius-sm);
  font-weight: 600; text-decoration: none; outline: 2px solid var(--blue-400); outline-offset: 2px;
}

/* ===== Rating Source Tooltip ===== */
.rating-source {
  display: inline-flex; align-items: center; position: relative; cursor: pointer;
}
button.rating-source {
  font: inherit; color: inherit; padding: 0; border: none; background: none;
}
.rating-source:focus-visible {
  outline: 2px solid var(--blue-500); outline-offset: 2px; border-radius: 4px;
}
.rating-source-icon {
  width: 15px; height: 15px; background: var(--gray-400); border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--white); font-size: 10px; font-weight: 700; font-style: italic;
  margin-left: 5px; flex-shrink: 0; line-height: 1;
}
.rating-source-tooltip {
  display: none; position: absolute; bottom: calc(100% + 8px); left: 50%;
  transform: translateX(-50%); background: var(--dark); color: white;
  font-size: 12px; font-weight: 400; padding: 7px 12px; border-radius: var(--radius-sm);
  white-space: nowrap; z-index: 250; pointer-events: none; box-shadow: var(--shadow-md);
}
.rating-source-tooltip::after {
  content: ''; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 5px solid transparent; border-top-color: var(--dark);
}
.rating-source:hover .rating-source-tooltip,
.rating-source.tooltip-open .rating-source-tooltip { display: block; }

/* ===== Half-Star Ratings ===== */
.stars-precise { display: inline-flex; align-items: center; gap: 2px; }
.stars-precise svg { width: 16px; height: 16px; }
.star-full { color: var(--star); }
.star-half { color: var(--star); }
.star-empty { color: var(--gray-300); }
.rating-number { font-size: 14px; font-weight: 600; color: var(--dark); margin-left: 6px; }
.rating-count { font-size: 13px; color: var(--gray-500); margin-left: 2px; }

/* ===== Map View ===== */
.view-switcher {
  display: flex; gap: 4px; background: var(--gray-100);
  border-radius: var(--radius-sm); padding: 3px;
}
.view-btn {
  display: flex; align-items: center; gap: 6px; padding: 8px 16px;
  font-size: 13px; font-weight: 600; border-radius: 6px;
  color: var(--gray-500); border: none; background: transparent;
  cursor: pointer; transition: all var(--transition);
}
.view-btn.active { background: var(--white); color: var(--blue-600); box-shadow: var(--shadow-sm); }
.view-btn svg { width: 16px; height: 16px; }

.map-container {
  width: 100%; height: 500px; border-radius: var(--radius-md);
  overflow: hidden; border: 1px solid var(--gray-200);
  box-shadow: var(--shadow-sm); display: none;
}
@media (max-width: 640px) {
  .map-container { height: 320px; }
}
.map-container.active { display: block; }
.provider-list.hidden { display: none; }

.leaflet-popup-content { padding: 12px 16px; min-width: 200px; }
.leaflet-popup-content h4 { font-size: 15px; font-weight: 700; color: var(--dark); margin-bottom: 4px; }
.leaflet-popup-content .popup-meta { font-size: 13px; color: var(--gray-500); margin-bottom: 8px; }
.leaflet-popup-content .popup-price { font-size: 16px; font-weight: 700; color: var(--blue-700); margin-bottom: 8px; }
.leaflet-popup-content .btn { font-size: 12px; padding: 6px 14px; }

/* Error Animation */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  10%, 30%, 50%, 70%, 90% { transform: translateX(-4px); }
  20%, 40%, 60%, 80% { transform: translateX(4px); }
}
.error-shake {
  animation: shake 0.4s cubic-bezier(.36,.07,.19,.97) both;
  border-color: #ef4444 !important;
  color: #ef4444;
}
.error-shake::placeholder {
  color: #ef4444;
}

/* ===== Buchungsmodal ===== */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(11,61,107,0.55);
  backdrop-filter: blur(4px);
  z-index: 9999;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.modal-overlay.open {
  display: flex;
  animation: modalFadeIn 0.22s ease;
}
@keyframes modalFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.modal-box {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 36px 32px 32px;
  position: relative;
  animation: modalSlideUp 0.25s cubic-bezier(.4,0,.2,1);
}
@keyframes modalSlideUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.modal-close {
  position: absolute;
  top: 16px;
  right: 18px;
  background: var(--gray-100);
  border: none;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  cursor: pointer;
  font-size: 18px;
  color: var(--gray-600);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition);
  touch-action: manipulation;
}
.modal-close:hover { background: var(--gray-200); color: var(--dark); }
.modal-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.modal-icon {
  width: 44px;
  height: 44px;
  background: var(--blue-50);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-600);
  flex-shrink: 0;
}
.modal-icon svg { width: 22px; height: 22px; }
.modal-kurs-info {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin-bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.modal-kurs-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--dark);
}
.modal-kurs-label {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--gray-500);
  min-width: 90px;
  font-size: 13px;
}
.modal-kurs-label svg { width: 14px; height: 14px; }
.modal-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 480px) {
  .modal-form-row { grid-template-columns: 1fr; }
  .modal-box { padding: 28px 20px 24px; }
}
#buchungs-form .form-group {
  margin-bottom: 16px;
}
#buchungs-form label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--dark);
  margin-bottom: 6px;
}
#buchungs-form input {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid var(--gray-200);
  border-radius: var(--radius-sm);
  font-size: 16px;
  font-family: inherit;
  color: var(--dark);
  background: var(--white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
#buchungs-form input:focus {
  border-color: var(--blue-600);
  box-shadow: 0 0 0 3px rgba(21,101,192,0.12);
}
.modal-error {
  background: #FFF5F5;
  border: 1px solid #FED7D7;
  color: #C53030;
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 14px;
}
.modal-submit-btn {
  width: 100%;
  padding: 14px;
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 14px;
}
.modal-submit-btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}
.modal-disclaimer {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--gray-500);
  text-align: center;
  justify-content: center;
}
.modal-disclaimer svg { width: 13px; height: 13px; flex-shrink: 0; }
.modal-success-wrap {
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 16px 0 8px;
}
.modal-success-icon {
  width: 72px;
  height: 72px;
  background: var(--green-100);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  color: var(--green-600);
  margin: 0 auto 24px;
}

/* ===== Geo Button ===== */
.search-location-wrap { position: relative; flex: 1; min-width: 0; display: flex; }
.search-location-wrap input { width: 100%; padding-right: 44px; }
.geo-btn {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; padding: 6px;
  color: var(--gray-400); border-radius: var(--radius-sm);
  transition: color var(--transition), background var(--transition);
  display: flex; align-items: center;
}
.geo-btn svg { width: 18px; height: 18px; }
.geo-btn:hover { color: var(--blue-600); background: var(--gray-100); }
.geo-btn.geo-loading { animation: spin 1s linear infinite; color: var(--blue-500); }
@keyframes spin { to { transform: translateY(-50%) rotate(360deg); } }

/* ===== Empty State ===== */
.empty-state {
  text-align: center; padding: 60px 20px;
  background: var(--gray-50); border-radius: var(--radius-lg);
  border: 2px dashed var(--gray-200);
}
.empty-state-icon {
  width: 64px; height: 64px; margin: 0 auto 16px;
  background: var(--blue-50); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--blue-400);
}
.empty-state-icon svg { width: 28px; height: 28px; }
.empty-state h3 { font-size: 20px; margin-bottom: 8px; color: var(--dark); }
.empty-state p { color: var(--gray-500); font-size: 14px; margin-bottom: 20px; max-width: 400px; margin-left: auto; margin-right: auto; }

/* ===== Review Form ===== */
.review-form-wrap { border: none; margin-top: 12px; }
.review-form-wrap summary { list-style: none; }
.review-form-wrap summary::-webkit-details-marker { display: none; }
.review-stars-select { display: flex; align-items: center; gap: 4px; }
.star-pick {
  background: none; border: none; cursor: pointer; padding: 2px;
  color: var(--gray-300); transition: color var(--transition), transform var(--transition);
}
.star-pick svg { width: 28px; height: 28px; }
.star-pick:hover, .star-pick.active { color: #F59E0B; transform: scale(1.15); }

/* ===== Review Card ===== */
.review-card { background: var(--gray-50); border-radius: var(--radius-md); padding: 16px 20px; margin-bottom: 12px; border: 1px solid var(--gray-100); }
.review-card .stars { color: #F59E0B; margin-bottom: 6px; }
.review-card p { color: var(--gray-700); font-size: 15px; line-height: 1.6; margin-bottom: 8px; }
.review-card .reviewer { font-size: 13px; color: var(--gray-400); font-weight: 500; }

/* ===== Provider Image Swiper (Karten-Ansicht) ===== */
.provider-img-wrap {
  width: 100%;
  /* 16:9 aspect ratio via padding trick – works on mobile + desktop */
  aspect-ratio: 16 / 9;
  position: relative; border-radius: 0;
  overflow: hidden;
  background: var(--gray-100);
}
.provider-img-slider {
  display: flex; width: 100%; height: 100%;
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.provider-img-slider::-webkit-scrollbar { display: none; }
.provider-img-slide {
  flex: 0 0 100%; scroll-snap-align: start;
  width: 100%; height: 100%;
  position: relative;
}
.provider-img-logo {
  width: 100%; height: 100%;
  background: var(--blue-50);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; font-weight: 800; color: var(--blue-600);
}
.provider-img-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* Echtes Logo-Bild: weißer Hintergrund, contain damit Logo vollständig sichtbar */
.provider-img-logo-img {
  object-fit: contain !important;
  background: white;
  padding: 16px 24px;
}
/* Bildlabel (z.B. "Außenansicht", "Kursraum") */
.provider-img-label {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,0.6));
  color: white; font-size: 11px; font-weight: 600;
  padding: 16px 12px 6px; pointer-events: none;
  letter-spacing: 0.3px; text-transform: uppercase;
}
.provider-img-dots {
  position: absolute; bottom: 8px; left: 0; right: 0;
  display: flex; justify-content: center; gap: 5px;
  pointer-events: none; z-index: 2;
}
.provider-img-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(255,255,255,0.6); transition: background 0.2s;
  box-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.provider-img-dot.active { background: var(--blue-600); }
@media (max-width: 640px) {
  .provider-img-wrap { aspect-ratio: 4 / 3; }
  .provider-img-logo { font-size: 22px; }
  .provider-img-label { font-size: 10px; padding: 14px 10px 5px; }
}

/* ===== Foto-Galerie (Detail-Seite) ===== */
.photo-gallery { margin-bottom: 28px; }
.photo-gallery-main {
  position: relative; width: 100%; height: 220px;
  border-radius: var(--radius-md); overflow: hidden;
  background: var(--gray-100); cursor: zoom-in;
}
.photo-gallery-slider {
  display: flex; height: 100%;
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: none; -webkit-overflow-scrolling: touch;
}
.photo-gallery-slider::-webkit-scrollbar { display: none; }
.photo-gallery-slide { flex: 0 0 100%; scroll-snap-align: start; height: 100%; }
.photo-gallery-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
.photo-gallery-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,0.85); border: none; border-radius: 50%;
  width: 34px; height: 34px; font-size: 20px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--dark); box-shadow: var(--shadow-sm);
  transition: background 0.15s;
}
.photo-gallery-nav:hover { background: white; }
.photo-gallery-nav.prev { left: 8px; }
.photo-gallery-nav.next { right: 8px; }
.photo-gallery-counter {
  position: absolute; bottom: 8px; right: 10px;
  background: rgba(0,0,0,0.5); color: white;
  font-size: 11px; padding: 2px 8px; border-radius: 99px;
}
.photo-gallery-thumbs {
  display: flex; gap: 6px; margin-top: 8px;
  overflow-x: auto; scrollbar-width: none;
}
.photo-gallery-thumbs::-webkit-scrollbar { display: none; }
.photo-gallery-thumb {
  width: 56px; min-width: 56px; height: 56px;
  border-radius: 6px; object-fit: cover; display: block;
  cursor: pointer; border: 2px solid transparent;
  opacity: 0.65; transition: opacity 0.15s, border-color 0.15s;
}
.photo-gallery-thumb.active { opacity: 1; border-color: var(--blue-500); }
@media (max-width: 640px) {
  .photo-gallery-main { height: 180px; }
}

/* ===== Lightbox ===== */
.lightbox {
  position: fixed; inset: 0; background: rgba(0,0,0,0.93);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999; animation: lbFadeIn 0.15s ease;
}
@keyframes lbFadeIn { from { opacity: 0 } to { opacity: 1 } }
.lightbox-img-wrap { max-width: 90vw; max-height: 85vh; position: relative; }
.lightbox-img-wrap img { max-width: 90vw; max-height: 85vh; border-radius: var(--radius-sm); object-fit: contain; display: block; }
.lightbox-close {
  position: absolute; top: 14px; right: 16px;
  color: white; font-size: 30px; line-height: 1;
  cursor: pointer; background: rgba(0,0,0,0.4); border: none;
  border-radius: 50%; width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.15s;
}
.lightbox-close:hover { background: rgba(0,0,0,0.7); }
.lightbox-nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  color: white; font-size: 38px; background: rgba(0,0,0,0.35); border: none;
  cursor: pointer; padding: 0 14px; height: 60px; display: flex;
  align-items: center; transition: background 0.15s;
}
.lightbox-nav:hover { background: rgba(0,0,0,0.6); }
.lightbox-nav.prev { left: 0; border-radius: 0 4px 4px 0; }
.lightbox-nav.next { right: 0; border-radius: 4px 0 0 4px; }
.lightbox-caption {
  position: absolute; bottom: 14px; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,0.7); font-size: 12px; white-space: nowrap;
}

/* ===== Redirect Overlay ===== */
#redirect-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0, 0, 0, 0.6); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity 0.3s ease;
}
#redirect-overlay.open {
  opacity: 1; pointer-events: auto;
}
.redirect-content {
  background: white; border-radius: var(--radius-lg); padding: 40px 48px;
  text-align: center; max-width: 420px; width: 90%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.redirect-spinner {
  width: 48px; height: 48px; margin: 0 auto 20px;
  border: 4px solid var(--gray-200); border-top-color: var(--blue-600);
  border-radius: 50%; animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.redirect-text {
  font-size: 18px; font-weight: 700; color: var(--dark);
  margin-bottom: 8px;
}
.redirect-sub {
  font-size: 13px; color: var(--gray-500);
}
.redirect-sub a {
  color: var(--blue-600); text-decoration: underline;
}

/* ===== Responsive Image Improvements ===== */
.photo-gallery-slide img {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: var(--radius-md);
}

/* ============================================================
   AUTH SYSTEM – Header User Menu, Modal, Favoriten
   ============================================================ */

/* ── Header Auth Slot ── */
.header-auth-slot { display:flex;align-items:center;gap:8px;margin-left:16px;flex-shrink:0; }
@media(max-width:768px){.header-auth-slot .btn{font-size:13px;padding:8px 14px;min-height:40px;}.header-auth-slot #header-register-btn{display:none;}}

/* ── User Avatar ── */
.user-menu-wrap{position:relative;}
.user-avatar-btn{position:relative;background:none;border:none;cursor:pointer;padding:0;display:flex;align-items:center;}
.user-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--blue-600),var(--blue-900));color:white;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:box-shadow var(--transition);box-shadow:0 2px 8px rgba(11,83,148,0.35);}
.user-avatar-btn:hover .user-avatar{box-shadow:0 4px 14px rgba(11,83,148,0.5);}
.user-avatar-lg{width:44px;height:44px;font-size:17px;}
.notif-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:#E11D48;color:white;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;pointer-events:none;}

/* ── User Dropdown ── */
.user-dropdown{position:absolute;top:calc(100% + 12px);right:0;min-width:240px;background:white;border-radius:var(--radius-md);border:1px solid var(--gray-200);box-shadow:var(--shadow-xl);padding:8px 0;z-index:9000;opacity:0;transform:translateY(-8px) scale(0.97);pointer-events:none;transition:opacity 0.18s ease,transform 0.18s ease;}
.user-dropdown.open{opacity:1;transform:translateY(0) scale(1);pointer-events:all;}
.user-dropdown-header{display:flex;align-items:center;gap:12px;padding:12px 16px;}
.user-dropdown-name{font-weight:700;font-size:14px;color:var(--dark);}
.user-dropdown-role{font-size:12px;color:var(--gray-400);margin-top:2px;}
.user-dropdown-divider{height:1px;background:var(--gray-100);margin:4px 0;}
.user-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:14px;color:var(--gray-600);cursor:pointer;transition:background var(--transition),color var(--transition);border:none;background:none;width:100%;text-align:left;}
.user-dropdown-item svg{width:16px;height:16px;flex-shrink:0;}
.user-dropdown-item:hover{background:var(--gray-50);color:var(--dark);}
.user-dropdown-logout{color:#E11D48 !important;}
.user-dropdown-logout:hover{background:#FFF1F2 !important;}
.user-dropdown-verify-banner{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#FFFBEB;color:#92400E;font-size:12px;font-weight:500;margin:4px 8px;border-radius:var(--radius-sm);border:1px solid #FDE68A;}

/* ── Auth Modal ── */
.auth-modal-box{max-width:420px !important;padding:40px 32px 32px !important;}
.auth-modal-brand{text-align:center;margin-bottom:24px;}
.auth-modal-logo{font-size:22px;font-weight:800;color:var(--dark);display:block;margin-bottom:6px;}
.auth-modal-logo span{color:var(--blue-600);}
.auth-modal-tagline{font-size:13px;color:var(--gray-400);}
.auth-tabs{display:flex;border-radius:var(--radius-sm);background:var(--gray-100);padding:4px;gap:4px;margin-bottom:24px;}
.auth-tab{flex:1;padding:9px 16px;border-radius:6px;font-size:14px;font-weight:600;color:var(--gray-500);border:none;background:transparent;cursor:pointer;transition:all var(--transition);}
.auth-tab.active{background:white;color:var(--blue-700);box-shadow:var(--shadow-sm);}
.google-btn-wrap{display:flex;justify-content:center;min-height:44px;margin-bottom:4px;}
.auth-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--gray-400);font-size:12px;}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--gray-200);}
.password-wrap{position:relative;display:flex;}
.password-wrap input{flex:1;padding-right:44px;}
.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--gray-400);padding:4px;line-height:0;transition:color var(--transition);}
.pw-toggle:hover{color:var(--blue-600);}
.pw-toggle svg{width:18px;height:18px;}
.auth-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
/* Auf kleinen Bildschirmen: Felder untereinander */
@media(max-width:500px){
  .auth-form-row{grid-template-columns:1fr;}
  .auth-modal-box{padding:28px 20px 24px !important;}
  .modal-overlay{padding:8px;}
}
.auth-submit-btn{width:100%;margin-top:8px;min-height:48px;font-size:15px;}
.auth-submit-btn:disabled{opacity:0.65;cursor:not-allowed;transform:none;}
.auth-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#FFF1F2;color:#9F1239;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:8px;border:1px solid #FECDD3;}
.auth-success{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--green-50);color:var(--green-600);border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:8px;border:1px solid var(--green-100);}
.auth-legal{font-size:11px;color:var(--gray-400);text-align:center;margin-top:12px;line-height:1.6;}
.auth-legal a{color:var(--blue-600);text-decoration:underline;}
.auth-switch-hint{text-align:center;font-size:13px;color:var(--gray-500);margin-top:20px;}
.auth-link-btn{color:var(--blue-600);font-weight:600;background:none;border:none;cursor:pointer;font-size:inherit;text-decoration:underline;padding:0;}

/* ── Verify Banners ── */
.verify-banner{position:fixed;top:68px;left:0;right:0;z-index:99;background:#FFFBEB;border-bottom:1px solid #FDE68A;color:#78350F;font-size:14px;font-weight:500;padding:12px 20px;display:flex;align-items:center;gap:10px;}
.verify-banner-inline{background:#FFFBEB;border:1px solid #FDE68A;color:#78350F;font-size:14px;padding:12px 20px;display:flex;align-items:center;gap:10px;}
.dashboard-success-banner{display:flex;align-items:center;gap:10px;background:var(--green-50);color:var(--green-600);border-bottom:1px solid var(--green-100);padding:14px 20px;font-size:14px;font-weight:600;}

/* ── Favoriten Herz ── */
.fav-btn{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.92);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--gray-400);box-shadow:var(--shadow-sm);transition:all 0.2s ease;z-index:5;}
.fav-btn svg{width:18px;height:18px;transition:all 0.2s ease;}
.fav-btn:hover{transform:scale(1.15);background:white;}
.fav-btn.fav-active{color:#E11D48;}
.fav-btn.fav-active svg{fill:currentColor;}
@keyframes fav-pop{0%{transform:scale(1)}50%{transform:scale(1.4)}100%{transform:scale(1)}}
.fav-btn.fav-active{animation:fav-pop 0.3s ease;}
.provider-img-wrap{position:relative;}

/* ============================================================
   DASHBOARD
   ============================================================ */
.dashboard-hero{background:linear-gradient(135deg,var(--blue-900),var(--blue-600));padding:100px 20px 40px;color:white;}
.dashboard-layout{display:grid;grid-template-columns:220px 1fr;gap:32px;align-items:start;}
@media(max-width:768px){.dashboard-layout{grid-template-columns:1fr;}}
.dashboard-nav{position:sticky;top:84px;background:white;border-radius:var(--radius-md);border:1px solid var(--gray-200);padding:8px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:2px;}
.dash-nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--gray-600);text-decoration:none;transition:all var(--transition);cursor:pointer;}
.dash-nav-item svg{width:16px;height:16px;flex-shrink:0;}
.dash-nav-item:hover{background:var(--gray-50);color:var(--dark);}
.dash-nav-item.active{background:linear-gradient(135deg,var(--blue-50),#EFF6FF);color:var(--blue-700);font-weight:700;border-left:3px solid var(--blue-600);padding-left:11px;}
.dash-nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;background:var(--gray-100);color:var(--gray-500);border-radius:50px;font-size:11px;font-weight:700;margin-left:auto;}
.dash-nav-badge-red{background:#FFF1F2;color:#E11D48;}
@media(max-width:768px){
  .dashboard-nav{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    position:static;
    overflow:visible;
    padding:4px;
    gap:2px;
  }
  .dash-nav-item{
    flex-direction:column;
    justify-content:center;
    gap:3px;
    font-size:10px;
    padding:8px 2px;
    text-align:center;
    min-width:0;
    word-break:break-word;
    line-height:1.2;
  }
  .dash-nav-item svg{width:20px;height:20px;flex-shrink:0;margin:0 auto;}
  .dash-nav-item.active{border-left:none;border-bottom:3px solid var(--blue-600);padding-left:2px;}
  .dash-nav-badge{display:none;}
}
.dash-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;}
.dash-stat-card{display:flex;align-items:center;gap:14px;background:white;border-radius:var(--radius-md);border:1px solid var(--gray-200);padding:18px 20px;box-shadow:var(--shadow-sm);}
.dash-stat-icon{width:44px;height:44px;border-radius:var(--radius-sm);background:var(--c-bg,var(--blue-50));display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--c,var(--blue-600));}
.dash-stat-icon svg{width:20px;height:20px;}
.dash-stat-value{font-size:24px;font-weight:800;color:var(--dark);line-height:1;}
.dash-stat-label{font-size:12px;color:var(--gray-500);margin-top:4px;}
.dashboard-content{display:flex;flex-direction:column;gap:20px;min-width:0;}
.dash-section-title{font-size:17px;font-weight:700;color:var(--dark);margin-bottom:16px;}
.dash-empty-card{text-align:center;padding:60px 24px;background:white;border-radius:var(--radius-md);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);}
.dash-empty-card h3{margin-bottom:8px;font-size:18px;}
.dash-empty-card p{color:var(--gray-500);font-size:14px;margin-bottom:20px;}
.dash-next-kurs{padding:24px !important;}
.buchungen-list{display:flex;flex-direction:column;gap:14px;}
.buchung-card{padding:18px 20px;}
.buchung-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px;}
.buchung-card-titel{font-weight:700;font-size:16px;margin-bottom:2px;}
.buchung-card-anbieter{font-size:13px;color:var(--gray-500);}
.buchung-card-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--gray-500);}
.favoriten-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;}
.favorit-card{padding:20px !important;}
.notif-card{display:flex;align-items:flex-start;gap:14px;background:white;border-radius:var(--radius-md);padding:16px 18px;border:1px solid var(--gray-200);border-left:4px solid var(--notif-color,var(--blue-400));box-shadow:var(--shadow-sm);position:relative;}
.notif-unread{background:var(--blue-50);}
.notif-icon{font-size:20px;flex-shrink:0;line-height:1;margin-top:2px;}
.notif-titel{font-weight:700;font-size:14px;margin-bottom:2px;}
.notif-text{font-size:13px;color:var(--gray-600);line-height:1.5;}
.notif-time{font-size:11px;color:var(--gray-400);margin-top:4px;}
.notif-dot{position:absolute;top:16px;right:16px;width:8px;height:8px;border-radius:50%;background:var(--blue-600);}
.profil-meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
@media(max-width:640px){
  .dashboard-hero{padding:88px 16px 32px;}
  .dash-stats-grid{grid-template-columns:1fr 1fr;}
  .favoriten-grid{grid-template-columns:1fr;}
  .buchung-card-header{flex-direction:column;align-items:flex-start;}
}

/* ===== Location Autocomplete ===== */
.autocomplete-wrap { position: relative; }
.autocomplete-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--white); border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm); box-shadow: var(--shadow-md);
  z-index: 250; overflow: hidden; max-height: 240px; overflow-y: auto;
}
.autocomplete-item {
  padding: 10px 14px; cursor: pointer; font-size: 14px;
  color: var(--dark); display: flex; align-items: center; gap: 8px;
  border-bottom: 1px solid var(--gray-100); transition: background 0.15s;
}
.autocomplete-item:last-child { border-bottom: none; }
.autocomplete-item:hover, .autocomplete-item.ac-active { background: var(--blue-50); }
.autocomplete-item svg { width: 14px; height: 14px; color: var(--gray-400); flex-shrink: 0; }
.autocomplete-item small { font-size: 11px; color: var(--gray-400); margin-left: auto; }

/* ===== Active Filter Chips ===== */
.filter-chips-bar { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 16px; }
.filter-chip {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--blue-100); color: var(--blue-700);
  padding: 5px 8px 5px 12px; border-radius: 999px;
  font-size: 13px; font-weight: 500; line-height: 1;
}
.filter-chip button {
  background: none; border: none; cursor: pointer;
  color: var(--blue-600); display: flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; border-radius: 50%; padding: 0;
  transition: background 0.15s;
}
.filter-chip button:hover { background: rgba(26,115,232,0.15); }
.filter-chips-clear { font-size: 12px; color: var(--gray-400); cursor: pointer; background: none; border: none; padding: 0; text-decoration: underline; }
.filter-chips-clear:hover { color: var(--gray-600); }

/* ===== Mobile Filter Bar & Drawer ===== */
.filter-mobile-bar { display: none; }
@media (max-width: 900px) {
  .filter-mobile-bar {
    display: flex; align-items: center; gap: 10px; margin-bottom: 16px;
  }
  .filter-mobile-btn {
    display: flex; align-items: center; gap: 6px;
    background: var(--white); border: 1px solid var(--gray-200);
    border-radius: var(--radius-sm); padding: 10px 16px; font-size: 14px;
    font-weight: 600; cursor: pointer; color: var(--dark);
    box-shadow: var(--shadow-sm); transition: all var(--transition);
  }
  .filter-mobile-btn:hover { border-color: var(--blue-400); }
  .filter-mobile-btn svg { width: 16px; height: 16px; }
  .filter-mobile-btn .filter-badge {
    background: var(--blue-600); color: var(--white);
    width: 18px; height: 18px; border-radius: 50%; font-size: 11px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
  }
  .filters-panel { display: none !important; }
}
.filter-drawer-overlay {
  display: none; position: fixed; inset: 0; z-index: 300;
  background: rgba(0,0,0,0.5); backdrop-filter: blur(2px);
  animation: fadeOverlay 0.25s ease;
}
.filter-drawer-overlay.open { display: block; }
@keyframes fadeOverlay { from { opacity: 0; } to { opacity: 1; } }
.filter-drawer {
  position: fixed; bottom: 0; left: 0; right: 0; max-height: 88vh;
  background: var(--white); border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  padding: 0 20px 32px; overflow-y: auto;
  transform: translateY(100%); transition: transform 0.35s cubic-bezier(.4,0,.2,1);
  z-index: 301;
}
.filter-drawer-overlay.open .filter-drawer { transform: translateY(0); }
.filter-drawer-handle { width: 40px; height: 4px; background: var(--gray-200); border-radius: 2px; margin: 12px auto 20px; }
.filter-drawer-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; padding-top: 4px;
}
.filter-drawer-header h3 { font-size: 17px; font-weight: 700; }
.filter-drawer-close {
  background: var(--gray-100); border: none; cursor: pointer;
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 16px;
}

/* ===== Price Slider ===== */
.price-slider-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.price-slider-label { font-size: 13px; font-weight: 600; color: var(--dark); }
.price-slider-val { font-size: 13px; font-weight: 700; color: var(--blue-700); }
input[type="range"].price-slider {
  width: 100%; height: 4px; accent-color: var(--blue-600);
  cursor: pointer; border-radius: 2px;
}

/* ===== Ratgeber / Blog ===== */

/* Hero */
.ratgeber-hero {
  background: linear-gradient(135deg, #1a237e 0%, #1565c0 60%, #1e88e5 100%);
  color: var(--white);
  padding: 100px 24px 64px;
  text-align: center;
}
.ratgeber-hero h1 {
  font-size: clamp(28px, 5vw, 48px);
  font-weight: 800;
  margin-bottom: 12px;
  letter-spacing: -0.5px;
}
.ratgeber-hero p {
  font-size: 17px;
  opacity: 0.85;
  max-width: 540px;
  margin: 0 auto;
}

/* Kategorie-Filter */
.blog-kat-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  padding: 28px 24px 8px;
  max-width: 900px;
  margin: 0 auto;
}
.kat-btn {
  padding: 7px 16px;
  border-radius: 999px;
  border: 1.5px solid var(--gray-200);
  background: var(--white);
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-600);
  cursor: pointer;
  transition: all var(--transition);
}
.kat-btn:hover { border-color: var(--blue-400); color: var(--blue-600); }
.kat-btn.active {
  background: var(--blue-600);
  border-color: var(--blue-600);
  color: var(--white);
}

/* Artikel-Liste */
.blog-section {
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 24px 80px;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
  background: var(--white);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--gray-100);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition);
  text-decoration: none;
}
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.blog-card-img {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--gray-100);
}
.blog-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.blog-card:hover .blog-card-img img { transform: scale(1.04); }
.blog-card-img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--blue-50) 0%, var(--blue-100) 100%);
  font-size: 40px;
}
.blog-card-body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.blog-kat-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--blue-700);
  background: var(--blue-50);
  padding: 3px 9px;
  border-radius: 999px;
  margin-bottom: 10px;
  align-self: flex-start;
}
.blog-card-body h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 8px;
  line-height: 1.35;
}
.blog-card-body p {
  font-size: 13px;
  color: var(--gray-500);
  line-height: 1.55;
  flex: 1;
  margin-bottom: 14px;
}
.blog-card-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--gray-400);
  border-top: 1px solid var(--gray-100);
  padding-top: 12px;
  margin-top: auto;
}
.blog-card-meta svg { width: 13px; height: 13px; }

/* Leere Suche */
.blog-empty {
  text-align: center;
  padding: 64px 24px;
  color: var(--gray-400);
}
.blog-empty svg { width: 48px; height: 48px; margin-bottom: 16px; opacity: 0.4; }
.blog-empty p { font-size: 16px; }

/* Lade-Skeleton */
.blog-skeleton-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 32px auto;
  padding: 0 24px;
}
@media (max-width: 900px) { .blog-skeleton-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .blog-skeleton-grid { grid-template-columns: 1fr; } }
.blog-skeleton-card {
  background: var(--white);
  border-radius: var(--radius-md);
  border: 1px solid var(--gray-100);
  overflow: hidden;
}
.skel { background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%); background-size: 200% 100%; animation: shimmer 1.4s infinite; border-radius: 4px; }
@keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.skel-img { height: 160px; border-radius: 0; }
.skel-line { height: 12px; margin: 16px 20px 8px; }
.skel-line.short { width: 55%; }
.skel-line.medium { width: 80%; }

/* ===== Artikel-Detailseite ===== */

.artikel-hero {
  background: linear-gradient(160deg, #1a237e 0%, #1565c0 100%);
  color: var(--white);
  padding: 100px 24px 56px;
}
.artikel-hero-inner {
  max-width: 800px;
  margin: 0 auto;
}
.artikel-hero .blog-kat-badge {
  background: rgba(255,255,255,0.18);
  color: var(--white);
  margin-bottom: 16px;
}
.artikel-hero h1 {
  font-size: clamp(24px, 4.5vw, 40px);
  font-weight: 800;
  margin-bottom: 16px;
  letter-spacing: -0.4px;
  line-height: 1.2;
}
.artikel-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 13px;
  opacity: 0.82;
}
.artikel-meta span {
  display: flex;
  align-items: center;
  gap: 5px;
}
.artikel-meta svg { width: 14px; height: 14px; }

/* Layout */
.artikel-layout {
  max-width: 1100px;
  margin: 0 auto;
  padding: 48px 24px 80px;
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 48px;
  align-items: start;
}
@media (max-width: 860px) {
  .artikel-layout {
    grid-template-columns: 1fr;
  }
  .artikel-sidebar { order: -1; }
}

/* Artikel-Body */
.artikel-body { min-width: 0; }
.artikel-bild-wrap {
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 32px;
  background: var(--gray-100);
}
.artikel-bild-wrap img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  display: block;
}

/* Artikel-Content (Prose) */
.artikel-content {
  font-size: 16px;
  line-height: 1.75;
  color: var(--dark);
}
.artikel-content h2 {
  font-size: 22px;
  font-weight: 700;
  color: var(--dark);
  margin: 36px 0 12px;
  padding-top: 8px;
  border-top: 2px solid var(--blue-100);
  scroll-margin-top: 80px;
}
.artikel-content h3 {
  font-size: 18px;
  font-weight: 700;
  margin: 28px 0 10px;
  color: var(--gray-700);
}
.artikel-content p { margin-bottom: 16px; }
.artikel-content ul, .artikel-content ol {
  padding-left: 20px;
  margin-bottom: 16px;
}
.artikel-content li { margin-bottom: 6px; }
.artikel-content strong { font-weight: 700; color: var(--dark); }
.artikel-content a { color: var(--blue-600); text-decoration: underline; }
.artikel-content blockquote {
  border-left: 4px solid var(--blue-400);
  background: var(--blue-50);
  padding: 12px 16px;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  margin: 20px 0;
  font-style: italic;
  color: var(--gray-600);
}

/* CTA-Box */
.artikel-cta-box {
  background: linear-gradient(135deg, var(--blue-600) 0%, #1565c0 100%);
  color: var(--white);
  border-radius: var(--radius-md);
  padding: 28px 28px 32px;
  margin-top: 40px;
  text-align: center;
}
.artikel-cta-box h3 { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.artikel-cta-box p { font-size: 14px; opacity: 0.88; margin-bottom: 20px; }
.artikel-cta-box .btn-white {
  display: inline-block;
  background: var(--white);
  color: var(--blue-700);
  font-weight: 700;
  font-size: 15px;
  padding: 12px 28px;
  border-radius: var(--radius-sm);
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: opacity var(--transition);
}
.artikel-cta-box .btn-white:hover { opacity: 0.92; }

/* Sidebar */
.artikel-sidebar { position: sticky; top: 90px; }
.artikel-sidebar-box {
  background: var(--white);
  border: 1px solid var(--gray-100);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  padding: 20px;
  margin-bottom: 20px;
}
.artikel-sidebar-box h4 {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--gray-400);
  margin-bottom: 14px;
}

/* TOC */
.artikel-toc { list-style: none; padding: 0; margin: 0; }
.artikel-toc li { border-bottom: 1px solid var(--gray-100); }
.artikel-toc li:last-child { border-bottom: none; }
.artikel-toc a {
  display: block;
  padding: 8px 4px;
  font-size: 13px;
  color: var(--gray-600);
  text-decoration: none;
  transition: color var(--transition);
  line-height: 1.4;
}
.artikel-toc a:hover { color: var(--blue-600); }

/* Related */
.related-artikel-list { display: flex; flex-direction: column; gap: 12px; }
.related-artikel-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  text-decoration: none;
  cursor: pointer;
  padding: 4px 0;
}
.related-artikel-thumb {
  width: 56px;
  height: 42px;
  border-radius: 6px;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--blue-50);
}
.related-artikel-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--dark);
  line-height: 1.4;
}
.related-artikel-kat {
  font-size: 11px;
  color: var(--gray-400);
  margin-top: 2px;
}

/* Zurück-Button */
.artikel-back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 600;
  color: var(--gray-500);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  margin-bottom: 32px;
  text-decoration: none;
  transition: color var(--transition);
}
.artikel-back-btn:hover { color: var(--blue-600); }
.artikel-back-btn svg { width: 16px; height: 16px; }

/* 404 Artikel */
.artikel-not-found {
  text-align: center;
  padding: 100px 24px;
  color: var(--gray-400);
}
.artikel-not-found h2 { font-size: 22px; font-weight: 700; margin-bottom: 12px; color: var(--dark); }

/* Admin-Badge (unveröffentlicht) */
.blog-card-draft-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  background: #f59e0b;
  color: white;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.blog-card { position: relative; }

@media (max-width: 580px) {
  .ratgeber-hero { padding: 80px 16px 48px; }
  .artikel-hero { padding: 80px 16px 44px; }
  .artikel-layout { padding: 32px 16px 60px; gap: 28px; }
  .blog-section { padding: 24px 16px 60px; }
}

/* ===== Google My Business Integration ===== */

.gmb-icon-wrap {
  width: 52px; height: 52px; border-radius: var(--radius-sm);
  background: var(--gray-50); border: 1px solid var(--gray-200);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.gmb-linked-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: #f0fdf4; color: #166534;
  border: 1px solid #bbf7d0; border-radius: 999px;
  padding: 6px 12px; font-size: 13px; font-weight: 600;
}
.gmb-rating-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: #fffbeb; color: #92400e;
  border: 1px solid #fde68a; border-radius: 999px;
  padding: 4px 10px; font-size: 13px; font-weight: 600;
}

/* Suchergebnisse */
.gmb-result-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border: 1px solid var(--gray-200);
  border-radius: var(--radius-sm); margin-bottom: 8px;
  cursor: pointer; transition: border-color var(--transition), background var(--transition);
}
.gmb-result-card:hover { border-color: var(--blue-400); background: var(--blue-50); }
.gmb-result-info { flex: 1; min-width: 0; }
.gmb-result-name { font-size: 14px; font-weight: 600; color: var(--dark); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gmb-result-addr { font-size: 12px; color: var(--gray-500); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.gmb-result-rating {
  display: flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 600; color: #92400e;
  white-space: nowrap; flex-shrink: 0;
}

/* Badge in Listing-Karte */
.gmb-card-badge {
  display: inline-flex; align-items: center; gap: 3px;
  background: #fff7ed; color: #c2410c;
  border: 1px solid #fed7aa; border-radius: 999px;
  padding: 2px 8px; font-size: 11px; font-weight: 700;
}

/* Badge in Hero der Detailseite */
.gmb-hero-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,0.15); color: white;
  border: 1px solid rgba(255,255,255,0.3); border-radius: 999px;
  padding: 4px 12px; font-size: 13px; font-weight: 600;
}

/* Admin Sync-All Button */
.gmb-sync-all-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--white); border: 1.5px solid var(--gray-200);
  color: var(--dark); border-radius: var(--radius-sm);
  padding: 9px 18px; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all var(--transition);
}
.gmb-sync-all-btn:hover { border-color: var(--blue-400); color: var(--blue-600); }

/* ===== Abo & Plans ===== */
.abo-upgrade-banner{display:flex;align-items:center;gap:16px;background:linear-gradient(135deg,#EFF6FF,#F0FDF4);border:1.5px solid var(--blue-200);border-radius:var(--radius-md);padding:16px 20px;}
.abo-upgrade-banner p{margin:0;}
.abo-plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;}
.abo-plan-card{position:relative;background:white;border:2px solid var(--gray-200);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm);transition:border-color var(--transition),box-shadow var(--transition);}
.abo-plan-card:hover{border-color:var(--plan-color,var(--blue-400));box-shadow:var(--shadow-md);}
.abo-plan-current{border-color:var(--plan-color,var(--blue-500));box-shadow:0 0 0 3px color-mix(in srgb,var(--plan-color,#2563EB) 15%,transparent);}
.abo-popular-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--plan-color,#2563EB);color:white;font-size:11px;font-weight:700;padding:3px 12px;border-radius:20px;letter-spacing:.5px;white-space:nowrap;}
.abo-plan-header{margin-bottom:16px;}
.abo-plan-name{font-size:18px;font-weight:800;color:var(--plan-color,var(--dark));}
.abo-plan-price{font-size:14px;color:var(--gray-600);margin-top:2px;}
.abo-plan-features{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:8px;}
.abo-plan-features li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--gray-700);}
.abo-plan-features li svg{flex-shrink:0;margin-top:2px;color:var(--plan-color,#2563EB);}
.abo-plan-active-badge{font-size:12px;font-weight:700;color:var(--plan-color,#2563EB);text-align:center;padding:8px;background:color-mix(in srgb,var(--plan-color,#2563EB) 8%,transparent);border-radius:6px;}
.abo-plan-btn{width:100%;}

/* ===== Analytics Chart ===== */
.stats-bar-chart{display:flex;align-items:flex-end;gap:4px;height:100px;overflow-x:auto;padding-bottom:20px;border-bottom:1px solid var(--gray-200);}
.stats-bar-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;flex:0 0 auto;min-width:24px;}
.stats-bar{width:20px;background:var(--blue-500);border-radius:3px 3px 0 0;min-height:4px;transition:opacity .2s;}
.stats-bar-wrap:hover .stats-bar{opacity:.75;}
.stats-bar-label{font-size:10px;color:var(--gray-400);white-space:nowrap;}

/* ===== Dashboard – Refined Components ===== */

/* Empty State Icon-Kreis */
.dash-empty-icon{
  width:64px; height:64px; border-radius:50%;
  background:var(--gray-50); color:var(--gray-400);
  display:inline-flex; align-items:center; justify-content:center;
  margin:0 auto 16px; border:1px solid var(--gray-100);
}
.dash-empty-icon svg{ width:28px; height:28px; }

/* Hero-Icon im Unternehmens-Dashboard */
.dash-hero-icon{
  width:36px; height:36px; border-radius:8px;
  background:rgba(255,255,255,0.15);
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.dash-hero-icon svg{ width:20px; height:20px; }

/* Inline Meta-Linie mit Icon + Text */
.meta-line{
  display:inline-flex; align-items:center; gap:6px;
  color:var(--gray-500); font-size:14px;
}
.meta-line svg{ flex-shrink:0; opacity:.7; }

/* Icon-Buttons (SVG + Text in einem Button) */
.btn-icon{ display:inline-flex; align-items:center; gap:6px; }
.btn-icon svg{ flex-shrink:0; }

/* Danger-Outline für Löschen-Buttons */
.btn-danger-outline{
  background:white; color:var(--red-500);
  border:1.5px solid var(--gray-200);
  padding:8px 12px;
}
.btn-danger-outline:hover{
  border-color:var(--red-500); background:#FEF2F2;
}

/* Subhead über Listen */
.dash-subhead{
  font-size:12px; font-weight:600; color:var(--gray-400);
  text-transform:uppercase; letter-spacing:.6px;
  margin-bottom:12px;
}
.dash-empty-line{ color:var(--gray-500); font-size:14px; }

/* Lock-Indikator in der Sidebar */
.dash-nav-lock{
  display:inline-flex; align-items:center;
  margin-left:auto; color:var(--gray-400);
}

/* ===== Kurs-Liste (Anbieter Dashboard) ===== */
.kurs-list{ display:flex; flex-direction:column; gap:10px; }
.kurs-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:14px 16px;
  border:1px solid var(--gray-100);
  transition:border-color .15s, box-shadow .15s;
}
.kurs-row:hover{ border-color:var(--blue-200); box-shadow:var(--shadow-sm); }
.kurs-row-main{ flex:1; min-width:0; }
.kurs-row-titel{ font-weight:600; font-size:15px; color:var(--dark); margin-bottom:6px; }
.kurs-row-meta{
  display:flex; flex-wrap:wrap; gap:14px;
  color:var(--gray-500); font-size:13px;
}
.kurs-row-meta span{ display:inline-flex; align-items:center; gap:5px; }
.kurs-row-meta svg{ opacity:.7; }
.kurs-row-actions{ display:flex; align-items:center; gap:8px; flex-shrink:0; }

@media (max-width: 640px){
  .kurs-row{ flex-direction:column; align-items:stretch; }
  .kurs-row-actions{ justify-content:flex-end; flex-wrap:wrap; }
}

/* ===== Kurs-Editor (Inline Form) ===== */
.kurs-editor{
  padding:0; overflow:hidden;
  border:1px solid var(--blue-200);
  box-shadow:0 4px 24px rgba(37,99,235,.08);
}
.kurs-editor-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 24px; border-bottom:1px solid var(--gray-100);
  background:linear-gradient(to bottom, #FAFBFD, white);
}
.kurs-editor-head h4{ margin:0; font-size:16px; font-weight:700; }
.kurs-editor-close{
  background:none; border:none; cursor:pointer;
  color:var(--gray-400); padding:4px; border-radius:6px;
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .15s, color .15s;
}
.kurs-editor-close:hover{ background:var(--gray-100); color:var(--gray-600); }
.kurs-form-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
  padding:24px;
}
.kurs-editor-actions{
  display:flex; gap:12px; padding:18px 24px;
  background:var(--gray-50); border-top:1px solid var(--gray-100);
}
.checkbox-line{
  display:flex; align-items:center; gap:10px;
  font-size:14px; color:var(--gray-600); cursor:pointer;
}
.checkbox-line input{ width:18px; height:18px; cursor:pointer; }

@media (max-width: 640px){
  .kurs-form-grid{ grid-template-columns:1fr; padding:16px; }
  .kurs-editor-head, .kurs-editor-actions{ padding:14px 16px; }
}

/* ===== Abo Upgrade Banner (verbessert) ===== */
.abo-upgrade-banner{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  background:linear-gradient(135deg,#EFF6FF 0%,#F5F3FF 100%);
  border:1px solid var(--blue-100);
  border-radius:var(--radius-md);
  padding:16px 20px; margin-bottom:24px;
}
.abo-upgrade-banner strong{ font-size:15px; color:var(--dark); }
.abo-upgrade-banner p{ margin:2px 0 0; font-size:13px; color:var(--gray-600); }
.abo-upgrade-icon{
  width:42px; height:42px; border-radius:10px;
  background:white; color:var(--blue-600);
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0; box-shadow:0 2px 8px rgba(37,99,235,.12);
}

/* ===== Notif-Icon ===== */
.notif-icon{
  width:36px; height:36px; border-radius:8px;
  background:color-mix(in srgb, var(--notif-color, var(--blue-600)) 12%, transparent);
  color:var(--notif-color, var(--blue-600));
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.notif-icon svg{ width:18px; height:18px; }

/* ===== Badge gray Variante ===== */
.badge-gray{ background:var(--gray-100); color:var(--gray-500); }
