/* ==============================================================
   opslag-v2.css — V2 MOCKUP STYLES (2026-06-07)
   --------------------------------------------------------------
   Ported TRO from the design-handoff "Bygpas Opslag.html". This file
   owns the COMPLETE visible opslag structure: result-header, glance
   band, "Det du bør bemærke" highlights, 6 foldable dimension cards
   with data-visualisations, datakilder grid, afkrydsbar tjekliste,
   and the dark upsell.

   Scope: ALL selectors are `body.v2 .v2o-*` (or `.opslag-v2`-nested),
   so the ~195 legacy pages are untouched. Tokens reuse editorial
   :root (--paper, --paper-2, --paper-3, --ink-*, --line*, --accent*,
   --ok/--warn/--risk + -soft, --f-*, --radius-ed-*).

   Posture (docs/legal/2026-06-06-redesign-v2-posture-decision.md):
   cat-colors (ok/warn/risk → grøn/gul/rød) + curated highlights are
   DELIBERATELY colored. The high band reads "Høj", never "God".
   ============================================================== */

/* Local radius aliases mapped onto editorial tokens. */
body.v2 .opslag-v2 {
  --vr: var(--radius-ed);
  --vr-sm: var(--radius-ed-sm);
  --vr-lg: var(--radius-ed-lg);
}

/* ---------- Layout container ---------- */
body.v2 .opslag-v2 .wrap { max-width: 1100px; margin: 0 auto; padding-inline: clamp(20px, 5vw, 56px); }
body.v2 .opslag-v2 .tnum { font-variant-numeric: tabular-nums; }

/* Scroll-reveal */
body.v2 .opslag-v2 .v2-rv { opacity: 0; transform: translateY(16px); transition: opacity .6s cubic-bezier(.22,.61,.36,1), transform .6s cubic-bezier(.22,.61,.36,1); }
body.v2 .opslag-v2 .v2-rv.in { opacity: 1; transform: none; }
body.v2 .opslag-v2 .v2-rv.shown { opacity: 1 !important; transform: none !important; transition: none !important; }
@media (prefers-reduced-motion: reduce) { body.v2 .opslag-v2 .v2-rv { opacity: 1 !important; transform: none !important; transition: none; } }

/* Eyebrow (mono rule) */
body.v2 .opslag-v2 .eyebrow {
  font-family: var(--f-mono); font-size: 11px; text-transform: uppercase;
  letter-spacing: .14em; font-weight: 600; color: var(--accent-2);
  display: inline-flex; align-items: center; gap: 10px; white-space: nowrap;
}
body.v2 .opslag-v2 .eyebrow::before { content: ''; width: 24px; height: 1px; background: currentColor; opacity: .6; }

/* ============================================================
   COMPACT IN-NAV SEARCH PILL (mockup .nav-search, CSS 47-55)
   Scoped to body.v2 .nav so only the opslag (v2) nav grows the pill;
   the shared editorial nav on ~195 legacy pages is untouched.
   ============================================================ */
body.v2 .nav .nav-inner { gap: 20px; }
body.v2 .nav .nav-search {
  flex: 1; max-width: 420px; display: flex; align-items: center; gap: 9px;
  background: var(--paper); border: 1px solid var(--line); border-radius: 99px;
  padding: 8px 8px 8px 16px;
}
body.v2 .nav .nav-search svg { color: var(--ink-3); flex-shrink: 0; }
body.v2 .nav .nav-search input {
  flex: 1; border: 0; background: transparent; font-family: var(--f-sans);
  font-size: 14px; color: var(--ink-1); outline: none; min-width: 0;
}
body.v2 .nav .nav-search button {
  background: var(--ink-1); color: var(--paper); border: 0; padding: 8px 14px;
  border-radius: 99px; font-size: 13px; font-weight: 500; white-space: nowrap;
}
@media (max-width: 820px) { body.v2 .nav .nav-search { display: none; } }

/* ============================================================
   1 / RESULT HEADER (.v2o-rhead)
   ============================================================ */
