/* ===== FKALENDER.DE — HAUPT-STYLESHEET ===== */
:root {
  --primary:      #00bfa6;
  --primary-dark: #007c91;
  --primary-light:#e0f7f4;
  --text:         #1a2a2a;
  --text-muted:   #5a7070;
  --bg:           #f5fafa;
  --white:        #ffffff;
  --border:       #d0e8e4;
  --radius:       10px;
  --shadow:       0 2px 12px rgba(0,191,166,0.10);
  --shadow-hover: 0 6px 24px rgba(0,124,145,0.16);
  --ferien-winter:     #5b9bd5;
  --ferien-ostern:     #e8a838;
  --ferien-pfingsten:  #6abf69;
  --ferien-sommer:     #f4693a;
  --ferien-herbst:     #cc7a00;
  --ferien-weihnachten:#9c5fbd;
  --feiertag-bg:       #fff3e0;
  --feiertag-border:   #e8a838;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  font-size: 16px;
}
a { color: var(--primary-dark); text-decoration: none; }
a:hover { color: var(--primary); text-decoration: underline; }
img { max-width: 100%; display: block; }

/* ===== HEADER / NAV ===== */
.site-header {
  background: var(--primary-dark);
  color: var(--white);
  position: sticky; top: 0; z-index: 1000;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.header-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px; height: 62px;
}
.logo { display:flex; align-items:center; gap:10px; font-size:1.35rem; font-weight:700; color:var(--white); }
.logo img { width:32px; height:32px; }
.logo span { letter-spacing:-0.5px; }
.logo:hover { text-decoration:none; color:var(--primary-light); }

/* Desktop Nav */
.main-nav { display:flex; gap:4px; align-items:center; list-style:none; }
.main-nav > li { position:relative; }
.main-nav > li > a {
  display:block; padding:8px 14px; border-radius:6px;
  color:var(--white); font-size:0.95rem; font-weight:500; white-space:nowrap;
  transition: background 0.2s;
}
.main-nav > li > a:hover, .main-nav > li.active > a {
  background: rgba(255,255,255,0.15); text-decoration:none;
}
/* Dropdown */
.has-dropdown > a::after { content:" ▾"; font-size:0.8em; }
.dropdown-menu {
  display:none; position:absolute; top:calc(100% + 4px); left:0;
  background:var(--white); border-radius:var(--radius); min-width:560px;
  box-shadow:0 8px 32px rgba(0,0,0,0.14); padding:16px;
  border-top:3px solid var(--primary);
}
.has-dropdown:hover .dropdown-menu { display:flex; gap:16px; }
.dropdown-col { flex:1; }
.dropdown-col h4 {
  font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em;
  color:var(--text-muted); margin-bottom:8px; padding-bottom:4px;
  border-bottom:1px solid var(--border);
}
.dropdown-col a {
  display:block; padding:5px 8px; border-radius:5px;
  color:var(--text); font-size:0.9rem;
}
.dropdown-col a:hover { background:var(--primary-light); color:var(--primary-dark); text-decoration:none; }

/* Burger */
.burger { display:none; background:none; border:none; cursor:pointer; padding:6px; }
.burger span { display:block; width:24px; height:2px; background:var(--white); margin:5px 0; border-radius:2px; transition:0.3s; }
.mobile-menu { display:none; }
@media(max-width:900px) {
  .main-nav { display:none; }
  .burger { display:flex; flex-direction:column; }
  .mobile-menu.open {
    display:block; position:fixed; top:62px; left:0; right:0; bottom:0;
    background:var(--primary-dark); overflow-y:auto; z-index:999; padding:16px;
  }
  .mobile-menu a {
    display:block; padding:12px 16px; color:var(--white); border-bottom:1px solid rgba(255,255,255,0.1);
    font-size:1rem;
  }
  .mobile-menu .mob-section { font-size:0.75rem; text-transform:uppercase; letter-spacing:0.1em; color:rgba(255,255,255,0.5); padding:14px 16px 4px; }
}

/* ===== HERO ===== */
.hero {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);
  color: var(--white); text-align:center; padding:56px 20px 48px;
}
.hero h1 { font-size:clamp(1.7rem,4vw,2.8rem); font-weight:800; margin-bottom:12px; }
.hero p  { font-size:1.1rem; opacity:0.9; max-width:600px; margin:0 auto 28px; }
.hero-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:8px; font-weight:600; font-size:0.95rem;
  transition:all 0.2s; cursor:pointer; border:none;
}
.btn-white  { background:var(--white); color:var(--primary-dark); }
.btn-white:hover { background:var(--primary-light); text-decoration:none; color:var(--primary-dark); }
.btn-outline { background:transparent; color:var(--white); border:2px solid rgba(255,255,255,0.7); }
.btn-outline:hover { background:rgba(255,255,255,0.15); text-decoration:none; color:var(--white); }
.btn-primary { background:var(--primary); color:var(--white); }
.btn-primary:hover { background:var(--primary-dark); text-decoration:none; color:var(--white); }

