
:root {
  --ink: #17110f;
  --muted: rgba(31, 22, 19, .68);
  --line: rgba(255, 255, 255, .56);
  --milk: rgba(255, 250, 245, .74);
  --soft: rgba(255, 255, 255, .42);
  --green: #7eef22;
  --yellow: #dbff5b;
  --paper: #fffaf1;
  --shadow: 0 26px 80px rgba(30, 20, 17, .16);
  --page: 1000px;
}
* { box-sizing: border-box; }
html { scroll-behavior: auto; }
body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: linear-gradient(135deg, #fff9ed 0%, #f1dfc4 48%, #c9a183 100%);
  background-attachment: scroll;
}
a { color: inherit; }
.macroBackdrop, .softOrbit { display: none !important; }
.macroBackdrop { display: none !important; }
.softOrbit { display: none !important; }
.siteTop {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  width: min(var(--page), calc(100% - 32px)); margin: 0 auto; padding: 14px 0 10px;
}
.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; font-weight: 1000; letter-spacing: -.08em; font-size: clamp(26px, 5vw, 48px); line-height: .86; }
.brandIcon { width: clamp(34px, 6vw, 54px); height: clamp(34px, 6vw, 54px); border-radius: 999px; }
.languageSwitch { display: inline-flex; gap: 6px; padding: 6px; border-radius: 999px; background: rgba(255,255,255,.54); border: 1px solid var(--line); box-shadow: 0 14px 34px rgba(30,20,17,.1); }
.languageSwitch a { display: inline-grid; place-items: center; min-width: 42px; height: 34px; border-radius: 999px; text-decoration: none; font-weight: 950; font-size: 13px; }
.languageSwitch a[aria-current="page"] { background: var(--ink); color: #fff; }
.page { width: min(var(--page), calc(100% - 32px)); margin: 0 auto; padding: 18px 0 56px; }
.glassCard { border: 1px solid var(--line); border-radius: clamp(26px, 4vw, 46px); background: var(--milk); box-shadow: var(--shadow); backdrop-filter: blur(20px); overflow: hidden; }
.logoRibbon, .appBanner { width: 100%; max-width: var(--page); margin: 0 auto 18px; border-radius: clamp(24px, 4vw, 42px); overflow: hidden; box-shadow: var(--shadow); background: #17110f; }
.logoRibbon img, .appBanner img { display: block; width: 100%; height: auto; }
.heroRibbon { margin-top: 6px; }
.copyPanel, .appPanel, .projectShowcase, .bookShelf, .bookHero, .readerShell { margin-top: 18px; padding: clamp(24px, 4.5vw, 46px); }
.copyPanel, .appPanel { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: clamp(18px, 4vw, 38px); align-items: center; }
.strongPanel { background: linear-gradient(135deg, rgba(255,255,255,.82), rgba(230,255,92,.20) 46%, rgba(255,246,222,.72)); }
.eyebrow, .kicker { margin: 0 0 12px; font-size: 12px; line-height: 1.1; letter-spacing: .18em; text-transform: uppercase; font-weight: 950; color: rgba(34, 25, 22, .62); }
.wordmark { margin: 0; font-size: clamp(58px, 13vw, 138px); line-height: .78; letter-spacing: -.11em; font-weight: 1000; text-transform: uppercase; }
.smallWordmark { font-size: clamp(46px, 9vw, 104px); overflow-wrap: anywhere; }
.copyPanel h1, .copyPanel h2, .appPanel h2, .projectShowcase h2, .bookShelf h2 { margin: 0; font-size: clamp(42px, 8vw, 92px); line-height: .86; letter-spacing: -.075em; }
.lead, .copyPanel p, .appPanel p, .projectGrid p, .bookShelf p { max-width: 650px; color: var(--muted); font-size: clamp(18px, 2.2vw, 24px); line-height: 1.38; }
.copyButton, .cardActions button, .readerTop a, .bookPager button, .bookSwitch button { border: 0; border-radius: 999px; padding: 16px 24px; min-height: 54px; background: var(--ink); color: #fff; font: 1000 15px/1 ui-sans-serif, system-ui, sans-serif; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; text-decoration: none; box-shadow: 0 18px 42px rgba(30,20,17,.22); }
.copyButton { min-width: min(280px, 42vw); min-height: 88px; font-size: 28px; }
.copyButton.secondary { min-height: 68px; font-size: 18px; min-width: 180px; }
.appPanel { grid-template-columns: minmax(0, 1fr) minmax(260px, 380px); }
.qrHero { display: grid; place-items: center; justify-self: end; width: min(100%, 380px); padding: 18px; border-radius: 34px; background: #fff; box-shadow: inset 0 0 0 1px rgba(0,0,0,.04), 0 22px 50px rgba(30,20,17,.18); }
.qrHero img { width: 100%; height: auto; display: block; border-radius: 20px; }
.projectGrid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: 22px; }
.projectGrid article, .bookSpine { display: flex; flex-direction: column; min-height: 210px; padding: 22px; border-radius: 28px; border: 1px solid rgba(255,255,255,.62); background: rgba(255,255,255,.42); }
.projectGrid h3 { margin: 0 0 8px; font-size: 26px; line-height: .95; letter-spacing: -.05em; overflow-wrap: anywhere; }
.projectGrid p { margin: 0; font-size: 16px; }
.cardActions { margin-top: auto; display: flex; flex-wrap: wrap; gap: 10px; padding-top: 18px; }
.cardActions a { display: inline-flex; align-items: center; min-height: 46px; padding: 13px 18px; border-radius: 999px; background: rgba(255,255,255,.68); text-decoration: none; font-weight: 950; }
.cardActions button { min-height: 46px; padding: 13px 18px; font-size: 13px; }
.libraryGrid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 22px; }
.bookSpine { min-height: 160px; text-decoration: none; justify-content: flex-end; transition: background .16s ease; }
.bookSpine:hover { background: rgba(255,255,255,.56); }
.bookSpine strong { font-size: clamp(30px, 5vw, 54px); line-height: .9; letter-spacing: -.07em; }
.bookSpine span { margin-top: 8px; color: var(--muted); font-weight: 850; }
.videoPanel { margin-top: 18px; width: 100%; }
.videoFrame { position: relative; width: 100%; aspect-ratio: 16/9; border-radius: clamp(20px, 3.5vw, 36px); overflow: hidden; background: var(--ink); box-shadow: var(--shadow); }
.videoFrame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.footer { width: min(var(--page), calc(100% - 32px)); margin: 0 auto 28px; display: flex; justify-content: space-between; gap: 16px; color: rgba(31,22,19,.66); font-weight: 800; }
.footer a { color: inherit; }
.toast { position: fixed; left: 50%; bottom: 24px; transform: translate(-50%, 30px); opacity: 0; pointer-events: none; padding: 14px 22px; border-radius: 999px; background: var(--ink); color: #fff; font-weight: 950; transition: opacity .18s ease, transform .18s ease; z-index: 50; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
.readPage { max-width: var(--page); }
.bookHero { min-height: 250px; }
.readerShell { background: rgba(255,250,245,.82); }
.readerTop, .bookPager, .bookSwitch { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.readerTop a { background: rgba(255,255,255,.7); color: var(--ink); box-shadow: none; }
.bookCounter { font-weight: 1000; color: var(--muted); }
.bookPanels { margin-top: 22px; }
.bookPanel { display: none; min-height: 54vh; max-height: 70vh; overflow: auto; padding: clamp(22px, 4vw, 46px); border-radius: 30px; background: var(--paper); border: 1px solid rgba(255,255,255,.70); }
.bookPanel.active { display: block; }
.chapterText h2 { margin: 0 0 24px; font-size: clamp(28px, 4.5vw, 54px); line-height: .98; letter-spacing: -.055em; }
.chapterText h3 { margin: 30px 0 10px; font-size: 24px; }
.chapterText p { margin: 0 0 18px; color: rgba(31,22,19,.78); font: 520 clamp(18px, 1.7vw, 21px)/1.72 Georgia, "Times New Roman", serif; }
.bookPager { margin-top: 18px; }
.bookPager button { min-width: 140px; }
.bookSwitch { justify-content: center; margin-top: 14px; }
.bookSwitch button { background: rgba(255,255,255,.68); color: var(--ink); box-shadow: none; min-height: 42px; padding: 12px 16px; font-size: 12px; }
.bookSwitch button.active { background: var(--ink); color: #fff; }
@media (max-width: 920px) {
  .appPanel, .copyPanel { grid-template-columns: 1fr; }
  .qrHero { justify-self: stretch; width: min(100%, 440px); margin: 0 auto; }
  .projectGrid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .siteTop { width: min(var(--page), calc(100% - 22px)); align-items: center; }
  .brand span { display: none; }
  .page, .footer { width: min(var(--page), calc(100% - 22px)); }
  .projectGrid, .libraryGrid { grid-template-columns: 1fr; }
  .copyButton { width: 100%; min-width: 0; }
  .footer { display: block; }
  .footer span { display: block; margin-top: 8px; }
  .bookPanel { max-height: 72vh; }
}

.vibesPanel { margin-top: 18px; padding: clamp(18px, 3.5vw, 34px); }
.vibesHead { display: flex; align-items: end; justify-content: space-between; gap: 14px; margin-bottom: 16px; }
.vibesHead h2 { margin: 0; font-size: clamp(40px, 7vw, 86px); line-height: .86; letter-spacing: -.075em; }
.vibesOpen { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 13px 18px; border-radius: 999px; background: rgba(255,255,255,.70); text-decoration: none; font-weight: 950; }
.vibesList { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 14px; }
.vibeButton { min-height: 84px; border: 1px solid rgba(255,255,255,.68); border-radius: 24px; padding: 16px 18px; text-align: left; background: linear-gradient(135deg, rgba(126,239,34,.30), rgba(219,255,91,.26), rgba(255,255,255,.38)); color: var(--ink); cursor: pointer; box-shadow: 0 14px 30px rgba(30,20,17,.09); }
.vibeButton strong { display: block; font-size: clamp(18px, 2.4vw, 25px); line-height: 1.02; letter-spacing: -.045em; }
.vibeButton span { display: block; margin-top: 8px; color: var(--muted); font-weight: 850; }
.vibeButton.active { background: var(--ink); color: #fff; }
.vibeButton.active span { color: rgba(255,255,255,.70); }
@media (max-width: 620px) { .vibesHead { display: block; } .vibesOpen { margin-top: 12px; } .vibesList { grid-template-columns: 1fr; } }


.instaPanel { margin-top: 18px; padding: clamp(18px, 3.5vw, 34px); }
.instaHead { display: flex; align-items: end; justify-content: space-between; gap: 14px; margin-bottom: 16px; }
.instaHead h2 { margin: 0; font-size: clamp(40px, 7vw, 86px); line-height: .86; letter-spacing: -.075em; }
.instaOpen { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 13px 18px; border-radius: 999px; background: rgba(255,255,255,.70); text-decoration: none; font-weight: 950; }
.instaStrip { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(180px, 260px); gap: 12px; overflow-x: auto; overscroll-behavior-inline: contain; scroll-snap-type: inline mandatory; padding: 4px 4px 12px; }
.instaTile { position: relative; display: block; aspect-ratio: 1 / 1; border-radius: 26px; overflow: hidden; text-decoration: none; background: linear-gradient(135deg, rgba(126,239,34,.38), rgba(219,255,91,.30), rgba(255,255,255,.42)); border: 1px solid rgba(255,255,255,.72); box-shadow: 0 16px 34px rgba(30,20,17,.11); scroll-snap-align: start; }
.instaTile img { display: block; width: 100%; height: 100%; object-fit: cover; transition: none; }
.instaTile:hover img { transform: none; }
.instaTile span { position: absolute; left: 10px; right: 10px; bottom: 10px; min-height: 42px; display: flex; align-items: center; justify-content: center; padding: 9px 12px; border-radius: 999px; background: rgba(23,17,15,.82); color: #fff; font-size: 12px; font-weight: 950; letter-spacing: .08em; text-transform: uppercase; backdrop-filter: blur(10px); }
@media (max-width: 620px) { .instaHead { display: block; } .instaOpen { margin-top: 12px; } .instaStrip { grid-auto-columns: minmax(150px, 72vw); } }


/* GREMMATIK 036: reduzierte Startseite */
.siteTop.compactTop { position: sticky; top: 0; z-index: 30; min-height: 74px; padding: 12px 0 8px; }
.categoryBrand { font-size: clamp(24px, 3.8vw, 42px); letter-spacing: -.07em; }
.languageDesktop { margin-left: auto; }
.languageMobile { display: none; }
.heroPanel { position: relative; margin-top: 6px; padding: clamp(26px, 5vw, 54px); min-height: 300px; display: flex; flex-direction: column; justify-content: flex-end; background: linear-gradient(135deg, rgba(255,255,255,.86), rgba(230,255,92,.18) 48%, rgba(255,246,222,.76)); }
.heroBrandLine, .panelName { display: inline-flex; align-items: center; gap: 10px; }
.heroBrandLine { margin-bottom: auto; }
.heroG { width: clamp(46px, 7vw, 76px); height: clamp(46px, 7vw, 76px); border-radius: 999px; }
.heroPanel h1 { margin: 26px 0 8px; font-size: clamp(48px, 10vw, 112px); line-height: .82; letter-spacing: -.085em; }
.heroPanel p { margin: 0; max-width: 720px; color: var(--muted); font-size: clamp(18px, 2.1vw, 24px); line-height: 1.38; }
.triplePanelGrid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 18px; }
.triPanel { min-height: 230px; padding: 22px; display: flex; flex-direction: column; justify-content: space-between; }
.greenBanner { background: linear-gradient(135deg, rgba(126,239,34,.38), rgba(219,255,91,.34) 42%, rgba(255,255,255,.54)); }
.panelName img { width: 30px; height: 30px; border-radius: 999px; flex: 0 0 auto; }
.panelName span { font-weight: 1000; letter-spacing: -.045em; font-size: clamp(21px, 2.4vw, 30px); line-height: .98; overflow-wrap: anywhere; }
.triPanel p { margin: 18px 0; color: var(--muted); font-weight: 760; line-height: 1.35; }
.copyButton.compactCopy, .panelButton { width: 100%; min-width: 0; min-height: 48px; padding: 14px 16px; border-radius: 999px; font-size: 14px; letter-spacing: .1em; display: inline-flex; align-items: center; justify-content: center; text-decoration: none; border: 0; background: var(--ink); color: #fff; font-weight: 1000; text-transform: uppercase; box-shadow: 0 16px 34px rgba(30,20,17,.18); cursor: pointer; }
.sectionHead { display: flex; justify-content: space-between; align-items: end; gap: 14px; margin-bottom: 16px; }
.sectionHead h2 { margin: 0; font-size: clamp(36px, 6vw, 76px); line-height: .86; letter-spacing: -.075em; }
.smallPill { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; padding: 11px 16px; border-radius: 999px; background: rgba(255,255,255,.70); text-decoration: none; font-weight: 950; white-space: nowrap; }
.artworkPanel, .leitBanner, .bookShelf, .vibesPanel, .instaPanel { margin-top: 18px; padding: clamp(18px, 3vw, 32px); }
.artworkFrame { border-radius: clamp(20px, 3vw, 34px); overflow: hidden; background: #17110f; max-height: 520px; }
.artworkFrame img { display: block; width: 100%; height: min(52vw, 520px); object-fit: cover; }
.leitBanner { background: linear-gradient(135deg, rgba(255,255,255,.86), rgba(126,239,34,.16), rgba(219,255,91,.24)); }
.leitBanner p { margin: 18px 0 0; max-width: 820px; color: rgba(31,22,19,.78); font-size: clamp(20px, 2.4vw, 30px); line-height: 1.26; letter-spacing: -.035em; font-weight: 840; }
.libraryGridThree { margin-top: 10px; }
.libraryGridThree .bookSpine { min-height: 142px; padding: 18px; border-radius: 24px; background: rgba(255,255,255,.44); }
.libraryGridThree .bookSpine strong { font-size: clamp(22px, 3.2vw, 36px); line-height: .94; }
.libraryGridThree .bookSpine span { font-size: 14px; line-height: 1.2; }
.vibesTwoCol { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(260px, .9fr); gap: 14px; align-items: stretch; }
.vibesTwoCol .videoFrame { height: 100%; min-height: 300px; aspect-ratio: 16 / 9; }
.cleanVibesList { margin-top: 0; display: flex; flex-direction: column; gap: 8px; max-height: min(54vw, 430px); overflow: auto; padding-right: 4px; }
.cleanVibesList .vibeButton { min-height: 58px; border-radius: 18px; padding: 12px 14px; background: rgba(255,255,255,.52); box-shadow: none; }
.cleanVibesList .vibeButton.active { background: linear-gradient(135deg, rgba(126,239,34,.44), rgba(219,255,91,.36)); border-color: rgba(23,17,15,.20); }
.cleanVibesList .vibeButton strong { font-size: 16px; line-height: 1.1; letter-spacing: -.025em; }
.cleanVibesList .vibeButton span { font-size: 12px; margin-top: 3px; }
.instaPanel .instaStrip { grid-auto-columns: minmax(150px, 210px); }
.instaPanel .instaTile { border-radius: 20px; }
.projectShowcase, .appBanner { display: none !important; }
@media (max-width: 920px) {
  .triplePanelGrid { grid-template-columns: 1fr; }
  .triPanel { min-height: 172px; }
  .vibesTwoCol { grid-template-columns: 1fr; }
  .cleanVibesList { max-height: 310px; }
}
@media (max-width: 620px) {
  .languageDesktop { display: none; }
  .languageMobile { display: inline-flex; position: absolute; right: 18px; top: 18px; }
  .siteTop.compactTop { position: static; min-height: 0; padding-bottom: 0; }
  .categoryBrand span { display: inline; font-size: 24px; }
  .heroPanel { min-height: 330px; padding: 22px; }
  .heroBrandLine { padding-right: 116px; }
  .sectionHead { display: block; }
  .smallPill { margin-top: 10px; }
  .artworkFrame img { height: 62vw; }
  .vibesTwoCol .videoFrame { min-height: 200px; }
}


/* GREMMATIK 037: ruhiger Hintergrund / kein Scroll-Zappeln */
.macroBackdrop, .softOrbit { display: none !important; }
body::before, body::after { content: none !important; display: none !important; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}


/* GREMMATIK 038: neues Logo, Kategorien, sichtbare Änderungsspur */
:root {
  --system-gray: #f3f2ef;
  --system-gray-2: #e8e6e1;
}
body { background: linear-gradient(135deg, #f6f5f2 0%, #ebe8df 52%, #d4cec2 100%); }
.logoBrand { letter-spacing: normal; font-size: 1rem; line-height: 1; }
.wordLogo { display: block; width: min(430px, 70vw); height: auto; }
.siteTop.compactTop { align-items: flex-start; }
.heroG, .brandIcon, .panelName img { object-fit: contain; background: transparent; border-radius: 0; }
.heroG { width: 54px; height: 54px; }
.categoryHero, .categoryWindow { position: relative; border-color: color-mix(in srgb, var(--cat, #7eef22) 42%, white 58%); }
.categoryHero::before, .categoryWindow::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 7px; background: var(--cat, #7eef22); opacity: .95; pointer-events: none; }
.categoryWindow { background: linear-gradient(135deg, rgba(255,255,255,.76), color-mix(in srgb, var(--cat, #7eef22) 18%, rgba(255,255,255,.62) 82%)); }
.kicker b { color: #777; font-weight: 850; }
.heroPanel h1 { margin-top: 10px; }
.shelfLead { max-width: 720px; margin: 0 0 18px; color: var(--muted); font-size: clamp(17px, 2vw, 21px); line-height: 1.42; }
.bookSpine em { display: block; margin-top: 14px; padding-top: 12px; border-top: 1px solid rgba(20,16,14,.12); color: rgba(31,22,19,.62); font-style: normal; font-size: 13px; line-height: 1.35; }
.chapterNote { margin-top: 22px; padding: 15px 16px; border-left: 7px solid var(--cat, #7eef22); background: color-mix(in srgb, var(--cat, #7eef22) 14%, white 86%); border-radius: 14px; color: rgba(31,22,19,.72); font-size: 15px; line-height: 1.45; }
.chapterNote strong { color: var(--ink); }
.logoRibbon { background: var(--system-gray); }
.logoRibbon img { mix-blend-mode: multiply; }
@media (min-width: 921px) { .libraryGridThree .bookSpine { min-height: 178px; } }
@media (max-width: 620px) { .wordLogo { width: min(310px, 76vw); } .heroG { width: 44px; height: 44px; } }


/* Stand 039: Antworten des Autors / FAQ */
.authorAnswers { margin-top: 18px; }
.faqList { display: grid; gap: 10px; margin-top: 18px; }
.faqItem { border-radius: 22px; border: 1px solid color-mix(in srgb, var(--cat) 42%, rgba(0,0,0,.08)); background: color-mix(in srgb, var(--cat) 9%, rgba(255,255,255,.84)); overflow: hidden; }
.faqItem summary { cursor: pointer; list-style: none; display: flex; align-items: center; gap: 12px; padding: 16px 18px; font-weight: 850; letter-spacing: -.02em; }
.faqItem summary::-webkit-details-marker { display: none; }
.faqItem summary span { width: 34px; height: 34px; border-radius: 999px; display: inline-grid; place-items: center; background: var(--cat); color: #111; font-size: 12px; flex: 0 0 auto; }
.faqItem p { margin: 0; padding: 0 18px 18px 64px; max-width: 92ch; line-height: 1.62; }
@media (max-width: 720px) { .faqItem p { padding-left: 18px; } .faqItem summary { align-items: flex-start; } }


/* Stand 040: nur Wortmarke sichtbar, transparenter Mitscroll-Kopf, Hintergrund etwas schärfer */
body {
  background-image: linear-gradient(135deg, rgba(246,245,242,.92) 0%, rgba(235,232,223,.86) 56%, rgba(212,206,194,.92) 100%), url("assets/grematik-makro-bg.jpg");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}
.siteTop {
  background: linear-gradient(180deg, rgba(243,242,239,.80), rgba(243,242,239,.56));
  border: 1px solid rgba(255,255,255,.62);
  border-radius: 999px;
  padding: 10px 18px;
  margin-top: 10px;
  box-shadow: 0 12px 26px rgba(30,20,17,.10);
}
.siteTop.compactTop { padding: 10px 18px; min-height: 0; }
.logoBrand { display: inline-flex; align-items: center; }
.wordLogo { width: min(410px, 58vw); }
.languageDesktop { margin-left: auto; }
.heroBrandLine { margin-bottom: 10px; }
.heroBrandLine .kicker { margin: 0; }
.panelName { gap: 0; }
.panelName img, .heroG, .brandIcon { display: none !important; }
.artworkFrame { background: #17110f; }
.artworkFrame img { filter: contrast(1.08) saturate(1.03); }
@media (max-width: 620px) {
  .siteTop { padding: 8px 14px; margin-top: 8px; border-radius: 24px; }
  .siteTop.compactTop { position: static; }
  .wordLogo { width: min(290px, 74vw); }
}

/* Stand 041: Sticky wirklich überall, alte G-Klassen nur noch totgelegt */
.siteTop,
.siteTop.compactTop {
  position: sticky !important;
  top: 8px !important;
  z-index: 80 !important;
}
.brandIcon,
.heroG,
.panelName img {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 0 !important;
}
@media (max-width: 620px) {
  .siteTop,
  .siteTop.compactTop {
    position: sticky !important;
    top: 6px !important;
    z-index: 80 !important;
  }
}


/* Stand 042: finale Befüll-ZIP / Bücher-Lesearten / Karussell / Zitate */
.squareCarousel {
  margin-top: 18px;
  padding: 12px;
  background: rgba(255,255,255,.50);
}
.squareTrack {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(280px, 1fr);
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: inline mandatory;
}
.squarePanel {
  scroll-snap-align: start;
  position: relative;
  aspect-ratio: 1 / 1;
  min-height: 280px;
  border-radius: 34px;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: clamp(20px, 3vw, 34px);
  color: #fff;
  background-image: linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.62)), url("assets/grematik-makro-bg.jpg");
  background-size: cover;
  box-shadow: 0 22px 55px rgba(30,20,17,.18);
}
.cropOne { background-position: 20% 30%; }
.cropTwo { background-position: 55% 42%; }
.cropThree { background-position: 82% 52%; }
.squarePanel h2 {
  margin: 0 0 18px;
  max-width: 8ch;
  font-size: clamp(42px, 6vw, 76px);
  line-height: .84;
  letter-spacing: -.08em;
}
.squarePanel .kicker { color: rgba(255,255,255,.74); }
.squarePanel .panelButton,
.squarePanel .copyButton {
  background: rgba(255,255,255,.92);
  color: var(--ink);
  box-shadow: none;
}
.quoteWindow {
  margin-top: 18px;
  padding: clamp(24px, 4vw, 42px);
}
.quoteRotator {
  min-height: 150px;
  display: flex;
  align-items: center;
  max-width: 880px;
  font-size: clamp(34px, 6vw, 74px);
  line-height: .92;
  letter-spacing: -.07em;
  font-weight: 1000;
  transition: opacity .26s ease;
}
.quoteRotator.fadeOut { opacity: 0; }
.artworkOnly {
  margin-top: 18px;
  aspect-ratio: 1 / 1;
  max-height: min(1000px, 92vw);
  background: #17110f;
  border-radius: clamp(26px, 4vw, 46px);
  overflow: hidden;
}
.artworkOnly img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.08) saturate(1.04);
}
.worldMini {
  background-image: linear-gradient(135deg, rgba(255,255,255,.70), rgba(255,255,255,.42)), url("assets/grematik-makro-bg.jpg");
  background-size: cover;
}
.longReader {
  padding: clamp(24px, 4vw, 46px);
}
.bookLongText {
  max-width: 78ch;
  margin-top: 28px;
}
.bookLongText .chapterText p {
  max-width: 74ch;
}
.bookPanels,
.bookPager,
.bookSwitch {
  display: none !important;
}
.footer {
  border-top: 1px solid rgba(31,22,19,.12);
  padding-top: 18px;
}
@media (min-width: 921px) {
  .squareTrack {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-flow: initial;
    grid-auto-columns: initial;
    overflow: visible;
  }
}
@media (max-width: 620px) {
  .squareTrack { grid-auto-columns: minmax(250px, 84vw); }
  .quoteRotator { min-height: 120px; }
}


/* Stand 043: Bildspur + Social + keine Einzel-G-Zeichen */
.socialGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}
.socialButton {
  min-height: 190px;
  border-radius: 32px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  overflow: hidden;
  position: relative;
  background-image: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.62)), url("assets/grematik-makro-bg.jpg");
  background-size: cover;
  color: #fff;
  box-shadow: 0 22px 55px rgba(30,20,17,.16);
}
.socialButton strong {
  font-size: clamp(30px, 4vw, 54px);
  line-height: .88;
  letter-spacing: -.065em;
}
.socialButton span {
  margin-top: 8px;
  font-weight: 900;
  color: rgba(255,255,255,.76);
}
.socialButton.insta { background-position: 20% 40%; }
.socialButton.youtube { background-position: 58% 42%; }
.socialButton.facebook { background-position: 82% 50%; }
img[src*="favicon.png"],
.brandIcon,
.heroG,
.panelName img {
  display: none !important;
}
.logoBrand img.wordLogo,
.artworkOnly img,
.artworkFrame img {
  display: block !important;
}
@media (max-width: 720px) {
  .socialGrid { grid-template-columns: 1fr; }
  .socialButton { min-height: 150px; }
}


/* Stand 044: transparente Wortmarke, schrumpfender Header, Panel-Scrollarray */
.siteTop {
  transition: padding .22s ease, border-radius .22s ease, background .22s ease, box-shadow .22s ease, transform .22s ease;
}
.wordLogo {
  transition: width .22s ease, opacity .22s ease, transform .22s ease;
}
body.headerCompact .siteTop {
  padding-top: 6px !important;
  padding-bottom: 6px !important;
  background: linear-gradient(180deg, rgba(243,242,239,.70), rgba(243,242,239,.42));
  box-shadow: 0 8px 18px rgba(30,20,17,.08);
}
body.headerCompact .wordLogo {
  width: min(285px, 48vw);
  opacity: .88;
}
.logoBrand img.wordLogo {
  mix-blend-mode: multiply;
}
.scrollArrayItem {
  transition: transform .26s ease, opacity .26s ease, box-shadow .26s ease, filter .26s ease;
  will-change: transform, opacity;
}
body.scrollDown .scrollArrayItem.isNear {
  transform: translateY(-4px) scale(.992);
}
body.scrollUp .scrollArrayItem.isNear {
  transform: translateY(3px) scale(1.004);
}
body.scrollFast .scrollArrayItem.isNear {
  filter: saturate(1.08) contrast(1.04);
  box-shadow: 0 28px 70px rgba(30,20,17,.18);
}
body.scrollSlow .scrollArrayItem.isNear {
  opacity: .98;
}
body.scrollDown .scrollArrayItem.isFar {
  opacity: .82;
}
body.scrollUp .scrollArrayItem.isFar {
  opacity: .92;
}
@media (prefers-reduced-motion: reduce) {
  .siteTop, .wordLogo, .scrollArrayItem {
    transition: none !important;
    transform: none !important;
    filter: none !important;
  }
}
@media (max-width: 620px) {
  body.headerCompact .wordLogo { width: min(230px, 66vw); }
}


/* Stand 045: Highlevel-Landingpage, scharfe Crops, sanfte Sätze */
:root { --radius-xl: clamp(28px, 4vw, 48px); }
.kicker {
  font-size: 12px !important;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 950;
}
.sectionHead h2,
.squarePanel h2,
.vibesHead h2 {
  display: none !important;
}
h1, h2, h3, strong, .wordmark, .bookSpine strong, .socialButton strong {
  overflow-wrap: anywhere;
  word-break: normal;
  text-wrap: balance;
}
p, .shelfLead, .lead, .bookSpine span, .bookSpine em {
  text-wrap: pretty;
}
.heroPanel h1 {
  font-size: clamp(44px, 9vw, 94px);
  max-width: 10ch;
}
.bookSpine {
  min-width: 0;
  overflow: hidden;
}
.bookSpine strong {
  font-size: clamp(26px, 3.8vw, 44px) !important;
  line-height: .88 !important;
}
.squarePanel,
.artworkOnly,
.worldMini,
.socialButton,
.cropOne, .cropTwo, .cropThree, .cropFour, .cropFive, .cropSix, .cropSeven, .cropEight {
  background-size: cover !important;
  background-repeat: no-repeat !important;
}
.cropOne { background-image: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.62)), url("assets/artwork-crop-01.jpg") !important; background-position: center; }
.cropTwo { background-image: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.62)), url("assets/artwork-crop-02.jpg") !important; background-position: center; }
.cropThree { background-image: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.62)), url("assets/artwork-crop-03.jpg") !important; background-position: center; }
.cropFour { background-image: url("assets/artwork-crop-04.jpg") !important; background-position: center; }
.cropFive { background-image: linear-gradient(135deg, rgba(255,255,255,.68), rgba(255,255,255,.28)), url("assets/artwork-crop-05.jpg") !important; background-position: center; }
.cropSix { background-image: linear-gradient(135deg, rgba(255,255,255,.68), rgba(255,255,255,.28)), url("assets/artwork-crop-06.jpg") !important; background-position: center; }
.cropSeven { background-image: linear-gradient(135deg, rgba(255,255,255,.68), rgba(255,255,255,.28)), url("assets/artwork-crop-07.jpg") !important; background-position: center; }
.cropEight { background-image: linear-gradient(135deg, rgba(255,255,255,.68), rgba(255,255,255,.28)), url("assets/artwork-crop-08.jpg") !important; background-position: center; }
.artworkOnly {
  background-size: cover !important;
  min-height: min(1000px, 92vw);
}
.artworkOnly img { display: none !important; }
.quoteRotator {
  transition: opacity .9s ease, transform .9s ease, filter .9s ease;
  min-height: clamp(150px, 24vw, 260px);
}
.quoteRotator.fadeOut {
  opacity: 0;
  transform: translateY(8px);
  filter: blur(3px);
}
.youtubeFull {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  min-height: min(62vw, 620px);
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: #17110f;
  box-shadow: var(--shadow);
}
.youtubeFull iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.vibesPanel .vibesTwoCol,
.vibesPanel .cleanVibesList,
.vibesPanel .vibesOpen,
.vibesPanel .videoFrame {
  display: none !important;
}
.socialPanel .sectionHead h2 { display: none !important; }
@media (max-width: 720px) {
  .heroPanel h1 { font-size: clamp(42px, 16vw, 72px); }
  .bookSpine strong { font-size: clamp(24px, 9vw, 38px) !important; }
  .youtubeFull { min-height: auto; }
}


/* Stand 046: radikal quadratisch */
.squareLanding {
  display: grid;
  gap: 16px;
}
.sectionShell {
  display: grid;
  gap: 12px;
}
.sectionHead {
  padding-inline: 4px;
}
.sectionHead h2,
.shelfLead,
.lead,
.bookSpine em,
.bookSpine span + em {
  display: none !important;
}
.squareSolo {
  width: min(100%, 1000px);
  aspect-ratio: 1 / 1;
  margin-inline: auto;
  border-radius: clamp(28px, 4vw, 44px);
  overflow: hidden;
  min-height: 0;
}
.squareRow,
.squareGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.squareCard {
  aspect-ratio: 1 / 1;
  min-width: 0;
  border-radius: clamp(24px, 3vw, 38px);
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: clamp(18px, 2.2vw, 28px);
  color: #fff;
  background-size: cover !important;
  background-position: center !important;
  box-shadow: 0 22px 55px rgba(30,20,17,.14);
}
.cardMeta {
  position: relative;
  z-index: 2;
  width: 100%;
}
.squareCard::after,
.squareSolo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.64));
  pointer-events: none;
}
.squareSolo .cardMeta,
.squareCard .cardMeta {
  position: relative;
  z-index: 3;
}
.heroPanel strong,
.squareCard strong,
.socialCard strong,
.imageCard strong,
.bookCard strong,
.projectCard strong {
  display: block;
  font-size: clamp(30px, 4vw, 56px);
  line-height: .9;
  letter-spacing: -.06em;
  overflow-wrap: anywhere;
  text-wrap: balance;
}
.heroPanel strong {
  font-size: clamp(44px, 7.5vw, 92px);
  max-width: 10ch;
}
.squareCard span,
.socialCard span,
.projectCard span {
  display: block;
  margin-top: 6px;
  font-weight: 900;
  color: rgba(255,255,255,.78);
  overflow-wrap: anywhere;
  text-wrap: pretty;
}
.imageCard {
  padding: 0;
  background: #0f0b0a !important;
}
.imageCard::after {
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.70));
}
.imageCard img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.imageCard .cardMeta {
  padding: 20px;
}
.quoteWindow {
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
}
.quoteWindow .cardMeta {
  padding: clamp(8px, 2vw, 18px);
}
.quoteRotator {
  min-height: 0;
  font-size: clamp(34px, 5.6vw, 72px);
  line-height: .92;
  letter-spacing: -.07em;
  font-weight: 1000;
  max-width: 10ch;
}
.artworkOnly {
  background-size: cover !important;
  background-position: center !important;
}
.youtubeSquare {
  position: absolute;
  inset: 0;
}
.youtubeSquare iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.vibesPanel .cardMeta,
.vibesPanel .kicker {
  position: relative;
  z-index: 3;
}
.vibesPanel .kicker {
  position: absolute;
  left: 22px;
  top: 18px;
}
.vibesPanel::after {
  background: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.18));
}
.socialCard strong {
  font-size: clamp(34px, 4vw, 52px);
}
.authorAnswers {
  display: grid;
  gap: 12px;
}
.authorAnswers .faqItem {
  border-radius: 28px;
}
.crop1 { background-image: url("assets/artwork-crop-01.jpg") !important; }
.crop2 { background-image: url("assets/artwork-crop-02.jpg") !important; }
.crop3 { background-image: url("assets/artwork-crop-03.jpg") !important; }
.crop4 { background-image: url("assets/artwork-crop-04.jpg") !important; }
.crop5 { background-image: url("assets/artwork-crop-05.jpg") !important; }
.crop6 { background-image: url("assets/artwork-crop-06.jpg") !important; }
.crop7 { background-image: url("assets/artwork-crop-07.jpg") !important; }
.crop8 { background-image: url("assets/artwork-crop-08.jpg") !important; }
@media (max-width: 880px) {
  .squareRow,
  .squareGrid {
    grid-template-columns: 1fr;
  }
  .squareSolo {
    width: 100%;
  }
}


/* Stand 047: Edelstein 3x3 Feedback-Navi */
.edelsteinSystem { gap: 12px; }
.edelGrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  width: min(100%, 1000px);
  margin-inline: auto;
  border-radius: clamp(24px, 4vw, 42px);
  overflow: hidden;
  box-shadow: 0 26px 70px rgba(30,20,17,.14);
  background: #f8f7f3;
}
.edelTile {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  display: block;
  text-decoration: none;
  color: #fff;
  background: #f8f7f3;
}
.edelTile img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block !important;
  transition: transform .28s ease, filter .28s ease;
}
.edelTile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(255,255,255,.02), rgba(0,0,0,.18));
  opacity: .72;
}
.edelTile span {
  position: absolute;
  left: 50%;
  bottom: clamp(10px, 2vw, 22px);
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(10,10,10,.82);
  color: #fff;
  font-size: clamp(12px, 1.6vw, 18px);
  font-weight: 900;
  letter-spacing: -.02em;
  white-space: nowrap;
  box-shadow: 0 8px 22px rgba(0,0,0,.18);
}
.edelTile:hover img {
  transform: scale(1.025);
  filter: contrast(1.04) saturate(1.04);
}
.edelActions {
  width: min(100%, 1000px);
  margin: 12px auto 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.edelActions .panelButton { justify-content: center; text-align: center; }
@media (max-width: 720px) {
  .edelGrid { width: 100%; }
  .edelActions { grid-template-columns: 1fr; }
  .edelTile span { bottom: 8px; padding: 6px 9px; }
}


/* Stand 048: scharfe Kristallhintergründe */
.crop1 { background-image: url("assets/edelstein-grid/white/web-weiss-01-oben-links.jpg") !important; }
.crop2 { background-image: url("assets/edelstein-grid/white/web-weiss-02-oben-mitte.jpg") !important; }
.crop3 { background-image: url("assets/edelstein-grid/white/web-weiss-03-oben-rechts.jpg") !important; }
.crop4 { background-image: url("assets/edelstein-grid/white/web-weiss-04-mitte-links.jpg") !important; }
.crop5 { background-image: url("assets/edelstein-grid/white/web-weiss-05-mitte.jpg") !important; }
.crop6 { background-image: url("assets/edelstein-grid/white/web-weiss-06-mitte-rechts.jpg") !important; }
.crop7 { background-image: url("assets/edelstein-grid/white/web-weiss-07-unten-links.jpg") !important; }
.crop8 { background-image: url("assets/edelstein-grid/white/web-weiss-08-unten-mitte.jpg") !important; }

.squareCard,
.squareSolo,
.socialCard,
.projectCard,
.bookCard {
  background-size: cover !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

.heroPanel::after,
.squareCard::after,
.squareSolo::after {
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.58)) !important;
}

