/* JSE 2026 v4 — Components (frisch geschrieben, master-skill konform) */

/* ============================================================ */
/* === HEADER (Sticky, mit Logo links + Nav rechts + CTA)   === */
/* ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  background: rgba(10, 14, 20, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-on-ink);
  color: var(--text-on-ink);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--s-5);
  min-height: 72px;
  padding-block: var(--s-3);
}
.brand { display: inline-flex; align-items: center; flex-shrink: 0; text-decoration: none; }
.brand img { height: 44px; width: auto; display: block; }
@media (max-width: 720px) {
  .site-header__inner { min-height: 60px; }
  .brand img { height: 36px; }
}

.nav { display: none; }
@media (min-width: 980px) {
  .nav { display: block; }
  .nav__list { display: flex; gap: var(--s-6); align-items: center; }
  .nav__link {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--text-on-ink-muted);
    padding-block: 6px;
    border-bottom: 2px solid transparent;
    transition: color var(--t-fast), border-color var(--t-fast);
  }
  .nav__link:hover { color: var(--text-on-ink); text-decoration: none; }
  .nav__link.is-active { color: var(--accent); border-bottom-color: var(--accent); }
}
.header-cta { display: none; }
@media (min-width: 980px) {
  .header-cta { display: inline-flex; }
}

.menu-toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px;
  background: transparent; border: 1px solid var(--border-on-ink);
  color: var(--text-on-ink); cursor: pointer;
}
@media (min-width: 980px) { .menu-toggle { display: none; } }
.menu-toggle__bar { width: 18px; height: 2px; background: currentColor; position: relative; }
.menu-toggle__bar::before, .menu-toggle__bar::after {
  content: ""; position: absolute; left: 0; right: 0; height: 2px; background: currentColor;
  transition: transform var(--t-fast);
}
.menu-toggle__bar::before { top: -6px; }
.menu-toggle__bar::after { top: 6px; }

/* Mobile-Panel */
.mobile-panel {
  position: fixed; inset: 0;
  background: var(--ink-900);
  padding: 80px var(--s-6) var(--s-7);
  z-index: var(--z-banner);
  transform: translateY(-100%);
  transition: transform var(--t-base);
  overflow-y: auto;
}
.mobile-panel.is-open { transform: translateY(0); }
.mobile-panel__group { display: block; font-size: var(--fs-eyebrow); letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin-block: var(--s-5) var(--s-3); border-bottom: 1px solid var(--border-on-ink); padding-bottom: var(--s-2); }
.mobile-panel__group:first-child { margin-top: 0; }
.mobile-panel a {
  display: block; font-size: 1.15rem; padding-block: var(--s-3);
  color: var(--text-on-ink-muted); border-bottom: 1px solid rgba(255,255,255,0.04);
}
.mobile-panel a:hover, .mobile-panel a.is-active { color: var(--text-on-ink); text-decoration: none; }

/* ============================================================ */
/* === BUTTONS                                              === */
/* ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: 14px 28px;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
  border: 0;
  cursor: pointer;
  transition: transform var(--t-fast), background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
  border-radius: var(--r-sm);
  white-space: nowrap;
}
.btn:hover { text-decoration: none; }

.btn--primary { background: var(--accent); color: var(--ink-900); }
.btn--primary:hover { background: var(--accent-dark); }

.btn--ghost-light { background: transparent; color: var(--text-on-ink); border: 1px solid rgba(255,255,255,0.4); }
.btn--ghost-light:hover { border-color: var(--accent); color: var(--accent); }

.btn--ghost-dark { background: transparent; color: var(--text-on-paper); border: 1px solid rgba(0,0,0,0.2); }
.btn--ghost-dark:hover { border-color: var(--ink-900); }

.btn--cyan { background: var(--cyan); color: var(--ink-900); }

.btn--lg { padding: 18px 36px; font-size: 1.05rem; }
.btn--sm { padding: 10px 18px; font-size: 0.85rem; }

/* Magnetic-Button (Animation 13) */
.btn--magnetic { will-change: transform; }
@media (prefers-reduced-motion: reduce) { .btn--magnetic { transform: none !important; } }

