/* Cacao! — editorial product page.
   Same publication language as the home page: Roca 800 display, terracotta
   hairline kickers, magazine numerals, hard edges, left-weighted. Token-driven.
   Three movements (Opphav / Håndverk / Innhold) culminating in the nutrition
   exposition: a felt-numbers band (wp:columns) + four compound families
   (wp:table panels in a grid group). Per-page enqueue (sibling cacao.css);
   scope to block classNames. All content is native core blocks — no wp:html. */

/* --- Editorial type roles (page-local) ------------------------------ */

.cacao-hero .kicker,
.mvmt .kicker,
.cacao-cta .kicker {
  font-family: "roca", serif;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.28em;
  font-size: clamp(0.72rem, 0.9vw, 0.82rem);
  color: var(--color-terracotta);
  margin-block: 0 0.6rem;
}

.cacao-hero .kicker::before,
.mvmt .kicker::before,
.cacao-cta .kicker::before {
  content: "";
  display: block;
  width: 2.75rem;
  height: 2px;
  background-color: var(--color-terracotta);
  margin-block: 0 0.9rem;
}

.cacao-hero .kicker::before {
  background-color: var(--color-cream-200);
}

.display {
  font-family: "roca", serif;
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--text-color-dark);
  text-wrap: balance;
  font-size: clamp(2.2rem, 5.2vw, 4rem);
}

.lede {
  font-size: clamp(1.15rem, 1.7vw, 1.45rem);
  line-height: 1.55;
  color: var(--text-color);
}

.sub-display {
  font-family: "roca", serif;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--text-color-dark);
  font-size: clamp(1.5rem, 3vw, 2.1rem);
}

/* --- Hero ----------------------------------------------------------- */

.cacao-hero .wp-block-cover__inner-container {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  gap: 1.1rem;
  padding-block: clamp(3.5rem, 10vw, 7rem);
}

.cacao-hero .display {
  color: inherit;
  font-size: clamp(3rem, 9vw, 6.5rem);
  line-height: 0.98;
}

.cacao-hero .lede {
  color: inherit;
  opacity: 0.94;
  max-width: 46ch;
}

/* The theme centers every constrained child:
   `.wp-block-cover__inner-container > :not(.alignleft):not(.alignright):not(.alignfull)
    { max-width: var(--max-width); margin-inline: auto; }`
   That auto margin — not contentPosition — is what pulls the hero copy to the
   centre. Re-anchor it left by mirroring the theme's 4-class specificity and
   loading later so we win the cascade. */
.cacao-hero .wp-block-cover__inner-container > :not(.alignleft):not(.alignright):not(.alignfull) {
  margin-inline: 0;
}

/* keep the lede a tight measure (theme would otherwise widen it to --max-width) */
.cacao-hero .wp-block-cover__inner-container > .lede:not(.alignfull) {
  max-width: 46ch;
}

/* --- Movements: chapter numerals (CSS counters from position) ------- */

.cacao-hero {
  counter-reset: mvmt;
}

.mvmt {
  counter-increment: mvmt;
  padding-block: clamp(3rem, 7vw, 5.5rem) 0;
}

.mvmt .display::before {
  content: counter(mvmt, decimal-leading-zero);
  display: block;
  font-family: "roca", serif;
  font-weight: 800;
  font-size: clamp(2.2rem, 5vw, 4rem);
  line-height: 1;
  color: var(--color-terracotta);
  margin-block: 0 0.12em;
}

.mvmt > * + *,
.mvmt-body > * + * {
  margin-block-start: 1.2rem;
}

.mvmt-body {
  padding-block: clamp(1.5rem, 4vw, 2.5rem) 0;
}

.aside-link {
  font-family: "new-spirit-condensed", serif;
  font-style: italic;
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: var(--text-color-muted);
}

.aside-link a {
  color: var(--color-terracotta);
  text-decoration: none;
  border-block-end: 1px solid currentColor;
}

/* --- Dark stats: the bitter numbers (grid-matrix) ------------------- */

/* 4-up → 2×2 → 2 (mobile). Dividers via the gap trick: band background is the
   hairline colour, cells carry the page background, so only the 1px gaps read
   as rules (adapts to 4-up and 2×2 alike). */
.dark-stats {
  --base-span: 2; /* short numbers stay 2-up even on mobile */
  --mid-span: 2;
  --matrix-gap: 1px;
  margin-block: clamp(2.5rem, 6vw, 4rem);
  border-block: 1px solid var(--border-color-light);
  background: var(--border-color-light);
}

.dark-stats > * {
  background: var(--bg-color);
  padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1rem, 3vw, 2.4rem);
}

