/* =========================================================
   Bindewald Nützel Specialmalt GmbH (BNS) – gemeinsames Stylesheet (Multi-Page)
   Look: ruhig & hell + dezenter BNS-Orange-Akzent
   Hintergrund: EIN kontinuierlicher Farbverlauf oben→unten
   Hausschrift: Aptos, Fallback Arial (BNS-Designregeln)
   ========================================================= */

/* ---- LIGHT (Standard) ---- */
:root {
  --orange: #F59E14;
  --orange-dark: #945c00;        /* abgedunkelt für ≥4.5:1 Kontrast auf Weiß (WCAG AA) */
  --orange-ring: #bd7a0d;        /* gedämpftes Marken-Orange für Ränder, ≥3:1 auf Weiß (WCAG UI) */
  --text-on-orange: #14130f;     /* dunkler Text/Icon auf orangefarbener Fläche – modusunabhängig */

  --g-top:    #fdf8f1;
  --g-bottom: #f0e4d1;
  --bg:        #ffffff;
  --surface:   #f3ece0;
  --text:      #14130f;
  --text-soft: #5c574e;
  --border:    #e6e0d6;
  --nav-bg:    rgba(255,255,255,0.82);
  --footer-bg: #1c1a16;
  --footer-text: rgba(255,255,255,0.6);
  --cta-bg:    rgba(245,158,20,0.10);
  --shadow:    0 1px 0 rgba(0,0,0,0.05), 0 10px 34px rgba(0,0,0,0.06);
}
/* ---- WHITE (dritte Variante: komplett weiß, flach, ohne warmen Verlauf) ---- */
[data-theme="white"] {
  --g-top:    #ffffff;
  --g-bottom: #ffffff;
  --bg:        #ffffff;
  --surface:   #f6f6f6;
  --text:      #14130f;
  --text-soft: #5f5f5f;
  --border:    #e8e8e8;
  --orange-ring: #bd7a0d;
  --nav-bg:    rgba(255,255,255,0.9);
  --footer-bg: #141414;
  --footer-text: rgba(255,255,255,0.6);
  --cta-bg:    rgba(245,158,20,0.08);
  --shadow:    0 1px 0 rgba(0,0,0,0.04), 0 10px 30px rgba(0,0,0,0.05);
}

