/* Sorten-Detail-Page Styles
 *
 * Extracted from website/de/sorten/og-cheese/imc-thc25-token-ogc/index.html.
 * Loaded by every Sorten-Detail-Page (Block B) via the
 * scripts/build_pages.py generator. Do not duplicate this CSS inline in
 * individual pages.
 */

.sorte-hero { display: grid; grid-template-columns: minmax(0, 4fr) minmax(0, 8fr); gap: var(--s-6); align-items: start; margin-top: var(--s-4); margin-bottom: var(--s-7); }
.sorte-hero--no-photo { grid-template-columns: 1fr; }
@media (max-width: 880px) { .sorte-hero { grid-template-columns: 1fr; } }
/* Produktfoto-Container mit hellem Sockel auch im Dark-Mode.
   Studio-Hintergrund (weiß) bleibt weiß, Foto behält Originalfarben.
   Trade-off: bewusster heller Bruch im dunklen Layout, aber Foto
   bleibt erkennbar und konsistent über alle Pages mit verschiedenen
   Bildquellen. Pre-Processing wäre Pipeline-Aufgabe, nicht CSS. */
.sorte-hero__photo {
  position: relative;
  background: #f4ecd8;
  border: 1px solid var(--ink-faint);
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  box-shadow: 0 2px 24px -8px rgba(0, 0, 0, 0.4);
}
.sorte-hero__photo img { width: 100%; height: 100%; max-height: 360px; object-fit: cover; display: block; }
.sorte-hero__photo { max-height: 360px; }
.sorte-hero__photo-glow { position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 20%, rgba(184,255,110,0.08) 0%, transparent 60%); pointer-events: none; }
.sorte-hero__photo-tag { position: absolute; bottom: var(--s-2); left: var(--s-2); padding: 0.3em 0.7em; background: rgba(0,0,0,0.55); color: #fff; font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.06em; border-radius: 3px; backdrop-filter: blur(4px); }
.sorte-hero__body { display: flex; flex-direction: column; justify-content: center; gap: var(--s-2); }
.sorte-hero__manuf { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); }
.sorte-hero__title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.6rem); line-height: 1; margin: 0; letter-spacing: -0.02em; }
.sorte-hero__lead { font-family: var(--font-body); font-size: var(--t-base); line-height: 1.5; color: var(--ink-soft); margin: var(--s-2) 0 var(--s-1) 0; max-width: 48ch; }
.sorte-hero__strain-link { display: inline-flex; align-items: center; gap: 0.4em; padding: 0.35em 0.9em 0.35em 0.7em; background: var(--bg-soft); border: 1px solid var(--ink-faint); border-radius: 999px; font-family: var(--font-body); font-size: var(--t-sm); color: var(--ink); text-decoration: none; transition: border-color var(--duration-quick), background-color var(--duration-quick); align-self: flex-start; }
.sorte-hero__strain-link:hover { border-color: var(--uv); background: var(--bg-card); }
.sorte-hero__strain-arrow { font-family: var(--font-mono); color: var(--uv); }
.sorte-hero__strain-name { font-family: var(--font-display); font-weight: 500; }

