/* ═══════════════════════════════════════════════════════════════════════════
   DARK MODE — Studio Pellio
   Shared dark mode CSS for all pages
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─ Color overrides ─ */
[data-theme="dark"] {
  --ink: #E8E8EE;
  --ink-mid: #9BA0AE;
  --white: #0E1117;
  --off: #161A23;
  --rule: rgba(255,255,255,0.07);
}

/* ─ Page transitions ─ */
body { transition: background 0.4s, color 0.4s; }

/* ─ Navigation ─ */
[data-theme="dark"] #nav,
[data-theme="dark"] #nav.bg { background: rgba(14,17,23,0.92); backdrop-filter: blur(16px); }
[data-theme="dark"] .nav-logo { color: var(--ink); }
[data-theme="dark"] .nav-logo:hover { color: var(--green); }
[data-theme="dark"] .nav-lnk.active { color: var(--green); }
[data-theme="dark"] .mobile-menu { background: #0a0d12; }

/* ─ Green Buttons: Text bleibt immer dunkel ─ */
[data-theme="dark"] .btn-green,
[data-theme="dark"] .btn-green-lg,
[data-theme="dark"] .nav-cta,
[data-theme="dark"] .mm-cta,
[data-theme="dark"] .ft-cta .btn-green-lg { color: #151D2C; }

/* ─ Blue Buttons/Links: weiße Schrift oder grün ─ */
[data-theme="dark"] .btn-blue,
[data-theme="dark"] a.btn-blue { color: #fff; }

/* ─ Kliniken-Badge ─ */
[data-theme="dark"] .klinik-badge { color: #FFFFFF; }

/* ─ Footer ─ */
[data-theme="dark"] .ft-brand-name { color: rgba(255,255,255,0.2); }
[data-theme="dark"] .ft-link { color: rgba(255,255,255,0.25); }
[data-theme="dark"] .ft-link:hover { color: var(--ink); }

/* ─ Images ─ */
[data-theme="dark"] img { opacity: 0.92; }

/* ─ Sidebar ─ */
[data-theme="dark"] .site-sidebar { background: var(--white); border-color: var(--rule); }
[data-theme="dark"] .ss-link.active { color: var(--green); background: rgba(0,255,12,0.06); }
[data-theme="dark"] .ss-pip { background: var(--green); }
[data-theme="dark"] .ss-link.active .ss-num { color: var(--green); }

/* ─ Manifesto scroll text ─ */
[data-theme="dark"] .m-word { color: #2A2E38; }

/* ─ Leistungen: grüne Nummern + grüne Chips ─ */
[data-theme="dark"] .svc-n { color: var(--green); }
[data-theme="dark"] .svc-tag {
  color: var(--green) !important;
  border-color: rgba(0,255,12,0.3) !important;
  background: rgba(0,255,12,0.06) !important;
}

/* ─ Floating Chips im Hero ─ */
[data-theme="dark"] .chip {
  background: var(--white); color: rgba(255,255,255,0.6);
  border-color: rgba(255,255,255,0.12); box-shadow: 0 2px 12px rgba(0,0,0,0.2);
}

/* ─ Clients/About Section: bleibt dunkel ─ */
[data-theme="dark"] #clients-about { background: #0a0d12; }
[data-theme="dark"] .ca-h { color: #fff; }
[data-theme="dark"] .ca-body { color: rgba(255,255,255,0.58); }
[data-theme="dark"] .ca-tag { color: rgba(255,255,255,0.38); }
[data-theme="dark"] .cl-row { color: rgba(255,255,255,0.75); }
[data-theme="dark"] .cl-cat { color: rgba(255,255,255,0.3); }

/* ─ Case Study Section ─ */
[data-theme="dark"] #case-study { background: var(--blue); }

/* ═══════════════════════════════════════════════════════════════════════════
   BLOG — Featured Cards (dark bg, normally inverted badly)
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="dark"] .featured-card {
  background: #0a0d12;
  border: 1px solid rgba(255,255,255,0.06);
}
[data-theme="dark"] .featured-card-title { color: #fff; }
[data-theme="dark"] .featured-card-excerpt { color: rgba(255,255,255,0.55); }
[data-theme="dark"] .featured-card-tag {
  color: var(--green);
  border-color: rgba(0,255,12,0.25);
}
[data-theme="dark"] .featured-card-time { color: rgba(255,255,255,0.35); }

/* ═══════════════════════════════════════════════════════════════════════════
   CASES — Filter Chips, Case Tags, Popup
   ═══════════════════════════════════════════════════════════════════════════ */
/* Filter Chips: Hover grün statt blau */
[data-theme="dark"] .filter-chip:hover {
  border-color: rgba(0,255,12,0.3); color: var(--green);
}
[data-theme="dark"] .filter-chip.active {
  background: var(--green); color: #151D2C; border-color: var(--green);
}

/* Case Card Tags: grün im Dark Mode */
[data-theme="dark"] .case-tag {
  color: var(--green);
  border-color: rgba(0,255,12,0.25);
  background: rgba(0,255,12,0.06);
}

/* Popup Header & Close Button */
[data-theme="dark"] .popup-header {
  background: rgba(14,17,23,0.95);
}
[data-theme="dark"] .popup-close-btn {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.15);
}
[data-theme="dark"] .popup-close-btn svg { stroke: #fff; }
[data-theme="dark"] .popup-close-btn:hover {
  background: rgba(255,255,255,0.15);
}
[data-theme="dark"] .popup-close-label { color: rgba(255,255,255,0.45); }

/* Popup Content Area */
[data-theme="dark"] .popup-scroll { background: var(--white); }
[data-theme="dark"] .popup-tag {
  color: var(--green);
  border-color: rgba(0,255,12,0.25);
  background: rgba(0,255,12,0.06);
}

/* ═══════════════════════════════════════════════════════════════════════════
   BLOG-ÜBERSICHT — Cards, Tags, Filter
   ═══════════════════════════════════════════════════════════════════════════ */
/* Blog Card Tags: grün im Dark Mode */
[data-theme="dark"] .blog-card-tag {
  color: var(--green) !important;
  border-color: rgba(0,255,12,0.3) !important;
}
/* Blog Filter Chips */
[data-theme="dark"] .blog-card .filter-chip:hover,
[data-theme="dark"] .filter-chip:hover {
  border-color: rgba(0,255,12,0.3); color: var(--green);
}
[data-theme="dark"] .filter-chip.active {
  background: var(--green); color: #151D2C; border-color: var(--green);
}

/* ═══════════════════════════════════════════════════════════════════════════
   LEISTUNGEN-SEITE — Karten
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="dark"] .l-card { background: var(--off); border-color: var(--rule); }
[data-theme="dark"] .l-card:hover { box-shadow: 0 16px 48px rgba(0,0,0,0.2); }
[data-theme="dark"] .l-card::before { background: var(--green); }
[data-theme="dark"] .l-card-icon { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); }
[data-theme="dark"] .l-card:hover .l-card-icon { background: var(--green); border-color: var(--green); }
[data-theme="dark"] .l-card:hover .l-card-icon svg { stroke: #151D2C; }
[data-theme="dark"] .l-card-tag {
  color: var(--green); background: rgba(0,255,12,0.06);
  border-color: rgba(0,255,12,0.2);
}

/* ═══════════════════════════════════════════════════════════════════════════
   BLOG-ARTIKEL — Tags in Artikeln
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="dark"] .article-tag {
  color: var(--green);
  border-color: rgba(0,255,12,0.25);
  background: rgba(0,255,12,0.06);
}

/* ═══════════════════════════════════════════════════════════════════════════
   COOKIE BANNER — Light Mode = helles Banner
   ═══════════════════════════════════════════════════════════════════════════ */
/* Default (dark banner) bleibt für Dark Mode.
   In Light Mode: helles Banner mit dunklem Text */
:root:not([data-theme="dark"]) #sp-cookie-banner {
  background: #FFFFFF !important;
  border: 1px solid rgba(21,29,44,0.1) !important;
  box-shadow: 0 8px 40px rgba(21,29,44,0.12) !important;
}
:root:not([data-theme="dark"]) .sp-cb-text {
  color: rgba(21,29,44,0.6) !important;
}
:root:not([data-theme="dark"]) .sp-cb-text a {
  color: var(--blue) !important;
  border-bottom-color: rgba(2,0,255,0.2) !important;
}
:root:not([data-theme="dark"]) .sp-cb-accept {
  background: var(--green) !important;
  color: #151D2C !important;
}
:root:not([data-theme="dark"]) .sp-cb-decline {
  color: rgba(21,29,44,0.35) !important;
}
:root:not([data-theme="dark"]) .sp-cb-decline:hover {
  color: rgba(21,29,44,0.7) !important;
}
/* Cookie Toggle in Light Mode */
:root:not([data-theme="dark"]) #sp-cookie-toggle {
  background: #FFFFFF !important;
  border-color: rgba(21,29,44,0.1) !important;
  box-shadow: 0 2px 10px rgba(21,29,44,0.08) !important;
}
:root:not([data-theme="dark"]) #sp-cookie-toggle svg circle {
  stroke: rgba(21,29,44,0.45) !important;
  fill: rgba(21,29,44,0.45) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   VINTAGE SLIDE SWITCH TOGGLE
   ═══════════════════════════════════════════════════════════════════════════ */
.theme-toggle {
  width: 48px; height: 24px;
  border: 1px solid rgba(21,29,44,0.15); border-radius: 6px;
  background: #E8E8EE; cursor: pointer;
  display: flex; align-items: center; padding: 2px;
  position: relative;
  transition: background 0.3s, border-color 0.3s, box-shadow 0.3s;
  flex-shrink: 0;
}
.theme-toggle:hover { background: #F0F0F6; border-color: rgba(21,29,44,0.25); }

.toggle-knob {
  display: block; width: 16px; height: 16px; border-radius: 4px;
  background: #fff; position: absolute; left: 3px;
  transition: left 0.35s cubic-bezier(0.4, 0.0, 0.2, 1), background 0.3s, box-shadow 0.3s;
  box-shadow: 0 1px 4px rgba(21,29,44,0.15);
}

[data-theme="dark"] .theme-toggle {
  background: #1a1f2e;
  border-color: rgba(0,255,12,0.2);
  box-shadow: inset 0 0 8px rgba(0,255,12,0.1);
}
[data-theme="dark"] .theme-toggle:hover {
  background: #232a38;
  box-shadow: inset 0 0 12px rgba(0,255,12,0.15);
}
[data-theme="dark"] .toggle-knob {
  left: 27px; background: #00FF0C;
  box-shadow: 0 2px 6px rgba(0,255,12,0.3);
}

/* Mobile: kleiner in der Nav */
@media (max-width: 600px) {
  .theme-toggle { width: 38px; height: 20px; }
  .theme-toggle .toggle-knob { width: 13px; height: 13px; border-radius: 3px; }
  [data-theme="dark"] .theme-toggle .toggle-knob { left: 21px; }
}

/* Toggle im Mobile-Menü */
.mm-theme-toggle {
  margin-top: 1.5rem; display: flex; align-items: center; gap: 0.75rem;
  transform: translateY(20px); opacity: 0;
  transition: transform 0.35s 0.32s, opacity 0.35s 0.32s;
}
.mobile-menu.open .mm-theme-toggle { transform: translateY(0); opacity: 1; }
.mm-theme-label {
  font-family: var(--font-m); font-size: 0.55rem; letter-spacing: 0.1em;
  text-transform: uppercase; color: rgba(255,255,255,0.35);
}
.mm-theme-toggle .theme-toggle {
  width: 52px; height: 26px;
}
.mm-theme-toggle .toggle-knob {
  width: 18px; height: 18px; border-radius: 4px;
}
[data-theme="dark"] .mm-theme-toggle .toggle-knob { left: 29px; }