.artworkOnly {
  background-image: url("assets/edelstein-grid/white/gremmatik-edelstein-weiss-original.jpg") !important;
  background-size: cover !important;
  background-position: center !important;
}

.vibesPanel {
  background-image: url("assets/edelstein-grid/white/web-weiss-05-mitte.jpg") !important;
  background-size: cover !important;
  background-position: center !important;
}

.sectionShell .sectionHead .kicker {
  text-shadow: 0 1px 0 rgba(255,255,255,.35);
}

.imageCard img {
  filter: contrast(1.06) saturate(1.04) !important;
}

.edelTile img {
  filter: contrast(1.06) saturate(1.05) !important;
}


/* Stand 049: Zitatorganismus frei im Raum */
.quoteOrbit {
  width: min(100%, 1000px);
  margin: 0 auto;
  padding: 8px 0 20px;
  position: relative;
  min-height: min(68vw, 640px);
}
.quoteOrbit .kicker {
  margin: 0 0 10px 4px;
  position: relative;
  z-index: 4;
}
.quoteStage {
  position: relative;
  width: 100%;
  min-height: min(64vw, 600px);
  overflow: hidden;
  background: transparent !important;
}
.quoteMeasure {
  position: absolute;
  left: -9999px;
  top: 0;
  visibility: hidden;
  width: min(86%, 860px);
  font-size: clamp(34px, 5.6vw, 78px);
  line-height: .92;
  letter-spacing: -.07em;
  font-weight: 1000;
  overflow-wrap: anywhere;
  text-wrap: balance;
  white-space: normal;
}
.quoteGlyph {
  position: absolute;
  display: inline-block;
  font-size: clamp(34px, 5.6vw, 78px);
  line-height: .92;
  letter-spacing: -.07em;
  font-weight: 1000;
  color: #15100f;
  will-change: transform, opacity, left, top, filter;
  transition:
    left 1.8s cubic-bezier(.22,.78,.18,1),
    top 1.8s cubic-bezier(.22,.78,.18,1),
    opacity 1.8s ease,
    transform 1.8s cubic-bezier(.22,.78,.18,1),
    filter 1.8s ease;
  text-shadow: 0 0 0 rgba(0,0,0,0);
}
.quoteGlyph.isScatter {
  opacity: .16;
  filter: blur(5px);
  transform: scale(.72) rotate(var(--rot, 0deg));
}
.quoteGlyph.isSettled {
  opacity: 1;
  filter: blur(0);
  transform: scale(1) rotate(0deg);
}
.quoteGlyph.isFading {
  opacity: 0;
  filter: blur(10px);
  transform: scale(1.24) rotate(var(--rot, 0deg));
}
@media (prefers-reduced-motion: reduce) {
  .quoteGlyph { transition: none !important; }
}
@media (max-width: 720px) {
  .quoteOrbit { min-height: 380px; }
  .quoteStage { min-height: 340px; }
}