body.v2 .opslag-v2 .v2o-crumb { padding: 18px 0 0; }
body.v2 .opslag-v2 .v2o-crumb .wrap { display: flex; align-items: center; gap: 8px; font-size: 13.5px; color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-crumb a { color: var(--ink-2); font-weight: 500; }
body.v2 .opslag-v2 .v2o-crumb a:hover { color: var(--accent-2); }
body.v2 .opslag-v2 .v2o-crumb [aria-current] { color: var(--ink-3); }

body.v2 .opslag-v2 .v2o-rhead { padding: clamp(26px,4vw,44px) 0 clamp(22px,3vw,32px); border-bottom: 1px solid var(--line); position: relative; overflow: hidden; }
body.v2 .opslag-v2 .v2o-rhead__bg {
  position: absolute; inset: 0; pointer-events: none; opacity: .4;
  background-image: linear-gradient(var(--line-soft) 1px, transparent 1px), linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size: 64px 64px;
  -webkit-mask-image: radial-gradient(ellipse 60% 90% at 80% 10%, #000, transparent 70%);
  mask-image: radial-gradient(ellipse 60% 90% at 80% 10%, #000, transparent 70%);
}
body.v2 .opslag-v2 .v2o-rhead .wrap { position: relative; }
body.v2 .opslag-v2 .v2o-rhead__main { display: grid; grid-template-columns: 1fr auto; gap: 30px; align-items: start; }
body.v2 .opslag-v2 .v2o-rhead__lead { min-width: 0; }

body.v2 .opslag-v2 .v2o-co-head { display: flex; align-items: flex-start; gap: 18px; }
body.v2 .opslag-v2 .v2o-co-mono {
  width: 62px; height: 62px; border-radius: 15px; flex-shrink: 0;
  background: linear-gradient(150deg, var(--accent), var(--accent-2)); color: #fff;
  display: grid; place-items: center; font-family: var(--f-display); font-style: italic; font-size: 33px;
  box-shadow: 0 14px 30px -16px rgba(61,81,40,.7);
}
body.v2 .opslag-v2 .v2o-co-meta {
  font-family: var(--f-mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent-2); margin: 0 0 10px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
body.v2 .opslag-v2 .v2o-co-name {
  font-family: var(--f-display); font-weight: 400; font-size: clamp(36px,5.2vw,64px);
  line-height: 1.02; letter-spacing: -.025em; margin: 0;
}
body.v2 .opslag-v2 .v2o-co-name em { font-style: italic; color: var(--accent-2); }

body.v2 .opslag-v2 .v2o-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
body.v2 .opslag-v2 .v2o-chip {
  font-size: 12.5px; font-weight: 500; padding: 6px 13px; border-radius: 99px;
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--paper); border: 1px solid var(--line); color: var(--ink-2);
}
body.v2 .opslag-v2 .v2o-chip b { width: 6px; height: 6px; border-radius: 99px; flex-shrink: 0; background: var(--line-hard); }
body.v2 .opslag-v2 .v2o-chip.live b { background: var(--accent); }
body.v2 .opslag-v2 .v2o-chip.ok { background: var(--ok-soft); border-color: transparent; color: #33491f; }
body.v2 .opslag-v2 .v2o-chip.ok b { background: #33491f; }

/* .v2o-rhead__meta (stamdata key/value grid) removed 2026-06-08 — the mockup
   header is chips-only; CVR/founded/branche live inline in the eyebrow + chips. */

body.v2 .opslag-v2 .v2o-rhead__actions { display: flex; flex-direction: column; gap: 10px; align-items: stretch; min-width: 210px; }
body.v2 .opslag-v2 .v2o-act-primary {
  background: var(--accent-2); color: var(--paper); border: 0; padding: 14px 18px; border-radius: var(--vr-sm);
  font-size: 14.5px; font-weight: 500; display: flex; align-items: center; justify-content: center; gap: 9px;
  transition: background .15s;
}
body.v2 .opslag-v2 .v2o-act-primary:hover { background: var(--ink-1); }
body.v2 .opslag-v2 .v2o-act-row { display: flex; gap: 10px; }
body.v2 .opslag-v2 .v2o-act-ghost {
  flex: 1; background: var(--paper); border: 1px solid var(--line-hard); padding: 11px; border-radius: var(--vr-sm);
  font-size: 13px; color: var(--ink-2); display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: background .15s;
}
body.v2 .opslag-v2 .v2o-act-ghost:hover { background: var(--paper-2); }
/* Funnel-friktion #3: Gem/Del sit side by side as the primary row; the 49 kr
   rapport is a quiet link beneath them (demoted out of the primary slot). */
body.v2 .opslag-v2 .v2o-act-half { flex: 1; }
body.v2 .opslag-v2 .v2o-act-link {
  display: block; margin-top: 2px; padding: 4px 0; text-align: center;
  font-size: 13px; color: var(--accent-2); text-decoration: underline; text-underline-offset: 2px;
  transition: color .15s;
}
body.v2 .opslag-v2 .v2o-act-link:hover { color: var(--ink-1); }
/* Offset the upsell scroll-target below the sticky nav (header link anchors here). */
body.v2 .opslag-v2 #opslag-upsell-h { scroll-margin-top: 90px; }

/* Funnel-friktion #3b: låst-preview teaser-kort for rapportens format/syntese
   (grafer, PDF, chat). Flad — opacity + stiplet kant, INGEN filter:blur. */
body.v2 .opslag-v2 .v2o-locked-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
body.v2 .opslag-v2 .v2o-locked {
  text-align: left; background: var(--paper-2); border: 1px dashed var(--line-hard); border-radius: var(--vr);
  padding: 18px; display: flex; flex-direction: column; gap: 5px; opacity: .92; cursor: pointer;
  transition: opacity .15s, border-color .15s;
}
body.v2 .opslag-v2 .v2o-locked:hover { opacity: 1; border-color: var(--accent); }
body.v2 .opslag-v2 .v2o-locked__lock { color: var(--ink-3); display: inline-flex; }
body.v2 .opslag-v2 .v2o-locked__title { font-family: var(--f-display); font-size: 18px; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-locked__sub { font-size: 13px; color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-locked__cta { font-family: var(--f-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--accent-2); margin-top: 4px; }
@media (max-width: 760px) { body.v2 .opslag-v2 .v2o-locked-row { grid-template-columns: 1fr; } }

@media (max-width: 760px) {
  body.v2 .opslag-v2 .v2o-rhead__main { grid-template-columns: 1fr; }
  body.v2 .opslag-v2 .v2o-rhead__actions { min-width: 0; }
}
@media (max-width: 560px) {
  body.v2 .opslag-v2 .v2o-co-mono { width: 50px; height: 50px; font-size: 27px; border-radius: 13px; }
}

/* ============================================================
   2 / GLANCE band (.v2o-glance)
   ============================================================ */
body.v2 .opslag-v2 .v2o-glance { background: var(--paper-2); border-bottom: 1px solid var(--line); padding: 24px 0 28px; }
body.v2 .opslag-v2 .v2o-glance__lead {
  font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .13em; text-transform: uppercase;
  color: var(--ink-3); margin: 0 0 15px; display: flex; align-items: center; gap: 10px;
}
body.v2 .opslag-v2 .v2o-glance__lead::before { content: ''; width: 22px; height: 1px; background: currentColor; opacity: .5; }
body.v2 .opslag-v2 .v2o-glance__row { display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px; }
body.v2 .opslag-v2 .v2o-gt {
  background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 14px 15px 16px;
  text-align: left; cursor: pointer; transition: transform .15s, box-shadow .15s, border-color .15s;
  display: flex; flex-direction: column; gap: 12px; font-family: inherit;
}
body.v2 .opslag-v2 .v2o-gt:hover { transform: translateY(-3px); box-shadow: 0 16px 30px -22px rgba(30,26,22,.5); border-color: var(--line-hard); }
body.v2 .opslag-v2 .v2o-gt:focus-visible { outline: 2px solid var(--accent-2); outline-offset: 2px; }
body.v2 .opslag-v2 .v2o-gt__top { display: flex; align-items: center; justify-content: space-between; }
body.v2 .opslag-v2 .v2o-gt__ic { width: 30px; height: 30px; border-radius: 8px; background: var(--accent-tint); color: var(--accent-2); display: grid; place-items: center; }
body.v2 .opslag-v2 .v2o-gt__dot { width: 10px; height: 10px; border-radius: 99px; }
body.v2 .opslag-v2 .v2o-gt__dot.ok { background: var(--ok); }
body.v2 .opslag-v2 .v2o-gt__dot.mid { background: var(--warn); }
body.v2 .opslag-v2 .v2o-gt__dot.low { background: var(--risk); }
body.v2 .opslag-v2 .v2o-gt__dot.neu { background: var(--line-hard); }
body.v2 .opslag-v2 .v2o-gt__name { font-size: 12.5px; font-weight: 600; line-height: 1.25; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-gt__cat { font-family: var(--f-mono); font-size: 9.5px; letter-spacing: .05em; text-transform: uppercase; font-weight: 600; }
body.v2 .opslag-v2 .v2o-gt__cat.ok { color: var(--accent-2); }
body.v2 .opslag-v2 .v2o-gt__cat.mid { color: var(--warn); }
body.v2 .opslag-v2 .v2o-gt__cat.low { color: var(--risk); }
body.v2 .opslag-v2 .v2o-gt__cat.neu { color: var(--ink-3); }
@media (max-width: 860px) { body.v2 .opslag-v2 .v2o-glance__row { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 520px) { body.v2 .opslag-v2 .v2o-glance__row { grid-template-columns: repeat(2, 1fr); } }

/* ============================================================
   Generic section (.v2o-sec / .v2o-sunken)
   ============================================================ */
body.v2 .opslag-v2 .v2o-sec { padding: clamp(40px,5vw,68px) 0; border-bottom: 1px solid var(--line); }
body.v2 .opslag-v2 .v2o-sec.v2o-sunken { background: var(--paper-2); }
body.v2 .opslag-v2 .v2o-sec-lead { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 28px; flex-wrap: wrap; }
body.v2 .opslag-v2 .v2o-sec-lead h2 { font-family: var(--f-display); font-weight: 400; font-size: clamp(26px,3.4vw,40px); line-height: 1.05; letter-spacing: -.02em; margin: 14px 0 0; }
body.v2 .opslag-v2 .v2o-sec-lead h2 em { font-style: italic; color: var(--accent-2); }
body.v2 .opslag-v2 .v2o-sec-note { font-size: 13px; color: var(--ink-3); max-width: 34ch; text-align: right; margin: 0; }
@media (max-width: 600px) { body.v2 .opslag-v2 .v2o-sec-note { text-align: left; } }

/* ============================================================
   3 / "Det du bør bemærke" indicators (.v2o-ind)
   ============================================================ */
body.v2 .opslag-v2 .v2o-ind-list { display: grid; gap: 12px; }
body.v2 .opslag-v2 .v2o-ind-list.two { grid-template-columns: 1fr 1fr; }
@media (max-width: 680px) { body.v2 .opslag-v2 .v2o-ind-list.two { grid-template-columns: 1fr; } }
body.v2 .opslag-v2 .v2o-ind {
  display: flex; gap: 14px; align-items: flex-start;
  background: var(--paper); border: 1px solid var(--line); border-left-width: 3px; border-radius: var(--vr); padding: 16px 18px;
}
body.v2 .opslag-v2 .v2o-ind.ok { border-left-color: var(--ok); }
body.v2 .opslag-v2 .v2o-ind.warn { border-left-color: var(--warn); }
body.v2 .opslag-v2 .v2o-ind.risk { border-left-color: var(--risk); }
body.v2 .opslag-v2 .v2o-ind.neutral { border-left-color: var(--line-hard); }
body.v2 .opslag-v2 .v2o-ind__ic { width: 26px; height: 26px; border-radius: 7px; display: grid; place-items: center; font-size: 14px; font-weight: 700; flex-shrink: 0; }
body.v2 .opslag-v2 .v2o-ind.ok .v2o-ind__ic { background: var(--ok-soft); color: #33491f; }
body.v2 .opslag-v2 .v2o-ind.warn .v2o-ind__ic { background: var(--warn-soft); color: #6e4d15; }
body.v2 .opslag-v2 .v2o-ind.risk .v2o-ind__ic { background: var(--risk-soft); color: #7d2a20; }
body.v2 .opslag-v2 .v2o-ind.neutral .v2o-ind__ic { background: var(--paper-3); color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-ind__body strong { display: block; font-size: 14.5px; font-weight: 600; margin-bottom: 3px; }
body.v2 .opslag-v2 .v2o-ind__body span { font-size: 13px; color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-ind__body a { color: var(--accent-2); text-decoration: underline; text-underline-offset: 2px; }

/* ============================================================
   4 / DIMENSIONS (.v2o-dim — foldable)
   ============================================================ */
body.v2 .opslag-v2 .v2o-dims { display: grid; gap: 12px; }
body.v2 .opslag-v2 .v2o-dim { background: var(--paper); border: 1px solid var(--line); border-radius: var(--vr); overflow: hidden; transition: box-shadow .2s; }
body.v2 .opslag-v2 .v2o-dim.open { box-shadow: 0 18px 40px -32px rgba(30,26,22,.5); }
body.v2 .opslag-v2 .v2o-dim__h {
  display: grid; grid-template-columns: 42px 1fr auto auto; gap: 18px; align-items: center;
  padding: 20px 22px; cursor: pointer; width: 100%; background: none; border: 0; text-align: left;
}
body.v2 .opslag-v2 .v2o-dim__h:focus-visible { outline: 2px solid var(--accent-2); outline-offset: -2px; }
body.v2 .opslag-v2 .v2o-dim__n { font-family: var(--f-mono); font-size: 12px; color: var(--accent-2); }
body.v2 .opslag-v2 .v2o-dim__t { font-family: var(--f-serif); font-size: 18.5px; font-weight: 600; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-dim__t small { display: block; font-family: var(--f-sans); font-size: 12.5px; font-weight: 400; color: var(--ink-3); margin-top: 2px; }
body.v2 .opslag-v2 .v2o-dim__cat { font-family: var(--f-mono); font-size: 11px; letter-spacing: .04em; text-transform: uppercase; padding: 6px 12px; border-radius: 99px; white-space: nowrap; }
body.v2 .opslag-v2 .v2o-cat-ok { background: var(--ok-soft); color: #33491f; }
body.v2 .opslag-v2 .v2o-cat-mid { background: var(--warn-soft); color: #6e4d15; }
body.v2 .opslag-v2 .v2o-cat-low { background: var(--risk-soft); color: #7d2a20; }
body.v2 .opslag-v2 .v2o-cat-neu { background: var(--paper-3); color: var(--ink-2); }
body.v2 .opslag-v2 .v2o-dim__chev { width: 26px; height: 26px; display: grid; place-items: center; color: var(--ink-3); transition: transform .25s; }
body.v2 .opslag-v2 .v2o-dim.open .v2o-dim__chev { transform: rotate(180deg); }
body.v2 .opslag-v2 .v2o-dim__body { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
body.v2 .opslag-v2 .v2o-dim.open .v2o-dim__body { max-height: 720px; }
body.v2 .opslag-v2 .v2o-dim__inner { padding: 4px 22px 24px; border-top: 1px solid var(--line-soft); }
body.v2 .opslag-v2 .v2o-dim__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-soft);
  border: 1px solid var(--line-soft); border-radius: var(--vr-sm); overflow: hidden; margin: 18px 0 16px;
}
body.v2 .opslag-v2 .v2o-kpi { background: var(--paper); padding: 16px; }
body.v2 .opslag-v2 .v2o-kpi__l { font-size: 11.5px; color: var(--ink-3); margin-bottom: 7px; text-transform: uppercase; letter-spacing: .05em; font-family: var(--f-mono); }
body.v2 .opslag-v2 .v2o-kpi__v { font-family: var(--f-display); font-size: 26px; line-height: 1; letter-spacing: -.01em; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-kpi__v span { font-size: 13px; color: var(--ink-3); font-family: var(--f-sans); }
body.v2 .opslag-v2 .v2o-dim__note { font-family: var(--f-serif); font-size: 14.5px; color: var(--ink-2); line-height: 1.55; margin: 0 0 16px; }
body.v2 .opslag-v2 .v2o-dim__src {
  display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--accent-2); font-weight: 500;
  padding: 8px 14px; border: 1px solid var(--accent-soft); border-radius: 99px; background: var(--accent-tint);
}
body.v2 .opslag-v2 .v2o-dim__src-ico { display: inline-flex; }
@media (max-width: 680px) {
  body.v2 .opslag-v2 .v2o-dim__h { grid-template-columns: 32px 1fr auto; gap: 12px; }
  body.v2 .opslag-v2 .v2o-dim__chev { display: none; }
  body.v2 .opslag-v2 .v2o-dim__grid { grid-template-columns: 1fr; }
}

/* ---------- dataviz ---------- */
body.v2 .opslag-v2 .v2o-dim__viz { margin: 18px 0 6px; }
body.v2 .opslag-v2 .v2o-viz-2 { display: grid; grid-template-columns: 1.5fr 1fr; gap: 28px; align-items: center; }
@media (max-width: 600px) { body.v2 .opslag-v2 .v2o-viz-2 { grid-template-columns: 1fr; gap: 22px; } }
body.v2 .opslag-v2 .v2o-chart { width: 100%; height: auto; display: block; overflow: visible; }
body.v2 .opslag-v2 .v2o-chart__cap { font-size: 12.5px; color: var(--ink-3); margin-top: 14px; line-height: 1.5; }
body.v2 .opslag-v2 .v2o-eco-single { display: flex; flex-direction: column; gap: 6px; }
body.v2 .opslag-v2 .v2o-eco-single b { font-family: var(--f-display); font-size: 38px; line-height: 1; letter-spacing: -.01em; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-eco-single span { font-size: 12.5px; color: var(--ink-3); }

body.v2 .opslag-v2 .v2o-solbar { display: flex; flex-direction: column; gap: 13px; }
body.v2 .opslag-v2 .v2o-solbar__head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
body.v2 .opslag-v2 .v2o-solbar__head b { font-family: var(--f-display); font-size: 33px; line-height: 1; letter-spacing: -.01em; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-solbar__band { font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .06em; white-space: nowrap; }
body.v2 .opslag-v2 .v2o-solbar__band.ok { color: var(--accent-2); }
body.v2 .opslag-v2 .v2o-solbar__band.mid { color: var(--warn); }
body.v2 .opslag-v2 .v2o-solbar__band.low { color: var(--risk); }
body.v2 .opslag-v2 .v2o-solbar__band.neu { color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-solbar__track { position: relative; display: flex; height: 12px; gap: 2px; }
body.v2 .opslag-v2 .v2o-seg { display: block; border-radius: 3px; }
body.v2 .opslag-v2 .v2o-seg.low { background: var(--risk-soft); }
body.v2 .opslag-v2 .v2o-seg.mid { background: var(--warn-soft); }
body.v2 .opslag-v2 .v2o-seg.ok { background: var(--ok-soft); }
body.v2 .opslag-v2 .v2o-solbar__marker { position: absolute; top: -5px; bottom: -5px; width: 3px; border-radius: 99px; background: var(--ink-1); transform: translateX(-50%); box-shadow: 0 0 0 3px var(--paper); }
body.v2 .opslag-v2 .v2o-solbar__x { display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-3); }

body.v2 .opslag-v2 .v2o-auth-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
@media (max-width: 520px) { body.v2 .opslag-v2 .v2o-auth-grid { grid-template-columns: 1fr; } }
body.v2 .opslag-v2 .v2o-auth { display: flex; align-items: center; gap: 11px; padding: 13px 15px; border: 1px solid var(--line); border-radius: 10px; background: var(--paper); }
body.v2 .opslag-v2 .v2o-ab { width: 25px; height: 25px; border-radius: 7px; display: grid; place-items: center; font-size: 12px; font-weight: 700; flex-shrink: 0; }
body.v2 .opslag-v2 .v2o-auth.no .v2o-ab { background: var(--risk-soft); color: var(--risk); }
body.v2 .opslag-v2 .v2o-auth.yes .v2o-ab { background: var(--ok-soft); color: var(--accent-2); }
body.v2 .opslag-v2 .v2o-at { font-size: 14px; font-weight: 500; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-at small { display: block; font-family: var(--f-mono); font-size: 10px; color: var(--ink-3); font-weight: 400; margin-top: 1px; }

body.v2 .opslag-v2 .v2o-frate { display: grid; gap: 17px; }
body.v2 .opslag-v2 .v2o-frate-row { display: grid; grid-template-columns: 150px 1fr 46px; gap: 16px; align-items: center; }
body.v2 .opslag-v2 .v2o-fn { font-size: 13.5px; font-weight: 500; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-fn small { display: block; font-family: var(--f-mono); font-size: 10.5px; color: var(--ink-3); font-weight: 400; margin-top: 2px; }
body.v2 .opslag-v2 .v2o-fstars { position: relative; display: inline-block; justify-self: start; font-size: 18px; line-height: 1; letter-spacing: 4px; font-family: Arial, sans-serif; }
body.v2 .opslag-v2 .v2o-fstars .bg { color: var(--line-hard); }
body.v2 .opslag-v2 .v2o-fstars .fg { position: absolute; top: 0; left: 0; color: var(--warn); overflow: hidden; white-space: nowrap; }
body.v2 .opslag-v2 .v2o-fv { font-family: var(--f-display); font-size: 22px; text-align: right; color: var(--ink-1); }
@media (max-width: 520px) {
  body.v2 .opslag-v2 .v2o-frate-row { grid-template-columns: 1fr auto; }
  body.v2 .opslag-v2 .v2o-fstars { display: none; }
}

/* ============================================================
   5 / DATAKILDER (.v2o-src-grid)
   ============================================================ */
body.v2 .opslag-v2 .v2o-src-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (max-width: 680px) { body.v2 .opslag-v2 .v2o-src-grid { grid-template-columns: 1fr; } }
body.v2 .opslag-v2 .v2o-srcc { display: flex; align-items: center; gap: 14px; background: var(--paper); border: 1px solid var(--line); border-radius: var(--vr); padding: 15px 18px; transition: background .15s; }
body.v2 .opslag-v2 .v2o-srcc:hover { background: var(--paper-2); }
body.v2 .opslag-v2 .v2o-srcc__dot { width: 9px; height: 9px; border-radius: 99px; background: var(--accent); flex-shrink: 0; }
body.v2 .opslag-v2 .v2o-srcc__dot.empty { background: var(--line-hard); }
body.v2 .opslag-v2 .v2o-srcc__name { flex: 1; font-size: 14.5px; font-weight: 500; color: var(--ink-1); }
body.v2 .opslag-v2 .v2o-srcc__name small { display: block; font-family: var(--f-mono); font-size: 11px; font-weight: 400; color: var(--ink-3); margin-top: 2px; }
body.v2 .opslag-v2 .v2o-srcc__link { font-size: 12.5px; color: var(--accent-2); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
body.v2 .opslag-v2 .v2o-srcc__arrow { display: inline-flex; }

/* ============================================================
   6 / TJEKLISTE (.v2o-checklist)
   ============================================================ */
body.v2 .opslag-v2 .v2o-checklist { display: grid; gap: 12px; }
body.v2 .opslag-v2 .v2o-ck { display: flex; gap: 14px; align-items: flex-start; background: var(--paper); border: 1px solid var(--line); border-radius: var(--vr); padding: 17px 20px; }
body.v2 .opslag-v2 .v2o-ck__box { width: 22px; height: 22px; border-radius: 6px; border: 2px solid var(--line-hard); flex-shrink: 0; margin-top: 1px; display: grid; place-items: center; color: transparent; transition: all .15s; cursor: pointer; font-size: 12px; }
body.v2 .opslag-v2 .v2o-ck__box:focus-visible { outline: 2px solid var(--accent-2); outline-offset: 2px; }
body.v2 .opslag-v2 .v2o-ck.done .v2o-ck__box { background: var(--accent); border-color: var(--accent); color: #fff; }
body.v2 .opslag-v2 .v2o-ck__body strong { display: block; font-size: 15px; font-weight: 600; color: var(--ink-1); margin-bottom: 3px; }
body.v2 .opslag-v2 .v2o-ck.done .v2o-ck__body strong { text-decoration: line-through; color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-ck__body span { font-size: 13.5px; color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-ck__tag { margin-left: auto; font-family: var(--f-mono); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: var(--accent-2); background: var(--accent-tint); padding: 4px 9px; border-radius: 99px; white-space: nowrap; align-self: center; }

/* ============================================================
   7 / UPSELL (.v2o-upsell — dark) + disclaimer
   ============================================================ */
body.v2 .opslag-v2 .v2o-upsell {
  background: var(--ink-1); color: #ece7da; border-radius: var(--vr-lg); padding: clamp(30px,4vw,48px);
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 36px; align-items: center; position: relative; overflow: hidden;
}
body.v2 .opslag-v2 .v2o-upsell__bg {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 54px 54px;
  -webkit-mask-image: radial-gradient(ellipse 70% 90% at 90% 10%, #000, transparent 70%);
  mask-image: radial-gradient(ellipse 70% 90% at 90% 10%, #000, transparent 70%);
}
body.v2 .opslag-v2 .v2o-upsell > *:not(.v2o-upsell__bg) { position: relative; }
body.v2 .opslag-v2 .v2o-upsell__ey { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: .13em; text-transform: uppercase; color: var(--accent-soft); margin-bottom: 16px; }
body.v2 .opslag-v2 .v2o-upsell__title { font-family: var(--f-display); font-weight: 400; font-size: clamp(28px,3.6vw,42px); line-height: 1.05; letter-spacing: -.01em; color: #f4efe2; margin: 0 0 14px; }
body.v2 .opslag-v2 .v2o-upsell__title em { font-style: italic; color: var(--accent-soft); }
body.v2 .opslag-v2 .v2o-upsell__text { font-family: var(--f-serif); font-size: 15.5px; color: #c7c0b0; margin: 0 0 24px; max-width: 40ch; }
body.v2 .opslag-v2 .v2o-upsell__list { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
body.v2 .opslag-v2 .v2o-upsell__list li { display: flex; gap: 12px; font-size: 14.5px; color: #e3ddcf; align-items: flex-start; }
body.v2 .opslag-v2 .v2o-upsell__list li b { color: var(--accent-soft); flex-shrink: 0; }
body.v2 .opslag-v2 .v2o-upsell__buy { background: var(--paper); border-radius: var(--vr); padding: 26px; text-align: center; }
body.v2 .opslag-v2 .v2o-upsell__pr { font-family: var(--f-display); font-size: 54px; line-height: 1; color: var(--ink-1); letter-spacing: -.02em; }
body.v2 .opslag-v2 .v2o-upsell__pr small { font-size: 17px; color: var(--ink-3); }
body.v2 .opslag-v2 .v2o-upsell__sub { font-size: 13px; color: var(--ink-3); margin: 6px 0 20px; }
body.v2 .opslag-v2 .v2o-upsell__btn { width: 100%; background: var(--accent-2); color: var(--paper); border: 0; padding: 15px; border-radius: var(--vr-sm); font-size: 15px; font-weight: 500; display: flex; align-items: center; justify-content: center; gap: 9px; transition: background .15s; }
body.v2 .opslag-v2 .v2o-upsell__btn:hover { background: var(--ink-1); }
body.v2 .opslag-v2 .v2o-upsell__fine { font-size: 11.5px; color: var(--ink-4); margin-top: 12px; }
@media (max-width: 760px) { body.v2 .opslag-v2 .v2o-upsell { grid-template-columns: 1fr; gap: 26px; } }

body.v2 .opslag-v2 .v2o-disc { padding: 30px 0 0; }
body.v2 .opslag-v2 .v2o-disc p { font-size: 12.5px; color: var(--ink-3); line-height: 1.6; max-width: 78ch; margin: 0 auto; text-align: center; }
body.v2 .opslag-v2 .v2o-disc strong { color: var(--ink-2); }
body.v2 .opslag-v2 .v2o-disc a { color: var(--accent-2); text-decoration: underline; text-underline-offset: 2px; }
body.v2 .opslag-v2 .v2o-disc__mono { font-family: var(--f-mono); font-size: 10.5px; margin-top: 12px; color: var(--ink-4); }

/* ============================================================
   Loading + error skeletons (kept lean — opslag.js shows/hides)
   These live OUTSIDE .opslag-v2, so scope on body.v2 + the ids.
   ============================================================ */
body.v2 .opslag-loading { padding: clamp(48px,7vw,96px) 0; }
body.v2 .opslag-loading.hidden, body.v2 .opslag-error.hidden, body.v2 .opslag-content.hidden { display: none; }
body.v2 .opslag-loading-inner { max-width: 640px; }
body.v2 .opslag-loading-eyebrow { font-family: var(--f-mono); font-size: 11px; text-transform: uppercase; letter-spacing: .14em; font-weight: 600; color: var(--accent-2); margin-bottom: 16px; }
body.v2 .opslag-loading-title { font-family: var(--f-display); font-weight: 400; font-size: clamp(30px,4.5vw,52px); line-height: 1.05; letter-spacing: -.02em; margin: 0 0 14px; }
body.v2 .opslag-loading-title em { font-style: italic; color: var(--accent-2); }
body.v2 .opslag-loading-deck { font-family: var(--f-serif); font-size: 17px; color: var(--ink-2); margin: 0 0 24px; }
body.v2 .opslag-loading-bar { height: 6px; background: var(--paper-3); border-radius: 99px; overflow: hidden; margin-bottom: 26px; }
body.v2 .opslag-loading-fill { height: 100%; width: 30%; background: linear-gradient(90deg, var(--accent), var(--accent-2)); border-radius: 99px; transition: width .4s ease; }
body.v2 .opslag-loading-steps { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
body.v2 .opslag-loading-steps li { font-family: var(--f-serif); font-size: 15px; color: var(--ink-3); display: flex; align-items: center; gap: 10px; }
body.v2 .opslag-loading-steps li::before { content: ''; width: 8px; height: 8px; border-radius: 99px; background: var(--line-hard); flex-shrink: 0; }
body.v2 .opslag-loading-steps li[data-state="scanning"] { color: var(--accent); }
body.v2 .opslag-loading-steps li[data-state="scanning"]::before { background: var(--accent); }
body.v2 .opslag-loading-steps li[data-state="done"] { color: var(--accent-2); }
body.v2 .opslag-loading-steps li[data-state="done"]::before { background: var(--accent-2); }

body.v2 .opslag-error { padding: clamp(48px,7vw,96px) 0; }
body.v2 .opslag-error-inner { max-width: 560px; }
body.v2 .opslag-error-title { font-family: var(--f-display); font-weight: 400; font-size: clamp(30px,4.5vw,52px); line-height: 1.05; margin: 12px 0 14px; }
body.v2 .opslag-error-title em { font-style: italic; color: var(--risk); }
body.v2 .opslag-error-actions { display: flex; gap: 12px; margin-top: 22px; flex-wrap: wrap; }
body.v2 .opslag-btn { padding: 13px 24px; border-radius: var(--radius-ed-sm); font-size: 14.5px; font-weight: 500; border: 0; cursor: pointer; }
body.v2 .opslag-btn-primary { background: var(--accent-2); color: var(--paper); }
body.v2 .opslag-btn-primary:hover { background: var(--ink-1); }
body.v2 .opslag-btn-secondary { background: var(--paper); border: 1px solid var(--line-hard); color: var(--ink-2); }
body.v2 .opslag-btn-secondary:hover { background: var(--paper-2); }

/* Hide the legacy/no-op opslag.js targets that we keep only for contract. */
body.v2 .opslag-v2 .opslag-legacy-targets,
body.v2 .opslag-v2 .opslag-side-legacy { display: none !important; }