/* ---- DARK ---- */
[data-theme="dark"] {
  --g-top:    #0e0e10;
  --g-bottom: #1a1a1d;
  --bg:        #131316;
  --surface:   #1b1b1e;
  --text:      #f3f1ec;
  --text-soft: #a6a097;
  --border:    #2a2a2e;
  --orange-ring: var(--orange);  /* auf dunklem Grund hat Marken-Orange hohen Kontrast (~9:1) */
  --nav-bg:    rgba(14,14,16,0.82);
  --footer-bg: #000000;
  --footer-text: rgba(255,255,255,0.5);
  --cta-bg:    rgba(0,0,0,0.45);
  --shadow:    0 1px 0 rgba(0,0,0,0.5), 0 10px 34px rgba(0,0,0,0.4);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Aptos', 'Aptos Display', Arial, 'Segoe UI', sans-serif;
  font-weight: 300; font-size: 16px; line-height: 1.7; color: var(--text);
  background: linear-gradient(180deg, var(--g-top) 0%, var(--g-bottom) 100%) no-repeat;
  min-height: 100vh; transition: color 0.35s ease;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
.container { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
section { padding: 92px 0; scroll-margin-top: 92px; }

.eyebrow {
  display: inline-block; font-size: 11px; font-weight: 800; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--orange-dark);
  border-left: 3px solid var(--orange); padding-left: 10px; margin-bottom: 18px;
}
[data-theme="dark"] .eyebrow { color: var(--orange); }
h1, h2, h3 { font-weight: 800; letter-spacing: -0.01em; line-height: 1.12; }
.lead { color: var(--text-soft); font-weight: 300; font-size: 17px; line-height: 1.8; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-size: 12px; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase; padding: 15px 28px; cursor: pointer;
  border: 1.5px solid transparent; transition: all 0.2s ease;
  min-height: 44px; max-width: 100%; overflow-wrap: anywhere;
}
.btn-primary { background: var(--orange); color: var(--text-on-orange); }
.btn-primary:hover { background: var(--orange-dark); color: #fff; }
.btn-ghost { border-color: var(--border); color: var(--text); background: transparent; }
.btn-ghost:hover { border-color: var(--orange); color: var(--orange-dark); }
[data-theme="dark"] .btn-ghost:hover { color: var(--orange); }
.btn-dark { background: #1c1a16; color: #fff; }
.btn-dark:hover { background: #000; }
[data-theme="dark"] .btn-dark { background: var(--orange); color: var(--text-on-orange); }
[data-theme="dark"] .btn-dark:hover { background: var(--orange-dark); color:#fff; }

/* ======================= HEADER / NAV ======================= */
header.site {
  position: sticky; top: 0; z-index: 100; background: var(--nav-bg);
  backdrop-filter: blur(10px); border-bottom: 1px solid var(--border);
}
.nav { display: flex; align-items: center; gap: 24px; height: 88px; padding: 0 26px; width: 100%; }
.brand { flex-shrink: 0; }
.brand img { height: 70px; width: auto; object-fit: contain; }
.brand .logo-dark { display: none; }
[data-theme="dark"] .brand .logo-light { display: none; }
[data-theme="dark"] .brand .logo-dark { display: block; }

.nav-links { flex: 1; display: flex; justify-content: space-evenly; list-style: none; }
.nav-links > li { position: relative; }
.nav-links > li > a {
  display: block; padding: 12px 10px; font-size: 14px; font-weight: 700;
  letter-spacing: 0.05em; color: var(--text); transition: color 0.2s;
}
.nav-links > li > a:hover, .nav-links > li > a.current { color: var(--orange-dark); }
[data-theme="dark"] .nav-links > li > a:hover, [data-theme="dark"] .nav-links > li > a.current { color: var(--orange); }
.dropdown { position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(6px);
  min-width: 210px; background: var(--bg); border: 1px solid var(--border); box-shadow: var(--shadow);
  padding: 8px; opacity: 0; visibility: hidden; transition: all 0.18s ease; }
.nav-links > li:hover .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.dropdown a { display: block; padding: 9px 12px; font-size: 13px; font-weight: 600; color: var(--text-soft); }
.dropdown a:hover { color: var(--orange-dark); background: var(--surface); }

.nav-tools { flex-shrink: 0; display: flex; align-items: center; gap: 12px; }
.lang { display: flex; gap: 2px; border: 1px solid var(--border); border-radius: 2px; overflow: hidden; flex-shrink: 0; }
.lang button { background: transparent; border: none; cursor: pointer; padding: 6px 9px; font-size: 11px; min-width: 34px; text-align: center;
  font-weight: 800; letter-spacing: 0.06em; color: var(--text-soft); font-family: inherit; transition: all 0.15s; }
.lang button.active { background: var(--orange); color: var(--text-on-orange); }
.lang button:not(.active):hover { color: var(--text); }
.theme-toggle { width: 38px; height: 38px; border: 1px solid var(--border); border-radius: 50%;
  background: transparent; cursor: pointer; display: grid; place-items: center; color: var(--text); transition: all 0.2s; }
.theme-toggle:hover { border-color: var(--orange); color: var(--orange); }
.theme-toggle .moon { display: none; }
[data-theme="dark"] .theme-toggle .sun { display: none; }
[data-theme="dark"] .theme-toggle .moon { display: block; }
.burger { display: none; background: none; border: none; cursor: pointer; color: var(--text); }

/* ======================= HERO (Startseite) ======================= */
.hero { position: relative; height: calc(100vh - 220px); min-height: 480px; max-height: 760px; display: flex; align-items: center; color: #fff; overflow: hidden; }
.hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(10,9,6,0.78) 0%, rgba(10,9,6,0.42) 52%, rgba(10,9,6,0.12) 100%),
    url('img/hero.webp') center/cover no-repeat;
  z-index: 0;
}
.hero .container { position: relative; z-index: 1; padding-top: 44px; padding-bottom: 44px; }
.hero .eyebrow { color: var(--orange); border-color: var(--orange); }
.hero h1 { font-size: clamp(40px, 6vw, 74px); color: #fff; max-width: 14ch; margin-bottom: 22px; }
.hero h1 .accent { color: var(--orange); }
.hero p { color: rgba(255,255,255,0.82); font-size: 19px; max-width: 52ch; margin-bottom: 36px; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.hero .btn-ghost { color: #fff; border-color: rgba(255,255,255,0.4); }
.hero .btn-ghost:hover { border-color: var(--orange); color: var(--orange); }

/* ======================= PAGE-HERO (Unterseiten) ======================= */
.page-hero { padding: 120px 0 56px; border-bottom: 1px solid var(--border); }
.page-hero h1 { font-size: clamp(34px, 5vw, 58px); margin-bottom: 18px; }
.page-hero .lead { max-width: 60ch; }
/* Einheitlicher Abstand zwischen Page-Hero und erstem Inhaltsabschnitt */
.section--after-hero { padding-top: 44px; }

/* Zahlen & Fakten */
.stats-band { padding: 54px 0; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); }
.stat { padding: 4px 26px; border-left: 1px solid var(--border); }
.stat:first-child { border-left: none; padding-left: 0; }
.stat .bar { width: 26px; height: 3px; background: var(--orange); margin-bottom: 12px; }
.stat .num { display: block; font-size: clamp(24px, 2.6vw, 34px); font-weight: 800; letter-spacing: -0.01em; line-height: 1.05; }
.stat .lbl { display: block; margin-top: 6px; font-size: 12px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-soft); }

/* ======================= SHELL ======================= */
.section-head { max-width: 660px; margin-bottom: 56px; }
.section-head h2, .section-title { font-size: clamp(30px, 4vw, 46px); margin-bottom: 16px; }

/* Split (Bild + Text) */
.split { display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px; align-items: center; }
.split.reverse .media { order: 2; }
.split .media { aspect-ratio: 4/3; background: var(--surface) center/cover no-repeat; position: relative; }
.split .media .stamp { position: absolute; left: 0; bottom: 24px; background: var(--orange); color: var(--text-on-orange);
  font-weight: 800; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; padding: 12px 22px; }
.values { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 30px; }
.values.cols-4 { grid-template-columns: repeat(4, 1fr); }
.value h3 { font-size: 14px; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 4px; }
.value p { font-size: 14px; color: var(--text-soft); }
.value .bar { width: 26px; height: 3px; background: var(--orange); margin-bottom: 10px; }

/* Prose (Fließtext-Seiten) */
.prose { max-width: 760px; }
.prose p { margin-bottom: 18px; color: var(--text-soft); }
.prose h2 { font-size: clamp(24px, 3vw, 34px); margin: 40px 0 14px; }

/* Timeline (Historie) */
.timeline { display: flex; flex-direction: column; gap: 0; max-width: 760px; }
.tl { display: grid; grid-template-columns: 110px 1fr; gap: 24px; padding: 22px 0; border-bottom: 1px solid var(--border); }
.tl:last-child { border-bottom: none; }
.tl .year { font-size: 18px; font-weight: 800; color: var(--orange-dark); }
[data-theme="dark"] .tl .year { color: var(--orange); }
.tl h3 { font-size: 17px; margin-bottom: 4px; }
.tl p { font-size: 14px; color: var(--text-soft); }

/* Freigestelltes Produktbild – transparent: zeigt die Modus-Hintergrundfarbe (hell/dunkel) */
.thumb.prod, .media.prod { background-size: contain; background-repeat: no-repeat; background-position: center; background-color: transparent; }
/* Freigestelltes Bild im Split (z. B. Röster, Wassermühle): transparente Füllung statt grauem Kasten – zeigt die Modus-Hintergrundfarbe */
.split .media.cutout { background-color: transparent; }
.card .thumb.prod { padding: 8px; }   /* etwas Luft in der Kachel */

/* Gebäude-Grafik mit automatischem Hell/Dunkel-Wechsel (positiv/negativ) */
.bld { line-height: 0; }
.bld img { width: 100%; display: block; }
.bld .neg { display: none; }
[data-theme="dark"] .bld .pos { display: none; }
[data-theme="dark"] .bld .neg { display: block; }

/* Standorte */
.loc-map { position: relative; line-height: 0; }
.loc-map img { width: 100%; height: auto; display: block; }
.loc-map .stamp { position: absolute; left: 0; bottom: 24px; background: var(--orange); color: var(--text-on-orange);
  font-weight: 800; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; padding: 12px 22px; line-height: 1; }
.locs { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.loc { background: var(--bg); border: 1px solid var(--border); border-left: 4px solid var(--orange); padding: 30px 28px; }
.loc .bld { margin: -30px -28px 22px; border-bottom: 1px solid var(--border); }
.loc .tag { font-size: 10px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; color: var(--orange-dark); margin-bottom: 10px; }
[data-theme="dark"] .loc .tag { color: var(--orange); }
.loc h3 { font-size: 21px; margin-bottom: 10px; }
.loc address { font-style: normal; color: var(--text-soft); font-size: 15px; line-height: 1.85; }
.loc address a { color: var(--orange-dark); font-weight: 700; }
[data-theme="dark"] .loc address a { color: var(--orange); }

/* Produkt-Karten (Übersicht) */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.cards.four { grid-template-columns: repeat(4, 1fr); }
.card { background: var(--bg); border: 1px solid var(--border); overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s; display: flex; flex-direction: column; }
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.card .thumb { aspect-ratio: 16/10; background: var(--surface) center/cover no-repeat; }
.card .body { padding: 26px 24px 28px; display: flex; flex-direction: column; flex: 1; }
.card .cat { font-size: 10px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; color: var(--orange-dark); margin-bottom: 10px; }
[data-theme="dark"] .card .cat { color: var(--orange); }
.card h3 { font-size: 21px; margin-bottom: 10px; }
.card p { font-size: 14px; color: var(--text-soft); margin-bottom: 18px; }
.card .more { margin-top: auto; font-size: 12px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--orange-dark); }
[data-theme="dark"] .card .more { color: var(--orange); }

/* dezente „Auf Anfrage"-Kachel für Weiteres */
.card.request { background: transparent; border: 1px dashed var(--border); }
.card.request .body { justify-content: center; text-align: left; }
.card.request .tailor { width: 34px; height: 34px; display: grid; place-items: center; color: var(--orange-dark);
  border: 1px solid var(--border); margin-bottom: 14px; }
[data-theme="dark"] .card.request .tailor { color: var(--orange); }
.card.request h3 { font-size: 19px; }
.card.request .more { color: var(--text-soft); }

/* Produktseite – Ansichts-Umschalter (Kategorie / Anwendung) */
.view-switch-wrap { padding-top: 40px; }
.view-switch { display: inline-flex; border: 1px solid var(--border); background: var(--bg); }
.vs-btn { background: transparent; border: none; cursor: pointer; font-family: inherit;
  font-size: 12px; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-soft); padding: 13px 26px; transition: all 0.18s; }
.vs-btn.active { background: var(--orange); color: var(--text-on-orange); }
.vs-btn:not(.active):hover { color: var(--text); }
.view-panel[hidden] { display: none; }

/* Produktseite – Anwendungs-Karten */
.app-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.app-card { background: var(--bg); border: 1px solid var(--border); border-top: 4px solid var(--orange);
  padding: 30px 28px; display: flex; flex-direction: column; }
.app-card .app-img { width: 100%; aspect-ratio: 3/2; margin-bottom: 18px; display: grid; place-items: center; }
.app-card .app-img img { width: 100%; height: 100%; object-fit: contain; display: block; }
.app-card h3 { font-size: 20px; margin-bottom: 8px; }
.app-card > p { font-size: 14px; color: var(--text-soft); margin-bottom: 16px; }
.app-card ul { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 18px; }
.app-card li { position: relative; padding-left: 18px; font-size: 14px; line-height: 1.55; }
.app-card li::before { content: ""; position: absolute; left: 0; top: 9px; width: 7px; height: 7px; background: var(--orange); }
.app-card .app-use { margin-top: auto; font-size: 13px; color: var(--text-soft);
  border-top: 1px solid var(--border); padding-top: 14px; }
.app-card .app-use strong { color: var(--orange-dark); font-weight: 800; }
[data-theme="dark"] .app-card .app-use strong { color: var(--orange); }

/* Zertifikate – zentrierter Teaser (Startseite) */
.cert-center { max-width: 720px; margin: 0 auto; text-align: center; }
.cert-center .eyebrow { border-left: none; padding-left: 0; }
.cert-center .lead { margin: 0 auto; }

/* Downloads (Zertifikate-Seite) */
.downloads { max-width: 860px; }
.dl-group { font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--orange-dark); margin: 34px 0 14px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
[data-theme="dark"] .dl-group { color: var(--orange); }
.dl-group:first-child { margin-top: 0; }
.dl { display: flex; align-items: center; gap: 18px; background: var(--bg); border: 1px solid var(--border);
  border-left: 4px solid var(--orange); padding: 16px 20px; margin-bottom: 12px; }
.dl .ic { width: 40px; height: 40px; flex-shrink: 0; background: var(--surface); display: grid; place-items: center; color: var(--orange-dark); font-weight: 800; font-size: 11px; }
[data-theme="dark"] .dl .ic { color: var(--orange); }
.dl .meta { flex: 1; }
.dl .meta strong { display: block; font-size: 16px; }
.dl .meta small { font-size: 13px; color: var(--text-soft); }
.dl .sites { display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end; align-items: center; flex-shrink: 0; max-width: 150px; }
.dl .badge { display: inline-block; font-size: 10px; font-weight: 800; letter-spacing: 0.06em; white-space: nowrap;
  text-transform: uppercase; color: var(--text-soft); border: 1px solid var(--border); padding: 3px 9px; }
.dl .langs { display: flex; gap: 8px; white-space: nowrap; }
.dl .langs a { font-size: 11px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--orange-dark); border: 1px solid var(--border); padding: 7px 12px; transition: all 0.15s; }
[data-theme="dark"] .dl .langs a { color: var(--orange); }
.dl .langs a:hover { border-color: var(--orange); background: var(--cta-bg); }
.note-box { max-width: 860px; margin-top: 26px; background: var(--surface); border: 1px solid var(--border); padding: 18px 22px; font-size: 14px; color: var(--text-soft); }
@media (max-width: 768px) { .dl { flex-wrap: wrap; } .dl .langs { width: 100%; } .dl .sites { width: 100%; max-width: none; justify-content: flex-start; } }

/* Karriere – Stellenliste */
.jobs { display: flex; flex-direction: column; gap: 14px; max-width: 880px; }
.job { background: var(--bg); border: 1px solid var(--border); border-left: 4px solid var(--orange);
  padding: 24px 26px; display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; align-items: center; }
.job .jtext { flex: 1; min-width: 240px; }
.job h3 { font-size: 19px; margin-bottom: 6px; }
.job .jmeta { font-size: 11px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--orange-dark); margin-bottom: 8px; }
[data-theme="dark"] .job .jmeta { color: var(--orange); }
.job p { font-size: 14px; color: var(--text-soft); max-width: 60ch; }
.job .apply { white-space: nowrap; }
.career-init { max-width: 880px; margin-top: 30px; background: var(--cta-bg); border: 1px solid var(--border); padding: 26px 28px; }
.career-init h3 { font-size: 18px; margin-bottom: 8px; }
.career-init p { color: var(--text-soft); margin-bottom: 16px; }
@media (max-width: 560px) { .job .apply { width: 100%; } }

/* Kontakt – dezentes Orange (Light) / neutral (Dark) */
.cta { background: var(--cta-bg); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); text-align: center; }
.cta h2 { font-size: clamp(30px, 4vw, 46px); margin-bottom: 14px; color: var(--text); }
.cta p { font-size: 18px; max-width: 56ch; margin: 0 auto 28px; color: var(--text-soft); }

/* Kontakt-Seite */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }
.contact-block h2 { font-size: 20px; margin-bottom: 12px; }
.contact-block .mailrow { margin-top: 18px; }