/* ============================================================ */
/* === HERO (Photo-BG + Stromfluss + Editorial Reveal)      === */
/* ============================================================ */
.hero {
  position: relative;
  isolation: isolate;
  background: var(--ink-900);
  color: var(--text-on-ink);
  overflow: hidden;
  padding-block: clamp(var(--s-9), 14vh, var(--s-11)) clamp(var(--s-9), 14vh, var(--s-11));
}
.hero__bg {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  filter: brightness(0.55) contrast(1.05);
}
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(10,14,20,0.35) 0%, rgba(10,14,20,0.85) 100%);
}
.hero__content { position: relative; z-index: 2; max-width: 64ch; }
.hero__title {
  font-size: var(--fs-display);
  font-weight: 900;
  line-height: 1.0;
  letter-spacing: -0.025em;
  margin-bottom: var(--s-4);
}
.hero__lead {
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: var(--text-on-ink-muted);
  margin-bottom: var(--s-6);
  max-width: 52ch;
}
.hero__actions {
  display: flex; gap: var(--s-4); flex-wrap: wrap;
}

/* Stromfluss-Animation (#02) */
.stromfluss-bg {
  position: absolute; inset: 0; z-index: 1;
  pointer-events: none; opacity: 0.14; overflow: hidden;
}
.stromfluss-bg svg { width: 100%; height: 100%; display: block; }
.stromfluss-bg .flow-line {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.5;
  stroke-dasharray: 8 14;
  animation: flow 12s linear infinite;
}
.stromfluss-bg .flow-line.l2 { animation-duration: 16s; animation-delay: -3s; }
.stromfluss-bg .flow-line.l3 { animation-duration: 20s; animation-delay: -8s; }
.stromfluss-bg .node { fill: var(--accent); animation: pulse 3s ease-in-out infinite; }
.stromfluss-bg .node.n2 { animation-delay: 1s; }
.stromfluss-bg .node.n3 { animation-delay: 2s; }
@keyframes flow { from { stroke-dashoffset: 0; } to { stroke-dashoffset: -100; } }
@keyframes pulse { 0%,100% { opacity: 0.5; r: 4; } 50% { opacity: 1; r: 6; } }
@media (prefers-reduced-motion: reduce) {
  .stromfluss-bg .flow-line, .stromfluss-bg .node { animation: none; }
}

/* Editorial-Reveal (#01) */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity var(--t-editorial), transform var(--t-editorial); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-d-1 { transition-delay: 0.15s; }
.reveal-d-2 { transition-delay: 0.30s; }
.reveal-d-3 { transition-delay: 0.45s; }
.reveal-d-4 { transition-delay: 0.60s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================ */
/* === SECTION-HEAD                                          === */
/* ============================================================ */
.section-head {
  margin-bottom: var(--s-7);
  max-width: 64ch;
}
.section-head h2 { margin-bottom: var(--s-3); }

/* ============================================================ */
/* === GRID                                                  === */
/* ============================================================ */
.grid { display: grid; gap: var(--s-5); }
.grid--2 { grid-template-columns: 1fr; }
.grid--3 { grid-template-columns: 1fr; }
.grid--4 { grid-template-columns: 1fr; }
@media (min-width: 720px) {
  .grid--2 { grid-template-columns: repeat(2, 1fr); }
  .grid--3 { grid-template-columns: repeat(2, 1fr); }
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 980px) {
  .grid--3 { grid-template-columns: repeat(3, 1fr); }
  .grid--4 { grid-template-columns: repeat(4, 1fr); }
}

/* ============================================================ */
/* === SERVICE-TILE (with photo-bg + stagger 3D #20)        === */
/* ============================================================ */
.service-tile {
  position: relative;
  display: block;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  text-decoration: none;
  color: var(--text-on-ink);
  background: var(--ink-700);
  isolation: isolate;
}
.service-tile__bg {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  transition: transform var(--t-slow);
}
.service-tile:hover .service-tile__bg { transform: scale(1.04); }
.service-tile__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(10,14,20,0.1) 0%, rgba(10,14,20,0.85) 100%);
  transition: background var(--t-base);
}
.service-tile:hover .service-tile__overlay { background: linear-gradient(180deg, rgba(10,14,20,0.2) 0%, rgba(10,14,20,0.92) 100%); }
.service-tile__body {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; justify-content: flex-end;
  height: 100%;
  padding: var(--s-6);
}
.service-tile__eyebrow {
  font-size: var(--fs-eyebrow);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--accent);
  margin-bottom: var(--s-3);
}
.service-tile__title {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: var(--s-3);
}
.service-tile__lead {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-on-ink-muted);
  margin-bottom: var(--s-4);
}
.service-tile__arrow {
  font-size: 0.9rem; font-weight: 700; color: var(--accent);
  display: inline-flex; align-items: center; gap: var(--s-2);
}
.service-tile__arrow::after { content: "→"; transition: transform var(--t-fast); }
.service-tile:hover .service-tile__arrow::after { transform: translateX(4px); }

