/* =========================================================================
   brobjerg.dk/ritt – »Hvad ikke alle kan lære«
   Arkivarisk longread. Fraunces (display) + Spectral (brød).
   ========================================================================= */

:root{
  --paper:#f4eee2;
  --paper-2:#efe7d8;
  --card:#fbf7ee;
  --ink:#1c1813;
  --ink-2:#443d34;
  --muted:#7c7263;
  --line:#dccfba;
  --line-2:#cdbfa6;
  --red:#9c2a16;
  --red-2:#7c1f0f;
  --green:#3b5a49;
  --gold:#a9772a;
  --dark:#16120d;
  --dark-2:#211b14;
  --cream:#efe5d2;
  --cream-2:#bdb19a;
  --maxw:1160px;
  --read:680px;
  --serif:"Spectral",Georgia,"Times New Roman",serif;
  --display:"Fraunces",Georgia,serif;
  --mono:ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--serif);font-weight:400;font-size:1.12rem;line-height:1.72;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video,picture{max-width:100%;display:block}
img{height:auto}
figure.doc img,.hero-portrait,.bio-fig img,.wit-portrait img{height:auto}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.04;
  letter-spacing:-.01em;margin:0;font-variation-settings:"opsz" 80}
a{color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,52px)}
.wrap.narrow{max-width:var(--read)}

/* ---- kicker / section heads ------------------------------------------------ */
.kicker{
  font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.26em;
  text-transform:uppercase;color:var(--red);margin:0 0 1.1rem;
  display:flex;align-items:center;gap:.8em;
}
.kicker::before{content:"";width:34px;height:1px;background:var(--red);opacity:.7;flex:none}
.sec-head{max-width:760px;margin:0 auto clamp(2.4rem,5vw,4rem);text-align:center}
.sec-head .kicker{justify-content:center}
.sec-head h2{font-size:clamp(1.9rem,4.6vw,3.1rem);font-variation-settings:"opsz" 120}
.sec-intro{font-size:1.16rem;color:var(--ink-2);margin:1.1rem auto 0;max-width:62ch}
.ink-red{color:var(--red);font-style:italic}

section{padding:clamp(3.6rem,9vw,7.5rem) 0;position:relative}

/* ---- reading progress ----------------------------------------------------- */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
  background:linear-gradient(90deg,var(--red),var(--gold));transition:width .1s linear}

/* ---- reveal --------------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(22px);
  transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{position:relative;padding:clamp(3rem,9vh,7rem) 0 clamp(3rem,7vh,5rem);
  background:radial-gradient(120% 90% at 50% -10%,var(--paper-2),var(--paper) 60%);
  overflow:hidden;border-bottom:1px solid var(--line)}
.hero-grain{position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  mix-blend-mode:multiply}
.hero-inner{position:relative;text-align:center}
.hero .kicker{justify-content:center}
.hero-quote{
  font-family:var(--display);font-weight:600;
  font-size:clamp(2.5rem,8.2vw,6.4rem);line-height:.98;letter-spacing:-.025em;
  font-variation-settings:"opsz" 144,"SOFT" 0;
  margin:.3rem auto .9rem;max-width:14ch;
}
.hero-quote .gm{color:var(--red);font-style:italic;font-weight:400;
  margin:0 .04em;font-variation-settings:"opsz" 144}
.hero-attrib{font-style:italic;color:var(--muted);font-size:1.18rem;margin:0 0 2.6rem}
.hero-cols{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(1.4rem,4vw,3.2rem);
  align-items:center;text-align:left;max-width:920px;margin:0 auto;
  padding-top:2.2rem;border-top:1px solid var(--line)}
.hero-lead{font-size:1.18rem;color:var(--ink-2);margin:0}
.hero-fig{margin:0}
.hero-portrait{border-radius:3px;filter:grayscale(.15) contrast(1.04);
  box-shadow:0 14px 36px rgba(28,24,19,.26);border:5px solid var(--card)}
.hero-fig figcaption{font-family:var(--mono);font-size:.68rem;line-height:1.5;
  letter-spacing:.04em;color:var(--muted);margin-top:.7rem;text-transform:uppercase}
.hero-verdict{font-family:var(--display);font-style:italic;font-weight:500;
  font-size:clamp(1.2rem,2.6vw,1.7rem);color:var(--red-2);
  max-width:30ch;margin:2.8rem auto 0;line-height:1.3}
.scroll-cue{display:inline-grid;place-items:center;width:44px;height:44px;margin-top:2.4rem;
  border:1px solid var(--line-2);border-radius:50%;color:var(--ink-2);text-decoration:none;
  font-size:1.1rem;animation:bob 2.2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
@media (prefers-reduced-motion:reduce){.scroll-cue{animation:none}}

/* =========================================================================
   TALLY
   ========================================================================= */
