/* ==========================================================================
 * custom.css - Gemeinde Lotte
 * Gem-lotte-spezifische Komponenten, die NICHT im ce-* Framework existieren
 * Nutzt ausschliesslich CSS Custom Properties aus dem Framework (--min-*)
 *
 * DUAL SELECTORS: Jede Komponenten-Klasse existiert sowohl als alte Klasse
 * (z.B. .news-featured) als auch als neue lotte-*-Klasse
 * (z.B. .lotte-news-featured) fuer die Migration.
 *
 * WICHTIG: @layer mandant damit die Cascade-Hierarchie des Frameworks
 * respektiert wird. Ohne @layer wuerde custom.css IMMER gewinnen.
 * ========================================================================== */
@layer mandant {

/* ==========================================================================
 * 1. PAGE HEADER (Unterseiten mit Foto-Header)
 * Verwendet auf: news.php, events.php, rubrik.php, unterseite.php,
 *   themen.php, stellenangebote.php, formulare.php, bekanntmachungen.php,
 *   veranstaltungen.php, maengel.php, termin.php, ratsinformation.php
 * ========================================================================== */

.page-header {
  position: relative;
  background: var(--min-color-surface);
  padding: var(--min-space-xl) 0 var(--min-space-lg);
  overflow: hidden;
}

.page-header--photo {
  position: relative;
  padding: var(--min-space-2xl) 0 var(--min-space-lg);
  color: var(--min-color-text);
}

.page-header__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.12;
  pointer-events: none;
}

.page-header h1 {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: var(--min-font-weight-bold);
  line-height: var(--min-line-height-heading);
  margin-bottom: var(--min-space-sm);
  position: relative;
}

.page-header__subtitle {
  font-size: var(--min-font-size-base);
  color: var(--min-color-muted);
  max-width: 42rem;
  position: relative;
}

.page-header .container {
  position: relative;
  z-index: 1;
}

/* ==========================================================================
 * 2. BREADCRUMB
 * Verwendet auf: allen Unterseiten
 * ========================================================================== */

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--min-space-xs);
  font-size: 0.875rem;
  margin-bottom: var(--min-space-md);
}

.breadcrumb__link {
  color: var(--min-color-primary);
  text-decoration: none;
  transition: color var(--min-transition);
}

.breadcrumb__link:hover {
  text-decoration: underline;
}

.breadcrumb__sep {
  color: var(--min-color-muted);
  user-select: none;
}

.breadcrumb__current {
  color: var(--min-color-muted);
}

/* ==========================================================================
 * 3. CONTENT LAYOUT (2-Spalter mit Sidebar)
 * Verwendet auf: news.php, unterseite.php, themen.php, stellenangebote.php,
 *   formulare.php, bekanntmachungen.php, veranstaltungen.php, maengel.php
 * ========================================================================== */

.content-layout,
.ce-two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-xl);
}

@media (min-width: 768px) {
  .content-layout,
  .ce-two-col {
    grid-template-columns: 1fr 320px;
  }
}

.content-main,
.main-content,
.ce-two-col__main {
  min-width: 0;
}

/* ==========================================================================
 * 4. SIDEBAR
 * Verwendet auf: news.php, unterseite.php, themen.php, stellenangebote.php,
 *   formulare.php, bekanntmachungen.php, veranstaltungen.php, maengel.php
 * ========================================================================== */

.sidebar,
.lotte-sidebar,
.content-sidebar,
.ce-two-col__aside {
  display: flex;
  flex-direction: column;
  gap: var(--min-space-lg);
}

/* -- Sidebar Section (news.php, themen.php) -- */
.sidebar-section,
.lotte-sidebar__section {
  background: var(--min-color-surface);
  padding: var(--min-space-lg);
  border-radius: var(--min-radius-md);
}

.sidebar-section__title,
.lotte-sidebar__title {
  font-size: 1rem;
  font-weight: var(--min-font-weight-bold);
  margin-bottom: var(--min-space-md);
  padding-bottom: var(--min-space-sm);
  border-bottom: 2px solid var(--min-color-primary);
}

/* -- Sidebar Card (unterseite.php, stellenangebote.php, etc.) -- */
.sidebar-card,
.lotte-sidebar-card {
  background: var(--min-color-surface);
  padding: var(--min-space-lg);
  border-radius: var(--min-radius-md);
}

.sidebar-card__title {
  font-size: 1rem;
  font-weight: var(--min-font-weight-bold);
  margin-bottom: var(--min-space-md);
  padding-bottom: var(--min-space-sm);
  border-bottom: 2px solid var(--min-color-primary);
}

/* -- Sidebar Navigation -- */
.sidebar-nav,
.lotte-sidebar-nav {
  display: flex;
  flex-direction: column;
}

.sidebar-nav a,
.lotte-sidebar-nav a {
  display: block;
  padding: var(--min-space-sm) 0;
  color: var(--min-color-text);
  text-decoration: none;
  border-bottom: 1px solid var(--min-color-border);
  transition: color var(--min-transition), padding-left var(--min-transition);
}

.sidebar-nav a:hover,
.sidebar-nav a.active,
.lotte-sidebar-nav a:hover,
.lotte-sidebar-nav a.active {
  color: var(--min-color-primary);
  padding-left: var(--min-space-sm);
}

.sidebar-nav a.active,
.lotte-sidebar-nav a.active {
  font-weight: var(--min-font-weight-bold);
}

.sidebar-nav a:last-child,
.lotte-sidebar-nav a:last-child {
  border-bottom: none;
}

/* -- Sidebar Hint -- */
.sidebar-hint,
.lotte-sidebar__hint {
  font-size: 0.875rem;
  color: var(--min-color-muted);
  margin-top: var(--min-space-md);
}

/* -- Related Links -- */
.related-links {
  display: flex;
  flex-direction: column;
}

.related-links li {
  border-bottom: 1px solid var(--min-color-border);
}

.related-links li:last-child {
  border-bottom: none;
}

.related-links a {
  display: block;
  padding: var(--min-space-sm) 0;
  color: var(--min-color-primary);
  text-decoration: none;
  transition: padding-left var(--min-transition);
}

.related-links a:hover {
  padding-left: var(--min-space-sm);
  text-decoration: underline;
}

/* ==========================================================================
 * 5. NEWS COMPONENTS (Startseite + news.php)
 * ========================================================================== */

/* -- Featured News Layout (index.php) -- */
.news-featured-layout,
.lotte-news-featured-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-lg);
}

@media (min-width: 768px) {
  .news-featured-layout,
  .lotte-news-featured-layout {
    grid-template-columns: 1fr 1fr;
  }
}

/* -- Featured News Card (index.php) -- */
.news-featured,
.lotte-news-featured {
  position: relative;
  border-radius: var(--min-radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
}

.news-featured img,
.lotte-news-featured img,
.lotte-news-featured__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-featured__overlay,
.lotte-news-featured__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--min-space-lg);
  background: linear-gradient(to top, rgba(0, 40, 80, 0.45) 0%, transparent 60%);
  color: white;
}

.news-featured__category,
.lotte-news-featured__category {
  display: inline-block;
  background: var(--min-color-secondary);
  color: white;
  padding: 2px 0.75rem;
  border-radius: var(--min-radius-full);
  font-size: 0.875rem;
  font-weight: var(--min-font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--min-space-sm);
  width: fit-content;
}

.news-featured__title,
.lotte-news-featured__title {
  font-size: clamp(1.125rem, 2vw, 1.375rem);
  line-height: var(--min-line-height-heading);
  margin-bottom: var(--min-space-xs);
  text-shadow: 0 1px 4px rgba(0, 20, 50, 0.55);
}

.news-featured__title a,
.lotte-news-featured__title a {
  color: white;
  text-decoration: none;
}

.news-featured__title a:hover,
.lotte-news-featured__title a:hover {
  text-decoration: underline;
}

.news-featured__date,
.lotte-news-featured__date {
  font-size: 0.875rem;
  opacity: 0.85;
}

/* -- News Stack (index.php - rechte Spalte) -- */
.news-stack,
.lotte-news-stack {
  display: flex;
  flex-direction: column;
  gap: var(--min-space-md);
}

/* -- Compact News (index.php) -- */
.news-compact,
.lotte-news-compact {
  display: flex;
  gap: var(--min-space-md);
  padding-bottom: var(--min-space-md);
  border-bottom: 1px solid var(--min-color-border);
}

.news-compact:last-child,
.lotte-news-compact:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.news-compact__image,
.lotte-news-compact__image {
  flex-shrink: 0;
  width: 100px;
  height: 75px;
  border-radius: var(--min-radius-sm);
  overflow: hidden;
}

.news-compact__image img,
.lotte-news-compact__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-compact__content,
.lotte-news-compact__content {
  min-width: 0;
}

.news-compact__date,
.lotte-news-compact__date {
  font-size: 0.875rem;
  color: var(--min-color-muted);
  display: block;
  margin-bottom: 2px;
}

.news-compact__title,
.lotte-news-compact__title {
  font-size: 0.9375rem;
  line-height: var(--min-line-height-heading);
  margin-bottom: 4px;
}

.news-compact__title a,
.lotte-news-compact__title a {
  color: var(--min-color-text);
  text-decoration: none;
}

.news-compact__title a:hover,
.lotte-news-compact__title a:hover {
  color: var(--min-color-primary);
}