/* ======================= FOOTER ======================= */
footer.site { background: var(--footer-bg); color: var(--footer-text); padding: 40px 0 20px; }
.footer-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 40px; align-items: center; padding-bottom: 28px; border-bottom: 1px solid rgba(255,255,255,0.1); }
footer.site img.flogo { height: 90px; width: auto; object-fit: contain; display: block; margin: 0 auto 18px; }
footer.site .fbrand { text-align: center; }
footer.site .fcol-legal { text-align: right; }
footer.site .fcol-legal ul { align-items: flex-end; }
footer.site .fclaim { text-align: center; color: var(--orange); font-size: 12px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; margin-top: 12px; }
footer.site h2 { color: var(--orange); font-size: 11px; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 14px; }
footer.site ul { list-style: none; display: flex; flex-direction: column; gap: 9px; }
footer.site ul a, footer.site address { font-size: 13px; color: var(--footer-text); transition: color 0.2s; font-style: normal; line-height: 1.75; }
footer.site ul a:hover, footer.site address a:hover { color: var(--orange); }
.footer-bottom { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 16px; padding-top: 18px; }
.footer-bottom p { font-size: 12px; color: rgba(255,255,255,0.35); }

/* ======================= RESPONSIVE ======================= */
@media (max-width: 980px) {
  .nav { gap: 12px; }
  .nav-links { position: fixed; inset: 88px 0 auto 0; flex-direction: column; gap: 0; background: var(--bg);
    border-bottom: 1px solid var(--border); padding: 8px 16px 16px; display: none; }
  .nav-links.open { display: flex; }
  .nav-links .dropdown { position: static; transform: none; opacity: 1; visibility: visible; box-shadow: none; border: none; padding: 0 0 8px 12px; min-width: 0; }
  .burger { display: block; }
  .hero { height: auto; min-height: 480px; }
  .split, .locs, .contact-grid { grid-template-columns: 1fr; gap: 36px; }
  .split.reverse .media { order: 0; }
  .cards, .cards.four { grid-template-columns: 1fr; }
  .app-grid { grid-template-columns: 1fr; }
  .values, .values.cols-4 { grid-template-columns: 1fr 1fr; }
  .stats { grid-template-columns: 1fr 1fr; gap: 28px 0; }
  .stat:nth-child(3) { border-left: none; padding-left: 0; }
  .footer-grid { grid-template-columns: 1fr; justify-items: center; text-align: center; gap: 28px; }
  .footer-grid .fbrand { order: -1; }
  .footer-grid .fcol-legal { text-align: center; }
  .footer-grid .fcol-legal ul { align-items: center; }
  section { padding: 68px 0; }
  .page-hero { padding: 96px 0 48px; }
}
@media (max-width: 520px) {
  .footer-grid { grid-template-columns: 1fr; }
  .values, .values.cols-4, .stats { grid-template-columns: 1fr; }
  .stat { border-left: none; padding-left: 0; }
  /* Kopfzeile kompakter, damit Sprachwahl (DE/EN/ES/FR) + Umschalter + Menü nebeneinander passen */
  .nav { gap: 8px; padding: 0 14px; }
  .brand img { height: 52px; }
  .nav-tools { gap: 8px; }
  .lang button { padding: 6px 7px; }
}
/* Sehr schmale Smartphones: vier Sprachkürzel + Wähler + Menü sicher in einer Zeile */
@media (max-width: 400px) {
  .nav { gap: 6px; padding: 0 10px; }
  .brand img { height: 46px; }
  .nav-tools { gap: 6px; }
  .lang button { padding: 6px 5px; font-size: 10.5px; letter-spacing: 0.03em; }
}