.tally{padding:clamp(2.4rem,5vw,3.6rem) 0;background:var(--ink);color:var(--cream)}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:rgba(239,229,210,.14);border:1px solid rgba(239,229,210,.14)}
.stat{background:var(--ink);padding:clamp(1.4rem,3vw,2.4rem) clamp(1rem,2vw,1.6rem);text-align:center}
.stat-n{font-family:var(--display);font-weight:600;font-size:clamp(2.4rem,6vw,4rem);
  line-height:1;font-variation-settings:"opsz" 144;color:#fff}
.stat-l{font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--gold);margin-top:.7rem}
.stat-note{font-size:.92rem;color:var(--cream-2);margin-top:.55rem;font-style:italic;line-height:1.45}

/* =========================================================================
   TV (dark)
   ========================================================================= */
.tv{background:var(--dark);color:var(--cream)}
.tv .kicker{color:var(--gold)}
.tv .kicker::before{background:var(--gold)}
.tv h2{color:#fff;font-size:clamp(1.9rem,4.4vw,3rem)}
.tv .sec-head{margin-bottom:clamp(2rem,4vw,3.2rem)}
.tv .sec-intro{color:var(--cream-2)}
.tv-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:start}
.video-wrap{position:relative;border-radius:4px;overflow:hidden;background:#000;
  box-shadow:0 24px 60px rgba(0,0,0,.5);aspect-ratio:16/9}
