/* xplat — designsystem.
   DNA fra ipLink (navy + pergament + diskret guld, serif-display) løftet til en
   moderne platforms-/tech-æstetik: krydset (×) der forbinder i ét punkt er det
   gennemgående motiv. Tilgængelig (WCAG 2.1 AA): kontrast, fokus, reduced-motion. */

:root {
  --ink: #16203a;           /* brødtekst på pergament */
  --ink-soft: #2c3650;
  --navy: #0f1b2e;          /* sidehoved/sidefod, dybt */
  --navy-2: #1a2b49;
  --navy-3: #24375b;
  --paper: #f5f2ea;         /* pergament */
  --paper-2: #fbf9f3;
  --card: #ffffff;
  --line: #e3ddcd;
  --line-2: #d6cebb;
  --muted: #5a6373;
  --gold-text: #6f571f;     /* tekst-guld, ~5.4:1 på pergament */
  --gold: #b89968;          /* dekorativ guldlinje */
  --gold-bright: #e0b15e;   /* node-glød / spark */
  --link: #1f4e79;          /* navy-blå link, ~6:1 */
  --link-light: #9cc2e6;    /* link på mørk baggrund */
  --ok: #1d6b3a; --ok-bg: #e8f3ea;
  --err: #98231f; --err-bg: #fbe9e7;
  --serif: "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, "Times New Roman", serif;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow-sm: 0 1px 2px rgba(15,27,46,.06), 0 2px 8px rgba(15,27,46,.05);
  --shadow: 0 8px 30px rgba(15,27,46,.10);
  --shadow-lg: 0 20px 60px rgba(15,27,46,.16);
  --maxw: 1120px;
}

* { box-sizing: border-box; }
html { font-size: 17px; -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0; font-family: var(--sans); line-height: 1.65; color: var(--ink);
  background: var(--paper); -webkit-font-smoothing: antialiased;
}
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

.wrap { width: min(var(--maxw), 92vw); margin-inline: auto; }
.site-main { display: block; }

h1, h2, h3 { font-family: var(--serif); font-weight: 600; line-height: 1.15; color: var(--navy); letter-spacing: -.01em; }
p { margin: 0 0 1rem; }
a { color: var(--link); text-decoration-thickness: 1px; text-underline-offset: 2px; }
img { max-width: 100%; height: auto; }
.center { text-align: center; }
.muted { color: var(--muted); }
.num { text-align: right; font-variant-numeric: tabular-nums; }