.news-compact__excerpt,
.lotte-news-compact__excerpt {
  font-size: 0.875rem;
  color: var(--min-color-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* -- News List (news.php) -- */
.news-list,
.lotte-news-list {
  display: flex;
  flex-direction: column;
  gap: var(--min-space-lg);
}

.news-item {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-md);
  padding-bottom: var(--min-space-lg);
  border-bottom: 1px solid var(--min-color-border);
}

@media (min-width: 480px) {
  .news-item {
    grid-template-columns: 180px 1fr;
  }
}

.news-item:last-child {
  border-bottom: none;
}

.news-item__image {
  border-radius: var(--min-radius-md);
  overflow: hidden;
  aspect-ratio: 16/10;
}

.news-item__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-item__date {
  font-size: 0.875rem;
  color: var(--min-color-muted);
}

.news-item__title {
  font-size: 1.125rem;
  line-height: var(--min-line-height-heading);
  margin-bottom: var(--min-space-xs);
}

.news-item__title a {
  color: var(--min-color-text);
  text-decoration: none;
}

.news-item__title a:hover {
  color: var(--min-color-primary);
}

.news-item__excerpt {
  font-size: 0.9375rem;
  color: var(--min-color-muted);
  margin-bottom: var(--min-space-sm);
}

/* -- News Card (stellenangebote.php, bekanntmachungen.php, veranstaltungen.php) -- */
.news-card h3 {
  margin-bottom: var(--min-space-sm);
}

.news-card p {
  margin-bottom: var(--min-space-sm);
}

/* ==========================================================================
 * 6. EVENTS TIMELINE (index.php)
 * ========================================================================== */

.events-timeline,
.lotte-events-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.event-timeline-item,
.lotte-event-item {
  display: flex;
  gap: var(--min-space-lg);
  padding: var(--min-space-md) 0;
  border-bottom: 1px solid var(--min-color-border);
  transition: background var(--min-transition);
}

.event-timeline-item:last-child,
.lotte-event-item:last-child {
  border-bottom: none;
}

.event-timeline-item:hover,
.lotte-event-item:hover {
  background: var(--min-color-surface);
  margin-inline: calc(-1 * var(--min-space-md));
  padding-inline: var(--min-space-md);
  border-radius: var(--min-radius-md);
}

.event-timeline-item__date,
.lotte-event-item__date {
  flex-shrink: 0;
  width: 72px;
  text-align: center;
  background: var(--min-color-primary);
  color: white;
  border-radius: var(--min-radius-md);
  padding: var(--min-space-sm) var(--min-space-sm);
  line-height: 1.2;
  align-self: flex-start;
}

.event-timeline-item__date strong,
.lotte-event-item__day {
  display: block;
  font-size: 1rem;
}

.event-timeline-item__date span,
.lotte-event-item__month {
  display: block;
  font-size: 0.875rem;
  opacity: 0.85;
}

.event-timeline-item__content,
.lotte-event-item__content {
  min-width: 0;
}

.event-timeline-item__title,
.lotte-event-item__title {
  font-size: 1.0625rem;
  line-height: var(--min-line-height-heading);
  margin-bottom: 4px;
}

.event-timeline-item__title a,
.lotte-event-item__title a {
  color: var(--min-color-text);
  text-decoration: none;
}

.event-timeline-item__title a:hover,
.lotte-event-item__title a:hover {
  color: var(--min-color-primary);
}

.event-timeline-item__meta,
.lotte-event-item__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--min-space-md);
  font-size: 0.875rem;
  color: var(--min-color-muted);
}

/* Event category tag — positioned over the image */
.lotte-event-item__tag {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
}

/* ==========================================================================
 * 7. TOPIC CARDS (index.php - Themen im Fokus + landing.php)
 * Overlay-Karten mit Bild und Text
 * ========================================================================== */

.topic-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-md);
}

@media (min-width: 640px) {
  .topic-cards {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  }
}

.topic-card,
.lotte-topic-card {
  position: relative;
  border-radius: var(--min-radius-md);
  overflow: hidden;
  aspect-ratio: 16/10;
  cursor: pointer;
}

.topic-card img,
.lotte-topic-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.topic-card:hover img,
.lotte-topic-card:hover img {
  transform: scale(1.04);
}

.topic-card__overlay,
.lotte-topic-card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--min-space-lg);
  background: linear-gradient(to top, rgba(0, 40, 80, 0.40) 0%, transparent 70%);
  color: white;
}

.topic-card__tag,
.lotte-topic-card__tag {
  display: inline-block;
  background: var(--min-color-secondary);
  color: white;
  padding: 2px 0.625rem;
  border-radius: var(--min-radius-full);
  font-size: 0.875rem;
  font-weight: var(--min-font-weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--min-space-xs);
  width: fit-content;
}

.topic-card__title,
.ce-cards__card-title {
  font-size: 1.125rem;
  line-height: var(--min-line-height-heading);
  text-shadow: 0 1px 4px rgba(0, 20, 50, 0.55);
}

.topic-card__title a,
.ce-cards__card-title a {
  color: white;
  text-decoration: none;
}

.topic-card__title a:hover,
.ce-cards__card-title a:hover {
  text-decoration: underline;
}

.topic-card__overlay p,
.lotte-topic-card__overlay p {
  font-size: 0.875rem;
  opacity: 0.9;
  margin-top: var(--min-space-xs);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ==========================================================================
 * 8. ORTSTEIL CARD (index.php - Swiper)
 * ========================================================================== */

.ortsteil-card,
.lotte-ortsteil-card {
  position: relative;
  border-radius: var(--min-radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
}

.ortsteil-card img,
.lotte-ortsteil-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ortsteil-card__content,
.lotte-ortsteil-card__content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--min-space-md) var(--min-space-lg);
  background: linear-gradient(to top, rgba(0, 40, 80, 0.40) 0%, transparent 100%);
  color: white;
}

.ortsteil-card__content h3,
.lotte-ortsteil-card__content h3 {
  font-size: 1.125rem;
  margin-bottom: 2px;
  text-shadow: 0 1px 4px rgba(0, 20, 50, 0.55);
}

.ortsteil-card__content p,
.lotte-ortsteil-card__content p {
  font-size: 0.875rem;
  opacity: 0.85;
}

/* ==========================================================================
 * 9. RUBRIK CARDS (rubrik.php, landing.php)
 * Kategorie-Kacheln mit Icon + Links
 * ========================================================================== */

.rubrik-grid,
.lotte-rubrik-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-md);
}

@media (min-width: 480px) {
  .rubrik-grid,
  .lotte-rubrik-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .rubrik-grid,
  .lotte-rubrik-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.rubrik-card,
.lotte-rubrik-card {
  background: var(--min-color-surface);
  border: 1px solid var(--min-color-border);
  border-radius: var(--min-radius-md);
  padding: var(--min-space-lg);
  transition: box-shadow var(--min-transition), transform var(--min-transition);
  text-decoration: none;
  color: inherit;
  display: block;
}

.rubrik-card:hover,
.lotte-rubrik-card:hover {
  box-shadow: var(--min-shadow-md);
  transform: translateY(-2px);
}

.rubrik-card__icon,
.lotte-rubrik-card__icon {
  width: 40px;
  height: 40px;
  color: var(--min-color-primary);
  margin-bottom: var(--min-space-md);
}

.rubrik-card__title,
.lotte-rubrik-card__title {
  font-size: 1.125rem;
  font-weight: var(--min-font-weight-bold);
  line-height: var(--min-line-height-heading);
  margin-bottom: var(--min-space-sm);
  color: var(--min-color-text);
}

.rubrik-card__desc,
.lotte-rubrik-card__desc {
  font-size: 0.9375rem;
  color: var(--min-color-muted);
  margin-bottom: var(--min-space-md);
}

.rubrik-card__links,
.lotte-rubrik-card__links {
  display: flex;
  flex-direction: column;
  gap: var(--min-space-xs);
}

.rubrik-card__links a,
.rubrik-card__links span,
.lotte-rubrik-card__links a,
.lotte-rubrik-card__links span {
  font-size: 0.875rem;
  color: var(--min-color-primary);
  text-decoration: none;
  transition: padding-left var(--min-transition);
}

.rubrik-card__links a:hover,
.lotte-rubrik-card__links a:hover {
  padding-left: var(--min-space-xs);
  text-decoration: underline;
}

/* ==========================================================================
 * 10. SERVICE SEARCH (rubrik.php)
 * ========================================================================== */

.service-search-section,
.lotte-service-search-section {
  text-align: center;
}

.service-search-form,
.lotte-service-search-form {
  margin: var(--min-space-lg) auto;
  max-width: 600px;
}

.service-search-form__wrapper,
.lotte-service-search-form__wrapper {
  display: flex;
  border-radius: var(--min-radius-md);
  overflow: hidden;
  box-shadow: var(--min-shadow-md);
}

.service-search-form__input,
.lotte-service-search-form__input {
  flex: 1;
  padding: var(--min-space-md) var(--min-space-lg);
  border: 1px solid var(--min-color-border);
  border-right: none;
  border-radius: var(--min-radius-md) 0 0 var(--min-radius-md);
  font-size: var(--min-font-size-base);
  outline: none;
  transition: border-color var(--min-transition);
}

.service-search-form__input:focus,
.lotte-service-search-form__input:focus {
  border-color: var(--min-color-primary);
}

.service-search-form__button,
.lotte-service-search-form__button {
  display: flex;
  align-items: center;
  gap: var(--min-space-sm);
  border-radius: 0 var(--min-radius-md) var(--min-radius-md) 0;
}

.service-search-hints,
.lotte-service-search-hints {
  margin-top: var(--min-space-md);
}

.service-search-hints ul,
.lotte-service-search-hints ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--min-space-sm);
  margin-top: var(--min-space-sm);
}

.service-search-hints a,
.lotte-service-search-hints a {
  display: inline-block;
  padding: 4px var(--min-space-md);
  background: var(--min-color-surface);
  border: 1px solid var(--min-color-border);
  border-radius: var(--min-radius-full);
  font-size: 0.875rem;
  color: var(--min-color-text);
  text-decoration: none;
  transition: background var(--min-transition), border-color var(--min-transition);
}

.service-search-hints a:hover,
.lotte-service-search-hints a:hover {
  background: color-mix(in srgb, var(--min-color-primary) 10%, transparent);
  border-color: var(--min-color-primary);
  color: var(--min-color-primary);
}

/* ==========================================================================
 * 11. DOWNLOAD LIST (unterseite.php, formulare.php, bekanntmachungen.php)
 * ========================================================================== */

.download-list,
.lotte-download-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.download-list li,
.lotte-download-list li {
  border-bottom: 1px solid var(--min-color-border);
}

.download-list li:last-child,
.lotte-download-list li:last-child {
  border-bottom: none;
}

.download-list a,
.lotte-download-list a {
  display: flex;
  align-items: center;
  gap: var(--min-space-md);
  padding: var(--min-space-md) var(--min-space-sm);
  text-decoration: none;
  color: var(--min-color-text);
  transition: background var(--min-transition);
  border-radius: var(--min-radius-sm);
}

.download-list a:hover,
.lotte-download-list a:hover {
  background: var(--min-color-surface);
}

.download-list a svg,
.lotte-download-list a svg {
  flex-shrink: 0;
  color: var(--min-color-primary);
}

.download-list__meta,
.lotte-download-list__meta {
  display: block;
  font-size: 0.875rem;
  color: var(--min-color-muted);
}

/* ==========================================================================
 * 12. HOURS TABLE (unterseite.php)
 * ========================================================================== */

.hours-table,
.lotte-hours-table {
  width: 100%;
}

.hours-table td,
.lotte-hours-table td {
  padding: var(--min-space-sm) 0;
  border-bottom: 1px solid var(--min-color-border);
  vertical-align: top;
}

.hours-table tr:last-child td,
.lotte-hours-table tr:last-child td {
  border-bottom: none;
}