.ds-num {
  font-family: "roca", serif;
  font-weight: 800;
  line-height: 1;
  font-size: clamp(1.7rem, 4vw, 3rem);
  color: var(--text-color-dark);
  margin: 0;
}

.ds-lab {
  font-family: "roca", serif;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: clamp(0.62rem, 0.85vw, 0.72rem);
  color: var(--text-color-muted);
  margin: 0.5rem 0 0;
}

.opphav-figure img {
  width: 100%;
}

/* --- Håndverk: media-text + negation pairs (grid group) ------------- */

.handverk .wp-block-media-text__content {
  padding-block: clamp(2rem, 5vw, 3.5rem);
}

.handverk .wp-block-media-text__content > * + * {
  margin-block-start: 1.2rem;
}

.craft-grid {
  --mid-span: 2; /* 2×2 on tablet */
  --base-span: 4; /* 1-up on mobile (longer pair text) */
  --matrix-gap: 0 clamp(1.5rem, 4vw, 3rem);
  margin-block: clamp(2rem, 5vw, 3.5rem);
}

.craft-pair {
  padding-block: 1.4rem;
  border-block-start: 1px solid var(--border-color-light);
}

.craft-pair > * {
  margin: 0;
}

.craft-no {
  font-family: "new-spirit-condensed", serif;
  font-style: italic;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  color: var(--text-color-muted);
  margin-block-end: 0.35rem;
}

.craft-no s {
  text-decoration-color: var(--color-terracotta);
  text-decoration-thickness: 2px;
}

.craft-yes {
  font-family: "roca", serif;
  font-weight: 800;
  letter-spacing: -0.01em;
  font-size: clamp(1.25rem, 2vw, 1.7rem);
  color: var(--text-color-dark);
}

.craft-yes::before {
  content: "→ ";
  color: var(--color-terracotta);
}

/* --- Innhold: felt-numbers band (wp:columns) ------------------------ */

.cacao-stats {
  --base-span: 2; /* short numbers stay 2-up even on mobile */
  --mid-span: 2;
  --matrix-gap: 1px;
  margin-block: clamp(2.5rem, 6vw, 4rem);
  border-block: 2px solid var(--color-terracotta);
  background: var(--border-color-light);
}

.cacao-stats > * {
  background: var(--bg-color);
  padding: clamp(2rem, 5vw, 3rem) clamp(1rem, 3vw, 2.6rem);
}

.cs-num {
  font-family: "roca", serif;
  font-weight: 800;
  line-height: 0.92;
  /* fits the widest value ("~200 mg") in a quarter-width cell at the tightest
     4-up width (~1100px container) without clipping */
  font-size: clamp(2rem, 4.4vw, 3.8rem);
  color: var(--color-terracotta);
  font-variant-numeric: tabular-nums;
  margin: 0;
}

.cs-lab {
  font-family: "roca", serif;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: clamp(0.66rem, 0.9vw, 0.78rem);
  line-height: 1.35;
  color: var(--text-color-muted);
  margin: 0.7rem 0 0;
  max-width: 16ch;
}

/* --- Innhold: four compound families (wp:table panels, grid group) -- */

.cc-grid {
  --base-span: 2; /* 1-up on mobile (content-heavy table panels) */
  --mid-span: 1;  /* 2 columns from tablet up (never 4-across) */
  --matrix-gap: clamp(1.2rem, 2.5vw, 2rem);
  margin-block: clamp(2rem, 4vw, 3rem);
}

.cc-panel {
  --accent: var(--color-terracotta);
  background: var(--color-cream-100);
  border-block-start: 3px solid var(--accent);
  padding: clamp(1.5rem, 3vw, 2.4rem);
}

.cc-anti { --accent: var(--color-berry); }
.cc-psy  { --accent: var(--color-terracotta); }
.cc-fat  { --accent: var(--color-spice); }
.cc-min  { --accent: var(--color-sage); }

.cc-fam {
  font-family: "roca", serif;
  font-weight: 800;
  letter-spacing: -0.01em;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  color: var(--text-color-dark);
  margin: 0;
}

.cc-frame {
  font-family: "roca", serif;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.66rem;
  color: var(--accent);
  margin: 0.35rem 0 0;
}

.cc-note {
  font-family: "new-spirit-condensed", serif;
  font-style: italic;
  font-size: clamp(0.95rem, 1.3vw, 1.1rem);
  line-height: 1.4;
  color: var(--text-color-muted);
  margin: 0.6rem 0 0;
}

.cc-table {
  margin: 1.1rem 0 0;
}

.cc-panel .wp-block-table table {
  width: 100%;
  border-collapse: collapse;
}

.cc-panel .wp-block-table td {
  border: 0;
  border-block-start: 1px solid var(--border-color-light);
  padding: 0.75rem 0;
  vertical-align: baseline;
  line-height: 1.3;
  color: var(--text-color-dark);
}

