/* ============================================================
   The Green Idea — Scandi-Öko Design System
   ============================================================ */

:root {
  /* — Palette (muted, natural) — */
  --paper:        oklch(0.971 0.009 95);    /* warm oat background */
  --paper-2:      oklch(0.955 0.012 92);    /* slightly deeper band */
  --surface:      oklch(0.992 0.004 95);    /* card / near white */
  --forest:       oklch(0.325 0.032 158);   /* deep brand green */
  --forest-deep:  oklch(0.272 0.030 160);   /* darker green */
  --sage:         oklch(0.715 0.050 148);   /* mid sage accent */
  --sage-soft:    oklch(0.895 0.030 146);   /* soft sage fill */
  --clay:         oklch(0.685 0.072 52);    /* muted terracotta accent */
  --clay-soft:    oklch(0.905 0.030 58);    /* soft clay fill */
  --sky-soft:     oklch(0.895 0.028 235);   /* soft cool fill */

  --ink:          oklch(0.285 0.014 140);   /* body text, warm near-black */
  --ink-soft:     oklch(0.455 0.012 140);   /* secondary text */
  --ink-faint:    oklch(0.500 0.012 140);   /* tertiary / meta — AA-fixed (was 0.585) */
  --label:        oklch(0.500 0.060 148);   /* eyebrow/label text on light — AA 5.35:1 (replaces sage-as-text) */
  --clay-ink:     oklch(0.470 0.090 52);    /* clay tag text on clay-soft — AA 5.27:1 */
  --line:         oklch(0.885 0.011 92);    /* hairline border */
  --line-strong:  oklch(0.820 0.013 92);

  /* — On dark — */
  --on-dark:      oklch(0.955 0.012 95);
  --on-dark-soft: oklch(0.800 0.020 140);
  --on-dark-sage: oklch(0.760 0.055 146);

  /* — Type — */
  --serif: "Newsreader", Georgia, serif;
  --sans:  "Hanken Grotesk", system-ui, sans-serif;

  /* — Geometry — */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-pill: 999px;
  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 56px);

  /* — Density (tweakable) — */
  --density: 1;
}

* { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body {
  margin: 0;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  font-size: 17px;
  line-height: 1.6;
  letter-spacing: -0.005em;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* — Typography scale — */
.display {
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--forest);
}
.serif-it { font-family: var(--serif); font-style: italic; font-weight: 500; }
.eyebrow {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--label);
}
.eyebrow-clay { color: var(--clay-ink); }

/* — Layout helpers — */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }
.section { padding-block: calc(72px * var(--density)); }
.divider { height: 1px; background: var(--line); border: 0; margin: 0; }

/* — Pills / chips — */
.chip {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  padding: 9px 16px; border-radius: var(--r-pill);
  border: 1px solid var(--line-strong); background: transparent; color: var(--ink);
  transition: all .18s ease; white-space: nowrap;
}
.chip:hover { border-color: var(--forest); color: var(--forest); }
.chip.is-active { background: var(--forest); border-color: var(--forest); color: var(--on-dark); }
.chip .dot { width: 7px; height: 7px; border-radius: 50%; }

.tag {
  font-family: var(--sans); font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 5px 11px; border-radius: var(--r-pill);
  background: var(--sage-soft); color: var(--forest-deep);
}

/* — Buttons — */
.btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--sans); font-size: 15px; font-weight: 600;
  padding: 13px 22px; border-radius: var(--r-pill); border: 1px solid transparent;
  transition: all .18s ease; white-space: nowrap;
}
.btn-primary { background: var(--forest); color: var(--on-dark); }
.btn-primary:hover { background: var(--forest-deep); transform: translateY(-1px); }
.btn-ghost { background: transparent; border-color: var(--line-strong); color: var(--ink); }
.btn-ghost:hover { border-color: var(--forest); color: var(--forest); }
.btn-sage { background: var(--sage-soft); color: var(--forest-deep); }
.btn-sage:hover { background: var(--forest); color: var(--on-dark); }

/* — Cards — */
.card {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-md); overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover { transform: translateY(-3px); border-color: var(--line-strong); box-shadow: 0 14px 34px -22px oklch(0.32 0.03 158 / 0.45); }