.hours-table td:first-child,
.lotte-hours-table td:first-child {
  font-weight: var(--min-font-weight-medium);
  padding-right: var(--min-space-md);
  white-space: nowrap;
}

.hours-table td:last-child,
.lotte-hours-table td:last-child {
  text-align: right;
}

/* ==========================================================================
 * 13. CONTACT CARD (unterseite.php, stellenangebote.php, etc.)
 * ========================================================================== */

.contact-card,
.lotte-contact-card {
  display: flex;
  gap: var(--min-space-md);
}

.contact-card__avatar,
.lotte-contact-card__avatar {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: var(--min-radius-full);
  background: color-mix(in srgb, var(--min-color-primary) 12%, transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--min-color-primary);
}

.contact-card__info,
.lotte-contact-card__info {
  min-width: 0;
}

.contact-card__name,
.lotte-contact-card__name {
  font-weight: var(--min-font-weight-bold);
  margin-bottom: 2px;
}

.contact-card__role,
.lotte-contact-card__role {
  font-size: 0.875rem;
  color: var(--min-color-muted);
  margin-bottom: var(--min-space-sm);
}

.contact-card__contact,
.lotte-contact-card__details {
  display: flex;
  flex-direction: column;
  gap: var(--min-space-xs);
}

.contact-detail,
.lotte-contact-card__detail {
  display: flex;
  align-items: center;
  gap: var(--min-space-sm);
  font-size: 0.875rem;
}

.contact-detail svg,
.lotte-contact-card__detail svg {
  flex-shrink: 0;
  color: var(--min-color-muted);
}

.contact-detail a,
.lotte-contact-card__detail a {
  color: var(--min-color-primary);
  text-decoration: none;
}

.contact-detail a:hover,
.lotte-contact-card__detail a:hover {
  text-decoration: underline;
}

/* ==========================================================================
 * 14. INFO BOX + NOTICE (unterseite.php)
 * ========================================================================== */

.info-box {
  background: var(--min-color-surface);
  border: 1px solid var(--min-color-border);
  border-left: 4px solid var(--min-color-primary);
  border-radius: var(--min-radius-md);
  padding: var(--min-space-lg);
  margin: var(--min-space-lg) 0;
}

.info-box h3 {
  margin-bottom: var(--min-space-sm);
}

.info-box--info {
  border-left-color: var(--min-color-secondary);
  background: color-mix(in srgb, var(--min-color-secondary) 6%, white);
}

.notice {
  background: color-mix(in srgb, var(--min-color-accent) 8%, white);
  border: 1px solid color-mix(in srgb, var(--min-color-accent) 20%, transparent);
  border-radius: var(--min-radius-md);
  padding: var(--min-space-md);
  margin: var(--min-space-md) 0;
}

.notice--info {
  background: color-mix(in srgb, var(--min-color-primary) 8%, white);
  border-color: color-mix(in srgb, var(--min-color-primary) 20%, transparent);
}

/* ==========================================================================
 * 15. CONTENT FIGURE (unterseite.php)
 * ========================================================================== */

.content-figure {
  margin: var(--min-space-lg) 0;
}

.content-figure img {
  border-radius: var(--min-radius-md);
  width: 100%;
}

.content-figure figcaption {
  font-size: 0.875rem;
  color: var(--min-color-muted);
  margin-top: var(--min-space-sm);
}

/* ==========================================================================
 * 16. FEATURE CARDS (landing.php)
 * Kacheln mit Icon, Titel und Text
 * ========================================================================== */

.feature-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-lg);
  margin-top: var(--min-space-lg);
}

@media (min-width: 640px) {
  .feature-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.feature-card {
  padding: var(--min-space-lg);
  background: var(--min-color-surface);
  border-radius: var(--min-radius-md);
  transition: box-shadow var(--min-transition);
}

.feature-card:hover {
  box-shadow: var(--min-shadow-md);
}

.feature-card__icon,
.lotte-feature-icon {
  width: 40px;
  height: 40px;
  color: var(--min-color-primary);
  margin-bottom: var(--min-space-md);
}

.feature-card__title {
  font-size: 1.125rem;
  font-weight: var(--min-font-weight-bold);
  margin-bottom: var(--min-space-sm);
}

.feature-card__text {
  font-size: 0.9375rem;
  color: var(--min-color-muted);
  line-height: var(--min-line-height);
}

/* ==========================================================================
 * 17. STATS BAR (landing.php)
 * ========================================================================== */

.stats-bar,
.lotte-stats-bar {
  background: var(--min-color-primary);
  color: white;
  padding: var(--min-space-xl) 0;
}

.stat-item__number,
.lotte-stat-item__number {
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  font-weight: var(--min-font-weight-bold);
  line-height: 1.1;
  margin-bottom: 4px;
}

.stat-item__label,
.lotte-stat-item__label {
  font-size: 0.875rem;
  opacity: 0.85;
}

/* ==========================================================================
 * 18. LANDING HERO (landing.php)
 * Heller Hero mit Hintergrundbild
 * ========================================================================== */

.landing-hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-size: cover;
  background-position: center;
}

.landing-hero__content {
  max-width: 700px;
  padding: var(--min-space-xl);
}

.landing-hero__content h1 {
  color: white;
  font-size: clamp(2rem, 5vw, 3rem);
}

.landing-hero__content .lead {
  color: rgba(255, 255, 255, 0.9);
}

/* ==========================================================================
 * 19. PARALLAX DIVIDER (index.php)
 * ========================================================================== */

.parallax-divider {
  position: relative;
  height: 200px;
  background-size: cover;
  background-position: center;
  background-attachment: scroll;
}

.parallax-divider__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 40, 80, 0.20);
}

/* ==========================================================================
 * 20. HERO (index.php - Startseite)
 * Ergaenzungen fuer Startseiten-Hero: Overlay + Suchfeld
 * Nutzt ce-hero aus dem Framework fuer die Basisstruktur
 * ========================================================================== */

.hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

.hero__overlay {
  position: absolute;
  inset: 0;
}

.hero__overlay--gradient {
  background: linear-gradient(to top, rgba(0, 40, 80, 0.40) 0%, rgba(0, 40, 80, 0.10) 100%);
}

.hero__content {
  position: relative;
  z-index: 1;
  text-align: center;
  color: white;
  padding: var(--min-space-3xl) var(--min-space-md);
  max-width: 700px;
  margin: 0 auto;
}

.hero__title {
  font-size: clamp(2rem, 5vw, 3rem);
  color: white;
  margin-bottom: var(--min-space-sm);
  text-shadow: 0 2px 8px rgba(0, 20, 50, 0.60);
}

.hero__subtitle {
  font-size: clamp(1rem, 2vw, 1.25rem);
  opacity: 0.9;
  margin-bottom: var(--min-space-lg);
}

.hero__search {
  display: flex;
  max-width: 480px;
  margin: 0 auto;
  border-radius: var(--min-radius-md);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.hero__search input {
  flex: 1;
  padding: var(--min-space-md) var(--min-space-lg);
  border: none;
  font-size: var(--min-font-size-base);
  outline: none;
  background: white;
  color: var(--min-color-text);
}

.hero__search button {
  padding: var(--min-space-md) var(--min-space-lg);
  background: var(--min-color-primary);
  color: white;
  border: none;
  cursor: pointer;
  transition: background var(--min-transition);
}

.hero__search button:hover {
  background: color-mix(in srgb, var(--min-color-primary) 85%, black);
}

/* ==========================================================================
 * 21. UTILITY CLASSES
 * Benoetigte Hilfsklassen (container, flex, text, etc.)
 * ========================================================================== */

/* Container (falls nicht im Framework enthalten) */
/* Nutzt Token statt hardcoded 1200px – konsistent mit @layer layout */
.container {
  width: 100%;
  max-width: var(--min-container-max, 1280px);
  margin-inline: auto;
  padding-inline: var(--min-container-padding, var(--min-space-md, 1.5rem));
}

/* Section Spacing */
.section {
  padding: var(--min-space-section) 0;
}

.section--sm {
  padding: var(--min-space-md) 0;
}

.section--alt {
  background: var(--min-color-surface);
}

/* Flexbox Helpers */
.flex { display: flex; }
.flex--col { flex-direction: column; }
.flex--center { justify-content: center; }
.flex--between { justify-content: space-between; }
.flex--wrap { flex-wrap: wrap; }

.gap-2 { gap: var(--min-space-sm); }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: var(--min-space-md); }

/* Text Helpers */
.text-center { text-align: center; }
.text-muted { color: var(--min-color-muted); }
.small { font-size: 0.875rem; }
.lead {
  font-size: 1.125rem;
  color: var(--min-color-muted);
  margin-bottom: var(--min-space-lg);
  line-height: var(--min-line-height);
}

/* Spacing Helpers */
.mb-2 { margin-bottom: var(--min-space-sm); }
.mb-4 { margin-bottom: var(--min-space-md); }
.mb-6 { margin-bottom: 1.5rem; }
.mb-8 { margin-bottom: var(--min-space-lg); }
.mt-4 { margin-top: var(--min-space-md); }
.mt-8 { margin-top: var(--min-space-lg); }

/* Visibility */
.sr-only,
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ==========================================================================
 * 22. BUTTONS
 * Nur falls nicht ausreichend im ce-btn des Frameworks
 * ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--min-space-sm);
  padding: 0.625rem 1.25rem;
  font-size: 0.9375rem;
  font-weight: var(--min-font-weight-medium);
  line-height: 1.4;
  border: 2px solid transparent;
  border-radius: var(--min-radius-md);
  cursor: pointer;
  text-decoration: none;
  transition: all var(--min-transition);
  white-space: nowrap;
}

.btn--primary {
  background: var(--min-color-primary);
  color: white;
}

.btn--primary:hover {
  background: color-mix(in srgb, var(--min-color-primary) 85%, black);
}

.btn--secondary {
  background: var(--min-color-secondary);
  color: white;
}

.btn--secondary:hover {
  background: color-mix(in srgb, var(--min-color-secondary) 80%, black);
}

.btn--outline {
  background: transparent;
  border-color: var(--min-color-primary);
  color: var(--min-color-primary);
}

.btn--outline:hover {
  background: var(--min-color-primary);
  color: white;
}

.btn--ghost {
  background: transparent;
  color: var(--min-color-text);
  border-color: var(--min-color-border);
}

.btn--ghost:hover {
  background: var(--min-color-surface);
  border-color: var(--min-color-primary);
  color: var(--min-color-primary);
}

.btn--sm {
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
}

.btn--lg {
  padding: 0.75rem 1.75rem;
  font-size: 1.0625rem;
}