.cc-panel .wp-block-table tr:first-child td {
  border-block-start: 0;
}

.cc-panel .wp-block-table td + td {
  text-align: end;
  padding-inline-start: 1rem;
  font-family: "roca", serif;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* soft / present values + italic sub-lines (rendered as <em> in cells) */
.cc-panel .wp-block-table td em {
  font-family: "new-spirit-condensed", serif;
  font-style: italic;
  font-weight: 400;
  font-size: 0.92em;
  color: var(--text-color-muted);
}

.cc-also {
  margin: 1rem 0 0;
  padding-block-start: 0.85rem;
  border-block-start: 1px solid var(--border-color-light);
  font-family: "new-spirit-condensed", serif;
  font-style: italic;
  font-size: 0.95rem;
  color: var(--text-color-muted);
}

.cc-footnote {
  margin-block: clamp(1.2rem, 2.5vw, 1.8rem) 0;
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--text-color-muted);
}

.cc-footnote::first-letter {
  color: var(--color-terracotta);
  font-weight: 800;
}

/* --- Closing CTA: inverted cacao-origin gradient -------------------- */

.cacao-cta {
  background: var(--gradient-cacao-origin);
  text-align: left;
  margin-block-start: clamp(3rem, 7vw, 5rem);
  padding-block: clamp(4rem, 10vw, 7.5rem);
}

.cacao-cta > * + * {
  margin-block-start: 1.2rem;
}

.cacao-cta .display {
  color: var(--color-cream-50);
  font-size: clamp(2.6rem, 7vw, 5rem);
}

.cacao-cta .lede {
  color: var(--color-cream-200);
}

.cacao-cta .kicker {
  color: var(--color-cream-200);
}

.cacao-cta .kicker::before {
  background-color: var(--color-cream-200);
}

.cacao-cta .wp-block-button__link {
  background-color: var(--color-cream-50);
  color: var(--text-color-dark);
  border: 1px solid var(--color-cream-50);
  border-radius: 0;
  padding: 1.1rem 2.8rem;
  font-family: "roca", serif;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.84rem;
  transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.cacao-cta .wp-block-button__link:hover {
  background-color: transparent;
  color: var(--color-cream-50);
  border-color: var(--color-cream-50);
}

/* Responsive collapse is handled by .grid-matrix (container queries) in the
   theme — the matrices step 4 → 2×2 → 1 on their own width, no media queries. */

/* --- Serving-size switch (per 100 g <-> per kopp), driven by cacao.js ---
   The pa_mengde / subscription toggle idiom (myrvann _variations.scss,
   _subscription.scss): one inset-bordered cream field, equal-width halves
   split by a divider. Inactive halves are muted transparent; the active half
   fills with selected-cream and carries the brown L-corner registration marks
   (top-left + bottom-right) on the segment itself. */

/* Outer wrapper centers the field without inline-axis margins. */
.cc-serving-switch {
  display: flex;
  justify-content: center;
  margin-block: 0 1.8em;
}

/* The field: equal columns (inline-grid 1fr) sized to the wider label. */
.cc-serving-frame {
  display: inline-grid;
  grid-auto-flow: column;
  grid-auto-columns: 1fr;
  background-color: var(--bg-color-light);
  border: 1px inset var(--border-color-inset);
  border-radius: var(--border-radius);
  overflow: hidden;
}

.cc-serving-btn {
  appearance: none;
  margin: 0;
  border: 0;
  background: transparent;
  padding: 0.75em 1.25em;
  font: inherit;
  font-size: 0.9em;
  letter-spacing: 0.01em;
  white-space: nowrap;
  text-align: center;
  cursor: pointer;
  position: relative;
  color: var(--text-color);
  opacity: 0.7;
  transition: background-color 0.18s ease, color 0.18s ease, opacity 0.18s ease;
}

/* Divider between the two halves. */
.cc-serving-btn + .cc-serving-btn {
  border-left: 1px solid var(--border-color-divider);
}

.cc-serving-btn:hover {
  background-color: var(--bg-color-hover);
  opacity: 1;
}

/* Active half: selected-cream fill + brown L-corner marks on the segment. */
.cc-serving-btn.is-active {
  background-color: var(--bg-color-selected);
  color: var(--text-color-dark);
  font-weight: 500;
  opacity: 1;
}
.cc-serving-btn.is-active::before,
.cc-serving-btn.is-active::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-color: var(--border-color);
  border-style: solid;
}
.cc-serving-btn.is-active::before {
  top: 2px;
  left: 2px;
  border-width: 2px 0 0 2px;
}
.cc-serving-btn.is-active::after {
  bottom: 2px;
  right: 2px;
  border-width: 0 2px 2px 0;
}