/* — Artikel-Karte (zentrales Bauteil, md + lg) — */
.tgi-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.tgi-card__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.tgi-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.tgi-card__media--empty {
  background: linear-gradient(135deg, oklch(0.92 0.02 150), oklch(0.88 0.03 150));
}
.tgi-card__body {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.tgi-card__top {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tgi-card__cat {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--forest);
}
.tgi-card__title {
  font-size: 21px;
  margin: 0;
  line-height: 1.1;
  color: var(--forest);
}
.tgi-card__dek {
  margin: 0;
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.tgi-card__date {
  margin-top: auto;
  padding-top: 8px;
}

/* lg-Variante (Lead-Karte auf Home / Magazin) */
.tgi-card--lg .tgi-card__media {
  aspect-ratio: 16 / 10;
}
.tgi-card--lg .tgi-card__body {
  padding: 26px 28px 30px;
}
.tgi-card--lg .tgi-card__title {
  font-size: clamp(26px, 2.6vw, 34px);
}
.tgi-card--lg .tgi-card__dek {
  font-size: 17px;
  -webkit-line-clamp: 3;
}

/* — Rezept-Karte (zentrales Bauteil, Daten aus REST-Endpoint) — */
.tgi-rcard {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.tgi-rcard__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.tgi-rcard__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.tgi-rcard__media-empty {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, oklch(0.92 0.02 150), oklch(0.88 0.03 150));
}
.tgi-rcard__season {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 1;
}
.tgi-rcard__body {
  padding: 18px 20px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.tgi-rcard__tags {
  display: flex;
  gap: 6px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.tag--clay {
  background: var(--clay-soft);
  color: var(--clay-ink);
}
.tgi-rcard__title {
  font-size: 19px;
  margin: 0 0 10px;
  line-height: 1.15;
  color: var(--forest);
}
.tgi-rcard__meta {
  margin-top: auto;
}

/* — Image placeholder (Scandi soft field + mono caption) — */
.ph {
  position: relative; overflow: hidden;
  background:
    linear-gradient(135deg, oklch(0.90 0.03 146 / .9), oklch(0.86 0.035 150 / .9));
  display: grid; place-items: center;
}
.ph[data-tone="sun"]   { background: linear-gradient(135deg, oklch(0.90 0.045 92), oklch(0.85 0.05 78)); }
.ph[data-tone="warm"]  { background: linear-gradient(135deg, oklch(0.90 0.035 58), oklch(0.85 0.045 46)); }
.ph[data-tone="bloom"] { background: linear-gradient(135deg, oklch(0.89 0.035 350), oklch(0.86 0.04 20)); }
.ph[data-tone="sky"]   { background: linear-gradient(135deg, oklch(0.90 0.028 235), oklch(0.87 0.035 220)); }
.ph[data-tone="calm"]  { background: linear-gradient(135deg, oklch(0.90 0.018 200), oklch(0.87 0.02 175)); }
.ph[data-tone="fresh"] { background: linear-gradient(135deg, oklch(0.90 0.04 146), oklch(0.85 0.05 138)); }
.ph::after {
  content: ""; position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg, transparent 0 11px, oklch(1 0 0 / .12) 11px 12px);
  mix-blend-mode: overlay; opacity: .5;
}
.ph .ph-label {
  position: relative; z-index: 1;
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 11px; letter-spacing: 0.04em; color: oklch(0.34 0.03 150 / .72);
  background: oklch(1 0 0 / .55); padding: 4px 10px; border-radius: var(--r-pill);
  backdrop-filter: blur(2px);
}

/* — Meta row — */
.meta { font-size: 13px; color: var(--ink-faint); display: flex; align-items: center; gap: 8px; }
.meta .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--ink-faint); }

/* — Status dots for seasonal — */
.s-feld { background: var(--sage); }
.s-lager { background: var(--clay); }
.s-gewaechshaus { background: oklch(0.70 0.05 235); }

/* — Utility — */
.tnum { font-variant-numeric: tabular-nums; }
.hover-underline { background-image: linear-gradient(currentColor, currentColor); background-size: 0% 1.5px; background-repeat: no-repeat; background-position: 0 100%; transition: background-size .25s ease; }
.hover-underline:hover { background-size: 100% 1.5px; }

/* ---------- Article prose ---------- */
.prose { font-size: 18px; line-height: 1.72; color: var(--ink); }
.prose .lede { font-size: 21px; line-height: 1.6; color: var(--ink); margin: 0 0 32px; }
.prose p { margin: 0 0 22px; }
.prose h2 { font-family: var(--serif); font-weight: 500; color: var(--forest); font-size: 30px; line-height: 1.15; letter-spacing: -0.015em; margin: 44px 0 16px; }
.prose .kurz { background: var(--sage-soft); border-radius: var(--r-md); padding: 26px 28px; margin: 8px 0 32px; }
.prose ul.checklist { list-style: none; margin: 0 0 28px; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.prose ul.checklist li { position: relative; padding-left: 34px; color: var(--ink-soft); }
.prose ul.checklist li::before { content: ""; position: absolute; left: 0; top: 3px; width: 20px; height: 20px; border-radius: 50%;
  background: var(--sage-soft);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2331513f' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: center; }
.prose blockquote { margin: 36px 0; padding: 8px 0 8px 28px; border-left: 3px solid var(--sage);
  font-family: var(--serif); font-style: italic; font-size: 26px; line-height: 1.4; color: var(--forest); }
.inline-link { background: none; border: 0; padding: 0; font: inherit; color: var(--forest); font-weight: 600;
  border-bottom: 1.5px solid var(--sage); cursor: pointer; }
.inline-link:hover { background: var(--sage-soft); }

/* ============================================================
   Motion layer — tasteful, on-brand dynamism
   Controlled by [data-motion] on <html>: dezent | lebhaft | aus
   ============================================================ */
:root { --reveal-y: 20px; --reveal-dur: .72s; --reveal-ease: cubic-bezier(.2,.75,.25,1); }
html[data-motion="lebhaft"] { --reveal-y: 36px; --reveal-dur: .82s; }
html[data-motion="aus"]     { --reveal-y: 0px;  --reveal-dur: .001s; }

/* Scroll reveal */
.reveal { opacity: 0; transform: translateY(var(--reveal-y)); transition:
  opacity var(--reveal-dur) var(--reveal-ease), transform var(--reveal-dur) var(--reveal-ease);
  will-change: opacity, transform; }
.reveal.is-in { opacity: 1; transform: none; }
html[data-motion="aus"] .reveal { opacity: 1 !important; transform: none !important; }

/* Reveal flavors */
.reveal.r-blur { filter: blur(7px); transition:
  opacity var(--reveal-dur) var(--reveal-ease), transform var(--reveal-dur) var(--reveal-ease), filter var(--reveal-dur) var(--reveal-ease); }
.reveal.r-blur.is-in { filter: blur(0); }
.reveal.r-scale { transform: translateY(var(--reveal-y)) scale(.975); }
.reveal.r-scale.is-in { transform: none; }

/* Hero entrance */
@keyframes heroRise { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: none; } }
.hero-rise { opacity: 0; animation: heroRise .9s var(--reveal-ease) both; }
html[data-motion="aus"] .hero-rise { animation: none; opacity: 1; }

/* Slow float for decorative orbs */
@keyframes floaty { 0%,100% { transform: translateY(0) translateX(0); } 50% { transform: translateY(-22px) translateX(10px); } }
.floaty { animation: floaty 11s ease-in-out infinite; }
html[data-motion="aus"] .floaty { animation: none; }

/* Scroll-down cue */
@keyframes cueBob { 0%,100% { transform: translateY(0); opacity: .85; } 50% { transform: translateY(7px); opacity: .4; } }
.scroll-cue { animation: cueBob 1.9s ease-in-out infinite; }
html[data-motion="aus"] .scroll-cue { animation: none; }

/* Placeholder living sheen (subtle) */
@keyframes phSheen { 0% { transform: translateX(-130%) skewX(-12deg); } 60%,100% { transform: translateX(140%) skewX(-12deg); } }
.ph::before {
  content: ""; position: absolute; top: 0; bottom: 0; left: 0; width: 55%; z-index: 0;
  background: linear-gradient(100deg, transparent 0%, oklch(1 0 0 / .22) 50%, transparent 100%);
  transform: translateX(-130%) skewX(-12deg);
  animation: phSheen 6.5s ease-in-out infinite; pointer-events: none;
}
html[data-motion="aus"] .ph::before { animation: none; opacity: 0; }
@media (prefers-reduced-motion: reduce) { .ph::before { animation: none; opacity: 0; } }

/* Card image zoom on hover */
.card .ph { transition: transform .55s var(--reveal-ease); }
.card:hover .ph { transform: scale(1.055); }

/* Button arrow nudge + chip lift */
.btn svg { transition: transform .25s var(--reveal-ease); }
.btn:hover svg { transform: translateX(4px); }
.chip { will-change: transform; }
.chip:hover { transform: translateY(-2px); }
.chip.is-active:hover { transform: none; }

/* Topic card arrow drift */
.topic-arrow { transition: transform .3s var(--reveal-ease); }
.card:hover .topic-arrow { transform: translate(4px, -4px); }

/* Reading / scroll progress bar */
.scroll-progress { position: absolute; left: 0; bottom: -1px; height: 2px; width: 100%;
  background: var(--sage); transform-origin: 0 50%; transform: scaleX(0);
  transition: transform .08s linear; z-index: 60; }
html[data-motion="aus"] .scroll-progress { display: none; }

/* Marquee / seasonal ticker */
@keyframes marqueeMove { from { transform: translateX(0); } to { transform: translateX(-50%); } }
.tgi-marquee { overflow: hidden; position: relative; }
.tgi-marquee-track { display: flex; width: max-content; animation: marqueeMove var(--marq-dur, 38s) linear infinite; }
.tgi-marquee:hover .tgi-marquee-track { animation-play-state: paused; }
html[data-motion="aus"] .tgi-marquee-track { animation: none; }
html[data-motion="lebhaft"] .tgi-marquee-track { animation-duration: calc(var(--marq-dur, 38s) * .7); }
.tgi-marquee::before, .tgi-marquee::after { content: ""; position: absolute; top: 0; bottom: 0; width: 90px; z-index: 2; pointer-events: none; }
.tgi-marquee::before { left: 0; background: linear-gradient(to right, var(--forest), transparent); }
.tgi-marquee::after  { right: 0; background: linear-gradient(to left, var(--forest), transparent); }
.marq-item { display: inline-flex; align-items: center; gap: 12px; padding: 0 28px;
  font-family: var(--serif); font-size: 19px; color: var(--on-dark); white-space: nowrap; }
.marq-item .marq-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--on-dark-sage); flex: none; }
.marq-item .marq-tag { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--on-dark-sage); }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none; }
  .hero-rise, .floaty, .scroll-cue, .tgi-marquee-track { animation: none !important; }
  .hero-rise { opacity: 1; }
}