/* ===== NAECHSTE FERIEN BANNER ===== */
.next-ferien-banner {
  background:var(--white); border-bottom:3px solid var(--primary);
  padding:14px 20px;
}
.next-ferien-inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.next-ferien-label { font-size:0.82rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-muted); white-space:nowrap; }
.next-ferien-items { display:flex; gap:10px; flex-wrap:wrap; }
.nf-chip {
  display:inline-flex; align-items:center; gap:6px; padding:5px 12px;
  border-radius:20px; font-size:0.88rem; font-weight:600;
  white-space:nowrap;
}
.nf-chip.winter    { background:#e8f2fc; color:#2c5f8a; }
.nf-chip.ostern    { background:#fef3e2; color:#8a5a10; }
.nf-chip.pfingsten { background:#e8f8e8; color:#2d7a2d; }
.nf-chip.sommer    { background:#fdeee8; color:#8a2d10; }
.nf-chip.herbst    { background:#fef0d6; color:#7a4a00; }
.nf-chip.weihnachten { background:#f3eaf8; color:#5a2f80; }

/* ===== LAYOUT ===== */
.container { max-width:1200px; margin:0 auto; padding:0 20px; }
.page-grid {
  display:grid; grid-template-columns:1fr 300px; gap:32px;
  padding:36px 20px; max-width:1200px; margin:0 auto;
}
@media(max-width:900px) { .page-grid { grid-template-columns:1fr; } }
.main-content {}
.sidebar {}

/* ===== SECTION TITLES ===== */
.section-title {
  font-size:1.35rem; font-weight:700; color:var(--text);
  margin-bottom:20px; padding-bottom:10px;
  border-bottom:3px solid var(--primary);
  display:flex; align-items:center; gap:8px;
}

/* ===== BUNDESLAND GRID ===== */
.bundesland-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:14px; margin:0 0 32px;
}
.bundesland-card {
  display:flex; flex-direction:column; align-items:center; gap:8px;
  padding:16px 10px; background:var(--white); border-radius:var(--radius);
  border:2px solid var(--border); text-align:center;
  transition:all 0.2s; text-decoration:none; color:var(--text);
}
.bundesland-card img { width:48px; height:32px; object-fit:contain; border-radius:3px; }
.bundesland-card span { font-size:0.82rem; font-weight:600; line-height:1.2; }
.bundesland-card:hover {
  border-color:var(--primary); box-shadow:var(--shadow-hover);
  transform:translateY(-2px); text-decoration:none; color:var(--primary-dark);
}

/* ===== JAHRES-TABS ===== */
.year-tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:24px; }
.year-tab {
  padding:8px 20px; border-radius:20px; font-weight:600; font-size:0.9rem;
  border:2px solid var(--border); background:var(--white); color:var(--text-muted);
  cursor:pointer; text-decoration:none; transition:all 0.2s;
}
.year-tab:hover, .year-tab.active {
  background:var(--primary); border-color:var(--primary); color:var(--white);
  text-decoration:none;
}

/* ===== KALENDER-SEITE ===== */
.page-hero {
  background:linear-gradient(135deg,var(--primary-dark),var(--primary));
  color:var(--white); padding:40px 20px;
}
.page-hero-inner { max-width:1200px; margin:0 auto; }
.page-hero .bundesland-flag { width:56px; height:37px; object-fit:contain; border-radius:4px; box-shadow:0 2px 8px rgba(0,0,0,0.2); float:left; margin-right:16px; }
.page-hero h1 { font-size:clamp(1.5rem,3.5vw,2.3rem); font-weight:800; }
.page-hero .breadcrumb { font-size:0.88rem; opacity:0.8; margin-bottom:8px; }
.page-hero .breadcrumb a { color:rgba(255,255,255,0.8); }
.page-hero .breadcrumb a:hover { color:var(--white); }

/* Jahr-Bundesland Switcher */
.switcher-bar {
  background:var(--white); border-bottom:1px solid var(--border);
  padding:14px 20px;
}
.switcher-inner { max-width:1200px; margin:0 auto; display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.switcher-label { font-size:0.85rem; color:var(--text-muted); font-weight:600; }
.switcher-select {
  padding:8px 14px; border:2px solid var(--border); border-radius:8px;
  background:var(--white); color:var(--text); font-size:0.9rem; cursor:pointer;
}
.switcher-select:focus { outline:none; border-color:var(--primary); }
.switcher-btn {
  padding:8px 20px; background:var(--primary); color:var(--white);
  border:none; border-radius:8px; cursor:pointer; font-weight:600; font-size:0.9rem;
  transition:background 0.2s;
}
.switcher-btn:hover { background:var(--primary-dark); }

/* Ferien-Übersicht Box */
.ferien-box {
  background:var(--white); border-radius:var(--radius); border:1px solid var(--border);
  padding:24px; margin-bottom:24px; box-shadow:var(--shadow);
}
.ferien-box h2 { font-size:1.1rem; margin-bottom:16px; color:var(--text); }
.ferien-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.ferien-item {
  display:flex; align-items:flex-start; gap:12px; padding:12px 14px;
  border-radius:8px; border-left:4px solid;
}
.ferien-item.winter    { background:#e8f2fc; border-color:var(--ferien-winter); }
.ferien-item.ostern    { background:#fef3e2; border-color:var(--ferien-ostern); }
.ferien-item.pfingsten { background:#e8f8e8; border-color:var(--ferien-pfingsten); }
.ferien-item.sommer    { background:#fdeee8; border-color:var(--ferien-sommer); }
.ferien-item.herbst    { background:#fef0d6; border-color:var(--ferien-herbst); }
.ferien-item.weihnachten { background:#f3eaf8; border-color:var(--ferien-weihnachten); }
.ferien-item-icon { font-size:1.3rem; line-height:1; }
.ferien-item-body {}
.ferien-item-name { font-weight:700; font-size:0.95rem; }
.ferien-item-date { font-size:0.9rem; color:var(--text-muted); margin-top:2px; }
.ferien-item-days { font-size:0.8rem; font-weight:600; margin-top:3px; }
.ferien-item.winter .ferien-item-days    { color:#2c5f8a; }
.ferien-item.ostern .ferien-item-days    { color:#8a5a10; }
.ferien-item.pfingsten .ferien-item-days { color:#2d7a2d; }
.ferien-item.sommer .ferien-item-days    { color:#8a2d10; }
.ferien-item.herbst .ferien-item-days    { color:#7a4a00; }
.ferien-item.weihnachten .ferien-item-days { color:#5a2f80; }

/* Feiertage */
.feiertage-box {
  background:var(--white); border-radius:var(--radius); border:1px solid var(--border);
  padding:24px; margin-bottom:24px; box-shadow:var(--shadow);
}
.feiertag-item {
  display:flex; justify-content:space-between; align-items:center;
  padding:9px 12px; border-radius:6px; margin-bottom:6px;
}
.feiertag-item:nth-child(odd) { background:var(--bg); }
.feiertag-item.regional { border-left:3px solid var(--ferien-ostern); }
.feiertag-datum { font-size:0.88rem; color:var(--text-muted); white-space:nowrap; }
.feiertag-name { font-weight:600; font-size:0.92rem; }
.feiertag-badge {
  font-size:0.7rem; padding:2px 7px; border-radius:10px; font-weight:600; white-space:nowrap;
}
.badge-bund { background:#e0f7f4; color:var(--primary-dark); }
.badge-regional { background:#fef3e2; color:#8a5a10; }

/* Download-Box */
.download-box {
  background:var(--white); border-radius:var(--radius); border:1px solid var(--border);
  padding:24px; margin-bottom:24px; box-shadow:var(--shadow);
}
.download-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:12px; margin-top:12px; }
.dl-btn {
  display:flex; flex-direction:column; align-items:center; gap:6px; padding:14px 10px;
  border:2px solid var(--border); border-radius:var(--radius); text-align:center;
  transition:all 0.2s; text-decoration:none; color:var(--text);
}
.dl-btn:hover { border-color:var(--primary); background:var(--primary-light); text-decoration:none; }
.dl-btn-icon { font-size:1.6rem; }
.dl-btn-label { font-size:0.82rem; font-weight:700; }
.dl-btn-sub { font-size:0.75rem; color:var(--text-muted); }

/* ===== KALENDER GRID ===== */
.calendar-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
@media(max-width:1024px){ .calendar-grid { grid-template-columns:repeat(2,1fr); gap:16px; } }
@media(max-width:600px) { .calendar-grid { grid-template-columns:repeat(2,1fr); gap:8px; } }

/* Monats-Karte — luftiger */
.month-card {
  background:#ffffff;
  border-radius:14px;
  padding:18px 14px 14px;
  box-shadow:0 2px 8px rgba(0,0,0,0.07);
  border:1px solid #e5e7eb;
}
.month-header {
  text-align:center;
  margin-bottom:14px;
  padding-bottom:10px;
  border-bottom:2px solid var(--primary);
}
.month-name-title {
  color:var(--primary-dark);
  font-size:1.05rem;
  font-weight:700;
  letter-spacing:0.01em;
}

/* Kalender-Tabelle */
.cal-table { width:100%; border-collapse:separate; border-spacing:1px; }
.cal-table thead th {
  padding:7px 3px;
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  color:#6b7280;
  text-align:center;
  letter-spacing:0.03em;
}
.cal-kw-head {
  background:#f3f4f6;
  color:#9ca3af;
  font-size:0.65rem;
  border-radius:4px;
}
.cal-we-head { color:var(--primary-dark); }

.cal-table tbody td {
  padding:8px 3px;
  text-align:center;
  font-size:0.875rem;
  border-radius:5px;
  position:relative;
  cursor:default;
  min-height:34px;
  height:34px;
  line-height:1.1;
}

/* KW-Spalte */
.cal-kw {
  background:#f3f4f6;
  color:#9ca3af;
  font-size:0.65rem;
  font-weight:700;
  text-align:center;
  border-radius:4px;
  white-space:nowrap;
  padding:4px 3px;
}
.cal-empty { background:transparent; }

/* Wochenende */
.cal-we {
  background:#f3f4f6;
  color:#374151;
  font-weight:600;
}

/* Ferien — einheitliche grüne Farbe für alle Ferientypen (wie euferien.de) */
.ferien-winter,
.ferien-ostern,
.ferien-pfingsten,
.ferien-sommer,
.ferien-herbst,
.ferien-weihnachten {
  background:#d1fae5; color:#065f46; font-weight:600; cursor:pointer;
}
/* Ferien + Wochenende: etwas dunkler grün */
.ferien-winter.cal-we,
.ferien-ostern.cal-we,
.ferien-pfingsten.cal-we,
.ferien-sommer.cal-we,
.ferien-herbst.cal-we,
.ferien-weihnachten.cal-we {
  background:#a7f3d0; color:#064e3b;
}

/* Feiertag auf weißem Tag */
.cal-feiertag-cell { cursor:help; }
.cal-table tbody td.cal-feiertag-cell:not([class*=ferien-]) {
  background:transparent;
}
/* Feiertag in Ferienzeit: grüner Hintergrund behalten */
.cal-table tbody td.ferien-winter.cal-feiertag-cell,
.cal-table tbody td.ferien-ostern.cal-feiertag-cell,
.cal-table tbody td.ferien-pfingsten.cal-feiertag-cell,
.cal-table tbody td.ferien-sommer.cal-feiertag-cell,
.cal-table tbody td.ferien-herbst.cal-feiertag-cell,
.cal-table tbody td.ferien-weihnachten.cal-feiertag-cell { background:#d1fae5; }
/* Feiertag-Span: rote Zahl */
.cal-feiertag {
  color:#dc2626;
  font-weight:700;
  cursor:help;
  display:inline-block;
  border-bottom:1px dotted #dc2626;
}

/* Heute */
.cal-today {
  background:#fff !important;
  outline:2px solid #ef4444;
  outline-offset:-2px;
  border-radius:6px !important;
  font-weight:700;
}

/* ── TOOLTIP POPUP (wie euferien.de) ── */
/* Wrapper um jeden td-Inhalt (wird per JS gesetzt) */
.cal-tooltip-wrap {
  position:relative;
  display:inline-block;
  width:100%;
  height:100%;
}
/* Das Popup selbst */
.cal-popup {
  display:none;
  position:absolute;
  z-index:9999;
  bottom:calc(100% + 6px);
  left:50%;
  transform:translateX(-50%);
  background:#1f2937;
  color:#fff;
  border-radius:10px;
  padding:12px 16px;
  min-width:200px;
  max-width:260px;
  box-shadow:0 8px 24px rgba(0,0,0,0.25);
  text-align:left;
  white-space:normal;
  pointer-events:none;
  font-size:0.875rem;
  line-height:1.5;
}
/* Pfeil nach unten */
.cal-popup::after {
  content:'';
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  border:6px solid transparent;
  border-top-color:#1f2937;
}
/* Popup sichtbar bei Hover auf TD */
.cal-table tbody td:hover .cal-popup,
.cal-table tbody td:focus .cal-popup {
  display:block;
}
/* Popup nach rechts wenn am linken Rand */
.cal-table tbody td:first-child .cal-popup,
.cal-table tbody td:nth-child(2) .cal-popup {
  left:0;
  transform:none;
}
/* Popup nach links wenn am rechten Rand */
.cal-table tbody td:last-child .cal-popup,
.cal-table tbody td:nth-last-child(2) .cal-popup {
  left:auto;
  right:0;
  transform:none;
}
.cal-popup-title {
  font-weight:700;
  font-size:0.9rem;
  color:#10b981;
  margin-bottom:4px;
}
.cal-popup-date {
  font-size:0.8rem;
  color:#d1d5db;
  margin-bottom:3px;
}
.cal-popup-extra {
  font-size:0.8rem;
  color:#d1d5db;
  margin-bottom:2px;
}
.cal-popup-feiertag {
  display:flex;
  align-items:center;
  gap:5px;
  margin-top:6px;
  padding-top:6px;
  border-top:1px solid rgba(255,255,255,0.15);
  font-size:0.82rem;
  color:#fbbf24;
  font-weight:600;
}
.cal-popup-divider {
  border:none;
  border-top:1px solid rgba(255,255,255,0.15);
  margin:6px 0;
}

/* Hover ohne Popup (leerer Tag) */
.cal-table tbody td:hover {
  filter:brightness(0.95);
}

/* Mondphasen im Kalender (nur Mondkalender-Seite) */
.cal-mond {
  display:block;
  font-size:0.7rem;
  line-height:1;
  margin-top:1px;
  opacity:0.85;
}

/* Legende */
.legende {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:16px 0 24px;
  align-items:center;
  padding:12px 16px;
  background:#f9fafb;
  border-radius:10px;
  border:1px solid #e5e7eb;
}
.legende-item {
  display:flex;
  align-items:center;
  gap:6px;
  font-size:0.82rem;
  color:#374151;
}
.legende-dot {
  width:16px;
  height:16px;
  border-radius:4px;
  flex-shrink:0;
  border:1px solid rgba(0,0,0,0.1);
}
.legende-dot.ferien-winter,
.legende-dot.ferien-ostern,
.legende-dot.ferien-pfingsten,
.legende-dot.ferien-sommer,
.legende-dot.ferien-herbst,
.legende-dot.ferien-weihnachten { background:#d1fae5; border-color:#10b981; }
.legende-dot.wochenende { background:#f3f4f6; }
.legende-dot.heute    { background:#fff; outline:2px solid #ef4444; outline-offset:1px; }
.legende-feiertag     { color:#dc2626; font-weight:700; border-bottom:1px dotted #dc2626; }

/* Mobile Kalender */
@media(max-width:600px) {
  .month-card { padding:8px 6px; }
  .month-name-title { font-size:0.88rem; }
  .cal-table thead th { font-size:0.6rem; padding:4px 1px; }
  .cal-table tbody td { font-size:0.75rem; padding:5px 1px; height:28px; min-height:28px; }
  .cal-kw { font-size:0.55rem; }
  /* Popup auf Mobile nach rechts/links aufklappen statt oben */
  .cal-popup {
    bottom:auto;
    top:calc(100% + 4px);
    min-width:180px;
    font-size:0.8rem;
    padding:8px 12px;
  }
  .cal-popup::after {
    bottom:100%;
    top:auto;
    border-top-color:transparent;
    border-bottom-color:#1f2937;
  }
}

/* ===== ADS ===== */
.ad-slot {
  background: transparent; border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-muted); font-size:0.82rem; text-align:center;
  padding:8px; margin-bottom:20px;
}
.ad-slot-banner {
  width: 100%;
  min-height: 90px;
  display: block;
  overflow: hidden;
}

.adsbygoogle {
  display: block !important;
  width: 100% !important;
  min-height: 90px;
}

.ad-slot-rectangle { width:300px; height:250px; }
.ad-slot-sidebar { width:100%; height:250px; }

/* ===== SIDEBAR ===== */
.sidebar-widget {
  background:var(--white); border-radius:var(--radius); border:1px solid var(--border);
  padding:20px; margin-bottom:20px; box-shadow:var(--shadow);
}
.sidebar-widget h3 { font-size:1rem; margin-bottom:14px; border-bottom:2px solid var(--primary); padding-bottom:8px; }
.sidebar-bl-list { list-style:none; display:flex; flex-direction:column; gap:4px; }
.sidebar-bl-list a {
  display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:6px;
  font-size:0.88rem; color:var(--text);
}
.sidebar-bl-list a img { width:28px; height:18px; object-fit:contain; }
.sidebar-bl-list a:hover { background:var(--primary-light); text-decoration:none; color:var(--primary-dark); }

/* ===== CONTENT TEXT ===== */
.content-text {
  background:var(--white); border-radius:var(--radius); border:1px solid var(--border);
  padding:28px; margin-bottom:24px; box-shadow:var(--shadow);
  line-height:1.75;
}
.content-text h2 { font-size:1.2rem; color:var(--primary-dark); margin:20px 0 10px; }
.content-text h2:first-child { margin-top:0; }
.content-text p { margin-bottom:12px; color:#2a3a3a; }
.content-text ul { margin:0 0 12px 20px; }
.content-text li { margin-bottom:4px; }

/* ===== FAQ ===== */
.faq-section { margin-bottom:24px; }
.faq-item {
  background:var(--white); border:1px solid var(--border); border-radius:var(--radius);
  margin-bottom:8px; overflow:hidden;
}
.faq-q {
  padding:15px 18px; font-weight:600; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  user-select:none; transition:background 0.2s;
}
.faq-q:hover { background:var(--primary-light); }
.faq-q::after { content:"＋"; font-size:1.1rem; color:var(--primary); flex-shrink:0; }
.faq-item.open .faq-q { background:var(--primary-light); color:var(--primary-dark); }
.faq-item.open .faq-q::after { content:"－"; }
.faq-a { display:none; padding:14px 18px; border-top:1px solid var(--border); color:#2a3a3a; }
.faq-item.open .faq-a { display:block; }

/* ===== KOMMENTARE ===== */
.comments-section {
  background:var(--white); border-radius:var(--radius); border:1px solid var(--border);
  padding:28px; margin-bottom:24px; box-shadow:var(--shadow);
}
.comments-section h2 { font-size:1.15rem; margin-bottom:20px; }
.comment-form { margin-bottom:28px; }
.comment-form .form-row { display:grid; gap:12px; margin-bottom:12px; }
.comment-form input, .comment-form textarea {
  width:100%; padding:11px 14px; border:2px solid var(--border); border-radius:8px;
  font-size:0.95rem; font-family:inherit; color:var(--text); background:var(--bg);
  transition:border-color 0.2s;
}
.comment-form input:focus, .comment-form textarea:focus {
  outline:none; border-color:var(--primary);
}
.comment-form textarea { min-height:100px; resize:vertical; }
.comment-form .char-count { font-size:0.78rem; color:var(--text-muted); text-align:right; margin-top:3px; }
.comment-form .submit-row { display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.comment-form .privacy-note { font-size:0.8rem; color:var(--text-muted); }
.btn-submit {
  padding:11px 28px; background:var(--primary); color:var(--white);
  border:none; border-radius:8px; font-weight:700; font-size:0.95rem;
  cursor:pointer; transition:background 0.2s;
}
.btn-submit:hover { background:var(--primary-dark); }
.comment-list { display:flex; flex-direction:column; gap:14px; }
.comment-card {
  background:var(--bg); border-radius:8px; border:1px solid var(--border);
  padding:14px 16px;
}
.comment-header { display:flex; justify-content:space-between; margin-bottom:6px; align-items:center; flex-wrap:wrap; gap:4px; }
.comment-author { font-weight:700; font-size:0.92rem; color:var(--primary-dark); }
.comment-date { font-size:0.78rem; color:var(--text-muted); }
.comment-body { font-size:0.92rem; line-height:1.6; }
.comment-reply { margin-top:10px; padding:10px 12px; background:var(--primary-light); border-radius:6px; border-left:3px solid var(--primary); }
.comment-reply-label { font-size:0.78rem; font-weight:700; color:var(--primary-dark); margin-bottom:4px; }
.comment-reply p { font-size:0.88rem; margin:0; }
.comment-empty { color:var(--text-muted); font-size:0.92rem; text-align:center; padding:20px 0; }

/* ===== FESTTAGE ===== */
.festtag-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:10px; margin-bottom:24px; }
.festtag-card {
  background:var(--white); border:1px solid var(--border); border-radius:var(--radius);
  padding:12px 14px; display:flex; flex-direction:column; gap:2px;
}
.festtag-date { font-size:0.78rem; color:var(--text-muted); font-weight:600; }
.festtag-name { font-size:0.9rem; font-weight:700; color:var(--text); }

/* ===== HOMEPAGE FEATURES ===== */
.features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:18px; margin:24px 0; }
.feature-card {
  background:var(--white); border:1px solid var(--border); border-radius:var(--radius);
  padding:22px 18px; text-align:center; box-shadow:var(--shadow);
  transition:all 0.2s; text-decoration:none; color:var(--text);
}
.feature-card:hover { border-color:var(--primary); box-shadow:var(--shadow-hover); transform:translateY(-2px); text-decoration:none; }
.feature-icon { font-size:2.2rem; margin-bottom:10px; }
.feature-title { font-weight:700; font-size:0.98rem; margin-bottom:6px; color:var(--text); }
.feature-desc { font-size:0.84rem; color:var(--text-muted); }

/* ===== FOOTER ===== */
.site-footer {
  background:var(--primary-dark); color:rgba(255,255,255,0.85);
  margin-top:48px; padding:40px 20px 20px;
}
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; margin-bottom:32px; }
@media(max-width:700px) { .footer-grid { grid-template-columns:1fr 1fr; gap:20px; } }
@media(max-width:420px) { .footer-grid { grid-template-columns:1fr; } }
.footer-brand .logo { margin-bottom:10px; }
.footer-brand p { font-size:0.88rem; opacity:0.7; max-width:240px; }
.footer-col h4 { font-size:0.8rem; text-transform:uppercase; letter-spacing:0.1em; margin-bottom:12px; opacity:0.6; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:6px; }
.footer-col a { color:rgba(255,255,255,0.75); font-size:0.9rem; }
.footer-col a:hover { color:var(--white); text-decoration:none; }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.15);
  padding-top:18px; display:flex; justify-content:space-between;
  font-size:0.82rem; opacity:0.6; flex-wrap:wrap; gap:8px;
}

/* ===== UTILS ===== */
.mt-0 {margin-top:0} .mb-0{margin-bottom:0}
.text-center{text-align:center}
.tag {display:inline-block;padding:2px 8px;border-radius:10px;font-size:0.75rem;font-weight:600;}
.tag-green{background:#e8f8e8;color:#2d7a2d;}
.tag-orange{background:#fef3e2;color:#8a5a10;}
.notice {
  background:var(--primary-light); border:1px solid var(--primary); border-radius:8px;
  padding:12px 16px; font-size:0.9rem; color:var(--primary-dark); margin-bottom:16px;
}
@media(max-width:600px) {
  .page-grid { padding:20px 14px; }
  .ferien-box, .feiertage-box, .download-box, .content-text, .comments-section { padding:16px; }
  .calendar-grid { grid-template-columns:1fr; }
}

/* ===== FERIENDICHTE FARBEN ===== */
.dichte-low  { background:#d1fae5; color:#065f46; font-weight:600; cursor:help; }
.dichte-mid  { background:#fef08a; color:#713f12; font-weight:600; cursor:help; }
.dichte-high { background:#fed7aa; color:#9a3412; font-weight:600; cursor:help; }
.dichte-peak { background:#fca5a5; color:#7f1d1d; font-weight:700; cursor:help; }
.dichte-low:hover, .dichte-mid:hover, .dichte-high:hover, .dichte-peak:hover {
  filter:brightness(0.95);
}

/* ===== MONDPHASEN IM KALENDER ===== */
.cal-mond { display:block; font-size:0.7rem; line-height:1; margin-top:1px; }
.mond-phase-neumond        { }
.mond-phase-vollmond       { }
.mond-phase-erstes-viertel { }
.mond-phase-letztes-viertel{ }

/* ===== MOBILE RESPONSIVE TABELLEN ===== */
/* Alle Tabellen auf Mobile horizontal scrollbar */
.table-scroll {
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  margin-bottom:20px;
}
.table-scroll table {
  min-width:600px; /* zwingt scroll statt quetschen */
  width:100%;
}

/* Jahres-Vergleichstabelle responsiv */
.schulferien-table-wrap {
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  margin-bottom:24px;
}
.schulferien-table-wrap table { min-width:700px; }

/* Ferien-Box Liste — immer gut lesbar */
.ferien-list { list-style:none; display:flex; flex-direction:column; gap:8px; }
.ferien-item {
  display:flex; align-items:flex-start; gap:10px; padding:11px 14px;
  border-radius:8px; border-left:4px solid;
}
.ferien-item.winter    { background:#e8f2fc; border-color:#5b9bd5; }
.ferien-item.ostern    { background:#fef3e2; border-color:#e8a838; }
.ferien-item.pfingsten { background:#e8f8e8; border-color:#6abf69; }
.ferien-item.sommer    { background:#fdeee8; border-color:#f4693a; }
.ferien-item.herbst    { background:#fef0d6; border-color:#cc7a00; }
.ferien-item.weihnachten { background:#f3eaf8; border-color:#9c5fbd; }
.ferien-item-icon { font-size:1.2rem; line-height:1; flex-shrink:0; margin-top:2px; }
.ferien-item-name { font-weight:700; font-size:0.9rem; }
.ferien-item-date { font-size:0.88rem; color:var(--text-muted); margin-top:2px; }
.ferien-item-days { font-size:0.78rem; font-weight:600; margin-top:2px; color:var(--primary-dark); }

/* Feiertage Tabelle */
.feiertag-item {
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 12px; border-radius:6px; margin-bottom:5px;
  flex-wrap:wrap; gap:6px;
}
.feiertag-item:nth-child(odd) { background:var(--bg); }
.feiertag-datum { font-size:0.85rem; color:var(--text-muted); white-space:nowrap; }
.feiertag-name { font-weight:600; font-size:0.9rem; flex:1; padding:0 8px; }
.feiertag-badge { font-size:0.7rem; padding:2px 7px; border-radius:10px; font-weight:600; white-space:nowrap; }
.badge-bund     { background:#e0f7f4; color:var(--primary-dark); }
.badge-regional { background:#fef3e2; color:#8a5a10; }

/* Page-Grid auf Mobile */
@media(max-width:768px) {
  .page-grid { grid-template-columns:1fr; padding:16px; }
  .sidebar { display:none; } /* Sidebar auf Mobile ausblenden */
  .ferien-item { padding:9px 10px; }
  .feiertag-name { font-size:0.85rem; }
  .download-grid { grid-template-columns:repeat(2,1fr); }
}

/* Switcher-Bar responsiv */
@media(max-width:600px) {
  .switcher-inner { flex-direction:column; align-items:stretch; gap:8px; }
  .switcher-select { width:100%; }
  .switcher-btn { width:100%; }
  .year-tabs { gap:6px; }
  .year-tab { padding:6px 12px; font-size:0.82rem; }
}

/* Content-Text responsiv */
@media(max-width:600px) {
  .content-text { padding:16px; }
  .ferien-box, .feiertage-box, .download-box { padding:14px; }
  .download-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
  .dl-btn { padding:10px 6px; }
  .dl-btn-label { font-size:0.75rem; }
}

/* ===== LOGO IM HEADER ===== */
.logo-img {
  width:32px;
  height:32px;
  object-fit:contain;
  border-radius:6px;
}

/* ===== MOBILE FIXES v7 ===== */

/* Hero auf Mobile */
@media(max-width:600px) {
  .hero { padding:32px 16px 28px; }
  .hero h1 { font-size:1.5rem; }
  .hero p  { font-size:0.95rem; }
  .hero-btns { flex-direction:column; align-items:center; }
  .btn { width:100%; max-width:280px; justify-content:center; }
}

/* Page-Hero auf Mobile */
@media(max-width:600px) {
  .page-hero { padding:24px 16px; }
  .page-hero h1 { font-size:1.3rem; }
  .page-hero .breadcrumb { font-size:0.78rem; }
  .bundesland-flag { width:40px !important; height:27px !important; }
}

/* Bundesland-Grid auf Mobile */
@media(max-width:600px) {
  .bundesland-grid { grid-template-columns:repeat(3,1fr); gap:8px; }
  .bundesland-card { padding:10px 6px; }
  .bundesland-card img { width:36px; height:24px; }
  .bundesland-card span { font-size:0.72rem; }
}

/* Year-Tabs auf Mobile scrollen horizontal */
.year-tabs {
  display:flex; gap:6px; flex-wrap:nowrap;
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  padding-bottom:4px; scrollbar-width:none;
}
.year-tabs::-webkit-scrollbar { display:none; }
.year-tab {
  flex-shrink:0;
  padding:7px 14px; border-radius:20px; font-weight:600; font-size:0.88rem;
  border:2px solid var(--border); background:var(--white); color:var(--text-muted);
  cursor:pointer; text-decoration:none; transition:all 0.2s; white-space:nowrap;
}
.year-tab:hover, .year-tab.active {
  background:var(--primary); border-color:var(--primary); color:var(--white); text-decoration:none;
}

/* Ferien-Box auf Mobile */
@media(max-width:480px) {
  .ferien-item { padding:9px 10px; gap:8px; }
  .ferien-item-icon { font-size:1rem; }
  .ferien-item-name { font-size:0.85rem; }
  .ferien-item-date { font-size:0.82rem; }
}

/* Features-Grid auf Mobile */
@media(max-width:480px) {
  .features-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .feature-card { padding:14px 10px; }
  .feature-icon { font-size:1.6rem; margin-bottom:6px; }
  .feature-title { font-size:0.85rem; }
  .feature-desc { font-size:0.75rem; }
}

/* Section-Title auf Mobile */
@media(max-width:480px) {
  .section-title { font-size:1.1rem; }
}

/* Feiertage Box auf Mobile */
@media(max-width:480px) {
  .feiertag-item { padding:7px 8px; }
  .feiertag-name { font-size:0.82rem; }
  .feiertag-datum { font-size:0.78rem; }
}

/* Download-Box auf Mobile */
@media(max-width:400px) {
  .download-grid { grid-template-columns:repeat(2,1fr); gap:6px; }
  .dl-btn-label { font-size:0.72rem; }
  .dl-btn-sub { display:none; }
}

/* Legende auf Mobile */
@media(max-width:480px) {
  .legende { gap:8px; padding:8px 10px; }
  .legende-item { font-size:0.75rem; }
  .legende-dot { width:12px; height:12px; }
}

/* Kommentare auf Mobile */
@media(max-width:480px) {
  .comments-section { padding:14px; }
  .comment-form input, .comment-form textarea { font-size:0.9rem; }
}

/* Sidebar-Widget auf Mobile ausblenden (bereits per page-grid) */
@media(max-width:768px) {
  .ad-slot-sidebar { display:none; }
}

/* Popup auf Mobile — erscheint mittig-oben */
@media(max-width:600px) {
  .cal-popup {
    position:fixed !important;
    bottom:auto !important;
    top:50% !important;
    left:50% !important;
    transform:translate(-50%,-50%) !important;
    right:auto !important;
    min-width:240px;
    max-width:280px;
    z-index:99999;
  }
  .cal-popup::after { display:none; }
}

/* ===== DOWNLOAD PREVIEW CARDS ===== */
.dl-preview-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-bottom:16px;
}
@media(max-width:700px) { .dl-preview-grid { grid-template-columns:1fr; gap:12px; } }

.dl-preview-card {
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  background:var(--white);
  box-shadow:var(--shadow);
  transition:box-shadow 0.2s;
}
.dl-preview-card:hover { box-shadow:var(--shadow-hover); }

.dl-preview-thumb {
  position:relative;
  cursor:pointer;
  overflow:hidden;
  background:#f0f0f0;
  aspect-ratio:3/4; /* Hochformat-ähnlich als Standard */
  display:flex;
  align-items:center;
  justify-content:center;
}
.dl-preview-thumb img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 0.3s;
  display:block;
}
.dl-preview-thumb:hover img { transform:scale(1.04); }

.dl-preview-overlay {
  position:absolute;
  bottom:0; left:0; right:0;
  background:rgba(0,0,0,0.55);
  color:#fff;
  text-align:center;
  padding:8px;
  font-size:0.85rem;
  font-weight:600;
  opacity:0;
  transition:opacity 0.2s;
}
.dl-preview-thumb:hover .dl-preview-overlay { opacity:1; }

.dl-no-preview {
  color:var(--text-muted);
  font-size:0.82rem;
  text-align:center;
  padding:20px;
}

.dl-preview-info {
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.dl-preview-label { font-weight:700; font-size:0.92rem; }
.dl-preview-sub   { font-size:0.8rem; color:var(--text-muted); }

.dl-preview-btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 14px;
  background:var(--primary);
  color:#fff;
  border-radius:7px;
  font-weight:600;
  font-size:0.85rem;
  text-decoration:none;
  transition:background 0.2s;
  border:none;
  cursor:pointer;
  width:100%;
  text-align:center;
}
.dl-preview-btn:hover { background:var(--primary-dark); color:#fff; text-decoration:none; }

/* ICS Zeile */
.dl-ics-row {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 16px;
  background:var(--bg);
  border-radius:var(--radius);
  border:1px solid var(--border);
  flex-wrap:wrap;
}
.dl-ics-info { display:flex; align-items:center; gap:12px; flex:1; }
.dl-ics-icon { font-size:1.8rem; flex-shrink:0; }
.dl-ics-label { font-weight:700; font-size:0.92rem; }
.dl-ics-sub   { font-size:0.8rem; color:var(--text-muted); margin-top:2px; }
.dl-ics-row .dl-preview-btn { width:auto; white-space:nowrap; flex-shrink:0; }

/* ===== LIGHTBOX ===== */
.dl-lightbox {
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.88);
  z-index:99999;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.dl-lightbox-inner {
  background:var(--white);
  border-radius:14px;
  padding:24px;
  max-width:90vw;
  max-height:90vh;
  overflow-y:auto;
  text-align:center;
  position:relative;
}
.dl-lightbox-close {
  position:absolute;
  top:12px; right:14px;
  background:none; border:none;
  font-size:1.4rem; cursor:pointer;
  color:var(--text-muted); font-weight:700;
  line-height:1;
}
.dl-lightbox-close:hover { color:var(--text); }
.dl-lightbox-title {
  font-weight:700; font-size:1rem;
  margin-bottom:16px; color:var(--primary-dark);
}
.dl-lightbox-inner img {
  max-width:100%;
  max-height:70vh;
  object-fit:contain;
  border-radius:8px;
  box-shadow:var(--shadow);
}
@media(max-width:480px) {
  .dl-lightbox-inner { padding:16px; border-radius:10px; }
}

/* Switcher ohne Button */
.switcher-inner { display:flex; gap:14px; align-items:center; flex-wrap:wrap; }
.switcher-label { font-size:0.88rem; color:var(--text-muted); font-weight:600; white-space:nowrap; }
.switcher-select {
  padding:9px 14px; border:2px solid var(--border); border-radius:8px;
  background:var(--white); color:var(--text); font-size:0.92rem;
  cursor:pointer; transition:border-color 0.2s; min-width:180px;
}
.switcher-select:focus { outline:none; border-color:var(--primary); }
.switcher-select:hover { border-color:var(--primary); }
@media(max-width:500px) {
  .switcher-inner { flex-direction:column; align-items:stretch; gap:8px; }
  .switcher-select { min-width:0; width:100%; }
}

/* ===== MOBILE TABELLE: Desktop/Mobile Toggle ===== */
.desktop-only { display:block; }
.mobile-only  { display:none; }
@media(max-width:700px) {
  .desktop-only { display:none; }
  .mobile-only  { display:block; }
}

/* Mobile BL-Karten (Jahres-Übersicht) */
.mob-bl-list {
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:16px 0;
}
.mob-bl-card {
  display:block;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:12px 14px;
  text-decoration:none;
  color:var(--text);
  box-shadow:var(--shadow);
  transition:border-color 0.2s;
}
.mob-bl-card:hover { border-color:var(--primary); text-decoration:none; }
.mob-bl-header {
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:8px;
  padding-bottom:8px;
  border-bottom:1px solid var(--border);
  font-size:1rem;
}
.mob-bl-arrow {
  margin-left:auto;
  color:var(--primary);
  font-size:1.2rem;
  font-weight:700;
}
.mob-ferien-row {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:4px 0;
  font-size:0.83rem;
  border-bottom:1px solid #f3f4f6;
}
.mob-ferien-row:last-child { border-bottom:none; }
.mob-ferien-label { color:var(--text-muted); }
.mob-ferien-date  { font-weight:600; color:var(--text); }

/* ===== MOBILE KALENDER: 2 Monate pro Reihe ===== */
@media(max-width:700px) {
  /* 2 Spalten auf Mobile */
  .calendar-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }

  /* Karte kompakter */
  .month-card {
    padding: 8px 5px !important;
    border-radius: 10px !important;
  }

  /* Monatsname kleiner */
  .month-name-title {
    font-size: 0.82rem !important;
    margin-bottom: 6px !important;
  }
  .month-header {
    margin-bottom: 8px !important;
    padding-bottom: 6px !important;
  }

  /* Tabellen-Header */
  .cal-table thead th {
    font-size: 0.58rem !important;
    padding: 4px 1px !important;
    letter-spacing: 0 !important;
  }
  .cal-kw-head { min-width: 18px !important; }

  /* Tabellen-Zellen */
  .cal-table tbody td {
    font-size: 0.7rem !important;
    padding: 4px 1px !important;
    height: 24px !important;
    min-height: 24px !important;
  }
  .cal-kw {
    font-size: 0.55rem !important;
    padding: 3px 2px !important;
  }

  /* Popup auf Mobile: fixiert in der Mitte */
  .cal-table tbody td:hover .cal-popup { display:none; }
}

/* Extra klein (< 380px): immer noch 2 Spalten aber noch kompakter */
@media(max-width:380px) {
  .calendar-grid { gap: 5px !important; }
  .month-card { padding: 5px 3px !important; }
  .month-name-title { font-size: 0.72rem !important; }
  .cal-table thead th { font-size: 0.5rem !important; padding: 3px 0 !important; }
  .cal-table tbody td { font-size: 0.62rem !important; padding: 3px 0 !important; height: 20px !important; }
}

/* ===== FERIENTYP JAHRES-SEITE — BL KARTEN ===== */
.bl-ferien-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:12px;
  margin-bottom:24px;
}
@media(max-width:600px) {
  .bl-ferien-grid { grid-template-columns:repeat(2,1fr); gap:8px; }
}

.bl-ferien-card {
  display:block;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:14px;
  text-decoration:none;
  color:var(--text);
  box-shadow:var(--shadow);
  transition:all 0.2s;
}
.bl-ferien-card:hover {
  border-color:var(--primary);
  box-shadow:var(--shadow-hover);
  transform:translateY(-2px);
  text-decoration:none;
}
.bl-ferien-card.is-now {
  border-color:#10b981;
  background:#f0fdf4;
}
.bl-ferien-card.is-past {
  opacity:0.65;
}
.bl-ferien-card-header {
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:8px;
  padding-bottom:8px;
  border-bottom:1px solid var(--border);
}
.bl-ferien-card-header img {
  width:28px;
  height:18px;
  object-fit:contain;
  flex-shrink:0;
}
.bl-ferien-card-name {
  font-weight:700;
  font-size:0.88rem;
  line-height:1.2;
}
.bl-ferien-card-date {
  font-size:0.82rem;
  color:var(--primary-dark);
  font-weight:600;
  margin-bottom:4px;
}
.bl-ferien-card-days {
  font-size:0.78rem;
  color:var(--text-muted);
  display:flex;
  align-items:center;
  gap:4px;
}
.bl-ferien-card-none {
  font-size:0.88rem;
  color:var(--text-muted);
  margin-top:4px;
}

/* Badges */
.bl-badge-now {
  display:inline-block;
  background:#10b981;
  color:#fff;
  font-size:0.68rem;
  font-weight:700;
  padding:2px 6px;
  border-radius:10px;
}
.bl-badge-past {
  display:inline-block;
  background:var(--border);
  color:var(--text-muted);
  font-size:0.68rem;
  font-weight:600;
  padding:2px 6px;
  border-radius:10px;
}