.btn--full {
  width: 100%;
}

/* ==========================================================================
 * 23. FORM ELEMENTS
 * ========================================================================== */

.form-input,
.form-select {
  display: block;
  width: 100%;
  padding: var(--min-space-sm) 0.75rem;
  font-size: var(--min-font-size-base);
  border: 1px solid var(--min-color-border);
  border-radius: var(--min-radius-md);
  background: white;
  transition: border-color var(--min-transition);
  outline: none;
}

.form-input:focus,
.form-select:focus {
  border-color: var(--min-color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--min-color-primary) 15%, transparent);
}

/* ==========================================================================
 * 24. CARD (Generic - news.php featured, events.php)
 * ========================================================================== */

.card {
  background: white;
  border: 1px solid var(--min-color-border);
  border-radius: var(--min-radius-md);
  overflow: hidden;
}

.card__image {
  overflow: hidden;
}

.card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card__body {
  padding: var(--min-space-lg);
}

.card__title {
  font-size: 1.25rem;
  font-weight: var(--min-font-weight-bold);
  line-height: var(--min-line-height-heading);
  margin-bottom: var(--min-space-sm);
}

.card__text {
  color: var(--min-color-muted);
  margin-bottom: var(--min-space-md);
}

/* ==========================================================================
 * 25. QUICK ACCESS (index.php - Schnellzugriffe)
 * Falls im HTML noch alte Klassen vorhanden sind
 * ========================================================================== */

.quick-access__icon {
  color: var(--min-color-primary);
}

.quick-access__label {
  font-weight: var(--min-font-weight-bold);
}

.quick-access__desc {
  font-size: 0.875rem;
  color: var(--min-color-muted);
}

/* ==========================================================================
 * 26. STYLE SWITCHER (head.php)
 * ========================================================================== */





.style-switcher__btn:hover,
.style-switcher__btn.is-active {
  background: var(--min-color-primary);
  color: white;
}

/* ==========================================================================
 * 27. SKIP LINK (head.php)
 * ========================================================================== */



.skip-link:focus {
  top: 0;
}

/* ==========================================================================
 * 28. BACK TO TOP (footer.php)
 * ========================================================================== */

.back-to-top {
  position: fixed;
  bottom: var(--min-space-lg);
  right: var(--min-space-lg);
  width: 44px;
  height: 44px;
  background: var(--min-color-primary);
  color: white;
  border: none;
  border-radius: var(--min-radius-full);
  cursor: pointer;
  box-shadow: var(--min-shadow-md);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--min-transition), background var(--min-transition);
  z-index: 100;
}

.back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.back-to-top:hover {
  background: color-mix(in srgb, var(--min-color-primary) 85%, black);
}

/* ==========================================================================
 * 29. NEWSLETTER (news.php sidebar)
 * ========================================================================== */

/* Newsletter form already handled via sidebar-section + form-input + btn */

/* ==========================================================================
 * 30. RESPONSIVE ADJUSTMENTS
 * ========================================================================== */

@media (max-width: 767px) {
  .page-header--photo {
    padding: var(--min-space-xl) 0 var(--min-space-md);
  }

  .news-featured,
  .lotte-news-featured {
    aspect-ratio: 16/9;
  }

  .event-timeline-item,
  .lotte-event-item {
    gap: var(--min-space-md);
  }

  .event-timeline-item__date,
  .lotte-event-item__date {
    width: 56px;
    font-size: 0.875rem;
  }

  .hero__content {
    padding: var(--min-space-2xl) var(--min-space-md);
  }
}

@media (max-width: 479px) {
  .rubrik-grid,
  .lotte-rubrik-grid {
    grid-template-columns: 1fr;
  }

  .hero__search {
    flex-direction: column;
    border-radius: var(--min-radius-md);
  }

  .hero__search input {
    border-radius: var(--min-radius-md) var(--min-radius-md) 0 0;
    border-right: none;
  }

  .hero__search button {
    border-radius: 0 0 var(--min-radius-md) var(--min-radius-md);
    justify-content: center;
  }
}

/* ==========================================================================
 * 31. MOSAIC DASHBOARD (index-v3.php – Bento-Grid Layout)
 * ========================================================================== */

.lotte-mosaic-dashboard {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--min-space-md);
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--min-space-lg) var(--min-space-md);
}

/* Base Tile */
.lotte-mosaic-tile {
  background: white;
  border-radius: var(--min-radius-lg);
  padding: var(--min-space-lg);
  border: 1px solid var(--min-color-border);
  overflow: hidden;
}

/* Tile shared elements */
.lotte-mosaic-tile__eyebrow {
  display: block;
  font-size: 0.875rem;
  font-weight: var(--min-font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--min-color-primary);
  margin-bottom: var(--min-space-sm);
}

.lotte-mosaic-tile__title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--min-font-weight-bold);
  line-height: var(--min-line-height-heading);
  color: var(--min-color-text);
  margin: 0 0 var(--min-space-sm);
}

.lotte-mosaic-tile__text {
  font-size: var(--min-font-size-base);
  color: var(--min-color-muted);
  margin: 0;
}

.lotte-mosaic-tile__subtitle {
  font-size: 1rem;
  font-weight: var(--min-font-weight-bold);
  color: var(--min-color-text);
  margin: 0;
}

.lotte-mosaic-tile__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--min-space-md);
}

.lotte-mosaic-tile__more {
  font-size: 0.875rem;
  color: var(--min-color-primary);
  text-decoration: none;
  font-weight: var(--min-font-weight-medium);
}

.lotte-mosaic-tile__more:hover {
  text-decoration: underline;
}

/* Welcome Tile */
.lotte-mosaic-tile--welcome {
  background: var(--min-color-surface);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Search Tile */
.lotte-mosaic-tile--search {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.lotte-mosaic-search {
  display: flex;
  align-items: center;
  gap: var(--min-space-sm);
  background: var(--min-color-surface);
  border: 1px solid var(--min-color-border);
  border-radius: var(--min-radius-full);
  padding: 0.625rem 1rem;
}

.lotte-mosaic-search svg {
  flex-shrink: 0;
  color: var(--min-color-muted);
}

.lotte-mosaic-search input {
  border: none;
  background: transparent;
  outline: none;
  font-size: var(--min-font-size-base);
  width: 100%;
  color: var(--min-color-text);
}

.lotte-mosaic-search input::placeholder {
  color: var(--min-color-muted);
}

.lotte-mosaic-search-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--min-space-xs);
  margin-top: var(--min-space-sm);
}

.lotte-mosaic-search-tags a {
  font-size: 0.875rem;
  padding: 0.25rem 0.625rem;
  background: var(--min-color-surface);
  border-radius: var(--min-radius-full);
  color: var(--min-color-muted);
  text-decoration: none;
  transition: all var(--min-transition);
}

.lotte-mosaic-search-tags a:hover {
  background: var(--min-color-primary);
  color: white;
}

/* Quick Links Tile */
.lotte-mosaic-quicklinks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--min-space-xs);
}

.lotte-mosaic-qlink {
  display: flex;
  align-items: center;
  gap: var(--min-space-sm);
  padding: 0.5rem 0.625rem;
  border-radius: var(--min-radius-md);
  color: var(--min-color-text);
  text-decoration: none;
  font-size: 0.875rem;
  transition: background var(--min-transition);
}

.lotte-mosaic-qlink:hover {
  background: var(--min-color-surface);
}

.lotte-mosaic-qlink svg {
  flex-shrink: 0;
  color: var(--min-color-primary);
}

/* Featured Tile */
.lotte-mosaic-tile--featured {
  grid-column: span 2;
  position: relative;
  padding: 0;
  min-height: 280px;
}

.lotte-mosaic-tile--featured img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}

.lotte-mosaic-tile--featured__content {
  position: relative;
  z-index: 1;
  padding: var(--min-space-lg);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  background: linear-gradient(to top, rgba(0, 40, 80, 0.40) 0%, transparent 60%);
  color: white;
}

.lotte-mosaic-tile--featured__content h3 {
  font-size: 1.25rem;
  font-weight: var(--min-font-weight-bold);
  margin: var(--min-space-sm) 0 0.25rem;
  text-shadow: 0 1px 4px rgba(0, 20, 50, 0.55);
}

.lotte-mosaic-tile--featured__content h3 a {
  color: white;
  text-decoration: none;
}

.lotte-mosaic-tile--featured__content h3 a:hover {
  text-decoration: underline;
}

.lotte-mosaic-tile--featured__content time {
  font-size: 0.875rem;
  opacity: 0.8;
}

/* Events Tile */
.lotte-mosaic-events-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.lotte-mosaic-event {
  display: flex;
  align-items: center;
  gap: var(--min-space-md);
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--min-color-border);
  text-decoration: none;
  color: var(--min-color-text);
  transition: background var(--min-transition);
}

.lotte-mosaic-event:last-child {
  border-bottom: none;
}

.lotte-mosaic-event:hover {
  background: var(--min-color-surface);
  margin: 0 calc(var(--min-space-sm) * -1);
  padding-left: var(--min-space-sm);
  padding-right: var(--min-space-sm);
  border-radius: var(--min-radius-md);
}

.lotte-mosaic-event__date {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 44px;
  text-align: center;
}

.lotte-mosaic-event__date strong {
  font-size: 1.25rem;
  font-weight: var(--min-font-weight-bold);
  color: var(--min-color-primary);
  line-height: 1;
}

.lotte-mosaic-event__date span {
  font-size: 0.875rem;
  text-transform: uppercase;
  color: var(--min-color-muted);
}

.lotte-mosaic-event__info {
  flex: 1;
  min-width: 0;
}