/* ============================================================
   Tile hover-reveal — calm editorial insight reveal (no 3D flip)
   Variant via html[data-tile-fx]: reveal (slide-up, default) | fade | lift
   ============================================================ */
.flip { position: relative; cursor: pointer; outline: none; height: 100%; border-radius: var(--r-md); overflow: hidden; }
.flip-inner { position: relative; height: 100%; }
.flip-front { position: relative; height: 100%; transition: transform .55s var(--reveal-ease), filter .55s var(--reveal-ease); will-change: transform; }
.flip-back { position: absolute; inset: 0; display: flex; transform: translateY(101%); transition: transform .6s var(--reveal-ease); will-change: transform; }
.flip:hover .flip-back, .flip.is-flipped .flip-back, .flip:focus-visible .flip-back { transform: translateY(0); }
.flip:hover .flip-front, .flip.is-flipped .flip-front, .flip:focus-visible .flip-front { transform: scale(1.015); filter: brightness(.965); }
.flip:focus-visible { box-shadow: 0 0 0 3px var(--sage); }
.flip .card { height: 100%; }
.flip .card:hover { transform: none; }
.flip:hover .card .ph, .flip.is-flipped .card .ph { transform: scale(1.04); }

/* Variant: cross-fade */
html[data-tile-fx="fade"] .flip-back { transform: none; opacity: 0; transition: opacity .45s var(--reveal-ease); }
html[data-tile-fx="fade"] .flip:hover .flip-back, html[data-tile-fx="fade"] .flip.is-flipped .flip-back, html[data-tile-fx="fade"] .flip:focus-visible .flip-back { opacity: 1; }
html[data-tile-fx="fade"] .flip:hover .flip-front, html[data-tile-fx="fade"] .flip.is-flipped .flip-front { transform: none; filter: none; }