.video-wrap video{width:100%;height:100%;object-fit:cover}
.video-play{position:absolute;inset:0;margin:auto;width:84px;height:84px;border:none;cursor:pointer;
  background:rgba(156,42,22,.92);border-radius:50%;display:grid;place-items:center;
  transition:transform .2s,background .2s;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.video-play svg{width:34px;height:34px;fill:#fff;margin-left:3px}
.video-play:hover{transform:scale(1.07);background:var(--red)}
.video-play.hide{opacity:0;pointer-events:none}
.transcript{font-size:1.06rem}
.tl-line{margin:0 0 1.2rem;color:var(--cream-2);position:relative;padding-left:3.4em}
.tl-line .who{position:absolute;left:0;top:.05em;font-family:var(--mono);font-size:.72rem;
  letter-spacing:.1em;color:var(--muted);border:1px solid rgba(239,229,210,.22);
  padding:.15em .5em;border-radius:3px}
.tl-line.rb{color:#fff;font-family:var(--display);font-style:italic;font-weight:500;
  font-size:1.3rem;line-height:1.4}
.tl-line.rb .who{color:var(--gold);border-color:rgba(169,119,42,.5);top:.2em}
.credit{font-family:var(--mono);font-size:.68rem;letter-spacing:.04em;color:var(--muted);
  text-transform:uppercase;margin-top:1.8rem;line-height:1.6}

/* =========================================================================
   BIO
   ========================================================================= */
.bio{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bio-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:center}
.bio-fig{margin:0}
.bio-fig img{border-radius:3px;filter:grayscale(.2) sepia(.08) contrast(1.03);
  box-shadow:0 12px 30px rgba(28,24,19,.22);border:5px solid var(--card)}
.bio h2{font-size:clamp(1.8rem,4vw,2.7rem)}
.bio-life{font-family:var(--mono);font-size:.82rem;letter-spacing:.08em;color:var(--red);
  text-transform:uppercase;margin:.7rem 0 1.4rem}
.bio-facts{list-style:none;margin:0 0 1.6rem;padding:0}
.bio-facts li{position:relative;padding-left:1.5em;margin:.55rem 0;color:var(--ink-2);font-size:1.04rem}
.bio-facts li::before{content:"–";position:absolute;left:0;color:var(--gold)}
.bio-note{font-style:italic;color:var(--muted);border-left:2px solid var(--line-2);padding-left:1.1em;margin:0}
.cap-credit{font-family:var(--mono);font-size:.64rem;letter-spacing:.03em;color:var(--muted);
  text-transform:uppercase;margin:.6rem 0 0;line-height:1.5}

/* portræt i domsslutningen (mørk sektion) */
.dom-portrait{max-width:300px;margin:clamp(2.6rem,6vw,4.2rem) auto 0;text-align:center}
.dom-portrait img{border-radius:3px;filter:grayscale(.12) contrast(1.03);
  border:5px solid rgba(239,229,210,.1);box-shadow:0 20px 48px rgba(0,0,0,.55)}
.dom-portrait .cap-credit{color:var(--cream-2)}

/* =========================================================================
   QUESTION
   ========================================================================= */
.question{text-align:center}
.big-q{font-family:var(--display);font-weight:600;font-variation-settings:"opsz" 130;
  font-size:clamp(1.7rem,4.4vw,2.9rem);line-height:1.18;letter-spacing:-.015em;margin:0 auto;max-width:18ch}
.big-q-sub{font-family:var(--display);font-style:italic;font-weight:400;color:var(--red);
  font-size:clamp(1.2rem,2.6vw,1.6rem);margin:1rem 0 0}
.method{color:var(--muted);font-size:1.05rem;margin:2.2rem auto 0;max-width:54ch}

/* =========================================================================
   TIMELINE
   ========================================================================= */
.timeline{background:var(--paper)}
.tl-list{list-style:none;margin:0 auto;padding:0;max-width:780px;position:relative}
.tl-list::before{content:"";position:absolute;left:11px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--line-2),var(--line-2));}
.tl-node{position:relative;padding:0 0 clamp(2.2rem,4vw,3.4rem) clamp(2.6rem,5vw,3.4rem)}
.tl-marker{position:absolute;left:0;top:.35em;width:24px;height:24px;border-radius:50%;
  background:var(--paper);border:2px solid var(--muted);z-index:1}
.tl-marker::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--muted)}
.tl-denial .tl-marker{border-color:var(--red)}
.tl-denial .tl-marker::after{background:var(--red)}
.tl-witness .tl-marker{border-color:var(--green)}
.tl-witness .tl-marker::after{background:var(--green)}
.tl-origin .tl-marker{border-color:var(--gold)}
.tl-origin .tl-marker::after{background:var(--gold)}
.tl-letter .tl-marker{border-color:var(--ink)}
.tl-letter .tl-marker::after{background:var(--ink)}
.tl-afterlife .tl-marker{border-color:var(--line-2)}
.tl-afterlife .tl-marker::after{background:var(--line-2)}
.tl-meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem .9rem;margin-bottom:.4rem}
.tl-date{font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;color:var(--ink);font-weight:600}
.tl-place{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}
.tl-tag{margin-left:auto;font-family:var(--mono);font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);border:1px solid var(--line-2);
  padding:.12em .55em;border-radius:99px}
.tl-denial .tl-tag{color:var(--red);border-color:rgba(156,42,22,.4)}
.tl-witness .tl-tag{color:var(--green);border-color:rgba(59,90,73,.4)}
.tl-title{font-size:clamp(1.3rem,2.8vw,1.75rem);margin:.1rem 0 .6rem;font-variation-settings:"opsz" 70}
.tl-body{margin:0 0 .8rem;color:var(--ink-2)}
.tl-ref{font-style:italic;color:var(--muted);font-size:.98rem;margin:.4rem 0 0}
.tl-aside{display:block;margin:1.1rem 0 0;padding:.95rem 1.15rem;font-size:.98rem;line-height:1.55;
  color:var(--ink-2);background:linear-gradient(90deg,rgba(169,119,42,.08),rgba(169,119,42,.02));
  border-left:3px solid var(--gold);border-radius:0 4px 4px 0}