/* Stagger 3D (#20) */
.service-tile.stagger { transform: rotateX(-12deg) translateY(40px); opacity: 0; transition: opacity var(--t-editorial), transform var(--t-editorial); transform-origin: 50% 100%; }
.service-tile.stagger.is-visible { transform: rotateX(0) translateY(0); opacity: 1; }

/* ============================================================ */
/* === CARD (general-purpose)                                === */
/* ============================================================ */
.card {
  background: var(--paper-tint);
  border: 1px solid var(--border-on-paper);
  padding: var(--s-6) var(--s-7);
  text-decoration: none;
  color: inherit;
  display: block;
  transition: transform var(--t-fast), border-color var(--t-fast);
}
.card:hover { transform: translateY(-2px); border-color: var(--accent); text-decoration: none; }
.card--ink { background: var(--ink-800); border-color: var(--border-on-ink); color: var(--text-on-ink); }

.card__eyebrow { font-size: var(--fs-eyebrow); letter-spacing: 0.22em; text-transform: uppercase; font-weight: 700; color: var(--accent-dark); }
.card--ink .card__eyebrow { color: var(--accent); }
.card__title { font-size: 1.2rem; line-height: 1.25; font-weight: 800; margin-block: var(--s-3) var(--s-2); }
.card__lead { font-size: 0.95rem; line-height: 1.55; color: var(--text-on-paper-muted); }
.card--ink .card__lead { color: var(--text-on-ink-muted); }

/* ============================================================ */
/* === ARTICLE-CARD (Blog-cards mit Photo)                  === */
/* ============================================================ */
.article-card {
  display: flex; flex-direction: column;
  background: var(--paper);
  border: 1px solid var(--border-on-paper);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: transform var(--t-fast), border-color var(--t-fast);
}
.article-card:hover { transform: translateY(-2px); border-color: var(--accent); text-decoration: none; }
.article-card__media { aspect-ratio: 16/10; overflow: hidden; background: var(--ink-700); }
.article-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow); }
.article-card:hover .article-card__media img { transform: scale(1.04); }
.article-card__body { padding: var(--s-5) var(--s-6); flex: 1; display: flex; flex-direction: column; gap: var(--s-2); }
.article-card__cat { font-size: var(--fs-eyebrow); letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent-dark); font-weight: 700; }
.article-card__title { font-size: 1.1rem; line-height: 1.3; font-weight: 800; }
.article-card__meta { display: flex; gap: var(--s-3); margin-top: auto; padding-top: var(--s-3); font-size: var(--fs-meta); color: var(--text-on-paper-muted); }
.section--ink .article-card { background: var(--ink-800); border-color: var(--border-on-ink); color: var(--text-on-ink); }
.section--ink .article-card__title { color: var(--text-on-ink); }
.section--ink .article-card__meta { color: var(--text-on-ink-dim); }