/* Variant: lift only (no insight panel) */
html[data-tile-fx="lift"] .flip { transition: transform .35s var(--reveal-ease), box-shadow .35s var(--reveal-ease); }
html[data-tile-fx="lift"] .flip-back { display: none; }
html[data-tile-fx="lift"] .flip:hover, html[data-tile-fx="lift"] .flip.is-flipped { transform: translateY(-5px); box-shadow: 0 22px 48px -28px oklch(0.32 0.03 158 / .55); }
html[data-tile-fx="lift"] .flip:hover .flip-front, html[data-tile-fx="lift"] .flip.is-flipped .flip-front { transform: none; filter: none; }
html[data-tile-fx="lift"] .flip:hover .card .ph, html[data-tile-fx="lift"] .flip.is-flipped .card .ph { transform: scale(1.04); }

html[data-motion="aus"] .flip-front, html[data-motion="aus"] .flip-back { transition: none; }
@media (prefers-reduced-motion: reduce) { .flip-front, .flip-back { transition-duration: .3s; } }

/* Insight panel (slides/fades in) */
.flip-back-panel {
  flex: 1; display: flex; flex-direction: column; height: 100%;
  border: 0; padding: 24px 24px 22px; background: var(--sage-soft);
}
.flip-back-panel.is-quote { background: var(--forest); color: var(--on-dark); }
.flip-back-panel .fb-eyebrow { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; }
.flip-back-panel .fb-quote { font-family: var(--serif); font-style: italic; line-height: 1.32; letter-spacing: -0.01em; }
.flip-back-panel .fb-mark { font-family: var(--serif); font-size: 46px; line-height: .6; opacity: .5; }
.flip-cta { margin-top: auto; display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-weight: 600; font-size: 14px; }