.lotte-mosaic-event__title {
  font-size: 0.875rem;
  font-weight: var(--min-font-weight-medium);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lotte-mosaic-event__meta {
  font-size: 0.875rem;
  color: var(--min-color-muted);
}

/* News Tiles */
.lotte-mosaic-tile--news {
  padding: 0;
  display: flex;
  flex-direction: column;
}

.lotte-mosaic-tile--news__img {
  height: 140px;
  overflow: hidden;
}

.lotte-mosaic-tile--news__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lotte-mosaic-tile--news__body {
  padding: var(--min-space-md);
}

.lotte-mosaic-tile--news__body time {
  font-size: 0.875rem;
  color: var(--min-color-muted);
}

.lotte-mosaic-tile--news__body h3 {
  font-size: 0.9375rem;
  font-weight: var(--min-font-weight-bold);
  margin: 0.25rem 0;
  line-height: var(--min-line-height-heading);
}

.lotte-mosaic-tile--news__body h3 a {
  color: var(--min-color-text);
  text-decoration: none;
}

.lotte-mosaic-tile--news__body h3 a:hover {
  color: var(--min-color-primary);
}

.lotte-mosaic-tile--news__body p {
  font-size: 0.875rem;
  color: var(--min-color-muted);
  margin: 0;
}

/* Accent colors for news tiles — C6: replaced hardcode with CSS var */
.lotte-mosaic-tile--news[data-accent="teal"] {
  border-top: 3px solid var(--lotte-accent-teal, #0d9488);
}

.lotte-mosaic-tile--news[data-accent="amber"] {
  border-top: 3px solid #d97706;
}

/* Service Tile */
.lotte-mosaic-tile--service {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Topic Tiles */
.lotte-mosaic-tile--topic {
  position: relative;
  padding: 0;
  text-decoration: none;
  color: white;
  min-height: 180px;
  display: flex;
  align-items: flex-end;
}

.lotte-mosaic-tile--topic img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.lotte-mosaic-tile--topic:hover img {
  transform: scale(1.05);
}

.lotte-mosaic-tile--topic__content {
  position: relative;
  z-index: 1;
  padding: var(--min-space-md);
  width: 100%;
  background: linear-gradient(to top, rgba(0, 40, 80, 0.40) 0%, transparent 100%);
}

.lotte-mosaic-tile--topic__content h3 {
  font-size: 1rem;
  font-weight: var(--min-font-weight-bold);
  color: white;
  margin: var(--min-space-xs) 0 0;
  text-shadow: 0 1px 4px rgba(0, 20, 50, 0.55);
}

/* Topic accent borders — C6: replaced hardcode with CSS var */
.lotte-mosaic-tile--topic[data-accent="teal"]::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--lotte-accent-teal, #0d9488);
  z-index: 2;
}

.lotte-mosaic-tile--topic[data-accent="amber"]::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #d97706;
  z-index: 2;
}

.lotte-mosaic-tile--topic[data-accent="slate"]::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: #64748b;
  z-index: 2;
}

/* Stats Tile */
.lotte-mosaic-tile--stats {
  grid-column: span 3;
  background: var(--min-color-primary);
  color: white;
  text-align: center;
}

.lotte-mosaic-tile--stats .lotte-mosaic-tile__subtitle {
  color: white;
}

.lotte-mosaic-stats {
  display: flex;
  justify-content: space-around;
}

/* Ortsteile Band */
.lotte-mosaic-tile--ortsteile {
  grid-column: span 3;
}

.lotte-mosaic-ortsteile {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--min-space-sm);
}

.lotte-mosaic-ort {
  position: relative;
  border-radius: var(--min-radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  text-decoration: none;
}

.lotte-mosaic-ort img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.lotte-mosaic-ort:hover img {
  transform: scale(1.08);
}

.lotte-mosaic-ort__label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--min-space-sm) var(--min-space-md);
  background: linear-gradient(to top, rgba(0, 40, 80, 0.35) 0%, transparent 100%);
  color: white;
  font-size: 0.875rem;
  font-weight: var(--min-font-weight-bold);
  text-shadow: 0 1px 3px rgba(0, 20, 50, 0.50);
}

/* Mosaic Responsive */
@media (max-width: 1023px) {
  .lotte-mosaic-dashboard {
    grid-template-columns: repeat(2, 1fr);
  }

  .lotte-mosaic-tile--featured {
    grid-column: span 2;
  }

  .lotte-mosaic-tile--stats {
    grid-column: span 2;
  }

  .lotte-mosaic-tile--ortsteile {
    grid-column: span 2;
  }

  .lotte-mosaic-ortsteile {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 639px) {
  .lotte-mosaic-dashboard {
    grid-template-columns: 1fr;
    padding: var(--min-space-md);
  }

  .lotte-mosaic-tile--featured {
    grid-column: span 1;
    min-height: 220px;
  }

  .lotte-mosaic-tile--stats {
    grid-column: span 1;
  }

  .lotte-mosaic-tile--ortsteile {
    grid-column: span 1;
  }

  .lotte-mosaic-ortsteile {
    grid-template-columns: repeat(2, 1fr);
  }

  .lotte-mosaic-quicklinks {
    grid-template-columns: 1fr;
  }

  .lotte-mosaic-stats {
    flex-wrap: wrap;
    gap: var(--min-space-md);
  }

  .lotte-mosaic-stats .lotte-stat-item {
    flex: 0 0 45%;
  }
}

/* ==========================================================================
 * 32. DESIGN-FIXES - 2026-02-18 LILY
 * Behebt: Bild-Layout, Sticky-Nav-Overflow, Border-Radius-Chaos
 * ========================================================================== */

/* --- Fix A: ce-page-header__image als Hintergrundbild ---
 * In den Templates wird das Bild als .ce-page-header__image direkt
 * in .ce-page-header--image eingebettet (kein .ce-page-header__bg Wrapper).
 * Dieses CSS macht .ce-page-header__image zu einem absoluten Hintergrundbild,
 * kompatibel mit der --image Variante.
 */
.ce-page-header--image > .ce-page-header__image,
.ce-page-header--image > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  pointer-events: none;
}

/* Overlay ueber dem Foto-Header-Bild (via ::before auf dem Container) */
.ce-page-header--image::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 40, 80, 0.25) 0%,
    rgba(0, 40, 80, 0.12) 40%,
    rgba(0, 40, 80, 0.04) 100%
  );
  z-index: 1;
  pointer-events: none;
}

/* Content des page-header muss ueber dem Overlay liegen */
.ce-page-header--image > .ce-page-header__content,
.ce-page-header--image .container {
  position: relative;
  z-index: 2;
}

/* --- Fix B: Einheitliche Schriftfarbe im photo page-header ---
 * Text muss lesbar bleiben auf dem Foto-Hintergrund
 */
.ce-page-header--image .ce-page-header__title,
.ce-page-header--image .ce-page-header__subtitle,
.ce-page-header--image .ce-breadcrumb__link,
.ce-page-header--image .ce-breadcrumb__sep,
.ce-page-header--image .ce-breadcrumb__current {
  color: #ffffff;
  text-shadow: 0 1px 6px rgba(0, 20, 50, 0.55);
}

/* Staerkerer Text-Shadow fuer den Haupttitel – lesbar auch bei hellen Fotos */
.ce-page-header--image .ce-page-header__title {
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35), 0 1px 4px rgba(0, 0, 0, 0.25);
}

.ce-page-header--image .ce-breadcrumb__link {
  opacity: 0.85;
}

.ce-page-header--image .ce-breadcrumb__link:hover {
  opacity: 1;
  text-decoration: underline;
}

/* --- Fix C: Style-Switcher Position ---
 * Ueberlagert keinen Content mehr, positioniert sich korrekt
 * neben der fixed Navigation (links oben, unter der Nav).
 * Ueberschreibt Sektion 26 (top:50%, right:0, transform).
 */


/* --- Fix D: Konsistente News-Featured Karte in news.php ---
 * lotte-news-featured__image ohne feste aspect-ratio Probleme
 */
.lotte-news-featured__image {
  overflow: hidden;
  border-radius: var(--min-radius-md);
}

.lotte-news-featured__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.lotte-news-featured__body {
  padding: var(--min-space-lg) 0;
}

/* --- Fix E: Tag/Badge Einheitlichkeit ---
 * Alle Kategorie-Tags auf denselben Radius (behördengerecht)
 * Kein pill/rund mehr (war 9999px)
 */
.lotte-news-featured__category,
.news-featured__category,
.topic-card__tag,
.lotte-topic-card__tag {
  border-radius: var(--min-radius-sm);
}

/* Suche-Tags in Mosaic: minimal gerundet */
.lotte-mosaic-search-tags a,
.service-search-hints a,
.lotte-service-search-hints a {
  border-radius: var(--min-radius-sm);
}

/* Suchfeld-Wrapper: leicht gerundet statt pill */
.lotte-mosaic-search {
  border-radius: var(--min-radius-md);
}

/* Back-to-Top: darf quadratisch bleiben, leicht gerundet */
.back-to-top {
  border-radius: var(--min-radius-md);
}

/* --- Fix F: Hero Ueberlappung mit fixed Nav ---
 * ce-hero streckt sich bis zum Viewport-Top.
 * Mit body padding-top bekommt er extra Raum - das nehmen wir zurueck
 * und nutzen den margin-top aus mandant.css.
 * Zusaetzlich: min-height korrigieren damit der Hero
 * immer noch gut aussieht.
 */
:is(.ce-hero, .min-hero),
.hero,
.page-hero {
  /* Volle Viewport-Hoehe MINUS Nav-Hoehe = sichtbarer Hero */
  min-height: calc(var(--min-hero-height, 75vh) - 0px);
}

/* --- Fix G: Parallax-Divider Bild-Fix ---
 * background-attachment: fixed funktioniert nicht auf mobilen Geraeten
 */
@media (max-width: 768px) {
  .parallax-divider {
    background-attachment: scroll;
  }
}

/* --- Fix H: ce-two-col Layout-Konflikt ---
 * In custom.css und style.css gibt es beide .ce-two-col Definitionen.
 * Die aus custom.css ist breiter definiert (1fr 320px) und passt fuer
 * Unterseiten (Hauptinhalt + Sidebar).
 * Stellen wir sicher dass sie nicht von .ce-two-col aus layout.css
 * (1fr 1fr) ueberschrieben wird.
 */
.ce-content-section .ce-two-col {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .ce-content-section .ce-two-col {
    grid-template-columns: 1fr 320px;
    align-items: start;
  }
}

/* ==========================================================================
 * 22. NEWS GRID (Startseite - 2x3 mit Foto)
 * Kundenvorgabe: 6 Meldungen im 2x3 Grid, jeweils mit Foto
 * ========================================================================== */

.lotte-news-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-md, 1rem);
}