/* Skip-link + fokus */
.skip { position: absolute; left: -999px; top: 0; background: var(--navy); color: #fff; padding: .6rem 1rem; border-radius: 0 0 var(--radius-sm) 0; z-index: 60; }
.skip:focus { left: 0; }
a:focus-visible, button:focus-visible, select:focus-visible, input:focus-visible, textarea:focus-visible {
  outline: 3px solid var(--gold-bright); outline-offset: 2px; border-radius: 3px;
}

/* ---------------------------------------------------------------- Logo */
.x-logo { display: block; overflow: visible; }
.x-logo line { stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; opacity: .9; }
.x-logo .x-node { fill: var(--gold-bright); stroke: none; filter: drop-shadow(0 0 4px rgba(224,177,94,.6)); }

/* ---------------------------------------------------------------- Sidehoved */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(15,27,46,.92); -webkit-backdrop-filter: saturate(140%) blur(10px); backdrop-filter: saturate(140%) blur(10px); border-bottom: 1px solid rgba(184,153,104,.28); }
.header-inner { display: flex; align-items: center; gap: 1rem; padding: .75rem 0; }
.brand { display: inline-flex; align-items: center; gap: .55rem; color: #fff; text-decoration: none; font-family: var(--serif); }
.brand .x-logo { color: #fff; }
.brand-word { font-size: 1.3rem; font-weight: 600; letter-spacing: .02em; }
.topnav { display: flex; gap: 1.4rem; margin-left: 1.6rem; }
.topnav a { color: #d7dde7; text-decoration: none; font-size: .96rem; padding: .2rem 0; border-bottom: 2px solid transparent; }
.topnav a:hover { color: #fff; }
.topnav a[aria-current="page"] { color: #fff; border-bottom-color: var(--gold-bright); }
.header-cta { margin-left: auto; }

/* ---------------------------------------------------------------- Knapper */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; font: 600 1rem/1 var(--sans); padding: .8rem 1.4rem; border-radius: var(--radius-sm); text-decoration: none; cursor: pointer; border: 1.5px solid transparent; transition: transform .12s ease, background .15s ease, box-shadow .15s ease, color .15s ease; }
.btn-lg { padding: .95rem 1.8rem; font-size: 1.05rem; }
.btn-primary { background: linear-gradient(180deg, var(--navy-2), var(--navy)); color: #fff; border-color: var(--navy); box-shadow: var(--shadow-sm); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: var(--shadow); }
.btn-ghost { background: transparent; color: var(--navy); border-color: var(--line-2); }
.btn-ghost:hover { border-color: var(--navy); background: rgba(15,27,46,.04); }
.btn-ghost-light { background: transparent; color: #fff; border-color: rgba(255,255,255,.5); }
.btn-ghost-light:hover { background: rgba(255,255,255,.1); border-color: #fff; }
/* Guld-CTA til mørke baggrunde (hero, header, cta-band) — høj kontrast, on-brand. */
.btn-accent { background: linear-gradient(180deg, #ecc074, var(--gold-bright)); color: #2a2008; border-color: var(--gold-bright); box-shadow: var(--shadow-sm); font-weight: 700; }
.btn-accent:hover { transform: translateY(-1px); box-shadow: var(--shadow); filter: brightness(1.04); }
.btn-edit { position: fixed; right: 1rem; bottom: 1rem; z-index: 40; background: var(--gold-text); color: #fff; box-shadow: var(--shadow); }
@media (prefers-reduced-motion: reduce) { .btn:hover { transform: none; } }

/* ---------------------------------------------------------------- Eyebrow + sektions-titler */
.eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: .76rem; font-weight: 700; color: var(--gold-text); margin: 0 0 .7rem; }
.eyebrow.center { text-align: center; }
.section-title { font-size: clamp(1.7rem, 3vw, 2.3rem); margin: 0 0 .7rem; text-align: center; }
.section-title::after { content: ""; display: block; width: 56px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-bright)); margin: .8rem auto 0; border-radius: 2px; }
.section-lead { max-width: 60ch; margin: 0 auto 2rem; color: var(--ink-soft); font-size: 1.08rem; }

/* Sektioner */
.band { padding: clamp(3rem, 7vw, 5rem) 0; }
.band-alt { background: linear-gradient(180deg, var(--paper-2), var(--paper)); border-block: 1px solid var(--line); }

/* ---------------------------------------------------------------- Hero */
.hero { position: relative; overflow: hidden; background: radial-gradient(1200px 600px at 78% -10%, #16284a 0%, var(--navy) 55%); color: #fff; }
.hero-bg { position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background-image:
    linear-gradient(115deg, transparent 49.6%, rgba(184,153,104,.55) 49.8%, rgba(184,153,104,.55) 50.2%, transparent 50.4%),
    linear-gradient(65deg, transparent 49.6%, rgba(156,194,230,.35) 49.8%, rgba(156,194,230,.35) 50.2%, transparent 50.4%),
    radial-gradient(circle at 50% 50%, rgba(224,177,94,.9), rgba(224,177,94,0) 8px);
  background-repeat: no-repeat;
  background-position: center, center, center;
  background-size: 140% 140%, 140% 140%, 100% 100%;
}
.hero-bg::after { content: ""; position: absolute; left: 50%; top: 50%; width: 14px; height: 14px; transform: translate(-50%,-50%); border-radius: 50%; background: var(--gold-bright); box-shadow: 0 0 24px 6px rgba(224,177,94,.7); }
.hero-inner { position: relative; padding: clamp(3.5rem, 9vw, 6.5rem) 0 clamp(3rem, 7vw, 5rem); max-width: 740px; }
.hero .eyebrow { color: var(--gold-bright); }
.hero-title { font-size: clamp(2.4rem, 6vw, 4rem); margin: 0 0 1.1rem; color: #fff; }
.hero-lead, .hero-lead p { font-size: clamp(1.1rem, 2.2vw, 1.3rem); color: #d9e0ea; margin: 0 0 1.8rem; max-width: 56ch; }
.hero-lead strong { color: #fff; }
.hero-cta { display: flex; gap: .9rem; flex-wrap: wrap; }
.hero-cta.center { justify-content: center; }
.hero-meta { display: flex; flex-wrap: wrap; gap: 2rem 2.6rem; margin: 2.6rem 0 0; padding-top: 1.6rem; border-top: 1px solid rgba(255,255,255,.14); }
.hero-meta div { margin: 0; }
.hero-meta dt { font-size: .76rem; text-transform: uppercase; letter-spacing: .12em; color: #93a0b5; }
.hero-meta dd { margin: .2rem 0 0; font-family: var(--serif); font-size: 1.05rem; color: #fff; }

/* ---------------------------------------------------------------- Sidehero (indre sider) */
.page-hero { background: linear-gradient(180deg, #fbf9f4, var(--paper)); border-bottom: 1px solid var(--line); padding: clamp(2.6rem, 6vw, 4rem) 0 clamp(1.6rem, 4vw, 2.4rem); }
.page-hero h1 { font-size: clamp(2rem, 4.5vw, 3rem); margin: 0 0 .7rem; }
.page-lead { font-size: 1.15rem; color: var(--ink-soft); max-width: 62ch; margin: 0; }

/* ---------------------------------------------------------------- Produkter */
.product-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: 1.4rem; }
.product-card { position: relative; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem 1.6rem 1.7rem; box-shadow: var(--shadow-sm); transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease; overflow: hidden; }
.product-card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-bright)); }
.product-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line-2); }
.product-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: .4rem; }
.product-num { font-family: var(--serif); font-size: 1.5rem; color: var(--gold); font-weight: 600; }
.badge { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; padding: .26rem .6rem; border-radius: 100px; }
.badge-live { background: var(--ok-bg); color: var(--ok); }
.badge-soon { background: #f1ece0; color: var(--gold-text); }
.product-name { font-size: 1.45rem; margin: .1rem 0 .15rem; }
.product-tag { color: var(--muted); font-size: .95rem; margin: 0 0 .8rem; }
.product-desc { color: var(--ink-soft); margin: 0 0 1rem; }
.product-link { font-weight: 600; text-decoration: none; }
.product-link:hover { text-decoration: underline; }

/* Tick-lister */
.ticks { list-style: none; padding: 0; margin: 0 0 1.1rem; }
.ticks li { position: relative; padding-left: 1.7rem; margin-bottom: .45rem; color: var(--ink-soft); }
.ticks li::before { content: ""; position: absolute; left: 0; top: .5em; width: 12px; height: 7px; border-left: 2.4px solid var(--gold-text); border-bottom: 2.4px solid var(--gold-text); transform: rotate(-45deg); }

/* ---------------------------------------------------------------- Kompetencer */
.cap-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1.2rem; }
.cap { background: var(--card); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: var(--radius); padding: 1.4rem 1.4rem 1.2rem; }
.cap h3 { font-size: 1.18rem; margin: 0 0 .5rem; }
.cap p { margin: 0; color: var(--ink-soft); }

/* ---------------------------------------------------------------- Trin */
.howto { max-width: 880px; margin-inline: auto; }
.steps { counter-reset: step; list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.4rem; }
.steps li { counter-increment: step; position: relative; padding-left: 3.2rem; min-height: 2.4rem; display: flex; align-items: center; color: var(--ink-soft); }
.steps li::before { content: counter(step); position: absolute; left: 0; top: -.1rem; width: 2.3rem; height: 2.3rem; border-radius: 50%; background: linear-gradient(180deg, var(--navy-2), var(--navy)); color: #fff; font: 700 1.05rem/2.3rem var(--serif); text-align: center; box-shadow: var(--shadow-sm); }

/* ---------------------------------------------------------------- CTA-band */
.cta-band { background: radial-gradient(900px 400px at 50% 120%, #16284a, var(--navy)); color: #fff; padding: clamp(3rem, 7vw, 4.5rem) 0; text-align: center; }
.cta-inner h2 { color: #fff; font-size: clamp(1.6rem, 3.5vw, 2.4rem); margin: 0 0 .5rem; }
.cta-inner p { color: #cdd5e2; margin: 0 0 1.6rem; }

/* ---------------------------------------------------------------- Ydelser */
.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.4rem; }
.service-card { display: flex; flex-direction: column; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem; box-shadow: var(--shadow-sm); transition: transform .16s ease, box-shadow .16s ease; }
.service-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.service-top { border-bottom: 1px solid var(--line); padding-bottom: 1rem; margin-bottom: 1rem; }
.service-top h3 { font-size: 1.35rem; margin: 0 0 .6rem; }
.service-price { display: flex; flex-direction: column; gap: .1rem; }
.price-main { font-family: var(--serif); font-size: 1.9rem; color: var(--navy); font-weight: 600; }
.price-unit { font-size: .9rem; color: var(--muted); }
.price-incl { font-size: .9rem; color: var(--gold-text); font-weight: 600; }
.service-summary { color: var(--ink-soft); }
.service-delivery { font-size: .92rem; color: var(--muted); margin: 0 0 1.2rem; }
.service-cta { margin-top: auto; }
.service-cta .btn { width: 100%; }

/* ---------------------------------------------------------------- Betalingskort */
.footer-cards, .cards-showcase { display: flex; flex-wrap: wrap; gap: .55rem; align-items: center; }
.cards-showcase { justify-content: center; gap: .9rem; margin: 0 auto 1rem; }
.cardlogo { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 36px; background: #fff; border: 1px solid var(--line); border-radius: 6px; padding: 4px 7px; box-shadow: var(--shadow-sm); }
.cardlogo img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; display: block; }
.cardlogo-lg { width: 74px; height: 48px; padding: 6px 10px; border-radius: 8px; }
.cards-text { font-size: 1.05rem; color: var(--ink-soft); }
.pay-facts { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.2rem; margin: 2rem 0; }
.pay-facts .fact { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.3rem; }
.pay-facts h3 { font-size: 1.1rem; margin: 0 0 .4rem; }
.pay-facts p { margin: 0; color: var(--ink-soft); }
.pay-note { max-width: 720px; margin-inline: auto; }

/* ---------------------------------------------------------------- Juridiske sider */
.legal { display: grid; grid-template-columns: 220px 1fr; gap: 2.4rem; align-items: start; }
.legal-toc { position: sticky; top: 84px; }
.legal-toc ul { list-style: none; padding: 0; margin: 0; border-left: 2px solid var(--line); }
.legal-toc li a { display: block; padding: .35rem .9rem; color: var(--ink-soft); text-decoration: none; font-size: .94rem; }
.legal-toc li a:hover { color: var(--navy); border-left: 2px solid var(--gold); margin-left: -2px; }
.legal-body { max-width: 70ch; }
.legal-sec { margin-bottom: 2rem; scroll-margin-top: 84px; }
.legal-sec h2 { font-size: 1.4rem; margin: 0 0 .6rem; }
.legal-sec p { color: var(--ink-soft); }
.legal-version { color: var(--muted); font-size: .9rem; border-top: 1px solid var(--line); padding-top: 1rem; }

/* ---------------------------------------------------------------- Formularer / kort */
.formcard { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem 1.7rem; box-shadow: var(--shadow-sm); margin: 0 0 1.4rem; }
.field, .typeset { display: block; margin: 0 0 1.1rem; }
.field > span, .typeset legend { display: block; font-weight: 600; margin-bottom: .35rem; color: var(--ink); }
.field small { font-weight: 400; color: var(--muted); }
.field i { color: var(--err); font-style: normal; }
input[type=text], input[type=email], input[type=tel], input[type=password], input[type=number], textarea, select {
  width: 100%; padding: .65rem .75rem; font: 1rem/1.4 var(--sans); color: var(--ink);
  border: 1px solid var(--line-2); border-radius: var(--radius-sm); background: #fff;
}
textarea { resize: vertical; }
.field.has-err input, .field.has-err textarea { border-color: var(--err); background: #fff7f6; }
.hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; overflow: hidden; }
.typeset { border: 1px solid var(--line); border-radius: var(--radius-sm); padding: .7rem .9rem; }
.radio { display: inline-flex; align-items: center; gap: .4rem; font-weight: 400; margin-right: 1.4rem; }
.fineprint { font-size: .88rem; color: var(--muted); margin: 1rem 0 0; }
.ok { color: var(--ok); background: var(--ok-bg); border: 1px solid #bfe0c8; border-left: 5px solid var(--ok); border-radius: var(--radius-sm); padding: .9rem 1.1rem; font-size: 1.05rem; }
.err { color: var(--err); }
.err-list { list-style: none; padding: .8rem 1rem; margin: 0 0 1.2rem; background: var(--err-bg); border: 1px solid #f1c7c2; border-left: 5px solid var(--err); border-radius: var(--radius-sm); color: var(--err); }
.err-list li { margin: .2rem 0; }
.inline-err { font-weight: 600; margin: 0 0 .8rem; }

/* Kontakt */
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 2rem; align-items: start; }
.contact-info { background: var(--card); border: 1px solid var(--line); border-top: 3px solid var(--gold); border-radius: var(--radius); padding: 1.5rem 1.6rem; }
.contact-info h2 { font-size: 1.25rem; margin: 0 0 .8rem; }

/* ---------------------------------------------------------------- Bestilling */
.order-grid, .review-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 2rem; align-items: start; }
.order-aside, .review-aside { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.5rem 1.6rem; position: sticky; top: 84px; }
.order-aside h2, .review-aside h2 { font-size: 1.15rem; margin: 0 0 .8rem; }
.order-sum { border-top: 1px solid var(--line); padding-top: 1rem; margin-top: 1rem; }
.order-sum-title { font-family: var(--serif); font-size: 1.2rem; color: var(--navy); margin: 0 0 .2rem; }
.order-sum-price { font-family: var(--serif); font-size: 1.5rem; color: var(--gold-text); margin: 0; }
.order-sum-price span { font-family: var(--sans); font-size: .85rem; color: var(--muted); }
.order-sum-incl { font-size: .88rem; color: var(--muted); margin: .2rem 0 .6rem; }
.order-sum-desc { font-size: .95rem; color: var(--ink-soft); margin: 0; }
.qty-field input { max-width: 8rem; }

/* Gennemse / kvittering */
.order-table { width: 100%; border-collapse: collapse; margin: 0 0 1rem; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.order-table th, .order-table td { padding: .8rem 1rem; text-align: left; border-bottom: 1px solid var(--line); }
.order-table thead th { background: #efe9dd; color: var(--navy); font-family: var(--serif); }
.order-table tfoot td { border-bottom: none; }
.order-table tfoot .grand td { font-weight: 700; font-size: 1.15rem; color: var(--navy); border-top: 2px solid var(--gold); }
.order-table .muted { font-size: .88rem; }
.currency-note { font-size: 1.05rem; color: var(--ink-soft); margin: 0 0 1.6rem; }
.currency-note strong { color: var(--navy); font-size: 1.15rem; }
.review-cards { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem 1.4rem; margin: 0 0 1.6rem; }
.review-cards h2 { font-size: 1.15rem; margin: 0 0 .5rem; }
.review-cards p { margin: 0 0 .8rem; color: var(--ink-soft); }
.terms-form { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem 1.5rem; box-shadow: var(--shadow-sm); }
.accept { display: flex; gap: .7rem; align-items: flex-start; margin: 0 0 1.2rem; cursor: pointer; }
.accept input[type=checkbox] { width: 1.3rem; height: 1.3rem; margin-top: .15rem; flex: none; accent-color: var(--navy); }
.terms-form .btn-lg { margin-right: .6rem; }
.kv { display: grid; grid-template-columns: auto 1fr; gap: .35rem 1rem; margin: 0 0 1.2rem; }
.kv dt { color: var(--muted); font-size: .9rem; }
.kv dd { margin: 0; color: var(--ink); }
.receipt .kv { max-width: 30rem; }

/* ---------------------------------------------------------------- Dashboard */
.dash-pages { margin: 0 0 1rem; padding-left: 1.2rem; }
.dash-scroll { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius-sm); margin-top: .6rem; }
.dash-table, table.wm-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.dash-table th, .dash-table td, .wm-table th, .wm-table td { text-align: left; padding: .55rem .7rem; border-bottom: 1px solid var(--line); vertical-align: top; }
.dash-table thead th, .wm-table thead th { background: #efe9dd; color: var(--navy); font-family: var(--serif); }
.dash-table tbody tr:nth-child(even), .wm-table tbody tr:nth-child(even) { background: var(--paper-2); }

/* ---------------------------------------------------------------- Sidefod */
.site-footer { background: var(--navy); color: #cdd5e2; margin-top: 2rem; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; padding: 3rem 0 2rem; }
.footer-brand .brand { margin-bottom: .8rem; }
.footer-tagline { color: #93a0b5; margin: 0 0 1rem; max-width: 30ch; }
.site-footer h2 { color: #fff; font-size: .95rem; text-transform: uppercase; letter-spacing: .1em; font-family: var(--sans); margin: 0 0 .8rem; }
.footer-legal { color: #cdd5e2; font-size: .94rem; line-height: 1.8; margin: 0 0 1rem; }
.footer-legal a { color: var(--link-light); }
.footer-links { display: flex; flex-direction: column; gap: .5rem; }
.footer-links a { color: #cdd5e2; text-decoration: none; }
.footer-links a:hover { color: #fff; text-decoration: underline; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); padding: 1.2rem 0; }
.footer-bottom p { margin: 0; font-size: .86rem; color: #8593a8; }

/* ---------------------------------------------------------------- Reveal
   No-JS-sikker: uden JS er alt fuldt synligt. Skjul-og-afslør sker KUN når
   scriptet har sat .js på <html> (progressiv forbedring). */
.reveal { opacity: 1; transform: none; }
.js .reveal { opacity: 0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease; }
.js .reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .js .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---------------------------------------------------------------- Responsiv */
@media (max-width: 860px) {
  .legal { grid-template-columns: 1fr; }
  .legal-toc { position: static; }
  .contact-grid, .order-grid, .review-grid { grid-template-columns: 1fr; }
  .order-aside, .review-aside { position: static; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .topnav { display: none; }
  .header-cta { margin-left: auto; }
  .footer-grid { grid-template-columns: 1fr; gap: 1.4rem; }
  .hero-meta { gap: 1.2rem 1.8rem; }
}