/* Match-Block: Hero-Headline mit Top-Goal-Score + Top-3-Balken */
.match-block { padding: var(--s-5) 0; border-top: 1px solid var(--ink-faint); border-bottom: 1px solid var(--ink-faint); margin: var(--s-6) 0; }
.match-block__eyebrow { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: var(--s-3); }
.match-block__headline { display: flex; align-items: baseline; gap: var(--s-3); flex-wrap: wrap; margin-bottom: var(--s-2); }
.match-block__goal { font-family: var(--font-display); font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 500; letter-spacing: -0.01em; line-height: 1; }
.match-block__score {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(2.4rem, 5vw, 3.5rem); line-height: 1;
  font-feature-settings: "tnum" 1;
  color: color-mix(in oklab, var(--ink-faint) calc((1 - var(--score-intensity, 1)) * 100%), var(--sage-deep) calc(var(--score-intensity, 1) * 100%));
  text-shadow: 0 0 calc(8px * var(--score-intensity, 1)) rgba(184, 255, 110, calc(0.35 * var(--score-intensity, 1)));
}
[data-theme="dark"] .match-block__score {
  color: color-mix(in oklab, var(--ink-faint) calc((1 - var(--score-intensity, 1)) * 100%), var(--uv) calc(var(--score-intensity, 1) * 100%));
}
.match-block__score-suffix { font-family: var(--font-mono); font-size: var(--t-sm); color: var(--ink-faint); letter-spacing: 0.05em; }
.match-block__sub { font-size: var(--t-base); color: var(--ink-soft); margin: 0 0 var(--s-5) 0; max-width: 56ch; line-height: 1.5; }
.match-bars { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--s-2); }
.match-bar { display: grid; grid-template-columns: 9em 1fr 4em; gap: var(--s-3); align-items: center; padding: 0.4em 0; }
.match-bar__label { font-family: var(--font-display); font-weight: 500; font-size: var(--t-base); }
.match-bar__track { height: 8px; background: var(--ink-faint); border-radius: 4px; overflow: hidden; position: relative; }
.match-bar__fill { display: block; height: 100%; background: linear-gradient(90deg, var(--ink), var(--uv)); border-radius: 4px; box-shadow: 0 0 8px rgba(184,255,110,0.35); transition: width 0.4s ease; }
.match-bar__value { font-family: var(--font-display); font-weight: 500; text-align: right; font-feature-settings: "tnum" 1; }
.match-bar--primary .match-bar__fill { background: var(--uv); box-shadow: 0 0 12px rgba(184,255,110,0.5); }
.match-bar--primary .match-bar__value { color: var(--uv); font-weight: 600; }
@media (max-width: 720px) { .match-bar { grid-template-columns: minmax(0, 1fr) 4em; } .match-bar__track { grid-column: 1 / -1; order: 99; } }

/* Match-Stack: Anteile Top-3 (Sum=100%) — schmale Bar + Labels unten editorial */
.match-stack-wrap { margin-top: var(--s-4); }
.match-stack {
  display: flex;
  height: 12px;
  border-radius: 6px;
  overflow: hidden;
  background: var(--bg-soft);
  border: 1px solid var(--rule-soft);
}
.match-stack__seg { display: block; min-width: 2px; }
.match-stack__seg--rank1 {
  background: var(--uv);
  box-shadow: inset 0 0 8px rgba(184, 255, 110, 0.35);
}
.match-stack__seg--rank2 { background: var(--sage); }
.match-stack__seg--rank3 { background: var(--sage-deep); }
[data-theme="dark"] .match-stack__seg--rank3 { background: color-mix(in oklab, var(--sage-deep), var(--ink) 30%); }
.match-stack-labels {
  display: flex;
  margin-top: var(--s-3);
  gap: 2px;
  align-items: flex-start;
}
.match-stack-label {
  display: flex;
  flex-direction: column;
  gap: 0.15em;
  padding: 0 var(--s-2) 0 0;
  min-width: 0;
}
.match-stack-label__name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-base);
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.match-stack-label--rank1 .match-stack-label__name { color: var(--sage-deep); }
.match-stack-label--rank2 .match-stack-label__name { color: color-mix(in oklab, var(--sage-deep) 70%, var(--ink)); }
.match-stack-label--rank3 .match-stack-label__name { color: color-mix(in oklab, var(--sage-deep) 45%, var(--ink)); }
[data-theme="dark"] .match-stack-label--rank1 .match-stack-label__name { color: var(--uv); }
[data-theme="dark"] .match-stack-label--rank2 .match-stack-label__name { color: var(--sage); }
[data-theme="dark"] .match-stack-label--rank3 .match-stack-label__name { color: color-mix(in oklab, var(--sage) 60%, var(--ink)); }
.match-stack-label__pct {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-faint);
  font-feature-settings: "tnum" 1;
  letter-spacing: 0.04em;
}
.match-stack-label--rank1 .match-stack-label__pct { color: var(--sage-deep); opacity: 0.85; }
[data-theme="dark"] .match-stack-label--rank1 .match-stack-label__pct { color: var(--uv); opacity: 0.8; }

