/* ═══════════════════════════════════════════════════════════════
   BRIMROOK — Das Play-Label von norwegen-lesen.de
   Tokens · Typesystem · Komponenten · Motion Rules
   Regel: Bewegung ist Beweis, nicht Dekoration.
   Verboten: Verläufe als Dekor, Glow, Konfetti, Neon, Bounce.
   ─────────────────────────────────────────────────────────────── */

:root {
  --brim-black:   #11110F;
  --paper-bone:   #F4EFE3;
  --archive-cream:#EDE6D6;
  --rust-mark:    #A0432A;
  --fjord-blue:   #2C5868;
  --lichen-green: #4E6A50;
  --signal-gold:  #D6A84A;
  --fog-grey:     #6E6757;
  --line-bone:    #CFC6B1;

  --brim-font-display: "Newsreader", Georgia, serif;
  --brim-font-ui: "Manrope", system-ui, sans-serif;
  --brim-font-mono: "JetBrains Mono", ui-monospace, Menlo, Consolas, monospace;

  --brim-bg: var(--paper-bone);
  --brim-ink: var(--brim-black);
  --brim-line: var(--line-bone);
}
@media (prefers-color-scheme: dark) {
  :root {
    --brim-bg: #181A17;
    --brim-ink: var(--paper-bone);
    --brim-line: rgba(207,198,177,.32);
  }
}

/* JetBrains Mono — selbst gehostet (SIL OFL), kein CDN */
@font-face {
  font-family: "JetBrains Mono";
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url("../assets/fonts/JetBrainsMono-VariableFont_wght.ttf") format("truetype-variations"),
       url("../assets/fonts/JetBrainsMono-VariableFont_wght.ttf") format("truetype");
}

/* ── Wordmark ─────────────────────────────────────────────── */
.brim-wordmark {
  display: inline-flex;
  align-items: center;
  gap: .55em;
  font-family: var(--brim-font-mono);
  font-weight: 700;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--brim-ink);
}
.brim-wordmark svg { display: block; height: 1.18em; width: auto; }

/* ── File Tab: Aktenreiter am Panelrand ───────────────────── */
.brim-tab {
  position: absolute;
  top: -0.62em;
  left: 14px;
  display: inline-block;
  padding: 0 .55em;
  background: var(--brim-bg);
  font-family: var(--brim-font-mono);
  font-size: .64rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--fog-grey);
  white-space: nowrap;
}

/* ── Brim Line: Rahmen mit offener Ecke (oben rechts) ─────── */
.brim-frame {
  position: relative;
  border: 1px solid var(--brim-line);
}
.brim-frame::after {
  content: "";
  position: absolute;
  top: -1px;
  right: -1px;
  width: 26px;
  height: 26px;
  border-top: 1px solid var(--brim-bg);
  border-right: 1px solid var(--brim-bg);
  pointer-events: none;
}
.brim-divider {
  border: 0;
  height: 1px;
  background: var(--brim-line);
  position: relative;
  margin: 0;
}
.brim-divider::after {
  content: "";
  position: absolute;
  right: 0;
  top: -3px;
  width: 22px;
  height: 7px;
  background: var(--brim-bg);
}

/* ── Rook Dot: versetzter Punkt für aktive States/Hinweise ── */
.rook-dot { position: relative; }
.rook-dot::after {
  content: "";
  position: absolute;
  top: -.28em;
  right: -.62em;
  width: .32em;
  height: .32em;
  border-radius: 50%;
  background: var(--rust-mark);
}

/* ── Rust Stamp: nur für bedeutungsvolle Abschlüsse ───────── */
.rust-stamp {
  display: inline-block;
  padding: .32em .7em;
  border: 2px solid var(--rust-mark);
  color: var(--rust-mark);
  font-family: var(--brim-font-mono);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  transform: rotate(-2.5deg);
  border-radius: 2px;
}

/* ── Seed Chip (DRAUMEN) ──────────────────────────────────── */
.seed-chip {
  display: inline-block;
  padding: .25em .6em;
  border: 1px solid var(--brim-line);
  font-family: var(--brim-font-mono);
  font-size: .72rem;
  letter-spacing: .14em;
  color: var(--brim-ink);
  border-radius: 2px;
}

/* ── Motion Rules: linear, knapp, ohne Overshoot ──────────── */
.brim-stamp-in { animation: brim-stamp-in .18s linear both; }
@keyframes brim-stamp-in {
  from { opacity: 0; transform: rotate(-2.5deg) scale(1.18); }
  to   { opacity: 1; transform: rotate(-2.5deg) scale(1); }
}
.brim-line-draw { animation: brim-line-draw .4s linear both; transform-origin: left center; }
@keyframes brim-line-draw {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}
.brim-pulse-once { animation: brim-pulse-once .5s linear 1 both; }
@keyframes brim-pulse-once {
  0% { opacity: .4; } 50% { opacity: 1; } 100% { opacity: .85; }
}
@media (prefers-reduced-motion: reduce) {
  .brim-stamp-in, .brim-line-draw, .brim-pulse-once { animation: none; }
}

/* ── Spielakte-Brücke: Kontext-CTA auf Orts-/Themenseiten ──── */
.brim-bruecke {
  max-width: 64rem;
  margin: clamp(2.5rem, 6vw, 4rem) auto;
  padding: 0 clamp(1.25rem, 4vw, 3rem);
}
.brim-bruecke__card {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem 2rem;
  border: 1px solid var(--brim-line);
  background: var(--brim-bg);
  padding: 1.5rem 1.6rem 1.4rem;
  border-radius: 3px;
}
.brim-bruecke__card::after {
  content: "";
  position: absolute;
  top: -1px; right: -1px;
  width: 26px; height: 26px;
  border-top: 1px solid var(--brim-bg);
  border-right: 1px solid var(--brim-bg);
  pointer-events: none;
}
.brim-bruecke .brim-tab { background: var(--brim-bg); }
.brim-bruecke__satz {
  font-family: var(--brim-font-display);
  font-style: italic;
  font-size: clamp(1.05rem, 1.8vw, 1.3rem);
  line-height: 1.4;
  color: var(--brim-ink);
  margin: 0;
  max-inline-size: 38ch;
}
.brim-bruecke__cta {
  font-family: var(--brim-font-ui);
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .02em;
  color: var(--brim-ink);
  text-decoration: none;
  border-bottom: 2px solid var(--rust-mark);
  padding-bottom: .15rem;
  white-space: nowrap;
}
.brim-bruecke__cta:hover { color: var(--rust-mark); }
.brim-bruecke__label {
  font-family: var(--brim-font-mono);
  font-size: .66rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--fog-grey);
  width: 100%;
  margin: .2rem 0 0;
}