/* =========================================================
   ERGÄNZUNGEN: Barrierefreiheit, Touch & Responsive-Feinschliff
   ========================================================= */

/* Skip-Link zum Hauptinhalt */
.skip-link { position: absolute; left: 8px; top: -56px; z-index: 200;
  background: var(--orange); color: var(--text-on-orange); font-weight: 800; font-size: 13px;
  letter-spacing: 0.04em; padding: 10px 16px; border-radius: 0 0 4px 4px; transition: top 0.15s ease; }
.skip-link:focus { top: 0; }
/* Fokusring auf orangem Skip-Link-Grund dunkel halten (sonst orange-auf-orange) */
.skip-link:focus-visible { outline: 3px solid var(--text-on-orange); outline-offset: 2px; }

/* <nav>-Landmark ohne Layout-Einfluss (Flexbox bleibt erhalten) */
.mainnav { display: contents; }

/* Sichtbarer Tastatur-Fokus */
:focus-visible { outline: 2px solid var(--orange-dark); outline-offset: 3px; }
[data-theme="dark"] :focus-visible { outline-color: var(--orange); }

/* Dropdown auch per Tastatur (Fokus) öffnen, nicht nur per Hover */
.nav-links > li:focus-within .dropdown { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
/* Dropdown-Links: gleiche farbige Hervorhebung bei Tastatur-Fokus wie bei Hover */
.dropdown a:focus-visible { color: var(--orange-dark); background: var(--surface); }
[data-theme="dark"] .dropdown a:focus-visible { color: var(--orange); }

/* Touch-Targets >= 44px (Sprache, Theme, Menü) */
.lang button { min-height: 44px; }
.theme-toggle { width: 44px; height: 44px; }
.burger { min-width: 44px; min-height: 44px; align-items: center; justify-content: center; }
@media (max-width: 980px) { .burger { display: flex; } }

/* Footer-Copyright lesbarer (Kontrast) */
.footer-bottom p { color: rgba(255,255,255,0.6); }

/* Download-Links: größere Tap-Fläche auf Mobil & kleinen Tablets */
@media (max-width: 768px) { .dl .langs a { padding: 11px 14px; } }

/* Schmale Smartphones (<= 520px) */
@media (max-width: 520px) {
  .container { padding: 0 20px; }
  .brand img { max-width: 120px; }
  .tl { grid-template-columns: 1fr; gap: 4px; }
  .page-hero { padding: 28px 0 34px; }
  .view-switch { display: flex; width: 100%; }
  .vs-btn { flex: 1; text-align: center; padding: 13px 8px; }
}

/* Bewegung reduzieren, wenn vom System gewünscht */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}