/* Treiber-Zeile unter Match-Bar: kompakte Terpen-Pillen in einer Zeile, keine Spalten */
.match-block__drivers {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5em;
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule-soft);
}
.match-block__drivers-label {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-right: 0.3em;
}
.match-block__driver {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  font-family: var(--font-body);
  font-size: var(--t-sm);
  font-weight: 500;
  padding: 0.3em 0.85em;
  border: 1px solid var(--sage);
  border-radius: 999px;
  color: var(--ink);
  background: color-mix(in oklab, var(--sage) 8%, transparent);
  text-decoration: none;
  white-space: nowrap;
  transition: border-color var(--duration-quick) var(--ease-out), background var(--duration-quick) var(--ease-out);
}
.match-block__driver:hover { border-color: var(--sage-deep); background: color-mix(in oklab, var(--sage) 18%, transparent); }
[data-theme="dark"] .match-block__driver:hover { border-color: var(--uv); }
.match-block__driver-soft {
  font-family: var(--font-mono);
  font-size: 0.8em;
  color: var(--ink-faint);
  letter-spacing: 0.04em;
}
@media (max-width: 720px) {
  .match-stack-label__name { font-size: var(--t-sm); }
}

/* City-Filter-Block über der Apothekenpreise-Liste */
.city-filter-block { margin-bottom: var(--s-3); position: relative; }
.city-filter-line { position: relative; max-width: 28em; }
.city-input {
  width: 100%;
  font-family: var(--font-mono); font-size: var(--t-sm);
  padding: 0.55em 0.9em;
  background: var(--bg-soft);
  border: 1px solid var(--rule-soft);
  border-radius: 4px;
  color: var(--ink);
  letter-spacing: 0.04em;
}
.city-input::placeholder { color: var(--ink-faint); }
.city-input:focus { outline: 1px solid var(--uv); border-color: var(--uv); }
.city-input-clear {
  position: absolute; top: 50%; right: 0.5em; transform: translateY(-50%);
  background: none; border: 0; color: var(--ink-faint); cursor: pointer;
  font-size: var(--t-base); line-height: 1; padding: 0.2em 0.4em;
}
.city-input-clear:hover { color: var(--ink); }
.city-suggest {
  position: absolute; top: 100%; left: 0; right: 0;
  max-height: 260px; overflow-y: auto;
  background: var(--bg-card); border: 1px solid var(--rule-soft); border-top: 0;
  list-style: none; padding: 0; margin: 0;
  font-family: var(--font-mono); font-size: var(--t-sm);
  z-index: 10;
}
.city-suggest li {
  padding: 0.5em 0.9em;
  cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  gap: var(--s-3);
  border-bottom: 1px solid var(--rule-color);
}
.city-suggest li:last-child { border-bottom: 0; }
.city-suggest li:hover, .city-suggest li.is-active { background: var(--bg-soft); color: var(--sage-deep); }
.city-suggest-count { color: var(--ink-faint); font-size: var(--t-xs); font-feature-settings: "tnum" 1; }
.city-caption {
  font-family: var(--font-mono); font-size: var(--t-xs);
  color: var(--ink-soft); letter-spacing: 0.04em;
  margin: var(--s-2) 0 0 0;
}
.city-caption.is-hit { color: var(--uv); }
.city-caption.is-miss { color: var(--clay); }

/* Apotheken-Tabelle: eine Zeile pro Apotheke, Plattformen als kleine Pills.
   Konzept wie auf Ergebnisliste-Homepage: was zaehlt ist die Apotheke, die
   Plattformen sind nur die Wege dorthin. Sortiert nach Preis aufsteigend.
   Top-10 sichtbar, weitere per Load-More. */