.tl-aside-label{display:block;font-family:var(--mono);font-size:.66rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:.35rem}
.tl-aside-link{color:var(--red);font-weight:500;text-decoration:none;
  border-bottom:1px solid currentColor;white-space:nowrap}
.tl-aside-link:hover{color:var(--red-2)}

/* blockquotes inside timeline / evidence */
.ev-quote{font-family:var(--display);font-weight:400;font-style:normal;
  font-variation-settings:"opsz" 40;font-size:1.18rem;line-height:1.5;
  color:var(--ink);margin:1rem 0;padding:.2rem 0 .2rem 1.2rem;
  border-left:3px solid var(--red);background:linear-gradient(90deg,rgba(156,42,22,.045),transparent 70%)}
.ev-quote.en{font-style:italic;color:var(--ink-2)}

/* =========================================================================
   DOCUMENT FIGURES + LIGHTBOX
   ========================================================================= */
figure.doc{margin:1.4rem 0 0;background:var(--card);padding:14px;border:1px solid var(--line);
  border-radius:3px;box-shadow:0 10px 26px rgba(28,24,19,.13);
  transform:rotate(var(--rot,0));transition:transform .3s,box-shadow .3s;position:relative}
figure.doc:hover{transform:rotate(0) translateY(-3px);box-shadow:0 18px 40px rgba(28,24,19,.2)}
figure.doc .lb-trigger{display:block;width:100%;padding:0;border:0;background:none;cursor:zoom-in}
figure.doc img{width:100%;border-radius:2px}
figure.doc figcaption{font-family:var(--mono);font-size:.72rem;line-height:1.6;
  color:var(--muted);margin-top:.85rem;letter-spacing:.01em}
.tl-doc{max-width:460px}
.ev-doc{margin-top:0}

.lightbox{position:fixed;inset:0;z-index:100;background:rgba(15,12,8,.94);
  display:grid;place-items:center;padding:clamp(16px,4vw,48px);
  opacity:0;animation:fade .25s forwards}
.lightbox[hidden]{display:none}
@keyframes fade{to{opacity:1}}
.lb-fig{margin:0;max-width:1000px;max-height:100%;display:flex;flex-direction:column;gap:1rem}
.lb-fig img{max-height:80vh;width:auto;margin:0 auto;border-radius:3px;
  box-shadow:0 30px 80px rgba(0,0,0,.6);background:#fff}
#lb-cap{font-family:var(--mono);font-size:.8rem;line-height:1.6;color:var(--cream-2);
  text-align:center;max-width:70ch;margin:0 auto}
.lb-close{position:fixed;top:18px;right:24px;width:48px;height:48px;border-radius:50%;
  border:1px solid rgba(239,229,210,.3);background:rgba(0,0,0,.3);color:var(--cream);
  font-size:1.8rem;line-height:1;cursor:pointer;transition:background .2s}
.lb-close:hover{background:var(--red)}

/* =========================================================================
   CHAT (facebook)
   ========================================================================= */
.chat{margin:1.2rem 0 0;max-width:440px;display:flex;flex-direction:column;gap:.5rem}
.bubble{max-width:90%;display:flex;flex-direction:column}
.bubble-date{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;color:var(--muted);
  text-transform:uppercase;margin:.3rem .2rem}