@media (min-width: 640px) {
  .lotte-news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .lotte-news-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.lotte-news-card {
  background: var(--mandant-bg, #fff);
  border: 1px solid var(--mandant-border, #ccc);
  border-radius: var(--mandant-radius-md, 4px);
  overflow: hidden;
  transition: box-shadow var(--mandant-transition, 250ms ease), transform var(--mandant-transition, 250ms ease);
}

.lotte-news-card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.lotte-news-card__image {
  aspect-ratio: 16/10;
  overflow: hidden;
}

.lotte-news-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.lotte-news-card:hover .lotte-news-card__image img {
  transform: scale(1.04);
}

.lotte-news-card__body {
  padding: var(--min-space-md, 1rem);
}

.lotte-news-card__date {
  font-size: 0.875rem;
  color: var(--mandant-muted, #4a4a4a);
  margin-bottom: var(--min-space-xs, 0.25rem);
}

.lotte-news-card__title {
  font-size: 1rem;
  font-weight: var(--min-font-weight-bold, 700);
  line-height: var(--min-line-height-heading, 1.3);
  margin-bottom: var(--min-space-xs, 0.25rem);
}

.lotte-news-card__title a {
  color: var(--mandant-text, #1a1a1a);
  text-decoration: none;
}

.lotte-news-card__title a:hover {
  color: var(--mandant-primary, #145675);
}

.lotte-news-card__excerpt {
  font-size: 0.875rem;
  color: var(--mandant-muted, #4a4a4a);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ==========================================================================
 * 23. EVENT GRID (Startseite - mit Foto)
 * Kundenvorgabe: Events mit Foto optimiert
 * ========================================================================== */

.lotte-event-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--min-space-md, 1rem);
}

@media (min-width: 640px) {
  .lotte-event-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .lotte-event-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.lotte-event-card {
  background: var(--mandant-bg, #fff);
  border: 1px solid var(--mandant-border, #ccc);
  border-radius: var(--mandant-radius-md, 4px);
  overflow: hidden;
  transition: box-shadow var(--mandant-transition, 250ms ease), transform var(--mandant-transition, 250ms ease);
}

.lotte-event-card:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
  transform: translateY(-2px);
}

.lotte-event-card__image {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
}

.lotte-event-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.lotte-event-card__date-badge {
  position: absolute;
  top: var(--min-space-sm, 0.5rem);
  left: var(--min-space-sm, 0.5rem);
  background: var(--mandant-primary, #145675);
  color: #fff;
  border-radius: var(--mandant-radius-md, 4px);
  padding: var(--min-space-xs, 0.25rem) var(--min-space-sm, 0.5rem);
  text-align: center;
  line-height: 1.2;
}

.lotte-event-card__date-day {
  display: block;
  font-size: 1.125rem;
  font-weight: var(--min-font-weight-bold, 700);
}

.lotte-event-card__date-month {
  display: block;
  font-size: 0.875rem;
  text-transform: uppercase;
}

.lotte-event-card__body {
  padding: var(--min-space-md, 1rem);
}

.lotte-event-card__title {
  font-size: 1rem;
  font-weight: var(--min-font-weight-bold, 700);
  line-height: var(--min-line-height-heading, 1.3);
  margin-bottom: var(--min-space-xs, 0.25rem);
}

.lotte-event-card__title a {
  color: var(--mandant-text, #1a1a1a);
  text-decoration: none;
}

.lotte-event-card__title a:hover {
  color: var(--mandant-primary, #145675);
}

.lotte-event-card__meta {
  font-size: 0.875rem;
  color: var(--mandant-muted, #4a4a4a);
}

/* ==========================================================================
 * 24. SECTION HEADING (Shared: alle Varianten)
 * ========================================================================== */

.lotte-section-heading {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: var(--min-font-weight-bold, 700);
  line-height: var(--min-line-height-heading, 1.3);
  margin-bottom: var(--min-space-lg, 2rem);
}

/* ==========================================================================
 * 25. STATS BAR (Shared)
 * ========================================================================== */

.lotte-stats {
  padding: var(--min-space-2xl, 3rem) 0;
  background: var(--mandant-primary, #145675);
  color: #fff;
}

.lotte-stats__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--min-space-md, 1rem);
}

@media (min-width: 768px) {
  .lotte-stats__grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.lotte-stats .lotte-stat__number {
  color: #fff;
}

.lotte-stats .lotte-stat__label {
  color: rgba(255, 255, 255, 0.85);
}

.lotte-stat {
  text-align: center;
  padding: var(--min-space-lg, 2rem) var(--min-space-md, 1rem);
}

.lotte-stat__number {
  display: block;
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: var(--min-font-weight-bold, 700);
  color: var(--mandant-primary, #145675);
  line-height: 1;
  margin-bottom: var(--min-space-xs, 0.25rem);
}

.lotte-stat__label {
  font-size: 0.875rem;
  color: var(--mandant-muted, #4a4a4a);
}

/* ==========================================================================
 * 26. CTA BAR (Startseite)
 * ========================================================================== */

.lotte-cta-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--min-space-md, 1rem);
  padding: var(--min-space-lg, 2rem);
  text-align: center;
}

.lotte-cta-bar p {
  font-size: 1.125rem;
  font-weight: var(--min-font-weight-medium, 500);
}

/* ==========================================================================
 * 27. FOOTER EXTRAS (Social, App, A11y, ChatBot, Weather)
 * ========================================================================== */

.lotte-footer-social {
  display: flex;
  gap: var(--min-space-md, 1rem);
  margin-bottom: var(--min-space-lg, 1.5rem);
}

.lotte-footer-social__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--mandant-radius-md, 4px);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.85);
  transition: background var(--mandant-transition, 250ms ease), color var(--mandant-transition, 250ms ease);
}

.lotte-footer-social__link:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.lotte-footer-app {
  margin-top: var(--min-space-md, 1rem);
}

.lotte-footer-app__label {
  font-size: 0.875rem;
  font-weight: var(--min-font-weight-bold, 700);
  margin-bottom: var(--min-space-xs, 0.25rem);
}

.lotte-footer-app__links {
  display: flex;
  gap: var(--min-space-md, 1rem);
}

.lotte-footer-app__links a {
  display: inline-flex;
  align-items: center;
  gap: var(--min-space-xs, 0.25rem);
}

.lotte-footer-a11y {
  display: flex;
  flex-direction: column;
  gap: var(--min-space-sm, 0.5rem);
  margin-top: var(--min-space-lg, 1.5rem);
  padding-top: var(--min-space-md, 1rem);
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.lotte-footer-a11y a {
  display: inline-flex;
  align-items: center;
  gap: var(--min-space-xs, 0.25rem);
  font-size: 0.875rem;
}

.lotte-footer-weather {
  display: inline-flex;
  align-items: center;
  gap: var(--min-space-xs, 0.25rem);
  font-size: 0.875rem;
  opacity: 0.75;
}

/* ==========================================================================
 * 28. CHATBOT (fixed, unten rechts)
 * ========================================================================== */

.lotte-chatbot {
  position: fixed;
  bottom: var(--min-space-lg, 2rem);
  right: var(--min-space-lg, 2rem);
  z-index: 1000;
}

.lotte-chatbot__trigger {
  width: 56px;
  height: 56px;
  border-radius: var(--mandant-radius-lg, 6px);
  background: var(--mandant-primary, #145675);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
  transition: background var(--mandant-transition, 250ms ease), transform var(--mandant-transition, 250ms ease);
}

.lotte-chatbot__trigger:hover {
  background: color-mix(in srgb, var(--mandant-primary, #145675) 80%, black);
  transform: scale(1.05);
}

.lotte-chatbot__panel {
  position: absolute;
  bottom: calc(100% + var(--min-space-md, 1rem));
  right: 0;
  width: 320px;
  max-height: 400px;
  background: var(--mandant-bg, #fff);
  border: 1px solid var(--mandant-border, #ccc);
  border-radius: var(--mandant-radius-md, 4px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}

.lotte-chatbot__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--min-space-md, 1rem);
  background: var(--mandant-primary, #145675);
  color: #fff;
  font-weight: var(--min-font-weight-bold, 700);
}

.lotte-chatbot__close {
  background: none;
  border: none;
  color: #fff;
  font-size: 1.25rem;
  cursor: pointer;
  line-height: 1;
}

.lotte-chatbot__body {
  padding: var(--min-space-lg, 1.5rem);
  font-size: 0.9375rem;
  color: var(--mandant-text, #1a1a1a);
}

/* Mobile: ChatBot kleinere Position */
@media (max-width: 479px) {
  .lotte-chatbot {
    bottom: var(--min-space-md, 1rem);
    right: var(--min-space-md, 1rem);
  }

  .lotte-chatbot__trigger {
    width: 48px;
    height: 48px;
  }

  .lotte-chatbot__panel {
    width: calc(100vw - 2rem);
    right: calc(-1 * var(--min-space-md, 1rem));
  }
}

/* ==========================================================================
 * 29. LOTTE BUTTON (Shared)
 * ========================================================================== */

.lotte-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--min-space-sm, 0.5rem);
  padding: 0.75rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: var(--min-font-weight-medium, 500);
  text-decoration: none;
  border-radius: var(--mandant-radius-md, 4px);
  border: 2px solid transparent;
  cursor: pointer;
  transition: background var(--mandant-transition, 250ms ease), color var(--mandant-transition, 250ms ease), border-color var(--mandant-transition, 250ms ease);
}

.lotte-btn--primary {
  background: var(--mandant-primary, #145675);
  color: #fff;
  border-color: var(--mandant-primary, #145675);
}

.lotte-btn--primary:hover {
  background: color-mix(in srgb, var(--mandant-primary, #145675) 80%, black);
  border-color: color-mix(in srgb, var(--mandant-primary, #145675) 80%, black);
}

.lotte-btn--outline {
  background: transparent;
  color: var(--mandant-primary, #145675);
  border-color: var(--mandant-primary, #145675);
}

.lotte-btn--outline:hover {
  background: var(--mandant-primary, #145675);
  color: #fff;
}

.lotte-btn--secondary {
  background: var(--mandant-secondary, #84BD00);
  color: #fff;
  border-color: var(--mandant-secondary, #84BD00);
}

.lotte-btn--secondary:hover {
  background: color-mix(in srgb, var(--mandant-secondary, #84BD00) 80%, black);
  border-color: color-mix(in srgb, var(--mandant-secondary, #84BD00) 80%, black);
}

.lotte-btn--white {
  background: #fff;
  color: var(--mandant-primary, #145675);
  border-color: #fff;
}

.lotte-btn--white:hover {
  background: var(--mandant-surface, #f5f8fa);
  border-color: var(--mandant-surface, #f5f8fa);
}


/* ==========================================================================
 * DARK MODE – custom.css
 * Gemeinsame Lotte-Komponenten: Page-Header, Sidebar, Cards, Forms,
 * Chatbot, Style-Switcher, Mosaic-Dashboard, News/Event-Karten.
 * Aktivierung: prefers-color-scheme:dark ODER [data-theme="dark"]
 *
 * Strategie: Komponenten die --min-color-* Variablen nutzen,
 * greifen automatisch via style.css Dark-Mode-Block.
 * Nur hardcodierte white/black/Hex-Farben müssen überschrieben werden.
 * ========================================================================== */

/* Smooth Body-Transition */
body {
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Wir nutzen einen kombinierten Selektor-Ansatz via :is() für DRY-Code */

/* --- Page-Header --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .page-header {
    background: var(--min-color-surface);
  }
}

[data-theme="dark"] .page-header {
  background: var(--min-color-surface);
}

/* --- Sidebar-Elemente --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .sidebar-section,
  :root:not([data-theme="light"]) .lotte-sidebar__section,
  :root:not([data-theme="light"]) .sidebar-card,
  :root:not([data-theme="light"]) .lotte-sidebar-card {
    background: var(--min-color-surface);
  }
}

[data-theme="dark"] .sidebar-section,
[data-theme="dark"] .lotte-sidebar__section,
[data-theme="dark"] .sidebar-card,
[data-theme="dark"] .lotte-sidebar-card {
  background: var(--min-color-surface);
}

/* --- Generische Card --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .card {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
  }
}

[data-theme="dark"] .card {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
}

/* --- Form-Inputs: background: white --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .form-input,
  :root:not([data-theme="light"]) .form-select {
    background: var(--min-color-surface);
    color: var(--min-color-text);
    border-color: var(--min-color-border);
  }
  :root:not([data-theme="light"]) .service-search-form__input,
  :root:not([data-theme="light"]) .lotte-service-search-form__input {
    background: var(--min-color-surface);
    color: var(--min-color-text);
    border-color: var(--min-color-border);
  }
}

[data-theme="dark"] .form-input,
[data-theme="dark"] .form-select {
  background: var(--min-color-surface);
  color: var(--min-color-text);
  border-color: var(--min-color-border);
}

[data-theme="dark"] .service-search-form__input,
[data-theme="dark"] .lotte-service-search-form__input {
  background: var(--min-color-surface);
  color: var(--min-color-text);
  border-color: var(--min-color-border);
}

/* --- Rubrik-Cards --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .rubrik-card,
  :root:not([data-theme="light"]) .lotte-rubrik-card {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
  }
}

[data-theme="dark"] .rubrik-card,
[data-theme="dark"] .lotte-rubrik-card {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
}

/* --- Feature-Cards --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .feature-card {
    background: var(--min-color-surface);
  }
}

[data-theme="dark"] .feature-card {
  background: var(--min-color-surface);
}

/* --- Info-Box / Notice: white hintergrund --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .info-box {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
  }
  :root:not([data-theme="light"]) .info-box--info {
    background: color-mix(in srgb, var(--min-color-secondary) 8%, var(--min-color-surface));
  }
  :root:not([data-theme="light"]) .notice {
    background: color-mix(in srgb, var(--min-color-accent) 8%, var(--min-color-surface));
    border-color: color-mix(in srgb, var(--min-color-accent) 20%, transparent);
  }
  :root:not([data-theme="light"]) .notice--info {
    background: color-mix(in srgb, var(--min-color-primary) 8%, var(--min-color-surface));
  }
}

[data-theme="dark"] .info-box {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
}

[data-theme="dark"] .info-box--info {
  background: color-mix(in srgb, var(--min-color-secondary) 8%, var(--min-color-surface));
}

[data-theme="dark"] .notice {
  background: color-mix(in srgb, var(--min-color-accent) 8%, var(--min-color-surface));
  border-color: color-mix(in srgb, var(--min-color-accent) 20%, transparent);
}

[data-theme="dark"] .notice--info {
  background: color-mix(in srgb, var(--min-color-primary) 8%, var(--min-color-surface));
}

/* --- Style-Switcher: background: white --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) 
  :root:not([data-theme="light"]) 
}

[data-theme="dark"] 

[data-theme="dark"] 

/* --- Hero-Suchfeld: background: white --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .hero__search input {
    background: rgba(255, 255, 255, 0.15);
    color: #ffffff;
  }
  :root:not([data-theme="light"]) .hero__search input::placeholder {
    color: rgba(255, 255, 255, 0.55);
  }
}

[data-theme="dark"] .hero__search input {
  background: rgba(255, 255, 255, 0.15);
  color: #ffffff;
}

[data-theme="dark"] .hero__search input::placeholder {
  color: rgba(255, 255, 255, 0.55);
}

/* --- Chatbot-Panel: background: white/var(--mandant-bg) --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .lotte-chatbot__panel {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
  }
  :root:not([data-theme="light"]) .lotte-chatbot__body {
    color: var(--min-color-text);
  }
}

[data-theme="dark"] .lotte-chatbot__panel {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .lotte-chatbot__body {
  color: var(--min-color-text);
}

/* --- Mosaic-Dashboard-Tiles: background: white --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .lotte-mosaic-tile {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
  }
  :root:not([data-theme="light"]) .lotte-mosaic-tile--welcome {
    background: var(--min-color-bg);
  }
  :root:not([data-theme="light"]) .lotte-mosaic-search {
    background: var(--min-color-bg);
    border-color: var(--min-color-border);
  }
  :root:not([data-theme="light"]) .lotte-mosaic-search input {
    color: var(--min-color-text);
  }
}

[data-theme="dark"] .lotte-mosaic-tile {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
}

[data-theme="dark"] .lotte-mosaic-tile--welcome {
  background: var(--min-color-bg);
}

[data-theme="dark"] .lotte-mosaic-search {
  background: var(--min-color-bg);
  border-color: var(--min-color-border);
}

[data-theme="dark"] .lotte-mosaic-search input {
  color: var(--min-color-text);
}

/* --- News-Karten (lotte-news-card) --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .lotte-news-card {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
  }
}

[data-theme="dark"] .lotte-news-card {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
}

/* --- Event-Karten (lotte-event-card) --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .lotte-event-card {
    background: var(--min-color-surface);
    border-color: var(--min-color-border);
  }
}

[data-theme="dark"] .lotte-event-card {
  background: var(--min-color-surface);
  border-color: var(--min-color-border);
}

/* --- Weißer Lotte-Button --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .lotte-btn--white {
    background: var(--min-color-surface);
    color: var(--min-color-text);
    border-color: var(--min-color-border);
  }
  :root:not([data-theme="light"]) .lotte-btn--white:hover {
    background: var(--min-color-bg);
    border-color: var(--min-color-primary);
    color: var(--min-color-primary);
  }
}

[data-theme="dark"] .lotte-btn--white {
  background: var(--min-color-surface);
  color: var(--min-color-text);
  border-color: var(--min-color-border);
}

[data-theme="dark"] .lotte-btn--white:hover {
  background: var(--min-color-bg);
  border-color: var(--min-color-primary);
  color: var(--min-color-primary);
}

/* --- Btn --outline (transparent auf hell): auf dunkel Farbe anpassen --- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .btn--outline {
    color: #7ec8e3;
    border-color: #7ec8e3;
  }
  :root:not([data-theme="light"]) .btn--outline:hover {
    background: #145675;
    color: #ffffff;
  }
  :root:not([data-theme="light"]) .btn--ghost {
    color: var(--min-color-muted);
    border-color: var(--min-color-border);
  }
  :root:not([data-theme="light"]) .btn--ghost:hover {
    background: var(--min-color-surface);
  }
}

[data-theme="dark"] .btn--outline {
  color: #7ec8e3;
  border-color: #7ec8e3;
}

[data-theme="dark"] .btn--outline:hover {
  background: #145675;
  color: #ffffff;
}

[data-theme="dark"] .btn--ghost {
  color: var(--min-color-muted);
  border-color: var(--min-color-border);
}

[data-theme="dark"] .btn--ghost:hover {
  background: var(--min-color-surface);
}

} /* end @layer mandant */

/* ==========================================================================
 * STYLEGUIDE CHROME – Gemeinde Lotte Design
 * AUSSERHALB @layer mandant — muss unlayered style.css sg-* überschreiben
 *
 * SCHRIFT-REGEL: 1.25rem (20px) als EINHEITLICHE Basis.
 * Kein Größen-Chaos: Absätze, Listen, Beschreibungen = alle 1.25rem.
 * Code-Bloecke duerfen auf 1rem reduziert sein (Lesbarkeit).
 * Tabellen-Header: klein + uppercase = Label-Charakter, nicht Fliesstext.
 * KEINE opacity-Tricks — Farbe statt Opacity, Text IMMER voll sichtbar.
 * Textfarbe: #1a1a1a (vollfarbig schwarz), keine ausgegrauten Absätze.
 * ========================================================================== */

/* -- Styleguide Sub-Navigation -------------------------------------------- */

.sg-nav {
  display: flex;
  gap: 0;
  padding: 0;
  background: var(--cone, #145675);
  border-bottom: 3px solid var(--ctwo, #84BD00);
  flex-wrap: wrap;
  align-items: stretch;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.sg-nav__brand {
  font-weight: 700;
  font-size: 1.125rem;
  text-decoration: none;
  color: #fff;
  padding: 0.75rem 1.25rem;
  margin-right: 0;
  background: rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: center;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.sg-nav__link {
  text-decoration: none;
  color: rgba(255, 255, 255, 0.85);
  padding: 0.75rem 1.125rem;
  border-radius: 0;
  font-size: 1rem;
  font-weight: 500;
  transition: background 200ms ease, color 200ms ease;
  display: flex;
  align-items: center;
  border-bottom: 3px solid transparent;
  margin-bottom: -3px;
}

.sg-nav__link:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  border-bottom-color: rgba(255, 255, 255, 0.4);
}

.sg-nav__link--active {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
  font-weight: 700;
  border-bottom-color: var(--ctwo, #84BD00);
}

/* -- Styleguide Main Container -------------------------------------------- */

.sg-main {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.5rem 2rem 4rem;
  font-size: 1.25rem;
  line-height: 1.7;
  color: #1a1a1a;
}

/* Alle Fliesstext-Elemente: einheitlich 1.25rem, kein Größen-Chaos */
.sg-main p,
.sg-main li,
.sg-main ul,
.sg-main ol {
  font-size: 1.25rem;
  line-height: 1.7;
  color: #1a1a1a;
}

.sg-main > h1 {
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 700;
  color: var(--cone, #145675);
  margin-bottom: 0.75rem;
  line-height: 1.2;
}

.sg-main section {
  margin-bottom: 2.5rem;
}

.sg-main h2 a {
  text-decoration: none;
  color: var(--cone, #145675);
  transition: color 200ms ease;
}

.sg-main h2 a:hover {
  color: var(--ctwo, #84BD00);
}

.sg-main ul {
  padding-left: 1.25rem;
  list-style: none;
}

.sg-main li {
  margin-bottom: 0.5rem;
  position: relative;
  padding-left: 1rem;
}

.sg-main li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 6px;
  height: 6px;
  background: var(--ctwo, #84BD00);
  border-radius: 50%;
}

.sg-main li a {
  color: var(--cone, #145675);
  text-decoration: none;
  font-weight: 500;
  font-size: 1.25rem;
}

.sg-main li a:hover {
  text-decoration: underline;
  text-decoration-color: var(--ctwo, #84BD00);
  text-underline-offset: 3px;
}

/* -- Element Block -------------------------------------------------------- */

.sg-element {
  margin-bottom: 3.5rem;
  border-bottom: none;
  padding-bottom: 3rem;
  position: relative;
}

.sg-element::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    to right,
    var(--cone, #145675) 0%,
    var(--ctwo, #84BD00) 30%,
    transparent 100%
  );
}

.sg-element > h2 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--cone, #145675);
  margin-bottom: 0.75rem;
  padding-left: 1rem;
  border-left: 4px solid var(--ctwo, #84BD00);
}

/* -- Description ---------------------------------------------------------- */

.sg-description {
  font-size: 1.25rem;
  color: #1a1a1a;
  margin-bottom: 1.5rem;
  line-height: 1.7;
  max-width: 72ch;
}

.sg-description code {
  background: color-mix(in srgb, var(--cone, #145675) 8%, transparent);
  color: var(--cone, #145675);
  padding: 0.15em 0.4em;
  border-radius: 3px;
  font-size: 0.85em;
  font-family: ui-monospace, 'Cascadia Code', 'Fira Code', monospace;
  font-weight: 500;
}

/* -- Variant -------------------------------------------------------------- */

.sg-variant {
  margin-bottom: 2.5rem;
}

.sg-variant h3 {
  font-size: 1.375rem;
  font-weight: 600;
  color: var(--cone, #145675);
  margin-bottom: 0.5rem;
}

/* Variant-Beschreibungs-Absatz: einheitlich, vollfarbig */
.sg-variant > h3 + p,
.sg-variant > h3 + .sg-description {
  font-size: 1.25rem;
  color: #1a1a1a;
  margin-bottom: 1rem;
}

/* -- Preview Container ---------------------------------------------------- */

.sg-preview {
  border: 1px solid color-mix(in srgb, var(--cone, #145675) 15%, transparent);
  border-radius: var(--min-radius-sm, 2px);
  overflow: hidden;
  margin-bottom: 0.75rem;
  position: relative;
  /* Animations-Ausgangsstate (wird per IntersectionObserver gesteuert) */
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 450ms ease, transform 450ms ease;
}

.sg-preview--visible {
  opacity: 1;
  transform: translateY(0);
}

.sg-preview::before {
  content: "Vorschau";
  position: absolute;
  top: 0;
  right: 0;
  background: var(--cone, #145675);
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 0.2rem 0.6rem;
  border-radius: 0 0 0 var(--min-radius-sm, 2px);
  z-index: 2;
}

/* Reduced motion: sofort sichtbar, keine Animation */
@media (prefers-reduced-motion: reduce) {
  .sg-preview {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* -- Code Block ----------------------------------------------------------- */

.sg-code {
  margin-top: 0.75rem;
}

.sg-code summary {
  cursor: pointer;
  font-size: 1rem;
  font-weight: 600;
  color: var(--cone, #145675);
  padding: 0.5rem 0.875rem;
  background: color-mix(in srgb, var(--cone, #145675) 6%, transparent);
  border-radius: var(--min-radius-sm, 2px);
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  transition: background 200ms ease;
  user-select: none;
}

.sg-code summary:hover {
  background: color-mix(in srgb, var(--cone, #145675) 12%, transparent);
}

.sg-code summary::marker {
  color: var(--ctwo, #84BD00);
}

.sg-code[open] summary {
  border-radius: var(--min-radius-sm, 2px) var(--min-radius-sm, 2px) 0 0;
  margin-bottom: 0;
}

.sg-code pre {
  background: #1a2332;
  color: #e0e8f0;
  padding: 1.25rem 1rem;
  overflow-x: auto;
  /* Code darf kleiner sein – bessere Lesbarkeit langer Zeilen */
  font-size: 1rem;
  margin-top: 0;
  font-family: ui-monospace, 'Cascadia Code', 'Fira Code', monospace;
  line-height: 1.6;
  border-radius: 0 0 var(--min-radius-sm, 2px) var(--min-radius-sm, 2px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: none;
}

.sg-code pre code {
  background: none;
  color: inherit;
  padding: 0;
  font-size: inherit;
}

/* -- Properties Table ----------------------------------------------------- */

.sg-props {
  width: 100%;
  border-collapse: collapse;
  font-size: 1rem;
  margin-top: 0.75rem;
  border: 1px solid color-mix(in srgb, var(--cone, #145675) 12%, transparent);
  border-radius: var(--min-radius-sm, 2px);
  overflow: hidden;
}

.sg-props th,
.sg-props td {
  padding: 0.625rem 0.875rem;
  border: 1px solid color-mix(in srgb, var(--cone, #145675) 8%, transparent);
  text-align: left;
}

.sg-props th {
  background: color-mix(in srgb, var(--cone, #145675) 8%, transparent);
  color: var(--cone, #145675);
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Tabellen-Zellen: 1.125rem — etwas kleiner als Fliesstext, aber gut lesbar */
.sg-props td {
  font-size: 1.125rem;
  color: #1a1a1a;
}

.sg-props td code {
  background: color-mix(in srgb, var(--cone, #145675) 6%, transparent);
  color: var(--cone, #145675);
  padding: 0.1em 0.35em;
  border-radius: 2px;
  font-size: 0.9em;
  font-family: ui-monospace, 'Cascadia Code', 'Fira Code', monospace;
}

.sg-props tr:nth-child(even) td {
  background: color-mix(in srgb, var(--cone, #145675) 3%, transparent);
}

/* -- Styleguide Overview (styleguide.php) Sections ------------------------ */

.sg-main > section > h2 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--cone, #145675);
}

.sg-main > section > h2 a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.sg-main > section > h2 a::after {
  content: "\2192";
  font-size: 0.875em;
  color: var(--ctwo, #84BD00);
  transition: transform 200ms ease;
}

.sg-main > section > h2 a:hover::after {
  transform: translateX(4px);
}

/* -- Responsive ----------------------------------------------------------- */

@media (max-width: 768px) {
  .sg-nav {
    gap: 0;
  }

  .sg-nav__brand {
    width: 100%;
    padding: 0.625rem 1rem;
    font-size: 1rem;
  }

  .sg-nav__link {
    font-size: 0.875rem;
    padding: 0.5rem 0.75rem;
  }

  .sg-main {
    padding: 1.5rem 1rem 3rem;
    font-size: 1.125rem;
  }

  .sg-main p,
  .sg-main li,
  .sg-main ul,
  .sg-main ol,
  .sg-description,
  .sg-variant > h3 + p,
  .sg-variant > h3 + .sg-description,
  .sg-main li a {
    font-size: 1.125rem;
  }

  .sg-element > h2 {
    font-size: 1.5rem;
  }

  .sg-variant h3 {
    font-size: 1.25rem;
  }
}

/* -- Verfuegbare Bilder Grid (Styleguide Overview) ------------------------ */

.sg-main section:last-child figure img {
  border-color: color-mix(in srgb, var(--cone, #145675) 15%, transparent);
}

.sg-main section:last-child figcaption {
  color: var(--cone, #145675);
  font-weight: 500;
}

/* -- Lotte News: template values without inline styles --------------------- */

.lotte-news-actions {
  margin-top: 2rem;
}

.lotte-news-actions--large {
  margin-top: 2.5rem;
}

.lotte-news-actions--center {
  text-align: center;
}

.lotte-news-filter-bar {
  background: var(--min-color-surface);
  border-bottom: 1px solid var(--min-color-border);
}

.lotte-news-filter-row,
.lotte-news-filter-form {
  align-items: center;
}

.lotte-news-search-input {
  width: 200px;
  max-width: 100%;
  padding: var(--min-space-sm) 0.75rem;
}

.lotte-news-featured--raised {
  border: none;
  box-shadow: var(--min-shadow-lg);
}

.lotte-news-featured__image--wide {
  aspect-ratio: 21 / 9;
}

.lotte-news-featured__title--index {
  font-size: 1.5rem;
}

.lotte-news-badge {
  display: inline-block;
  padding: var(--min-space-xs) 0.75rem;
  border-radius: var(--min-radius-sm);
  font-size: var(--min-font-sm);
  font-weight: var(--min-weight-semibold);
  line-height: 1.4;
}

.lotte-news-badge--secondary {
  background: var(--min-color-secondary);
  color: #fff;
}

.lotte-news-badge--primary-soft {
  background: color-mix(in srgb, var(--min-color-primary) 15%, transparent);
  color: var(--min-color-primary);
  padding: 2px 8px;
  font-size: 0.8125rem;
  font-weight: 500;
}

/* -- Badges (news categories) --------------------------------------------- */

.ce-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--min-radius-full);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.4;
}

.ce-badge--warm {
  background: var(--min-bg-warm, #fef3c7);
  color: var(--min-color-warm-text, #92400e);
}

.ce-badge--cool {
  background: var(--min-bg-cool, #dbeafe);
  color: var(--min-color-cool-text, #1e40af);
}

/* -- Table head row ------------------------------------------------------- */

.ce-table__head {
  background: var(--min-color-primary);
  color: #fff;
}

/* ==========================================================================
 * Brief 698 (2026-06-08) — Floating-Button Footer-Safe-Area (Befund B4/656)
 * AUSSERHALB @layer mandant — Override muss die @layer-mandant-Footer-Regeln
 * schlagen; bridge.css setzt keine .lotte-footer__bottom-Geometrie.
 *
 * Problem: Die fixen Floating-Buttons (Styleswitcher unten links,
 * bottom:2rem + 3rem hoch reservieren ~5rem Safe-Zone; Optigov-Bubble rechts)
 * überdecken auf kurzen Seiten den Footer-Inhalt (Copyright/Adresse/Legal).
 * Lösung: Reserviert eine Safe-Area am Footer-Boden, so dass der unterste
 * Footer-Text immer oberhalb der Button-Zone in beiden Ecken liegt. Auf
 * langen Seiten ist es ein dezenter dunkler Streifen am Footer-Ende.
 * ========================================================================== */
.lotte-footer__bottom {
  /* Styleswitcher: bottom 2rem + 3rem hoch = 80px Footprint; Optigov-Bubble
   * ähnlich. 8rem (128px) hält den untersten Footer-Text auch auf sehr kurzen
   * Desktop-Seiten über der Button-Zone in beiden Ecken. */
  padding-bottom: 8rem;
}