/* =========================================================
   SUBSTITUTIONSRECHNER (.calc) – im Seiten-Design, theme-fähig
   Alles unter .calc gekapselt, damit nichts mit dem Seiten-CSS kollidiert.
   ========================================================= */
.calc { max-width: 1120px; margin: 0 auto; }
.calc .calc-hero {
  background: var(--cta-bg); border: 1px solid var(--border); border-radius: 16px;
  padding: 26px; display: grid; grid-template-columns: 1.3fr 0.7fr; gap: 24px; align-items: center;
}
.calc .calc-hero h3 { font-size: clamp(22px, 3vw, 30px); margin-bottom: 10px; }
.calc .calc-hero p { color: var(--text-soft); }
.calc .calc-summary { background: var(--orange); color: var(--text-on-orange); border-radius: 12px; padding: 22px; }
.calc .calc-summary span { color: rgba(20,19,15,0.72); font-size: 13px; display: block; }
.calc .calc-summary strong { color: var(--text-on-orange); font-size: 34px; line-height: 1.05; display: block; margin: 6px 0 4px; }
.calc .calc-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 18px; margin-top: 18px; }
.calc .panel { background: var(--bg); border: 1px solid var(--border); border-radius: 14px; padding: 22px; }
.calc .panel h3 { font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-soft); margin-bottom: 14px; }
.calc label { display: block; font-weight: 700; font-size: 13px; margin-bottom: 6px; }
.calc .field { margin-bottom: 14px; }
.calc input[type="number"], .calc input[type="text"] {
  width: 100%; border: 1px solid var(--border); border-radius: 9px; padding: 10px 11px;
  font: inherit; font-size: 15px; background: var(--bg); color: var(--text);
}
.calc input:focus { outline: 2px solid var(--orange-dark); outline-offset: 1px; border-color: var(--orange); }
.calc input[readonly] { background: var(--surface); color: var(--text-soft); }
.calc .help { font-size: 12px; color: var(--text-soft); margin-top: 4px; }
.calc .results { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.calc .metric { background: var(--surface); border-left: 4px solid var(--orange); border-radius: 10px; padding: 13px; min-height: 84px; }
.calc .metric span { display: block; color: var(--text-soft); font-size: 12px; margin-bottom: 6px; }
.calc .metric strong { font-size: 21px; }
.calc .metric.highlight { background: var(--orange); color: var(--text-on-orange); border-left-color: var(--footer-bg); }
.calc .metric.highlight span { color: #14130f; }
.calc .bars { margin-top: 14px; display: grid; gap: 9px; }
.calc .bar-row { display: grid; grid-template-columns: 70px 1fr 112px; gap: 10px; align-items: center; font-size: 13px; }
.calc .bar-bg { height: 13px; background: var(--surface); border: 1px solid var(--border); border-radius: 999px; overflow: hidden; }
.calc .bar-fill { height: 100%; background: var(--text-soft); width: 0; transition: width 0.25s ease; }
.calc .bar-fill.orange { background: var(--orange); }
.calc .table-panel { margin-top: 18px; }
.calc .table-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 14px; }
.calc .table-head h3 { margin-bottom: 6px; }
.calc .table-head p { color: var(--text-soft); font-size: 14px; max-width: 620px; }
.calc .table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 12px; }
.calc table { width: 100%; border-collapse: collapse; min-width: 760px; }
.calc th, .calc td { padding: 10px 9px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.calc th { background: var(--orange); color: var(--text-on-orange); font-size: 13px; text-align: left; }
.calc th.group { background-color: var(--orange); background-image: linear-gradient(rgba(0,0,0,0.08), rgba(0,0,0,0.08)); text-align: center; }
.calc tbody tr:nth-child(even) { background: var(--surface); }
.calc tbody tr[data-substitute] { background: rgba(245,158,20,0.12); }
.calc td.name { min-width: 180px; }
.calc td.num { width: 110px; }
.calc .row-actions { width: 80px; text-align: center; }
.calc .calc-auto { font-size: 11px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; color: var(--orange-dark); }
[data-theme="dark"] .calc .calc-auto { color: var(--orange); }
.calc .actions { display: flex; gap: 10px; flex-wrap: wrap; }
/* Aktions-Leiste UNTER der Tabelle – neutraler Grund, damit der orange
   „Zeile hinzufügen"-Knopf klar heraussticht */
.calc .calc-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; align-items: center;
  margin-top: 16px; padding: 14px 16px; background: var(--surface); border: 1px solid var(--border); border-radius: 12px; }