.bubble-body{padding:.7em 1em;border-radius:18px;font-size:1rem;line-height:1.45}
.bubble.out{align-self:flex-end;align-items:flex-end}
.bubble.out .bubble-body{background:#2b6fe0;color:#fff;border-bottom-right-radius:5px}
.bubble.in{align-self:flex-start}
.bubble.in .bubble-body{background:#e7e0d2;color:var(--ink);border-bottom-left-radius:5px}

/* =========================================================================
   WITNESSES
   ========================================================================= */
.witnesses{background:var(--dark);color:var(--cream)}
.witnesses .kicker{color:var(--gold)}.witnesses .kicker::before{background:var(--gold)}
.witnesses h2{color:#fff}.witnesses .sec-intro{color:var(--cream-2)}
.wit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(239,229,210,.13);border:1px solid rgba(239,229,210,.13)}
.wit-fill{background:var(--dark)}
.wit{background:var(--dark);padding:clamp(1.5rem,3vw,2.2rem);position:relative}
.wit-no{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;color:var(--gold)}
.wit-name{color:#fff;font-size:1.5rem;margin:.7rem 0 .3rem;font-variation-settings:"opsz" 60}
.wit-role{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--cream-2);
  text-transform:uppercase;margin:0 0 1rem}
.wit-claim{color:var(--cream);font-size:1.02rem;margin:0 0 1.2rem}
.wit-at{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--gold);
  text-transform:uppercase;padding-top:.9rem;border-top:1px solid rgba(239,229,210,.14);margin:0}

/* =========================================================================
   EVIDENCE
   ========================================================================= */
.evidence{background:var(--paper-2)}
.ev-item{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3.6rem);
  align-items:center;padding:clamp(2.2rem,4vw,3.4rem) 0;border-top:1px solid var(--line)}
.ev-item:nth-child(even) .ev-text{order:2}
.ev-q{font-size:clamp(1.4rem,3vw,2rem);margin:0 0 1rem;font-variation-settings:"opsz" 90}
.ev-a{font-family:var(--display);font-style:italic;font-weight:600;color:var(--green);
  font-size:clamp(1.2rem,2.4vw,1.5rem);margin:0 0 1rem;display:flex;align-items:baseline;gap:.5em}
.ev-a::before{content:"✓";font-style:normal;color:var(--green);font-size:.85em}
.ev-body{color:var(--ink-2);margin:0}
.ev-figs{display:flex;flex-direction:column;gap:1.2rem}

/* =========================================================================
   VARIANTS
   ========================================================================= */
.variants{background:var(--paper)}
.var-list{list-style:none;margin:0;padding:0;border-top:1px solid var(--line)}
.var{display:grid;grid-template-columns:5.5rem 1fr;gap:.4rem 1.4rem;align-items:baseline;
  padding:1.2rem 0;border-bottom:1px solid var(--line)}
.var-year{font-family:var(--mono);font-size:.85rem;font-weight:600;color:var(--red);letter-spacing:.04em}
.var-text{font-family:var(--display);font-weight:500;font-variation-settings:"opsz" 50;
  font-size:clamp(1.05rem,2.2vw,1.35rem);line-height:1.4;color:var(--ink)}
.var-text.en{font-style:italic;font-weight:400;color:var(--ink-2)}
.var-who{grid-column:2;font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--muted)}

/* =========================================================================
   CONCLUSION (dark)
   ========================================================================= */
.conclusion{background:var(--dark);color:var(--cream);
  background-image:radial-gradient(110% 80% at 50% 0%,var(--dark-2),var(--dark))}