/* ============================================================ */
/* === KPI-Strip (Animation #17)                            === */
/* ============================================================ */
.kpi-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--s-5); }
.kpi {
  position: relative; overflow: hidden;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-on-ink);
  padding: var(--s-7) var(--s-6);
}
.section--paper .kpi, .section--paper-tint .kpi { background: rgba(0,0,0,0.025); border-color: var(--border-on-paper); }
.kpi::before { content: ""; position: absolute; top: 0; left: 0; height: 2px; background: var(--accent); width: 0; transition: width 1.2s ease; }
.kpi.is-visible::before { width: 100%; }
.kpi__icon { width: 48px; height: 48px; margin-bottom: var(--s-4); color: var(--accent); }
.kpi__num { font-size: clamp(2.4rem, 4vw, 3.4rem); font-weight: 900; letter-spacing: -0.02em; line-height: 1; font-variant-numeric: tabular-nums; }
.kpi__label { font-size: 0.92rem; color: var(--text-on-ink-muted); margin-top: var(--s-2); letter-spacing: 0.04em; }
.section--paper .kpi__label, .section--paper-tint .kpi__label { color: var(--text-on-paper-muted); }

/* ============================================================ */
/* === PULL-QUOTE                                           === */
/* ============================================================ */
.pullquote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.5;
  max-width: 36ch;
  position: relative;
  padding-left: var(--s-5);
  border-left: 3px solid var(--accent);
  margin: var(--s-7) 0;
}
.pullquote__cite { display: block; margin-top: var(--s-4); font-style: normal; font-family: var(--font-display); font-size: 0.85rem; color: var(--text-on-paper-muted); letter-spacing: 0.05em; }
.section--ink .pullquote__cite { color: var(--text-on-ink-dim); }

/* ============================================================ */
/* === FORMS                                                 === */
/* ============================================================ */
.form { display: grid; gap: var(--s-5); }
.form__row { display: grid; gap: var(--s-4); }
@media (min-width: 720px) { .form__row { grid-template-columns: 1fr 1fr; } }
.form__label {
  font-size: var(--fs-meta);
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: var(--s-2);
  display: block;
  color: var(--text-on-paper);
}
.section--ink .form__label, .section--ink-2 .form__label { color: var(--text-on-ink); }
.form__field, .form__select, .form__textarea {
  width: 100%;
  padding: 12px 14px;
  font-family: inherit;
  font-size: 1rem;
  background: var(--paper);
  color: var(--ink-900);
  border: 0;
  border-bottom: 1px solid rgba(0,0,0,0.2);
  transition: border-color var(--t-fast);
}
.section--ink .form__field, .section--ink .form__select, .section--ink .form__textarea {
  background: rgba(255,255,255,0.05);
  color: var(--text-on-ink);
  border-bottom: 1px solid rgba(255,255,255,0.18);
}
.form__field:focus, .form__select:focus, .form__textarea:focus {
  outline: none;
  border-bottom-color: var(--accent);
}
.form__textarea { min-height: 8rem; resize: vertical; }
.form__honeypot { position: absolute !important; left: -9999px !important; }
.form__check { display: flex; gap: var(--s-3); align-items: flex-start; font-size: var(--fs-meta); line-height: 1.5; }
.form__check input { margin-top: 4px; }
.section--ink .form__check { color: var(--text-on-ink-muted); }

