:root{
  --bg:        #f7f3ea;
  --bg-2:      #f1ebdd;
  --surface:   #fffdf8;
  --surface-2: #efe7d6;
  --ink:       #1c1a17;
  --ink-soft:  #4b463d;
  --ink-faint: #8a8275;
  --line:        rgba(28,26,23,0.10);
  --line-strong: rgba(28,26,23,0.20);
  --gold:      #9a7b3f;
  --gold-soft: rgba(154,123,63,0.13);
  --c:         #9a7b3f;
  --radius: 18px;
  --maxw: 1080px;

  --display: "Fraunces", "Iowan Old Style", Palatino, Georgia, serif;
  --serif:   "Spectral", Georgia, Cambria, "Times New Roman", serif;
  --sans:    system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ---------- selvhostede skrifter ---------- */
@font-face{font-family:"Fraunces";font-style:normal;font-weight:100 900;font-display:swap;src:url(/digte/assets/fonts/fraunces-roman.woff2) format("woff2")}
@font-face{font-family:"Fraunces";font-style:italic;font-weight:100 900;font-display:swap;src:url(/digte/assets/fonts/fraunces-italic.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:normal;font-weight:400;font-display:swap;src:url(/digte/assets/fonts/spectral-normal-400.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:italic;font-weight:400;font-display:swap;src:url(/digte/assets/fonts/spectral-italic-400.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:normal;font-weight:500;font-display:swap;src:url(/digte/assets/fonts/spectral-normal-500.woff2) format("woff2")}
@font-face{font-family:"Spectral";font-style:normal;font-weight:600;font-display:swap;src:url(/digte/assets/fonts/spectral-normal-600.woff2) format("woff2")}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; min-height:100vh;
  background:var(--bg); color:var(--ink);
  font-family:var(--serif); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
:focus-visible{ outline:2px solid var(--gold); outline-offset:4px; border-radius:6px; }
.sr-only{ position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ---------- atmosfære (lys) ---------- */
.ambient{
  position:fixed; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(1100px 620px at 50% -8%, rgba(154,123,63,0.10), transparent 62%),
    radial-gradient(900px 600px at 12% 6%,  rgba(86,112,140,0.05), transparent 60%),
    radial-gradient(1000px 720px at 88% 102%, rgba(168,95,67,0.05), transparent 60%),
    var(--bg);
}
.grain{
  position:fixed; inset:-50%; z-index:-1; pointer-events:none; opacity:0.03;
  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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.eyebrow{ font-family:var(--sans); font-size:.72rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); }

/* ---------- galleri: masthead ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:clamp(1.25rem,4vw,2.5rem); }
.masthead{ text-align:center; padding:clamp(3rem,8vw,5.5rem) clamp(1rem,4vw,2rem) clamp(1rem,3vw,2rem); max-width:680px; margin:0 auto; }
.masthead .eyebrow{ display:block; margin-bottom:1.1rem; }
.masthead h1{ font-family:var(--display); font-weight:560; font-size:clamp(2.7rem,8vw,4.6rem); line-height:1.02; letter-spacing:-0.02em; margin:0 0 1rem; text-wrap:balance; }
.lede{ font-family:var(--serif); color:var(--ink-soft); font-size:clamp(1.05rem,2.3vw,1.24rem); line-height:1.6; margin:0 auto; max-width:48ch; text-wrap:balance; }
.lede em{ font-style:italic; color:var(--ink); }
.ornament{ display:flex; align-items:center; justify-content:center; gap:.9rem; margin:clamp(1.4rem,4vw,2rem) auto 0; }
.ornament::before,.ornament::after{ content:""; height:1px; width:min(80px,18vw); background:linear-gradient(90deg,transparent,var(--line-strong)); }
.ornament::after{ background:linear-gradient(90deg,var(--line-strong),transparent); }
.ornament span{ font-size:.7rem; color:var(--gold); transform:translateY(-1px); }

/* ---------- kategori-sektioner ---------- */
.cat{ margin:clamp(2rem,5vw,3.25rem) 0 0; }
.cat-title{
  display:flex; align-items:center; gap:.7rem;
  font-family:var(--sans); font-size:.78rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint);
  margin:0 0 1.1rem; padding-bottom:.85rem; border-bottom:1px solid var(--line);
}
.cat-title .dot{ width:8px; height:8px; border-radius:50%; background:var(--c); }
.cat-count{ margin-left:auto; font-variant-numeric:tabular-nums; color:var(--c); }

/* ---------- kort-grid ---------- */
.grid{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(auto-fill,minmax(264px,1fr)); gap:clamp(.9rem,1.8vw,1.4rem); }
.card{
  --c:var(--c);
  position:relative; display:flex; flex-direction:column; height:100%;
  min-height:clamp(150px,17vw,182px); padding:clamp(1.3rem,2.3vw,1.7rem);
  border:1px solid var(--line); border-radius:var(--radius);
  background:
    radial-gradient(420px circle at 84% -10%, color-mix(in srgb, var(--c) 10%, transparent), transparent 56%),
    linear-gradient(180deg, var(--surface) 0%, var(--bg-2) 100%);
  overflow:hidden; isolation:isolate;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), border-color .3s ease, box-shadow .3s ease;
  animation:card-in .65s cubic-bezier(.2,.7,.2,1) both; animation-delay:calc(var(--i,0) * 40ms);
}
.card::before{ content:""; position:absolute; left:0; right:0; top:0; height:2px; background:linear-gradient(90deg,transparent,var(--c),transparent); opacity:.55; transition:opacity .3s ease; }
.card::after{ content:""; position:absolute; inset:0; border-radius:var(--radius); box-shadow:inset 0 0 0 1px transparent; pointer-events:none; transition:box-shadow .3s ease; }
.card:hover,.card:focus-visible{ transform:translateY(-5px); border-color:var(--line-strong); box-shadow:0 26px 50px -28px rgba(40,30,15,0.45), 0 3px 10px -8px rgba(40,30,15,0.35); }
.card:hover::before{ opacity:1; }
.card:hover::after{ box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--c) 38%, transparent); }
.card-lang{ position:absolute; top:clamp(1.1rem,2vw,1.45rem); right:clamp(1.2rem,2.2vw,1.6rem); font-family:var(--sans); font-size:.62rem; font-weight:600; letter-spacing:.14em; color:var(--c); border:1px solid color-mix(in srgb,var(--c) 32%,transparent); border-radius:999px; padding:.12rem .46rem; opacity:.85; }
.card-title{ position:relative; z-index:2; margin:.2rem 3rem 0 0; font-family:var(--display); font-weight:540; font-size:clamp(1.32rem,2.4vw,1.7rem); line-height:1.12; letter-spacing:-0.012em; text-wrap:balance; }
.card-by{ position:relative; z-index:2; margin:.55rem 0 0; font-family:var(--serif); font-style:italic; font-size:.92rem; color:var(--ink-soft); }
.card-foot{ position:relative; z-index:2; margin-top:auto; padding-top:1.2rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.card-go{ font-family:var(--sans); font-size:.76rem; letter-spacing:.02em; color:var(--ink-faint); transition:color .3s ease; }
.card:hover .card-go{ color:var(--ink-soft); }
.card-arrow{ width:32px; height:32px; flex:none; border-radius:50%; display:grid; place-items:center; border:1px solid var(--line-strong); color:var(--ink-soft); transition:transform .3s cubic-bezier(.2,.7,.2,1), border-color .3s ease, color .3s ease, background .3s ease; }
.card-arrow svg{ width:15px; height:15px; }
.card:hover .card-arrow{ color:#fffdf8; background:var(--c); border-color:var(--c); transform:translate(2px,-2px); }

/* ---------- galleri-footer ---------- */
.site-foot{ max-width:var(--maxw); margin:clamp(3rem,7vw,4.5rem) auto 0; padding:clamp(1.75rem,4vw,2.5rem) clamp(1.25rem,4vw,2.5rem) clamp(2.5rem,5vw,3.5rem); border-top:1px solid var(--line); text-align:center; }
.source-note{ font-family:var(--serif); font-style:italic; color:var(--ink-soft); margin:0 auto .8rem; max-width:52ch; }
.colophon{ font-family:var(--sans); font-size:.78rem; color:var(--ink-faint); letter-spacing:.02em; margin:0; }
.colophon a{ color:var(--ink-faint); border-bottom:1px solid var(--line); }
.colophon a:hover{ color:var(--gold); }

/* ---------- digtside (læse-layout) ---------- */
.reading{ max-width:46rem; margin:0 auto; padding:clamp(1.5rem,5vw,3rem) clamp(1.25rem,5vw,2rem) clamp(2.5rem,6vw,4rem); }
.back{ display:inline-flex; align-items:center; gap:.5rem; margin-bottom:clamp(1.75rem,5vw,2.75rem); transition:color .2s ease; }
.back:hover{ color:var(--gold); }
.poem{ }
.poem-cat{ display:inline-flex; align-items:center; gap:.55rem; font-family:var(--sans); font-size:.7rem; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 1rem; }
.poem-cat .dot{ width:7px; height:7px; border-radius:50%; background:var(--c); }
.poem-title{ font-family:var(--display); font-weight:560; font-size:clamp(2rem,5.4vw,3rem); line-height:1.08; letter-spacing:-0.018em; margin:0 0 clamp(1.5rem,4vw,2.25rem); text-wrap:balance; }
.verse{
  font-family:var(--serif); font-size:clamp(1.06rem,1.6vw,1.18rem); line-height:1.72;
  color:var(--ink); white-space:pre-wrap; word-wrap:break-word;
  hanging-punctuation:first;
  padding:clamp(1.4rem,3.5vw,2.2rem) clamp(1.25rem,3.5vw,2.1rem);
  background:linear-gradient(180deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 70%, var(--bg)) 100%);
  border:1px solid var(--line); border-left:3px solid var(--c); border-radius:14px;
  box-shadow:0 22px 48px -30px rgba(40,30,15,0.35);
}

/* ---------- pager ---------- */
.pager{ display:grid; grid-template-columns:1fr 1fr; gap:.9rem; margin:clamp(2rem,5vw,3rem) 0 0; }
.pager-link{ display:flex; align-items:center; gap:.7rem; padding:1rem 1.15rem; border:1px solid var(--line); border-radius:14px; background:var(--surface); transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease; min-width:0; }
.pager-link.prev{ justify-content:flex-start; }
.pager-link.next{ justify-content:flex-end; text-align:right; }
.pager-link:hover{ transform:translateY(-2px); border-color:var(--line-strong); box-shadow:0 16px 34px -24px rgba(40,30,15,0.4); }
.pager-link.is-disabled{ visibility:hidden; }
.pager-dir{ color:var(--ink-faint); flex:none; }
.pager-link:hover .pager-dir{ color:var(--gold); }
.pager-txt{ display:flex; flex-direction:column; min-width:0; }
.pager-lbl{ font-family:var(--sans); font-size:.66rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-faint); }
.pager-name{ font-family:var(--display); font-size:1.02rem; line-height:1.2; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ---------- digtside-footer ---------- */
.reading-foot{ margin-top:clamp(2.5rem,6vw,3.5rem); padding-top:1.6rem; border-top:1px solid var(--line); text-align:center; display:flex; flex-direction:column; gap:.9rem; }
.foot-home{ font-family:var(--sans); font-size:.84rem; font-weight:600; letter-spacing:.04em; color:var(--ink-soft); display:inline-block; }
.foot-home:hover{ color:var(--gold); }

/* ---------- animationer ---------- */
.reveal{ animation:fade-up .7s cubic-bezier(.2,.7,.2,1) both; }
@keyframes fade-up{ from{ opacity:0; transform:translateY(14px);} to{ opacity:1; transform:none;} }
@keyframes card-in{ from{ opacity:0; transform:translateY(18px);} to{ opacity:1; transform:none;} }
@media (prefers-reduced-motion:reduce){ .reveal,.card{ animation:none; } .card,.card-arrow,.pager-link{ transition:none; } }

/* ---------- responsivt ---------- */
@media (max-width:560px){
  .grid{ grid-template-columns:1fr; }
  .pager{ grid-template-columns:1fr; }
  .pager-link.next{ justify-content:flex-start; text-align:left; flex-direction:row-reverse; }
}