/* Stand 050: fokussierte Vier-Säulen-Landingpage */
body { background: #f3f2ef; }
.siteTop {
  position: sticky !important;
  top: max(8px, env(safe-area-inset-top)) !important;
  z-index: 30 !important;
  margin-bottom: 18px !important;
}
.focusedLanding {
  display: grid;
  gap: 18px;
  padding-top: 0 !important;
}
.coreHero {
  position: relative;
  width: min(100%, 1000px);
  aspect-ratio: 1 / 1;
  margin-inline: auto;
  border-radius: clamp(30px, 4vw, 48px);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: clamp(26px, 5vw, 58px);
  color: #fff;
  background-size: cover !important;
  background-position: center !important;
  box-shadow: 0 28px 80px rgba(30,20,17,.16);
}
.coreHero::after,
.pillarCard::after,
.webappIntro::after,
.webappTile::after {
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.66));
  pointer-events:none;
}
.coreHero > * { position: relative; z-index: 2; }
.coreHero strong {
  display:block;
  max-width: 10ch;
  font-size: clamp(46px, 9vw, 98px);
  line-height: .86;
  letter-spacing: -.075em;
  overflow-wrap: anywhere;
  text-wrap: balance;
}
.pillarGrid {
  width: min(100%, 1000px);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.pillarCard {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: clamp(24px, 3vw, 38px);
  overflow: hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding: clamp(16px, 2.4vw, 26px);
  color:#fff;
  text-decoration:none;
  background-size: cover !important;
  background-position:center !important;
  box-shadow: 0 22px 55px rgba(30,20,17,.14);
}
.pillarCard > * { position:relative; z-index:2; }
.pillarCard strong {
  display:block;
  font-size: clamp(24px, 3.3vw, 42px);
  line-height:.9;
  letter-spacing:-.055em;
  overflow-wrap:anywhere;
}
.pillarCard span {
  margin-top: 8px;
  display:inline-flex;
  width:fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(10,10,10,.78);
  color:#fff;
  font-size: 12px;
  font-weight:950;
  letter-spacing:.08em;
}
.legalStrip {
  width: min(100%, 1000px);
  margin-inline:auto;
  display:flex;
  justify-content:center;
  gap: 14px;
  padding: 18px 0 8px;
}
.legalStrip a {
  color: #17110f;
  font-weight: 900;
  text-decoration: none;
  border-bottom: 1px solid rgba(23,17,15,.35);
}
.crop1 { background-image: url("assets/edelstein-grid/white/web-weiss-01-oben-links.jpg") !important; }
.crop2 { background-image: url("assets/edelstein-grid/white/web-weiss-02-oben-mitte.jpg") !important; }
.crop3 { background-image: url("assets/edelstein-grid/white/web-weiss-03-oben-rechts.jpg") !important; }
.crop4 { background-image: url("assets/edelstein-grid/white/web-weiss-04-mitte-links.jpg") !important; }
.crop5 { background-image: url("assets/edelstein-grid/white/web-weiss-05-mitte.jpg") !important; }
.crop6 { background-image: url("assets/edelstein-grid/white/web-weiss-06-mitte-rechts.jpg") !important; }
.crop7 { background-image: url("assets/edelstein-grid/white/web-weiss-07-unten-links.jpg") !important; }
.crop8 { background-image: url("assets/edelstein-grid/white/web-weiss-08-unten-mitte.jpg") !important; }

.quoteOrbit {
  width:min(100%,1000px);
  margin-inline:auto;
  min-height: min(72vw, 640px);
  padding: 8px 0 18px;
  position:relative;
}
.quoteStage {
  position:relative;
  min-height: min(66vw, 600px);
  overflow:hidden;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.quoteMeasure {
  position:absolute;
  visibility:hidden;
  left:-9999px;
  top:0;
  width:min(86%,860px);
  font-size:clamp(34px,5.8vw,82px);
  line-height:.92;
  letter-spacing:-.075em;
  font-weight:1000;
  white-space:normal;
}
.quoteGlyph {
  position:absolute;
  display:inline-block;
  color:#17110f;
  font-size:clamp(34px,5.8vw,82px);
  line-height:.92;
  letter-spacing:-.075em;
  font-weight:1000;
  will-change: transform, opacity, left, top, filter;
  transition:
    left 1900ms cubic-bezier(.18,.76,.16,1),
    top 1900ms cubic-bezier(.18,.76,.16,1),
    transform 1900ms cubic-bezier(.18,.76,.16,1),
    opacity 1900ms ease,
    filter 1900ms ease;
}
.quoteGlyph.isSeed {
  opacity:.10;
  filter: blur(9px);
  transform: translate3d(var(--dx,0), var(--dy,0),0) scale(.54) rotate(var(--rot,0deg));
}
.quoteGlyph.isForm {
  opacity:1;
  filter: blur(0);
  transform: translate3d(0,0,0) scale(1) rotate(0deg);
}
.quoteGlyph.isExit {
  opacity:0;
  filter: blur(12px);
  transform: translate3d(var(--dx,0), var(--dy,0),0) scale(1.26) rotate(var(--rot,0deg));
}
.webappIntro {
  position:relative;
  width:min(100%,1000px);
  aspect-ratio:1/1;
  margin-inline:auto;
  border-radius: clamp(30px,4vw,48px);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:clamp(24px,4vw,44px);
  color:#fff;
  background-size:cover!important;
  background-position:center!important;
}
.webappIntro > * { position:relative; z-index:2; }
.webappIntro strong {
  font-size:clamp(42px,8vw,90px);
  line-height:.86;
  letter-spacing:-.075em;
  max-width: 9ch;
}
.webappGrid {
  width:min(100%,1000px);
  margin:18px auto;
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.webappTile {
  position:relative;
  aspect-ratio:1/1;
  border:0;
  border-radius:28px;
  overflow:hidden;
  color:#fff;
  background-size:cover!important;
  background-position:center!important;
  cursor:pointer;
}
.webappTile span {
  position:absolute;
  left:16px;
  bottom:16px;
  z-index:2;
  font-weight:1000;
  font-size:clamp(18px,2.4vw,30px);
}
.focusRoom {
  width:min(100%,1000px);
  margin-inline:auto;
  border-radius:34px;
  background:rgba(255,255,255,.72);
  padding:clamp(24px,4vw,44px);
}
.focusText {
  max-height: 48vh;
  overflow:auto;
  font-size: clamp(26px,4vw,54px);
  line-height:1.02;
  letter-spacing:-.055em;
  font-weight:950;
}
@media (max-width: 760px) {
  .pillarGrid, .webappGrid { grid-template-columns: 1fr 1fr; }
  .pillarCard strong { font-size: clamp(26px,8vw,42px); }
  .quoteOrbit { min-height: 430px; }
  .quoteStage { min-height: 390px; }
}
@media (max-width: 420px) {
  .pillarGrid, .webappGrid { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .quoteGlyph { transition: none !important; }
}

.editionLabel{margin:.25rem 0 .8rem;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;opacity:.72}


/* Stand 053: Buchstabenwolke stabilisiert, freischwebend, 8s Lesefenster + 2s Übergang */
.quoteOrbit {
  min-height: min(72vw, 680px) !important;
  overflow: visible !important;
  isolation: isolate;
}
.quoteStage {
  min-height: min(66vw, 620px) !important;
  overflow: visible !important;
  background: transparent !important;
  pointer-events: none;
}
.quoteMeasure,
.quoteGlyph {
  width: auto;
  max-width: none;
  font-size: clamp(28px, 4.9vw, 70px) !important;
  line-height: .96 !important;
  letter-spacing: -.065em !important;
  font-weight: 1000 !important;
  text-wrap: balance;
}
.quoteMeasure {
  overflow-wrap: anywhere;
  white-space: normal;
}
.quoteGlyph {
  z-index: 3;
  transform-origin: 50% 54%;
  backface-visibility: hidden;
  will-change: transform, opacity, left, top, filter;
  transition:
    left 2000ms cubic-bezier(.18,.76,.16,1),
    top 2000ms cubic-bezier(.18,.76,.16,1),
    transform 2000ms cubic-bezier(.18,.76,.16,1),
    opacity 2000ms ease,
    filter 2000ms ease !important;
}
.quoteGlyph.isSeed {
  opacity: .12 !important;
  filter: blur(7px) !important;
  transform: translate3d(var(--dx,0), var(--dy,0),0) scale(.58) rotate(var(--rot,0deg)) !important;
}
.quoteGlyph.isForm {
  opacity: 1 !important;
  filter: blur(0) !important;
  transform: translate3d(0,0,0) scale(1) rotate(0deg) !important;
}
.quoteGlyph.isExit {
  opacity: 0 !important;
  filter: blur(11px) !important;
  transform: translate3d(var(--dx,0), var(--dy,0),0) scale(1.18) rotate(var(--rot,0deg)) !important;
}
@media (max-width: 720px) {
  .quoteOrbit { min-height: 520px !important; }
  .quoteStage { min-height: 480px !important; }
  .quoteMeasure,
  .quoteGlyph { font-size: clamp(26px, 8.4vw, 46px) !important; line-height: 1.02 !important; letter-spacing: -.055em !important; }
}


/* Stand 055: Iris-/Edelstein-Hero oben, Raster bleibt unverändert */
.irisHero {
  background: #060805 !important;
  isolation: isolate;
}
.irisHeroImage {
  position: absolute !important;
  inset: -4%;
  z-index: 0 !important;
  background-image: url("assets/hero/gremmatik-iris-edelstein-hero-stand-055.jpeg");
  background-size: cover;
  background-position: center center;
  transform: scale(var(--iris-scale, 1.12));
  filter: saturate(1.03) contrast(1.04) brightness(.92);
  will-change: transform;
  transition: transform 180ms linear;
}
.irisHero::after {
  z-index: 1 !important;
  background:
    radial-gradient(circle at 50% 46%, rgba(0,0,0,.03) 0 24%, rgba(0,0,0,.14) 48%, rgba(0,0,0,.58) 100%),
    linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.72)) !important;
}
.irisHero > :not(.irisHeroImage) {
  position: relative;
  z-index: 2;
}
@media (prefers-reduced-motion: reduce) {
  .irisHeroImage { transform: scale(1.02) !important; transition: none !important; }
}


/* Stand 057: Suchfeld für Buchstabenwolke */
.quoteSearch {
  position: relative;
  z-index: 8;
  width: min(100%, 900px);
  margin: 10px auto 8px;
  padding: 14px;
  border: 1px solid rgba(20, 18, 14, .12);
  border-radius: 28px;
  background: rgba(255,255,255,.58);
  box-shadow: 0 18px 55px rgba(30,20,17,.08);
  backdrop-filter: blur(18px);
}
.quoteSearchLabel {
  display: block;
  margin: 0 0 9px;
  font-size: 11px;
  line-height: 1.1;
  letter-spacing: .17em;
  text-transform: uppercase;
  font-weight: 950;
  color: rgba(24,20,18,.55);
}
.quoteSearchRow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
}
.quoteSearchInput {
  width: 100%;
  min-height: 48px;
  border: 0;
  outline: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: rgba(255,255,255,.88);
  color: #151515;
  font: 850 16px/1.1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: -.015em;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.09);
}
.quoteSearchInput:focus {
  box-shadow: inset 0 0 0 2px rgba(70, 180, 70, .52), 0 0 0 5px rgba(140, 240, 80, .16);
}
.quoteSearchButton {
  min-height: 48px;
  border: 0;
  border-radius: 999px;
  padding: 0 16px;
  background: #151515;
  color: #fff;
  font: 950 12px/1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.quoteSearchButton.ghost {
  background: rgba(255,255,255,.78);
  color: #151515;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.12);
}
.quoteSearchStatus {
  min-height: 1.25em;
  margin: 9px 4px 0;
  color: rgba(24,20,18,.58);
  font-size: 13px;
  line-height: 1.25;
}
.quoteGlyph.isHit {
  color: var(--hit-color, #7eef22) !important;
  text-shadow:
    0 0 12px color-mix(in srgb, var(--hit-color, #7eef22) 72%, transparent),
    0 0 32px color-mix(in srgb, var(--hit-color, #7eef22) 42%, transparent) !important;
}
@media (max-width: 720px) {
  .quoteSearch {
    border-radius: 24px;
    padding: 12px;
  }
  .quoteSearchRow {
    grid-template-columns: 1fr;
  }
  .quoteSearchButton {
    width: 100%;
  }
}


/* Stand 058: ruhigere Suchwolke, ohne Hilfszeilen */
.quoteSearch {
  position: relative;
  z-index: 8;
  width: min(100%, 760px);
  margin: 6px auto 18px;
  padding: 10px;
  border: 1px solid rgba(20, 18, 14, .10);
  border-radius: 999px;
  background: rgba(255,255,255,.48);
  box-shadow: 0 16px 48px rgba(30,20,17,.06);
  backdrop-filter: blur(18px);
}
.quoteSearchLabel,
.quoteSearchStatus {
  display: none !important;
}
.quoteSearchRow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}
.quoteSearchInput {
  width: 100%;
  min-height: 46px;
  border: 0;
  outline: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: rgba(255,255,255,.86);
  color: #151515;
  font: 850 16px/1.1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: -.015em;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
}
.quoteSearchInput:focus {
  box-shadow: inset 0 0 0 2px rgba(70, 180, 70, .38), 0 0 0 5px rgba(140, 240, 80, .11);
}
.quoteSearchButton {
  min-height: 46px;
  border: 0;
  border-radius: 999px;
  padding: 0 16px;
  background: #151515;
  color: #fff;
  font: 950 12px/1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .11em;
  text-transform: uppercase;
}
.quoteSearchButton.ghost {
  display: none !important;
}
.quoteGlyph {
  transition:
    left 8000ms cubic-bezier(.25,.74,.18,1),
    top 8000ms cubic-bezier(.25,.74,.18,1),
    transform 8000ms cubic-bezier(.25,.74,.18,1),
    opacity 8000ms ease,
    filter 8000ms ease !important;
}
.quoteGlyph.isSeed {
  opacity: .10 !important;
  filter: blur(8px) !important;
  transform: translate3d(var(--dx,0), var(--dy,0),0) scale(.62) rotate(var(--rot,0deg)) !important;
}
.quoteGlyph.isForm {
  opacity: 1 !important;
  filter: blur(0) !important;
  transform: translate3d(0,0,0) scale(1) rotate(0deg) !important;
}
.quoteGlyph.isExit {
  opacity: 0 !important;
  filter: blur(14px) !important;
  transform: translate3d(var(--dx,0), var(--dy,0),0) scale(1.12) rotate(var(--rot,0deg)) !important;
}
.quoteGlyph.isHit {
  color: var(--hit-color, #7eef22) !important;
  text-shadow:
    0 0 12px color-mix(in srgb, var(--hit-color, #7eef22) 72%, transparent),
    0 0 32px color-mix(in srgb, var(--hit-color, #7eef22) 38%, transparent) !important;
}
.quoteGlyph.isCarry {
  opacity: 1 !important;
  filter: blur(0) !important;
}
@media (max-width: 720px) {
  .quoteSearch {
    border-radius: 24px;
    padding: 10px;
  }
  .quoteSearchRow {
    grid-template-columns: 1fr auto;
  }
  .quoteSearchButton {
    padding: 0 13px;
  }
}


/* Stand 059: radikal billige Wortkarten-Animation */
.quoteGlyph {
  transition:
    left 5200ms linear,
    top 5200ms linear,
    opacity 2400ms ease !important;
  transform: none !important;
  filter: none !important;
  will-change: left, top, opacity;
}
.quoteGlyph.isSeed {
  opacity: 0 !important;
  filter: none !important;
  transform: none !important;
}
.quoteGlyph.isForm {
  opacity: 1 !important;
  filter: none !important;
  transform: none !important;
}
.quoteGlyph.isExit {
  opacity: 0 !important;
  filter: none !important;
  transform: none !important;
}
.quoteGlyph.isHit {
  color: var(--hit-color, #7eef22) !important;
  text-shadow: 0 0 14px color-mix(in srgb, var(--hit-color, #7eef22) 62%, transparent) !important;
}
.quoteGlyph.isCarry {
  opacity: 1 !important;
}


/* Stand 060: Panels, Lesearten, Top-9-Fragen, Buchdownloads */
.mainPanelGrid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}
.projectFolderPanel,
.topQuestions,
.bookDownloadPanel {
  width: min(100%, 1000px);
  margin-inline: auto;
}
.twoSquareGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.downloadSquare {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: clamp(24px, 3vw, 38px);
  overflow: hidden;
  padding: clamp(18px, 3vw, 34px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  color: #151515;
  background:
    radial-gradient(circle at 62% 26%, rgba(126,239,34,.20), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(238,235,226,.74));
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08), 0 18px 54px rgba(30,20,17,.08);
}
.downloadSquare strong {
  display: block;
  margin: auto 0 10px;
  font-size: clamp(30px, 6vw, 70px);
  line-height: .82;
  letter-spacing: -.075em;
  overflow-wrap: anywhere;
}
.downloadSquare span {
  font-size: 12px;
  line-height: 1.1;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(20,18,14,.54);
  font-weight: 950;
}
.squareActions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 18px;
}
.squareActions a {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(21,21,21,.92);
  color: #fff;
  text-decoration: none;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.questionList {
  border-top: 1px solid rgba(0,0,0,.13);
}
.topQuestion {
  border-bottom: 1px solid rgba(0,0,0,.13);
  padding: 0;
}
.topQuestion summary {
  cursor: pointer;
  list-style: none;
  padding: 18px 2px;
  font-size: clamp(20px, 3vw, 34px);
  line-height: 1.05;
  letter-spacing: -.045em;
  font-weight: 900;
}
.topQuestion summary::-webkit-details-marker {
  display: none;
}
.topQuestion summary::after {
  content: "+";
  float: right;
  opacity: .42;
  font-weight: 600;
}
.topQuestion[open] summary::after {
  content: "–";
}
.topQuestion p {
  margin: 0;
  padding: 0 2px 22px;
  max-width: 760px;
  color: rgba(24,20,18,.64);
  font-size: clamp(16px, 2vw, 21px);
  line-height: 1.45;
}
@media (max-width: 760px) {
  .mainPanelGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .twoSquareGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .downloadSquare {
    border-radius: 24px;
    padding: 15px;
  }
  .downloadSquare strong {
    font-size: clamp(25px, 10vw, 44px);
  }
  .squareActions {
    grid-template-columns: 1fr;
  }
}


/* Stand 061: Bibliothekssuche und App-Buch/Map */
.librarySearchPanel,
.appLibraryPanel {
  width: min(100%, 1000px);
  margin-inline: auto;
}
.librarySearch {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 999px;
  background: rgba(255,255,255,.56);
  box-shadow: 0 18px 55px rgba(30,20,17,.07);
  backdrop-filter: blur(18px);
}
.librarySearchInput {
  min-height: 50px;
  border: 0;
  outline: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: rgba(255,255,255,.9);
  color: #151515;
  font: 850 16px/1.1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
}
.librarySearchButton {
  min-height: 50px;
  border: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: #151515;
  color: #fff;
  font: 950 12px/1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.libraryMeta {
  margin: 12px 4px 0;
  color: rgba(24,20,18,.56);
  font-size: 13px;
  line-height: 1.35;
}
.libraryResults {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}
.libraryResult {
  display: block;
  text-decoration: none;
  color: #151515;
  padding: 16px 0;
  border-top: 1px solid rgba(0,0,0,.12);
}
.libraryResult:last-child {
  border-bottom: 1px solid rgba(0,0,0,.12);
}
.libraryResult strong {
  display: block;
  font-size: clamp(20px, 3vw, 34px);
  line-height: 1;
  letter-spacing: -.045em;
}
.libraryResult small {
  display: block;
  margin-top: 5px;
  color: rgba(24,20,18,.50);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.libraryResult p {
  margin: 8px 0 0;
  color: rgba(24,20,18,.68);
  font-size: 15px;
  line-height: 1.38;
}
.libraryResult mark {
  background: rgba(126,239,34,.28);
  color: inherit;
  border-radius: 4px;
  padding: 0 .08em;
}
@media (max-width: 720px) {
  .librarySearch {
    grid-template-columns: 1fr;
    border-radius: 24px;
  }
}


/* Stand 062: Suchfilter, App-Buch/Map-Seite, Downloadordnung */
.libraryFilters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0 0;
}
.libraryFilter {
  min-height: 36px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 999px;
  padding: 0 13px;
  background: rgba(255,255,255,.62);
  color: rgba(20,18,14,.68);
  font: 900 11px/1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.libraryFilter.isActive {
  background: #151515;
  color: #fff;
  border-color: #151515;
}
.appLibraryPage {
  display: grid;
  gap: 18px;
}
.appLibraryHero h1 {
  margin: 0;
  max-width: 860px;
  font-size: clamp(48px, 10vw, 112px);
  line-height: .82;
  letter-spacing: -.085em;
}
.appLibraryHero p:not(.kicker) {
  max-width: 760px;
  color: rgba(24,20,18,.68);
  font-size: clamp(17px, 2.2vw, 24px);
  line-height: 1.35;
}
.appHeroActions {
  max-width: 460px;
  grid-template-columns: repeat(3, 1fr);
}
.appChapter {
  border-bottom: 1px solid rgba(0,0,0,.13);
}
.appChapter summary {
  cursor: pointer;
  list-style: none;
  padding: 16px 2px;
  font-size: clamp(18px, 2.6vw, 30px);
  line-height: 1.06;
  letter-spacing: -.04em;
  font-weight: 900;
}
.appChapter summary::-webkit-details-marker { display: none; }
.appChapter summary::after {
  content: "+";
  float: right;
  opacity: .42;
}
.appChapter[open] summary::after { content: "–"; }
.appChapter p {
  white-space: pre-wrap;
  margin: 0;
  padding: 0 2px 22px;
  max-width: 900px;
  color: rgba(24,20,18,.66);
  font-size: 14px;
  line-height: 1.45;
}
.mapNodeGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
}
.mapNode {
  min-height: 120px;
  border-radius: 24px;
  padding: 16px;
  background: rgba(255,255,255,.58);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
}
.mapNode strong {
  display: block;
  font-size: clamp(18px, 2.4vw, 28px);
  line-height: 1.02;
  letter-spacing: -.04em;
}
.mapNode small {
  display: block;
  margin-top: 10px;
  color: rgba(24,20,18,.48);
  font-size: 11px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
.downloadOverviewPanel {
  width: min(100%, 1000px);
  margin-inline: auto;
}
@media (max-width: 760px) {
  .mapNodeGrid { grid-template-columns: 1fr; }
  .appHeroActions { grid-template-columns: 1fr; }
}


/* Stand 063: Quellenzeile unter der Buchstabenwolke */
.quoteSourceLine {
  position: relative;
  z-index: 8;
  width: min(100%, 900px);
  min-height: 18px;
  margin: -6px auto 0;
  text-align: right;
  color: rgba(24,20,18,.48);
  font-size: 11px;
  line-height: 1.25;
  letter-spacing: .04em;
  overflow-wrap: anywhere;
}
.quoteSourceLine:empty {
  display: none;
}
@media (max-width: 720px) {
  .quoteSourceLine {
    text-align: left;
    font-size: 10px;
  }
}


/* Stand 066: Filterbutton neben Suche */
.librarySearchWithFilter {
  grid-template-columns: minmax(0, 1fr) auto auto;
}
.libraryFilterToggle {
  min-height: 50px;
  border: 0;
  border-radius: 999px;
  padding: 0 18px;
  background: rgba(255,255,255,.86);
  color: #151515;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.10);
  font: 950 12px/1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.libraryFilterPanel {
  width: min(100%, 760px);
  margin: 10px 0 0 auto;
  padding: 14px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 24px;
  background: rgba(255,255,255,.70);
  box-shadow: 0 18px 55px rgba(30,20,17,.07);
  backdrop-filter: blur(18px);
}
.libraryFilterPanel[hidden] {
  display: none !important;
}
.libraryFilterPanelHead {
  margin: 0 0 10px;
  color: rgba(24,20,18,.50);
  font-size: 11px;
  line-height: 1;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 950;
}
.libraryFilters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
}
.libraryCheck {
  cursor: pointer;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 0 13px;
  background: rgba(255,255,255,.62);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.10);
  color: rgba(20,18,14,.70);
  font: 900 11px/1 ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  letter-spacing: .10em;
  text-transform: uppercase;
}
.libraryCheck input {
  accent-color: #151515;
}
.libraryCheck:has(input:checked) {
  background: #151515;
  color: #fff;
}
@media (max-width: 720px) {
  .librarySearchWithFilter {
    grid-template-columns: 1fr;
  }
  .libraryFilterPanel {
    margin-left: 0;
  }
}