.form__success, .form__error {
  display: none;
  padding: var(--s-3) var(--s-4);
  font-size: var(--fs-meta);
  margin-top: var(--s-2);
}
.form__success { background: rgba(46, 125, 50, 0.18); color: #c8e6c9; border-left: 3px solid var(--success); }
.form__error { background: rgba(198, 40, 40, 0.18); color: #ffcdd2; border-left: 3px solid var(--danger); }
.form__success.is-visible, .form__error.is-visible { display: block; }

/* Contact-Block layout */
.contact-grid { display: grid; gap: var(--s-7); grid-template-columns: 1fr; }
@media (min-width: 900px) { .contact-grid { grid-template-columns: 1fr 1.1fr; gap: var(--s-9); } }
.contact-meta { list-style: none; padding: 0; margin: var(--s-5) 0 0; display: grid; gap: var(--s-2); font-size: var(--fs-meta); }
.contact-meta li { padding-left: var(--s-3); border-left: 2px solid var(--accent); color: var(--text-on-ink-muted); }
.contact-meta strong { display: inline-block; min-width: 100px; color: var(--text-on-ink); }
.section--paper .contact-meta li { color: var(--text-on-paper-muted); }
.section--paper .contact-meta strong { color: var(--text-on-paper); }
.contact-form { background: rgba(255,255,255,0.03); padding: var(--s-6); border: 1px solid var(--border-on-ink); }

/* ============================================================ */
/* === FOOTER                                                === */
/* ============================================================ */
.site-footer {
  background: var(--ink-900);
  color: var(--text-on-ink);
  padding-block: var(--s-9) var(--s-6);
  border-top: 1px solid var(--border-on-ink);
}
.site-footer a { color: var(--text-on-ink-muted); }
.site-footer a:hover { color: var(--text-on-ink); text-decoration: none; border-bottom: 1px solid var(--accent); }
.footer-grid { display: grid; gap: var(--s-7); grid-template-columns: 1fr; padding-bottom: var(--s-7); border-bottom: 1px solid var(--border-on-ink); }
@media (min-width: 720px) { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.footer-col h4 { font-size: var(--fs-eyebrow); letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s-4); }
.footer__links { display: flex; flex-direction: column; gap: var(--s-2); }
.footer__links li { font-size: 0.92rem; }
.footer-meta { display: flex; flex-wrap: wrap; gap: var(--s-5); padding-top: var(--s-5); font-size: var(--fs-meta); color: var(--text-on-ink-dim); }
.footer-meta a { color: var(--text-on-ink-dim); }
.site-footer .brand img { height: 44px; }
.site-footer__pitch { font-size: 0.92rem; color: var(--text-on-ink-muted); margin-top: var(--s-4); max-width: 36ch; line-height: 1.55; }

/* ============================================================ */
/* === COOKIE-BANNER                                         === */
/* ============================================================ */
.cookie-banner {
  position: fixed;
  bottom: var(--s-3);
  left: var(--s-3);
  right: var(--s-3);
  max-width: 460px;
  background: var(--ink-800);
  color: var(--text-on-ink);
  padding: var(--s-5);
  border: 1px solid var(--border-on-ink);
  z-index: 9999;
  box-shadow: var(--shadow-lg);
  display: none;
}
.cookie-banner.is-visible {
  display: block !important;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
  animation: none !important;
  transition: none !important;
}
}
.cookie-banner h4 { font-size: 1rem; margin-bottom: var(--s-2); }
.cookie-banner p { font-size: 0.85rem; color: var(--text-on-ink-muted); line-height: 1.55; margin-bottom: var(--s-4); }
.cookie-banner__actions { display: flex; gap: var(--s-3); flex-wrap: wrap; }

/* ============================================================ */
/* === ARTICLE-PROSE (Blog-Body)                            === */
/* ============================================================ */
.article-hero {
  position: relative; isolation: isolate;
  min-height: clamp(360px, 50vh, 560px);
  display: flex; align-items: flex-end;
  padding-block: var(--s-9);
  color: var(--text-on-ink);
  background: var(--ink-900);
  overflow: hidden;
}
.article-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; filter: brightness(0.55); }
.article-hero::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(10,14,20,0.45) 0%, rgba(10,14,20,0.85) 100%); }
.article-hero h1 { font-size: clamp(2rem, 5vw, 3.6rem); line-height: 1.05; letter-spacing: -0.02em; max-width: 22ch; margin-bottom: var(--s-4); }
.article-hero .meta { font-size: var(--fs-eyebrow); letter-spacing: 0.22em; text-transform: uppercase; color: var(--accent); margin-bottom: var(--s-3); }
.article-prose { max-width: 72ch; margin: 0 auto; padding: var(--s-9) var(--s-5) var(--s-10); font-size: 1.0625rem; line-height: 1.75; }
@media (min-width: 720px) { .article-prose { padding-inline: var(--s-7); font-size: 1.125rem; } }
.article-prose p { margin: 0 0 var(--s-5); }
.article-prose h2 { font-size: clamp(1.5rem, 2.4vw, 2rem); margin: var(--s-8) 0 var(--s-4); padding-top: var(--s-3); border-top: 1px solid var(--border-on-paper); }
.article-prose h2:first-child { border-top: 0; padding-top: 0; margin-top: 0; }
.article-prose h3 { font-size: clamp(1.2rem, 1.8vw, 1.4rem); margin: var(--s-6) 0 var(--s-3); }
.article-prose ul, .article-prose ol { margin: 0 0 var(--s-5); padding-left: 1.4em; list-style: disc; }
.article-prose li { margin-bottom: var(--s-2); }
.article-prose li::marker { color: var(--accent-dark); }
.article-prose strong { font-weight: 700; color: var(--text-on-paper); }
.article-prose blockquote { margin: var(--s-7) 0; padding: var(--s-5) var(--s-6); border-left: 3px solid var(--accent); background: var(--paper-tint); font-family: var(--font-serif); font-style: italic; font-size: 1.2rem; line-height: 1.5; }
.article-prose .danger { margin: var(--s-5) 0; padding: var(--s-4) var(--s-5); background: rgba(220,100,80,0.08); border-left: 3px solid var(--danger); }
.article-prose .danger h4 { color: var(--danger); margin-bottom: var(--s-2); }
.article-prose .danger p { margin: 0; }
.article-prose .tip { margin: var(--s-5) 0; padding: var(--s-4) var(--s-5); background: rgba(255,212,0,0.08); border-left: 3px solid var(--accent); }
.article-prose .tip h4 { margin-bottom: var(--s-2); }