.conclusion .kicker{color:var(--gold)}.conclusion .kicker::before{background:var(--gold)}
.conclusion h2{color:#fff;font-size:clamp(2rem,5vw,3.4rem)}
.dom-cols{display:grid;grid-template-columns:1fr 1fr;gap:1px;max-width:880px;margin:0 auto;
  background:rgba(239,229,210,.13);border:1px solid rgba(239,229,210,.13)}
.dom-col{background:var(--dark);padding:clamp(1.6rem,3vw,2.4rem)}
.dom-col h3{font-family:var(--mono);font-weight:500;font-size:.78rem;letter-spacing:.2em;
  text-transform:uppercase;margin:0 0 1.2rem}
.dom-for h3{color:var(--green)}.dom-against h3{color:var(--red)}
.dom-col ul{list-style:none;margin:0;padding:0}
.dom-col li{position:relative;padding-left:1.6em;margin:.85rem 0;color:var(--cream);font-size:1.02rem;line-height:1.55}
.dom-for li::before{content:"✓";position:absolute;left:0;color:var(--green)}
.dom-against li::before{content:"–";position:absolute;left:0;color:var(--red)}
.dom-verdict{font-family:var(--display);font-weight:500;font-variation-settings:"opsz" 110;
  font-size:clamp(1.5rem,3.6vw,2.4rem);line-height:1.28;color:#fff;text-align:center;
  max-width:24ch;margin:clamp(2.6rem,6vw,4.5rem) auto 0}
.dom-coda{font-family:var(--display);font-style:italic;font-weight:400;color:var(--gold);
  font-size:clamp(1.1rem,2.4vw,1.45rem);text-align:center;max-width:42ch;margin:1.8rem auto 0}

/* =========================================================================
   SOURCES + FOOTER
   ========================================================================= */
.sources{background:var(--paper-2);border-top:1px solid var(--line)}
.src-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:clamp(1.6rem,3vw,2.6rem);max-width:980px;margin:0 auto}
.src-group h3{font-family:var(--mono);font-weight:500;font-size:.74rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--red);margin:0 0 1rem;padding-bottom:.6rem;border-bottom:1px solid var(--line)}
.src-group ul{list-style:none;margin:0;padding:0}
.src-group li{font-size:.96rem;color:var(--ink-2);margin:.6rem 0;line-height:1.5}

.foot{background:var(--ink);color:var(--cream);padding:clamp(2.8rem,6vw,4.5rem) 0;text-align:center}
.foot-mark{font-family:var(--display);font-weight:600;font-size:1.7rem;font-variation-settings:"opsz" 120;margin:0}
.foot-mark span{color:var(--gold)}
.foot-by{color:var(--cream);margin:1.2rem 0 .3rem;font-size:1rem}
.foot-rights{color:var(--cream-2);font-size:.9rem;max-width:54ch;margin:.3rem auto 1.6rem}
.foot-top{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);text-decoration:none;border:1px solid rgba(169,119,42,.4);
  padding:.6em 1.2em;border-radius:99px;transition:background .2s,color .2s;display:inline-block}
.foot-top:hover{background:var(--gold);color:var(--ink)}
.foot-contact{margin:.2rem 0 .4rem}
.foot-contact a{color:var(--gold);text-decoration:none;font-size:1.02rem;
  border-bottom:1px solid transparent;transition:border-color .2s}
.foot-contact a:hover{border-color:var(--gold)}

/* =========================================================================
   STICKY BANNER ("Ved du mere?")
   ========================================================================= */
.topbar{position:sticky;top:0;z-index:50;display:block;text-decoration:none;
  background:var(--ink);color:var(--cream);text-align:center;padding:.62em 1em;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.07em;
  border-bottom:1px solid rgba(239,229,210,.16);transition:background .25s}
.topbar:hover{background:var(--red-2)}
.topbar strong{color:var(--gold);font-weight:600;text-transform:uppercase;letter-spacing:.12em}
.topbar-arrow{color:var(--gold)}

/* =========================================================================
   BIDRAG-SIDE (/ritt/bidrag/)
   ========================================================================= */
.bidrag-hero{padding:clamp(3.2rem,8vw,5.6rem) 0 clamp(1.8rem,4vw,2.8rem);text-align:center;
  background:radial-gradient(120% 90% at 50% -10%,var(--paper-2),var(--paper) 60%);
  border-bottom:1px solid var(--line)}
.bidrag-hero .kicker{justify-content:center}
.bidrag-hero h1{font-size:clamp(2rem,5.5vw,3.4rem);font-variation-settings:"opsz" 130;margin:.2rem 0}
.bidrag-lead{font-size:1.18rem;color:var(--ink-2);max-width:58ch;margin:1.2rem auto 0}
.bidrag-list{padding:clamp(2.6rem,6vw,4.5rem) 0}
.le-list{list-style:none;margin:0;padding:0;counter-reset:le;display:grid;gap:1.1rem}
.le{counter-increment:le;position:relative;background:var(--card);border:1px solid var(--line);
  border-radius:4px;padding:clamp(1.2rem,3vw,1.7rem) clamp(1.3rem,3vw,2rem);
  box-shadow:0 6px 18px rgba(28,24,19,.06);transition:transform .25s,box-shadow .25s}