.apo-table {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--rule-soft);
  border-radius: 6px;
  overflow: hidden;
  background: var(--bg-card);
}
.apo-table__head {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.7fr) minmax(0, 18em) minmax(0, 6em) 1.4em;
  gap: var(--s-3);
  padding: 0.55em var(--s-4);
  background: var(--bg-soft);
  border-bottom: 1px solid var(--rule-soft);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-faint);
  align-items: center;
}
.apo-table__head-price { text-align: right; }
.apo-row {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.7fr) minmax(0, 18em) minmax(0, 6em) 1.4em;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--rule-soft);
  align-items: center;
  text-decoration: none;
  color: inherit;
  transition: background var(--duration-quick) var(--ease-out);
}
.apo-row:last-of-type { border-bottom: 0; }
.apo-row:hover { background: var(--bg-soft); }
.apo-row__platforms {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3em 0.4em;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0;
}
.apo-row__platforms li { display: inline-flex; }
.apo-row__platform-pill {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 0.2em 0.55em;
  border: 1px solid color-mix(in oklab, var(--sage) 50%, transparent);
  border-radius: 3px;
  background: color-mix(in oklab, var(--sage) 8%, transparent);
  color: var(--ink-soft);
  text-decoration: none;
  white-space: nowrap;
  transition: border-color var(--duration-quick) var(--ease-out), color var(--duration-quick), background var(--duration-quick);
}
.apo-row__platform-pill:hover {
  border-color: var(--sage-deep);
  background: color-mix(in oklab, var(--sage) 22%, transparent);
  color: var(--ink);
}
[data-theme="dark"] .apo-row__platform-pill:hover {
  border-color: var(--uv);
  color: var(--uv);
}
.apo-row__apo {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-base);
  color: var(--ink);
  font-variation-settings: "wdth" 95, "opsz" 60;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-decoration: none;
  transition: color var(--duration-quick) var(--ease-out);
}
a.apo-row__apo, a.apo-row__price { border: 0; padding-bottom: 0; }
a.apo-row__apo:hover { color: var(--sage-deep); }
[data-theme="dark"] a.apo-row__apo:hover { color: var(--uv); }
.apo-row__apo-soft { font-family: var(--font-body); font-size: 0.8em; font-weight: 400; color: var(--ink-soft); }
.apo-row__city {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-soft);
  letter-spacing: 0.04em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.apo-row__price {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-lg);
  font-feature-settings: "tnum" 1;
  text-align: right;
  white-space: nowrap;
  text-decoration: none;
  transition: filter var(--duration-quick) var(--ease-out);
  color: color-mix(in oklab,
    color-mix(in oklab, var(--ink-soft) 78%, var(--sage)) calc((1 - var(--price-intensity, 0.5)) * 100%),
    var(--sage-deep) calc(var(--price-intensity, 0.5) * 100%));
  text-shadow: 0 0 calc(5px * var(--price-intensity, 0.5)) rgba(180, 200, 130, calc(0.35 * var(--price-intensity, 0.5)));
}
[data-theme="dark"] .apo-row__price {
  color: color-mix(in oklab,
    color-mix(in oklab, var(--ink) 78%, var(--sage)) calc((1 - var(--price-intensity, 0.5)) * 100%),
    var(--uv) calc(var(--price-intensity, 0.5) * 100%));
  text-shadow: 0 0 calc(5px * var(--price-intensity, 0.5)) rgba(184, 255, 110, calc(0.4 * var(--price-intensity, 0.5)));
}
a.apo-row__price:hover { filter: brightness(1.15); }
.apo-row__price small { font-size: 0.55em; color: var(--ink-faint); letter-spacing: 0.04em; font-family: var(--font-mono); }
.apo-row__status {
  display: inline-block;
  width: 18px;
  height: 18px;
  position: relative;
  text-indent: -9999px;
}
.apo-row__status::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--rule-color);
}
.apo-row__status--ok::before { background: var(--sage-deep); box-shadow: 0 0 8px var(--sage-deep); }
[data-theme="dark"] .apo-row__status--ok::before { background: var(--uv); box-shadow: 0 0 8px var(--uv); }
.apo-row[hidden] { display: none; }
.apo-table__loadmore {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6em;
  width: 100%;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-soft);
  border: 0;
  border-top: 1px solid var(--rule-soft);
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  cursor: pointer;
  transition: color var(--duration-quick), background var(--duration-quick);
}
.apo-table__loadmore:hover { color: var(--sage-deep); background: var(--bg-card); }
[data-theme="dark"] .apo-table__loadmore:hover { color: var(--uv); }
.apo-table__loadmore[hidden] { display: none; }
.apo-table__loadmore-count { color: var(--ink-faint); font-feature-settings: "tnum" 1; }
@media (max-width: 720px) {
  .apo-table__head { display: none; }
  .apo-row {
    grid-template-columns: 1fr auto;
    gap: 0.3em var(--s-3);
    padding: var(--s-3) var(--s-4);
  }
  .apo-row__apo { grid-column: 1; grid-row: 1; }
  .apo-row__city { grid-column: 1; grid-row: 2; }
  .apo-row__platforms { grid-column: 1 / -1; grid-row: 3; padding-top: 0.2em; }
  .apo-row__price { grid-column: 2; grid-row: 1 / span 2; align-self: center; }
  .apo-row__status { grid-column: 2; grid-row: 2; justify-self: end; }
}