/* ============================================================ */
/* === STRIP (Trust-bar)                                    === */
/* ============================================================ */
.strip {
  background: var(--ink-800);
  color: var(--text-on-ink);
  padding-block: var(--s-5);
  border-block: 1px solid var(--border-on-ink);
}
.strip-inner {
  display: grid; gap: var(--s-3);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  align-items: center;
}
.strip-item { font-size: 0.85rem; color: var(--text-on-ink-muted); letter-spacing: 0.05em; }
.strip-item strong { color: var(--accent); margin-right: var(--s-2); }

/* === Visible Breadcrumb === */
.breadcrumb { display: none !important; visibility: hidden !important; height: 0 !important; max-height: 0 !important; padding: 0 !important; margin: 0 !important; border: 0 !important; overflow: hidden !important; }
.breadcrumb__list { display: flex; flex-wrap: wrap; gap: var(--s-2); align-items: center; }
.breadcrumb__list li { display: flex; align-items: center; gap: var(--s-2); }
.breadcrumb__list li:not(:last-child)::after { content: "→"; color: var(--accent-dark); margin-left: var(--s-2); }
.breadcrumb__list a { color: var(--text-on-paper-muted); text-decoration: none; }
.breadcrumb__list a:hover { color: var(--ink-900); text-decoration: underline; text-decoration-color: var(--accent); }
.breadcrumb__list [aria-current="page"] { color: var(--ink-900); font-weight: 700; }

/* ==========================================================================
   V5 FIXES — Mai 2026
   1. Breadcrumb auf Subseiten ausblenden (Wunsch Geschäftsführung)
   2. Horizontal-Scroll auf Mobile verhindern
   3. Touch-Targets vergrößern (iPhone/Android/iPad)
   4. Site-Header bleibt dunkel (kein Glas-Effekt)
   ========================================================================== */

/* --- 1. Breadcrumb komplett raus --- */
.breadcrumb,
nav.breadcrumb,
nav[aria-label="Brotkrümel"],
nav[aria-label="Breadcrumb"],
nav[aria-label="breadcrumb"] {
  display: none !important;
}

/* --- 2. Horizontal-Overflow weg --- */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw;
  width: 100%;
}
body {
  position: relative;
}
/* Sicherheits-Wrapper für alle Container */
.container,
.container--narrow,
.container--prose,
.container--full,
section,
header,
footer,
main {
  max-width: 100vw;
}
img, video, iframe, svg {
  max-width: 100%;
}

/* --- 3. Site-Header dauerhaft dunkel (kein weißer Schimmer bei scroll) --- */
.site-header {
  background: #0a0e14 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.mobile-panel {
  background: #0a0e14 !important;
}

/* --- 4. Mobile-Optimierung (iPhone/iPad/Android) --- */
@media (max-width: 1024px) {
  /* Touch-Targets — Apple HIG min 44px, Material 48px */
  .nav__link,
  .mobile-panel a,
  .btn,
  .menu-toggle,
  button {
    min-height: 44px;
  }
  .btn {
    padding-block: 0.85rem;
  }
}