.le:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(28,24,19,.12)}
.le::before{content:counter(le,decimal-leading-zero);position:absolute;top:1.1rem;right:1.4rem;
  font-family:var(--mono);font-size:.78rem;color:var(--line-2)}
.le h2{font-size:clamp(1.15rem,2.6vw,1.45rem);margin:0 0 .5rem;font-variation-settings:"opsz" 50;padding-right:2.5rem}
.le p{margin:0;color:var(--ink-2);font-size:1.02rem}
.bidrag-cta{background:var(--dark);color:var(--cream);text-align:center;padding:clamp(2.8rem,6vw,4.8rem) 0}
.bidrag-cta .cta-label{font-family:var(--mono);font-size:.76rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);margin:0 0 1.1rem}
.mailbtn{display:inline-block;font-family:var(--display);font-weight:600;
  font-size:clamp(1.4rem,4.5vw,2.6rem);color:#fff;text-decoration:none;
  border-bottom:2px solid var(--red);padding-bottom:.08em;transition:color .2s,border-color .2s}
.mailbtn:hover{color:var(--gold);border-color:var(--gold)}

/* =========================================================================
   SLÆGT-SIDE (/ritt/slaegt/) – familietræ
   ========================================================================= */
.slaegt-hero{padding:clamp(3.2rem,8vw,5.6rem) 0 clamp(1.8rem,4vw,2.8rem);text-align:center;
  background:radial-gradient(120% 90% at 50% -10%,var(--paper-2),var(--paper) 60%);
  border-bottom:1px solid var(--line)}
.slaegt-hero .kicker{justify-content:center}
.slaegt-hero h1{font-size:clamp(2rem,5.5vw,3.4rem);font-variation-settings:"opsz" 130;margin:.2rem 0}

.slaegt-letter{padding:clamp(2rem,5vw,3.2rem) 0;background:var(--paper-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.letter-q{font-family:var(--display);font-style:italic;font-weight:500;font-variation-settings:"opsz" 40;
  font-size:clamp(1.12rem,2.6vw,1.5rem);line-height:1.55;color:var(--ink);margin:0;
  padding-left:1.2rem;border-left:3px solid var(--gold)}
.letter-src{font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;
  color:var(--muted);margin:1rem 0 0;padding-left:1.3rem}

.slaegt-tree-sec{padding:clamp(3rem,7vw,5rem) 0}
.tree{max-width:860px;margin:0 auto}
.tree-root{display:flex;justify-content:center}
.tree-stem{width:2px;height:30px;background:var(--line-2);margin:0 auto}
.tree-split{height:2px;background:var(--line-2);margin:0 25%}
.tree-grid-wrap{position:relative;padding-top:4px}
.tree-grid-wrap::before,.tree-grid-wrap::after{content:"";position:absolute;top:0;bottom:30px;
  width:2px;background:var(--line-2);z-index:0}
.tree-grid-wrap::before{left:25%}
.tree-grid-wrap::after{left:75%}
.tree-labels{display:grid;grid-template-columns:1fr 1fr;position:relative;z-index:1}
.tree-collabel{text-align:center;padding:14px 0 24px}
.tree-collabel span{font-family:var(--mono);font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--red);background:var(--paper);padding:.25em .7em}
.tree-grid{display:grid;grid-template-columns:1fr 1fr;row-gap:22px;position:relative;z-index:1}
.tree-cell{display:flex;justify-content:center;align-items:flex-start;padding:0 .5rem}

.node{background:var(--card);border:1px solid var(--line);border-radius:4px;
  padding:.8rem 1.1rem;text-align:center;max-width:280px;width:100%;
  display:flex;flex-direction:column;gap:.12rem;box-shadow:0 4px 12px rgba(28,24,19,.06)}
.node-name{font-family:var(--display);font-weight:600;font-variation-settings:"opsz" 40;
  font-size:1.04rem;line-height:1.2}
.node-life{font-family:var(--mono);font-size:.68rem;letter-spacing:.02em;color:var(--muted);text-transform:uppercase}
.node-root{max-width:340px;border-color:var(--gold);
  background:linear-gradient(var(--card),var(--paper-2));box-shadow:0 8px 22px rgba(169,119,42,.16)}
.node-tag{font-family:var(--mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.25rem}
.node-root .node-name{font-size:1.25rem}
.node-hl{border-color:var(--red);box-shadow:0 8px 22px rgba(156,42,22,.15)}
.node-hl .node-name{color:var(--red-2)}
.node-spouse{font-family:var(--display);font-style:italic;font-size:.92rem;color:var(--ink-2);margin-top:.1rem}
.node-note{font-size:.8rem;color:var(--muted);font-style:italic;margin-top:.25rem}
.node-ph{border-style:dashed;border-color:var(--line-2);background:transparent;box-shadow:none}
.node-q{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--line-2);line-height:1}
.node-ph .node-life{color:var(--line-2)}

.tree-note{max-width:60ch;margin:clamp(2.2rem,5vw,3.4rem) auto 0;text-align:center;
  font-style:italic;color:var(--muted);font-size:.98rem;line-height:1.6}

.slaegt-clips{padding:0 0 clamp(3rem,7vw,5rem)}
.slaegt-clips .kicker{justify-content:center}
.clip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:1.4rem;margin-top:1.6rem;max-width:840px;margin-left:auto;margin-right:auto}
.slaegt-clip{margin:0}