/* ============================================================
   Partner-shop modules (structure prepared; activated later)
   ============================================================ */
.shop-band { border-radius: var(--r-lg); padding: clamp(28px,3.5vw,40px); border: 1px solid var(--line); background: var(--surface); }
.shop-badge { display: inline-flex; align-items: center; gap: 8px; font-family: var(--sans); font-size: 12px; font-weight: 600;
  letter-spacing: .04em; padding: 6px 12px 6px 10px; border-radius: var(--r-pill); border: 1px solid var(--line-strong); color: var(--ink-soft); }
.shop-badge .shop-glyph { width: 18px; height: 18px; border-radius: 5px; display: grid; place-items: center; color: #fff; font-size: 11px; font-weight: 700; font-family: var(--serif); }
.product-ph { border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--surface); display: flex; flex-direction: column; }
.shop-soon { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 11px; letter-spacing: .04em; color: var(--ink-faint);
  border: 1px dashed var(--line-strong); border-radius: var(--r-pill); padding: 4px 11px; display: inline-flex; align-items: center; gap: 7px; }

/* ---------- Saisonkalender · Wiki · Rezepte UI ---------- */
.jetzt-saison { display: inline-flex; align-items: center; gap: 5px; font-family: var(--sans); font-size: 10.5px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase; color: var(--forest-deep); background: var(--sage-soft);
  padding: 3px 9px; border-radius: var(--r-pill); }
.month-mini { display: grid; grid-template-columns: repeat(12, 1fr); gap: 2px; }
.month-mini span { height: 5px; border-radius: 2px; background: var(--line); }
.az-bar { display: flex; flex-wrap: wrap; gap: 4px; justify-content: center; }
.az-bar a, .az-bar button { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 7px; border: 1px solid var(--line);
  font-family: var(--sans); font-size: 12.5px; font-weight: 600; color: var(--ink-soft); background: var(--surface); cursor: pointer; text-decoration: none; }