@media (max-width: 768px) {
  /* Header-Layout */
  .site-header__inner {
    gap: 0.5rem;
    padding-block: 0.6rem;
  }
  .brand img {
    width: 140px !important;
    height: auto !important;
    max-height: 36px;
  }
  /* CTA im Header — nur Symbol auf kleinen Schirmen */
  .header-cta {
    padding: 0.65rem 0.9rem;
    font-size: 0.85rem;
    white-space: nowrap;
  }
  .menu-toggle {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* Mobile Panel — Touch-freundlich */
  .mobile-panel {
    padding: 1.5rem 1.25rem !important;
  }
  .mobile-panel a {
    padding: 0.9rem 0;
    font-size: 1.05rem;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .mobile-panel__group {
    margin-top: 1.5rem !important;
    margin-bottom: 0.5rem;
    color: var(--accent);
    font-size: 0.7rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
  }

  /* Typographie — größere Headlines auf Mobile */
  h1, .hero__title {
    font-size: clamp(2rem, 9vw, 3.5rem) !important;
    line-height: 1.05;
  }
  h2 {
    font-size: clamp(1.6rem, 6vw, 2.4rem) !important;
  }
  .hero__lead, .lead {
    font-size: 1.05rem;
    line-height: 1.55;
  }

  /* Grid — auf Mobile alles untereinander */
  .grid--2,
  .grid--3,
  .grid--4 {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }

  /* Sections — kompaktes Padding */
  .section {
    padding-block: 3rem !important;
  }
  .hero {
    min-height: 70vh;
    padding-block: 4rem 3rem;
  }

  /* Cards/Service-Tiles — voll-breit */
  .card,
  .service-tile,
  .article-card {
    width: 100%;
    min-width: 0;
  }
  .service-tile__title { font-size: 1.4rem; }
  .service-tile__body { padding: 1.5rem !important; }

  /* Strip — als Spalte */
  .strip-inner {
    flex-direction: column;
    gap: 0.75rem;
    text-align: center;
  }

  /* Buttons — full-width auf Mobile wo sinnvoll */
  .hero__actions {
    flex-direction: column;
    gap: 0.75rem;
    width: 100%;
  }
  .hero__actions .btn {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  /* Kleinste Schirme */
  .container {
    padding-inline: 1rem !important;
  }
  .brand img {
    width: 120px !important;
    max-height: 32px;
  }
  .header-cta {
    /* Auf sehr kleinen Schirmen evtl. ausblenden, Menü reicht */
    padding: 0.55rem 0.7rem;
    font-size: 0.78rem;
  }
}

/* --- 5. iOS-spezifisch: kein Zoom auf Form-Input --- */
input,
textarea,
select {
  font-size: 16px !important; /* verhindert iOS-Zoom */
}

/* --- 6. Smooth scroll + reduced motion respect --- */
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}


/* Cookie-Banner DSGVO Verbesserung */
.cookie-banner__details { margin: 0.8rem 0; }
.cookie-banner__details summary { cursor: pointer; font-size: 0.85rem; color: var(--accent); padding: 0.3rem 0; user-select: none; }
.cookie-banner__details summary:hover { text-decoration: underline; }
.cookie-banner__details[open] summary { margin-bottom: 0.5rem; }
.cookie-banner__details ul li { margin-bottom: 0.4rem; color: var(--text-on-paper-muted); }
.cookie-banner__actions { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; }
.cookie-banner__actions .btn--ghost-light:last-child { margin-left: auto; }
@media (max-width: 480px) {
 .cookie-banner__actions { flex-direction: column; align-items: stretch; }
 .cookie-banner__actions .btn--ghost-light:last-child { margin-left: 0; }
}


/* Blog-Cards ohne Bilder — kompakteres Layout */
.article-card:not(:has(.article-card__media)) .article-card__body {
  padding: var(--s-6) var(--s-5);
}
.article-card:not(:has(.article-card__media)) {
  background: var(--paper);
  border: 1px solid var(--border-on-paper);
  border-radius: 4px;
  transition: border-color 200ms, transform 200ms;
}
.article-card:not(:has(.article-card__media)):hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}


/* Service-Tile ohne BG-Bild (flat-Variant) */
.service-tile--flat { background: var(--paper-tint); border: 1px solid var(--border-on-paper); }
.service-tile--flat .service-tile__overlay { display: none; }
.service-tile--flat .service-tile__body { color: var(--text-on-paper); position: relative; z-index: 1; padding: var(--s-6); }
.service-tile--flat .service-tile__eyebrow { color: var(--accent-dark); }
.service-tile--flat .service-tile__title { color: var(--ink-900); }
.service-tile--flat .service-tile__lead { color: var(--text-on-paper-muted); }
.service-tile--flat .service-tile__arrow { color: var(--accent-dark); }
.service-tile--flat:hover { border-color: var(--accent); transform: translateY(-2px); transition: 200ms; }


/* Hero-Crossfade Animation (Startseite) */
.hero__bg-slider { position: absolute; inset: 0; overflow: hidden; }
.hero__bg-slider .hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  animation: heroFade 32s infinite;
}
.hero__bg-slider .hero__bg:nth-child(1) { animation-delay: 0s; }
.hero__bg-slider .hero__bg:nth-child(2) { animation-delay: 8s; }
.hero__bg-slider .hero__bg:nth-child(3) { animation-delay: 16s; }
.hero__bg-slider .hero__bg:nth-child(4) { animation-delay: 24s; }
@keyframes heroFade {
  0% { opacity: 0; }
  5% { opacity: 1; }
  25% { opacity: 1; }
  30% { opacity: 0; }
  100% { opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .hero__bg-slider .hero__bg { animation: none; }
  .hero__bg-slider .hero__bg:nth-child(1) { opacity: 1; }
}

/* ==========================================================================
   PRINT-STYLESHEET — saubere Druckansicht
   ========================================================================== */
@media print {
  /* Hide non-essential elements */
  .site-header,
  .mobile-panel,
  .menu-toggle,
  .cookie-banner,
  .stromfluss-bg,
  .hero__bg,
  .hero__bg-slider,
  .service-tile__bg,
  .service-tile__overlay,
  .footer-trust,
  .footer__bottom-bar,
  .site-footer,
  nav,
  .btn--ghost-light,
  .btn--magnetic,
  .breadcrumb,
  [data-cookie-banner],
  [data-cookie-reopen],
  .skip-link,
  .footer-trust__cookies {
    display: none !important;
  }
  /* Make page readable B&W */
  body {
    background: white !important;
    color: black !important;
    font-size: 11pt;
    line-height: 1.5;
  }
  .hero {
    background: white !important;
    color: black !important;
    min-height: auto !important;
    padding: 0 !important;
  }
  .hero__content { padding: 1rem 0 !important; }
  .hero__title, h1, h2, h3 { color: black !important; }
  .hero__lead, .lead, p { color: #222 !important; }
  .section--ink, .section--ink-2 {
    background: white !important;
    color: black !important;
  }
  .section { padding: 1rem 0 !important; }
  .eyebrow { color: #555 !important; border-bottom-color: #999 !important; }
  /* Show full URLs after links for paper-reader */
  a[href^="http"]:after { content: " (" attr(href) ")"; font-size: 0.85em; color: #555; }
  a[href^="/"]:after,
  a[href^="#"]:after { content: ""; }
  /* Page-break control */
  h1, h2, h3 { page-break-after: avoid; }
  p, li { page-break-inside: avoid; orphans: 3; widows: 3; }
  img { max-width: 100% !important; page-break-inside: avoid; }
  /* Footer note pro Page */
  @page {
    margin: 2cm 1.5cm;
    @bottom-center { content: "Just Solution Elektrotechnik GmbH · Egerten 3 · 74388 Talheim · 07133 922 04 13"; font-size: 9pt; color: #666; }
  }
  /* Datenschutz/Impressum: Vollanzeige, ohne Grid */
  .footer-grid { display: block !important; }
  .grid--2, .grid--3, .grid--4 { display: block !important; }
  .grid--2 > *, .grid--3 > *, .grid--4 > * { margin-bottom: 1rem; page-break-inside: avoid; }
}