.calc .calc-btn { appearance: none; border: 1.5px solid var(--orange); border-radius: 9px; padding: 10px 15px;
  font: inherit; font-weight: 800; font-size: 12px; letter-spacing: 0.05em; text-transform: uppercase;
  cursor: pointer; background: var(--orange); color: var(--text-on-orange); transition: background 0.15s, box-shadow 0.15s; }
/* Primär-Aktion „Zeile hinzufügen": kräftiges Orange + Schatten + Plus, fällt ins Auge */
.calc .calc-btn:not(.secondary) { box-shadow: 0 2px 9px rgba(245,158,20,0.40); }
.calc .calc-btn:not(.secondary)::before { content: "+"; margin-right: 8px; font-weight: 900; font-size: 15px; vertical-align: middle; }
.calc .calc-btn:not(.secondary):hover { background: var(--orange-dark); color: #fff; box-shadow: 0 3px 12px rgba(245,158,20,0.50); }
.calc .calc-btn.secondary { background: transparent; color: var(--text); border-color: var(--border); box-shadow: none; }
.calc .calc-btn.secondary:hover { border-color: var(--orange); color: var(--orange); }
.calc .row-actions button.warn { background: transparent; color: #b3261e; border: 1px solid var(--border);
  border-radius: 8px; padding: 7px 10px; font: inherit; font-size: 12px; font-weight: 700; cursor: pointer; }
.calc .row-actions button.warn:hover { border-color: #b3261e; }
.calc .notice { margin-top: 14px; background: var(--cta-bg); border-left: 5px solid var(--orange);
  border-radius: 10px; padding: 14px 16px; font-size: 13px; color: var(--text-soft); }
@media (max-width: 760px) {
  .calc .calc-hero, .calc .calc-grid { grid-template-columns: 1fr; }
  .calc .results { grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   FOOTER: Social-Icons + Zugehörigkeit zur Mühlengruppe
   ========================================================= */
.fsocial { display: flex; gap: 10px; margin-top: 16px; }
.fsocial a, .fsocial .is-soon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 50%;
  color: var(--footer-text); border: 1px solid rgba(255,255,255,0.18);
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.fsocial a:hover { color: #fff; border-color: var(--orange); background: rgba(245,158,20,0.16); }
.fsocial svg { width: 18px; height: 18px; }
/* Platzhalter (z. B. LinkedIn folgt): sichtbar, aber gedämpft und nicht klickbar */
.fsocial .is-soon { opacity: 0.4; pointer-events: none; cursor: default; }
.footer-group {
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
  margin-top: 8px; padding: 22px 0 6px; border-top: 1px solid rgba(255,255,255,0.10);
}
.footer-group img { height: 40px; width: auto; object-fit: contain; background: #fff; padding: 7px 12px; border-radius: 7px; }

/* Rechner: Trenner zwischen „Bisherige" und „Optimierte" Rezeptur + leere Felder (Chocmalt) */
.calc .col-div { border-left: 2px solid var(--orange-ring); }
.calc .calc-na { color: var(--text-soft); display: inline-block; text-align: center; width: 100%; }

/* Kontaktseite: mehrere Postfächer zur Auswahl */
.mailrow-multi { display: flex; flex-direction: column; gap: 10px; align-items: stretch; max-width: 420px; }
.mailrow-multi .btn { flex-direction: column; align-items: flex-start; gap: 2px; text-transform: none; letter-spacing: 0; padding: 12px 18px; }
.mailrow-multi .btn small { font-weight: 600; font-size: 12px; opacity: 0.85; text-transform: none; letter-spacing: 0; }
.footer-group p { color: var(--footer-text); font-size: 13px; max-width: 560px; line-height: 1.5; }

/* =========================================================
   KITCHEN LAB – gemeinsame Entwicklung (Produkte-Seite)
   ========================================================= */
.kitchen-lab { padding-top: 8px; }
.kitchen-lab .kl-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 36px; }
.kitchen-lab .kl-gallery figure { margin: 0; }
.kitchen-lab .kl-gallery img, .kitchen-lab .kl-ph {
  width: 100%; aspect-ratio: 3 / 2; object-fit: cover; border-radius: 12px; display: block;
}
.kitchen-lab .kl-ph {
  display: grid; place-items: center; text-align: center; padding: 10px;
  background: var(--surface); border: 1px dashed var(--border); color: var(--text-soft);
  font-size: 13px; font-weight: 700; letter-spacing: 0.03em;
}
.kitchen-lab .kl-gallery figcaption { margin-top: 9px; font-size: 13px; font-weight: 700; color: var(--text-soft); }
@media (max-width: 760px) { .kitchen-lab .kl-gallery { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .kitchen-lab .kl-gallery { grid-template-columns: 1fr; } }

/* Mobile-Feinschliff (aus Prüfung 2026-06-08): Rechner & Tabs auf schmalen Geräten */
@media (max-width: 520px) {
  .calc .results { grid-template-columns: 1fr; }
  .view-switch .vs-btn { font-size: 11px; padding: 11px 6px; white-space: normal; line-height: 1.25; }
}
@media (max-width: 400px) {
  .calc .bar-row { grid-template-columns: 48px 1fr 78px; gap: 6px; font-size: 12px; }
}


/* =========================================================
   MALZFARBE NACH EBC – tönt das gesamte Theme
   Auswahl per Kopf-Steuerung (siehe bns.js). Die [data-ebc]-Blöcke
   überschreiben die Theme-Variablen; helle Stufen (30/100/300) laufen
   auf data-theme="light", dunkle (500/1000/1500) auf data-theme="dark",
   damit Schrift-Kontrast & Logo-Wechsel erhalten bleiben.
   ========================================================= */

/* ---- helle Stufen: warmer Grund, dunkle Schrift ---- */
[data-ebc="e30"] {
  --g-top:#fdf6e9; --g-bottom:#f4e7cd; --bg:#fffaf0; --surface:#f3e8d4;
  --text:#1c1710; --text-soft:#6b5f49; --border:#e8dcc4;
  --nav-bg:rgba(255,251,243,0.85); --cta-bg:rgba(245,158,20,0.10);
}
[data-ebc="e100"] {
  --g-top:#f9ecca; --g-bottom:#f0db9f; --bg:#fdf4dc; --surface:#f1e3ba;
  --text:#1d1808; --text-soft:#6a5c34; --border:#e2d0a0;
  --nav-bg:rgba(252,245,224,0.85); --cta-bg:rgba(245,158,20,0.12);
}
[data-ebc="e300"] {
  --g-top:#f0d6a3; --g-bottom:#e3bd76; --bg:#f5e0b6; --surface:#e9cb92;
  --text:#20160a; --text-soft:#5f4a2a; --border:#d8b97e;
  --nav-bg:rgba(244,224,180,0.84); --cta-bg:rgba(120,70,20,0.10);
}

/* ---- dunkle Stufen: dunkler Grund, helle Schrift ---- */
[data-ebc="e500"] {
  --g-top:#3c2613; --g-bottom:#4f3019; --bg:#311f10; --surface:#402815;
  --text:#f6ecdc; --text-soft:#cbb597; --border:#56391f;
  --nav-bg:rgba(49,31,16,0.82); --footer-bg:#160d06; --cta-bg:rgba(0,0,0,0.40);
}
[data-ebc="e1000"] {
  --g-top:#261609; --g-bottom:#341f0f; --bg:#1f1308; --surface:#2c1b0d; --border:#422814;
  --text:#f4e9d8; --text-soft:#bda88a;
  --nav-bg:rgba(31,19,8,0.85); --footer-bg:#120a04; --cta-bg:rgba(0,0,0,0.45);
}
[data-ebc="e1500"] {
  --g-top:#150d06; --g-bottom:#20130a; --bg:#120a05; --surface:#1d1109; --border:#34200f;
  --text:#f2e7d6; --text-soft:#b3a085;
  --nav-bg:rgba(18,10,5,0.88); --footer-bg:#0a0502; --cta-bg:rgba(0,0,0,0.50);
}

/* ---- Steuerung im Kopf (Knopf + Menü) ---- */
/* Der EBC-Wähler ersetzt den früheren Hell/Dunkel-Knopf (per JS entfernt;
   hier zusätzlich ausgeblendet, falls JS später lädt). */
.theme-toggle { display: none !important; }

.ebc { position: relative; display: flex; align-items: center; flex-shrink: 0; }
/* Der Knopf selbst ist rahmenlos – der dezente Orange-Ring sitzt klein und eng
   direkt um die Farbpalette (den Punkt), damit klar ist: hier lässt sich die Farbe einstellen. */
.ebc-toggle {
  width: 44px; height: 44px; border: none; border-radius: 50%; padding: 0;
  background: transparent; cursor: pointer; display: grid; place-items: center;
  color: var(--text); transition: all 0.2s;
}
.ebc-dot {
  position: relative;
  width: 22px; height: 22px; border-radius: 50%;
  background: conic-gradient(from 180deg, #f4e7cd, #e3bd76, #b9702f, #6b3e1c, #2e1a0d, #120a05, #f4e7cd);
  box-shadow: 0 0 0 1.5px var(--orange-ring);   /* kleiner, dezenter Orange-Ring um die Palette */
  transition: box-shadow 0.2s;
}
.ebc-toggle:hover .ebc-dot, .ebc-toggle[aria-expanded="true"] .ebc-dot {
  box-shadow: 0 0 0 2px var(--orange);          /* bei Hover/geöffnet etwas kräftiger */
}
/* Symbole in der Palette: Sonne bei Weiß, Mond bei Schwarz, sonst Farbfläche/Verlauf */
.ebc-dot .ebc-ic { position: absolute; inset: 0; margin: auto; display: none; }
.ebc-toggle[data-appearance="white"] .ebc-dot { background: #ffffff; }
.ebc-toggle[data-appearance="white"] .ebc-sun  { display: block; color: #b07d12; }
.ebc-toggle[data-appearance="dark"]  .ebc-dot { background: #141414; }
.ebc-toggle[data-appearance="dark"]  .ebc-moon { display: block; color: #f3e6cc; }
.ebc-toggle[data-appearance="color"] .ebc-dot { background: var(--ebc-dot-c); }

.ebc-menu {
  position: absolute; top: calc(100% + 8px); right: 0; z-index: 120;
  background: var(--bg); border: 1px solid var(--border); box-shadow: var(--shadow);
  padding: 8px; min-width: 210px; max-width: calc(100vw - 20px); display: flex; flex-direction: column; gap: 2px;
}
.ebc-menu[hidden] { display: none; }
.ebc-head {
  font-size: 10px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-soft); padding: 6px 8px 8px;
}
.ebc-opt {
  display: flex; align-items: center; gap: 11px; width: 100%; text-align: left;
  background: transparent; border: none; cursor: pointer; font-family: inherit;
  font-size: 13px; font-weight: 600; color: var(--text); padding: 9px 8px;
  min-height: 44px; transition: background 0.15s;
}
.ebc-opt:hover { background: var(--surface); }
.ebc-opt .sw {
  width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
  border: 1px solid rgba(0,0,0,0.2); background: var(--c);
}
[data-theme="dark"] .ebc-opt .sw { border-color: rgba(255,255,255,0.3); }
.ebc-opt[aria-checked="true"] { color: var(--orange-dark); }
[data-theme="dark"] .ebc-opt[aria-checked="true"] { color: var(--orange); }
.ebc-opt[aria-checked="true"] .sw { box-shadow: 0 0 0 2px var(--orange); }


/* =========================================================
   HINTERGRUND-STRUKTUR – Weizenkörner (nur bei EBC-Farben)
   Bei WEISS und SCHWARZ bewusst KEIN Effekt. Aktiv, sobald ein EBC-Ton
   gewählt ist (data-ebc) oder das warme EBC 10 (data-theme="light").
   Für die Körner liegt der Verlauf auf <html>, body wird transparent,
   die Konturen liegen als fixe ::before-Maske dahinter.
   ========================================================= */
/* Konturfarbe – passt sich dem Theme an (malzig getönt).
   "strong" = kräftig in den Seitenrändern, "faint" = sehr transparent hinter dem Text. */
:root {
  --grain-strong: rgba(40,30,12,0.26);
  --grain-faint:  rgba(40,30,12,0.05);
}
[data-theme="dark"] {
  --grain-strong: rgba(245,230,205,0.20);
  --grain-faint:  rgba(245,230,205,0.045);
}

/* Verlauf auf <html>, body transparent – nur für EBC-Farben (inkl. EBC 10) */
html[data-ebc], html[data-theme="light"] {
  background: linear-gradient(180deg, var(--g-top) 0%, var(--g-bottom) 100%) fixed no-repeat;
}
html[data-ebc] body,
html[data-theme="light"] body { background: transparent; }

/* Die verteilten Weizenkorn-Konturen */
html[data-ebc] body::before,
html[data-theme="light"] body::before {
  content: ""; position: fixed; inset: 0; z-index: -1; pointer-events: none;
  /* kräftig in den Seitenrändern, sehr transparent in der zentralen Textspalte (~1180px) */
  background: linear-gradient(90deg,
    var(--grain-strong) 0,
    var(--grain-strong) calc(50% - 660px),
    var(--grain-faint)  calc(50% - 560px),
    var(--grain-faint)  calc(50% + 560px),
    var(--grain-strong) calc(50% + 660px),
    var(--grain-strong) 100%);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='360' height='360' viewBox='0 0 360 360'%3E%3Cg fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cg transform='translate(60 70) rotate(18) scale(1.0)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(250 55) rotate(-32) scale(0.8)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(165 150) rotate(60) scale(1.18)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(70 255) rotate(-12) scale(0.92)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(295 250) rotate(40) scale(1.06)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(205 315) rotate(-50) scale(0.75)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(330 150) rotate(8) scale(0.7)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") 0 0 / 360px 360px repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='360' height='360' viewBox='0 0 360 360'%3E%3Cg fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cg transform='translate(60 70) rotate(18) scale(1.0)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(250 55) rotate(-32) scale(0.8)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(165 150) rotate(60) scale(1.18)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(70 255) rotate(-12) scale(0.92)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(295 250) rotate(40) scale(1.06)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(205 315) rotate(-50) scale(0.75)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3Cg transform='translate(330 150) rotate(8) scale(0.7)'%3E%3Cpath d='M0,-16 C5.5,-15 8.6,-7 8.6,0 C8.6,8 4.6,15.6 0,16 C-4.6,15.6 -8.6,8 -8.6,0 C-8.6,-7 -5.5,-15 0,-16 Z'/%3E%3Cpath d='M0,-11 C2.2,-4 2.2,4 0,11'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") 0 0 / 360px 360px repeat;
}