@media (max-width:560px){
  .tree-cell{padding:0 .2rem}
  .node{padding:.7rem .7rem;max-width:100%}
  .node-name{font-size:.9rem}
  .node-life{font-size:.62rem}
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:860px){
  .hero-cols{grid-template-columns:1fr;text-align:center}
  .hero-fig{max-width:320px;margin:0 auto}
  .hero-fig figcaption{text-align:center}
  .tv-grid{grid-template-columns:1fr}
  .bio-grid{grid-template-columns:1fr}
  .bio-fig{max-width:300px}
  .ev-item{grid-template-columns:1fr;gap:1.4rem}
  .ev-item:nth-child(even) .ev-text{order:0}
  .dom-cols{grid-template-columns:1fr}
  .wit-grid{grid-template-columns:repeat(2,1fr)}
  .wit-fill{display:none}
}
@media (max-width:560px){
  body{font-size:1.06rem}
  .stat-grid{grid-template-columns:repeat(2,1fr)}
  .wit-grid{grid-template-columns:1fr}
  .var{grid-template-columns:1fr;gap:.2rem}
  .var-who{grid-column:1}
}

/* --- Sprog (da/en via webmoduler.i18n) ------------------------------------ */
/* Skifteren ligger fast over den sticky topbar (z-index > .topbar). */
.lang-switch{position:fixed;top:.5rem;right:.7rem;z-index:60;display:flex;gap:.1rem;
  font-family:var(--mono);font-size:.68rem;letter-spacing:.06em}
.lang-switch a{color:rgba(239,229,210,.6);text-decoration:none;padding:.12rem .44rem;
  border-radius:999px;line-height:1.5;transition:color .2s,background .2s}
.lang-switch a:hover{color:var(--cream)}
.lang-switch a[aria-current]{color:var(--ink);background:var(--cream)}
@media (max-width:560px){.lang-switch{top:.46rem;right:.5rem;font-size:.63rem}
  /* Skifteren er fast i øverste højre hjørne og overlapper ellers den
     centrerede bannertekst (.topbar) på smalle skærme. Reservér et højre-gab
     på størrelse med skifterens fodaftryk (~103px bred + .5rem offset). */
  .topbar{padding-right:7.5rem}}
/* Engelsk gloss under hero-citatet (kun en-siden). currentColor+opacity → bg-robust. */
.hero-gloss{margin:.25rem 0 0;font-style:italic;font-size:.92rem;opacity:.66}
/* Engelsk gloss i variant-listen: dansk ordlyd bevares, betydningen under. */
.var-gloss{display:block;font-style:italic;font-size:.8em;opacity:.7;margin-top:.12rem;line-height:1.4}