/* Pharmacy-list (legacy, kept for backward compat) */
.pharm-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1px; background: var(--ink-faint); border: 1px solid var(--ink-faint); border-radius: 6px; overflow: hidden; }
.pharm-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) auto auto auto;
  gap: var(--s-3);
  align-items: center;
  padding: var(--s-3) var(--s-4);
  background: var(--bg-card);
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--duration-quick) var(--ease-out);
}
.pharm-row:hover { background: var(--bg-soft); }
.pharm-row:hover .pharm-row__platform { color: var(--uv); }
.pharm-row--no-city { opacity: 0.5; }
.pharm-row__platform {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--t-base);
  border-bottom: 1px solid var(--rule-soft);
  padding-bottom: 1px;
  align-self: center;
  transition: color var(--duration-quick) var(--ease-out), border-color var(--duration-quick) var(--ease-out);
}
.pharm-row:hover .pharm-row__platform { border-bottom-color: var(--uv); }
.pharm-row__pharmacies { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ink-soft); letter-spacing: 0.04em; }
.pharm-row__price {
  font-family: var(--font-display); font-weight: 500; font-size: var(--t-lg);
  font-feature-settings: "tnum" 1; white-space: nowrap;
  color: color-mix(in oklab,
    var(--ink) calc((1 - var(--price-intensity, 0.5)) * 100%),
    var(--sage-deep) calc(var(--price-intensity, 0.5) * 100%));
  text-shadow: 0 0 calc(6px * var(--price-intensity, 0.5)) rgba(184, 255, 110, calc(0.5 * var(--price-intensity, 0.5)));
}
[data-theme="dark"] .pharm-row__price {
  color: color-mix(in oklab,
    var(--ink) calc((1 - var(--price-intensity, 0.5)) * 100%),
    var(--uv) calc(var(--price-intensity, 0.5) * 100%));
}
.pharm-row__status { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-soft); white-space: nowrap; }
.pharm-row__status--ok { color: var(--uv); }
.pharm-row--stale { opacity: 0.55; }
.pharm-row--stale .pharm-row__price { text-shadow: none; }
.pharm-stand { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ink-faint); letter-spacing: 0.04em; margin: var(--s-2) 0 0 0; text-align: right; }
@media (max-width: 720px) { .pharm-row { grid-template-columns: 1fr auto; gap: 0.4em var(--s-3); } .pharm-row__pharmacies { grid-column: 1; } .pharm-row__price { grid-column: 2; grid-row: 1; } .pharm-row__status { grid-column: 2; } }

/* Datenblatt — kompakt im Hero rechts, editorial Linien-Stil */
.data-sheet--hero {
  margin-top: var(--s-4);
  border-top: 1px solid var(--rule-color);
  padding-top: var(--s-2);
}
.data-sheet--hero .data-sheet__row {
  display: grid;
  grid-template-columns: 8.5em 1fr;
  gap: var(--s-3);
  padding: 0.55em 0;
  border-bottom: 1px solid var(--rule-color);
  margin: 0;
}
.data-sheet--hero .data-sheet__row:last-child {
  border-bottom: 0;
}
.data-sheet--hero .data-sheet__label {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  align-self: center;
  margin: 0;
}
.data-sheet--hero .data-sheet__value {
  font-family: var(--font-body);
  font-size: var(--t-sm);
  font-weight: 400;
  color: var(--ink);
  margin: 0;
  align-self: center;
  letter-spacing: 0;
}
.data-sheet--hero .data-sheet__value a { color: inherit; text-decoration: none; border-bottom: 1px solid var(--rule-soft); padding-bottom: 1px; }
.data-sheet--hero .data-sheet__value a:hover { border-color: var(--uv); color: var(--uv); }
.data-sheet--hero .data-sheet__value--irradiated { color: var(--clay); }
@media (max-width: 720px) {
  .data-sheet--hero .data-sheet__row { grid-template-columns: 7em 1fr; }
}

/* Aroma-Section: zusätzliche Plattform-Note unter den Tags */
.aroma-source-note {
  margin-top: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-soft);
  letter-spacing: 0.04em;
}
.aroma-source-note__label {
  text-transform: uppercase;
  margin-right: 0.6em;
  color: var(--ink-faint);
  letter-spacing: 0.1em;
}