.az-bar a:hover { background: var(--sage-soft); color: var(--forest-deep); border-color: var(--sage); }
.az-bar .is-empty { opacity: .35; pointer-events: none; }
.tgi-modal-back { position: fixed; inset: 0; z-index: 80; background: oklch(0.27 0.03 160 / .5); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center; padding: 24px; }
.tgi-modal { background: var(--surface); border-radius: var(--r-lg); max-width: 560px; width: 100%; max-height: 86vh; overflow-y: auto;
  box-shadow: 0 40px 100px -40px oklch(0.2 0.03 160 / .6); }

/* ---------- Member „Heute"-Dashboard ---------- */
.member-shell { display: grid; grid-template-columns: 218px minmax(0,1fr) 300px; gap: 28px; align-items: start; }
.member-side { position: sticky; top: 92px; display: flex; flex-direction: column; gap: 3px; }
.member-side button { display: flex; align-items: center; gap: 11px; width: 100%; text-align: left; background: none; border: 0;
  padding: 11px 13px; border-radius: var(--r-md); font-family: var(--sans); font-size: 14.5px; font-weight: 500; color: var(--ink-soft); cursor: pointer; transition: background .15s ease, color .15s ease; }
.member-side button:hover { background: var(--paper-2); color: var(--forest); }
.member-side button.is-active { background: var(--sage-soft); color: var(--forest-deep); font-weight: 600; }
.member-aside { position: sticky; top: 92px; display: flex; flex-direction: column; gap: 16px; }
.bento { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.bento-card { border: 1px solid var(--line); border-radius: var(--r-lg); padding: 22px 22px 24px; background: var(--surface); display: flex; flex-direction: column; min-height: 168px; transition: border-color .18s ease, transform .18s ease; }
.bento-card:hover { border-color: var(--sage); transform: translateY(-2px); }
.task-row { display: flex; align-items: flex-start; gap: 13px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.task-check { flex: none; width: 24px; height: 24px; border-radius: 7px; border: 1.5px solid var(--line-strong); background: var(--surface); cursor: pointer; display: grid; place-items: center; color: transparent; transition: all .15s ease; margin-top: 1px; }
.task-check.is-done { background: var(--sage); border-color: var(--sage); color: #fff; }
.task-row.is-done .task-title { text-decoration: line-through; color: var(--ink-faint); }
.pantry-chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: var(--r-pill); font-family: var(--sans); font-size: 13.5px; font-weight: 500; }
.pantry-chip.ok { background: var(--sage-soft); color: var(--forest-deep); }
.pantry-chip.no { background: var(--paper-2); color: var(--ink-faint); border: 1px dashed var(--line-strong); }

@media (max-width: 1040px) {
  .member-shell { grid-template-columns: 1fr; }
  .member-side { position: static; flex-direction: row; flex-wrap: wrap; gap: 7px; margin-bottom: 8px; }
  .member-side button { width: auto; padding: 8px 13px; border: 1px solid var(--line); }
  .member-aside { position: static; }
}
@media (max-width: 560px) {
  .bento { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
  .redaktion-grid { grid-template-columns: 1fr !important; }
}
/* ---------- Responsive ---------- */
@media (max-width: 1040px) {
  .hero-grid, .feat-grid, .tools-grid, .news-band, .article-grid { grid-template-columns: 1fr !important; }
  .feat-grid > div { grid-template-rows: none !important; }
  .article-grid aside { position: static !important; }
  .topics-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .latest-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .hero-float { display: none; }
}
@media (max-width: 1000px) {
  .tgi-nav { display: none !important; }
  .tgi-burger { display: grid !important; }
  .tgi-mega { display: none !important; }
}
@media (max-width: 760px) {
  .topics-grid, .latest-grid { grid-template-columns: 1fr !important; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; }
  .tgi-cta { display: none !important; }
  body { font-size: 16px; }
  .interview-grid { grid-template-columns: 1fr !important; }
  .podcast-row { grid-template-columns: 64px 1fr !important; }
  .podcast-row .podcast-meta { grid-column: 1 / -1; text-align: left !important; display: flex; align-items: center; gap: 14px; margin-top: 6px; }
  .wiki-strip { grid-template-columns: repeat(6, 1fr) !important; row-gap: 10px !important; }
}
@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr !important; }
  .wrap { padding-inline: 18px; }
}

/* TGI Fix 2026-06-02: Chip-Hover lesbar (ueberschreibt Kadence button:hover blau) */
.chip:hover { background: var(--sage-soft); border-color: var(--forest); color: var(--forest-deep); }
.chip.is-active:hover { background: var(--forest); border-color: var(--forest); color: var(--on-dark); }

/* TGI Saison-Badges + Wiki-Statusfilter (zentral) */
.tgi-saison-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;line-height:1;white-space:nowrap}
.tgi-saison-dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto}
.tgi-saison--saison{background:var(--sage-soft);color:oklch(0.40 0.06 148)}
.tgi-saison--lager{background:var(--clay-soft);color:var(--clay-ink)}
.tgi-saison--gwhs{background:oklch(0.93 0.03 235);color:oklch(0.40 0.07 235)}
.wi-sfilterwrap{padding-top:6px}
.wi-sfilter{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.wi-schip{appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.wi-schip:hover{border-color:var(--sage)}
.wi-schip.is-active{background:var(--forest-deep);color:var(--on-dark);border-color:var(--forest-deep)}

/* tgi-msbar — Monats-Verfuegbarkeits-Leiste */
.tgi-msbar { display: grid; grid-template-columns: repeat(12, 1fr); gap: 3px; max-width: 480px; margin: 20px auto 4px; }
.tgi-msbar__cell { height: 26px; border-radius: 6px; background: var(--line); display: grid; place-items: center; }
.tgi-msbar__cell b { font-family: var(--sans); font-size: 10.5px; font-weight: 700; line-height: 1; color: var(--ink-soft); opacity: .7; }
.tgi-msbar__cell.is-saison { background: var(--sage); }
.tgi-msbar__cell.is-lager  { background: var(--clay); }
.tgi-msbar__cell.is-gwhs   { background: oklch(0.62 0.06 235); }
.tgi-msbar__cell.is-saison b, .tgi-msbar__cell.is-lager b, .tgi-msbar__cell.is-gwhs b { color: var(--forest-deep); opacity: 1; }
.tgi-msbar__cell.is-now { outline: 2px solid var(--forest-deep); outline-offset: 1px; }
@media (max-width: 600px) {
    .tgi-msbar { max-width: 100%; gap: 2px; }
    .tgi-msbar__cell { height: 22px; border-radius: 5px; }
    .tgi-msbar__cell b { font-size: 9px; }
}

/* tgi-msbar--mini */
.tgi-msbar--mini { max-width: none; margin: 0; gap: 2px; }
.tgi-msbar--mini .tgi-msbar__cell { height: 5px; border-radius: 2px; }
.tgi-msbar--mini .tgi-msbar__cell.is-now { outline: none; }
/* ===== Newsletter-Seite (page-id-1256) — TGI-Stil ===== */

/* Seitentitel in Forest statt Kadence-Default-Grau */
body.page-id-1256 .entry-title,
body.page-id-1256 .hero-container h1 {
  color: #26392E;
}

/* Formular als zentrierte TGI-Karte (Look wie .tgi-cta) */
body.page-id-1256 .mailpoet_form_shortcode {
  max-width: 540px;
  margin: 2rem auto;
  background: #F0F7F0;
  border: 1px solid #8FAC92;
  border-radius: 10px;
  padding: 2rem 1.75rem;
  box-sizing: border-box;
}

/* Eine Schrift, Forest, saubere Hierarchie */
body.page-id-1256 .mailpoet_form_shortcode h1,
body.page-id-1256 .mailpoet_form_shortcode h2,
body.page-id-1256 .mailpoet_form_shortcode h3 {
  font-family: "Hanken Grotesk", system-ui, sans-serif !important;
  color: #26392E !important;
}
body.page-id-1256 .mailpoet_form_shortcode h2:first-of-type {
  font-size: 1.6rem !important;
  line-height: 1.2;
  margin: 0 0 0.5rem;
}

/* Eingabefelder: TGI statt MailPoet-Grau */
body.page-id-1256 .mailpoet_form_shortcode input[type="text"],
body.page-id-1256 .mailpoet_form_shortcode input[type="email"] {
  width: 100% !important;
  background: #ffffff !important;
  color: #26392E !important;
  border: 1px solid #8FAC92 !important;
  border-radius: 8px !important;
  padding: 12px 14px !important;
  font-family: "Hanken Grotesk", system-ui, sans-serif !important;
  font-size: 1rem !important;
  box-sizing: border-box;
}
body.page-id-1256 .mailpoet_form_shortcode input[type="text"]:focus,
body.page-id-1256 .mailpoet_form_shortcode input[type="email"]:focus {
  border-color: #26392E !important;
  outline: 2px solid rgba(143, 172, 146, 0.4);
  outline-offset: 1px;
}

/* Button: Forest-Pill, gleiche Schrift wie der Rest */
body.page-id-1256 .mailpoet_form_shortcode input[type="submit"],
body.page-id-1256 .mailpoet_form_shortcode button[type="submit"],
body.page-id-1256 .mailpoet_form_shortcode .mailpoet_submit input {
  width: 100% !important;
  background: #26392E !important;
  color: #F2F0E7 !important;
  border: 0 !important;
  border-radius: 40px !important;
  padding: 14px 24px !important;
  font-family: "Hanken Grotesk", system-ui, sans-serif !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  cursor: pointer;
  transition: background 0.2s ease;
}
body.page-id-1256 .mailpoet_form_shortcode input[type="submit"]:hover,
body.page-id-1256 .mailpoet_form_shortcode button[type="submit"]:hover,
body.page-id-1256 .mailpoet_form_shortcode .mailpoet_submit input:hover {
  background: #1A2C22 !important;
}
/* ===== Newsletter (page-id-1256) — Fix 2: Karte zentrieren + Header-Band ===== */

/* Formular-Karte wirklich zentrieren + Innenabstand
   (MailPoet setzt margin:0 und padding:10px inline -> !important noetig) */
body.page-id-1256 .mailpoet_form_shortcode {
  display: block !important;
  width: 100% !important;
  max-width: 540px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 2rem 1.75rem !important;
}

/* Seitenkopf: TGI-Forest-Band statt Kadence-Grau, Titel in Creme */
body.page-id-1256 .entry-hero-container-inner {
  background-color: #26392E !important;
}
body.page-id-1256 .entry-title,
body.page-id-1256 .hero-container h1 {
  color: #F2F0E7 !important;
  font-size: 2.4rem !important;
}
/* ===== Newsletter (page-id-1256) — Fix 3: einheitlicher Hintergrund (kein Weiss) ===== */
body.page-id-1256,
body.page-id-1256 article,
body.page-id-1256 .content-bg,
body.page-id-1256 .entry-content-wrap {
  background-color: #F0F7F0 !important;
}
/* ===== Newsletter (page-id-1256) — Fix 4: Formular vergroessern, ~2cm Rand, mobil sicher ===== */
body.page-id-1256 .mailpoet_form_shortcode {
  width: auto !important;
  max-width: none !important;
  margin: 2cm !important;          /* ~76px Rand auf allen Seiten (Desktop) */
}
@media (max-width: 760px) {
  body.page-id-1256 .mailpoet_form_shortcode {
    margin: 1.25rem !important;    /* ~20px Rand mobil, sonst zu eng */
    padding: 1.25rem !important;   /* Innenpolster mobil etwas kompakter */
  }
}
/* ===== Newsletter (page-id-1256) — Fix 5: Untertitel im Header-Band ===== */
body.page-id-1256 .entry-hero-container-inner .entry-title::after {
  content: "Mit viel Liebe und Sorgfalt für dich zusammengestellt.";
  display: block;
  margin-top: 0.6rem;
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  font-size: 1.15rem;
  font-weight: 400;
  line-height: 1.4;
  color: #F2F0E7;
}
/* ===== Headlines site-weit auf die Serife (--serif) ===== */
h1, h2, h3, h4, h5, h6 { font-family: var(--serif); }