/* Geschmack & Aroma: Lead + Tag-Cloud */
.aroma-section { margin-top: var(--s-7); }
.aroma-lead {
  font-family: var(--font-display);
  font-size: var(--t-lg);
  line-height: 1.5;
  color: var(--ink);
  margin: 0 0 var(--s-4) 0;
  max-width: 60ch;
  font-weight: 400;
}
.aroma-tags { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.aroma-tag {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.06em;
  padding: 0.45em 0.95em;
  background: var(--bg-soft);
  border: 1px solid var(--rule-soft);
  border-radius: 999px;
  color: var(--ink-soft);
  white-space: nowrap;
}
/* Aroma-Tag Naturtoene-Palette (single source of truth).
   Ueber clay/sage/ink-Tokens, die im design-system automatisch invertieren
   (hell in dark, dunkel in light). Keine Ampelfarben.
     blumig:  altrosa-taupe (clay-deep mit ink-soft entsaettigt) - nicht-rot
     zitrisch:dunkles Gold  (uv-warm + ink)                     - Zitrusschale
     erdig:   sage-deep     (dunkler Wald, dunkles Moos)
     harzig:  Bernstein     (clay-deep + uv-warm)               - dunkler Harz
     wuerzig: terra         (clay)                              - Paprika
     mild:    pale          (sage-pale + ink-soft)              - gedeckt */
.aroma-tag--blumig {
  border-color: color-mix(in oklab, var(--clay-deep) 55%, var(--ink-soft) 45%);
  color: color-mix(in oklab, var(--clay-deep) 55%, var(--ink-soft) 45%);
}
.aroma-tag--zitrisch {
  border-color: color-mix(in oklab, var(--uv-warm) 75%, var(--ink) 25%);
  color: color-mix(in oklab, var(--uv-warm) 75%, var(--ink) 25%);
}
.aroma-tag--erdig {
  border-color: var(--sage-deep);
  color: var(--sage-deep);
}
.aroma-tag--harzig {
  border-color: color-mix(in oklab, var(--clay-deep) 60%, var(--uv-warm) 40%);
  color: color-mix(in oklab, var(--clay-deep) 60%, var(--uv-warm) 40%);
}
.aroma-tag--wuerzig {
  border-color: var(--clay);
  color: var(--clay);
}
.aroma-tag--mild {
  border-color: color-mix(in oklab, var(--sage-pale), var(--ink-soft) 30%);
  color: color-mix(in oklab, var(--sage-deep), var(--ink-soft) 40%);
}
[data-theme="dark"] .aroma-tag--mild {
  color: var(--sage-pale);
  border-color: color-mix(in oklab, var(--sage-pale), var(--rule-color) 50%);
}

/* Other variants of strain — kompakte Card-Liste */
.other-variants { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--s-3); }
.other-variant { padding: var(--s-3); background: var(--bg-soft); border: 1px solid var(--ink-faint); border-radius: 6px; text-decoration: none; color: inherit; display: flex; flex-direction: column; gap: 0.4em; position: relative; }
.other-variant__name { font-family: var(--font-display); font-weight: 500; font-size: var(--t-base); }
.other-variant__meta { display: flex; gap: var(--s-3); align-items: baseline; font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ink-soft); letter-spacing: 0.04em; }
.other-variant__price { font-family: var(--font-display); font-weight: 500; color: var(--ink); font-feature-settings: "tnum" 1; }
.other-variant__price .uv { color: var(--uv); }
.other-variant__price--off { color: var(--ink-soft); font-style: italic; }
.other-variant__goal { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--uv); letter-spacing: 0.08em; text-transform: uppercase; }

/* Variant-D Apo-Tabelle Styles: jetzt global in design-system.css. */

/* Brotkrumen-Leiste auf Sorten-Detail. Subtil, transparenter Hintergrund,
   monospaced uppercase wie auf der Strain-Hub-Linie aber ohne Banner-Background.
   Strain-Hub und Listing-Pages nutzen weiter .summary-line mit dunklem Banner. */
.breadcrumbs {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin-bottom: var(--s-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}
.breadcrumbs a { color: var(--ink-soft); text-decoration: none; border-bottom: 1px dotted var(--ink-faint); padding-bottom: 1px; }
.breadcrumbs a:hover { color: var(--ink); border-bottom-color: var(--uv); }
.breadcrumbs span { color: var(--ink); }

/* Charge-Terpenprofil: integriert in den Match-Block, unter den Goal-Spalten.
   .terp-glyph kommt aus design-system.css. */
.match-block__charge { margin-top: var(--s-4); }
.match-block__charge-label { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: var(--s-2); }
.terp-glyph-row { display: flex; flex-wrap: wrap; gap: var(--s-2); align-items: center; }
