/* ==========================================================================
   Moneyweb — Production stylesheet
   Self-contained: design tokens + layout. One font family (Comfortaa).
   No framework, no runtime build. Hand-authored for speed & PageSpeed.
   ========================================================================== */

/* ---------- Tokens ---------- */
:root {
  /* Forest */
  --forest-900: #0B2418;
  --forest-800: #123521;
  --forest-700: #1A4631;
  --forest-600: #235B40;
  --forest-500: #2F7351;
  /* Lime */
  --lime-600: #9CB52F;
  --lime-500: #ABC53A;
  --lime-400: #BCD544;
  --lime-300: #CFE173;
  --lime-200: #E4EFAE;
  /* Cream */
  --cream-50:  #FAF7F1;
  --cream-100: #F4F0E8;
  --cream-200: #ECE6D8;
  --cream-300: #E1D9C7;
  /* Ink */
  --ink-900: #16271E;
  --ink-700: #3A4A41;
  --ink-500: #647067;
  --ink-300: #97A199;
  /* On forest */
  --on-forest-strong: #F4F0E8;
  --on-forest-muted:  #A9BCAF;
  --on-forest-faint:  #6F8576;
  /* Status */
  --success: #3F8F5B;
  --danger:  #C2552F;

  /* Semantic */
  --text-primary: var(--ink-900);
  --text-secondary: var(--ink-700);
  --text-muted: var(--ink-500);
  --border: var(--cream-300);
  --border-on-dark: rgba(244, 240, 232, 0.16);

  /* Type */
  --font-brand: 'Comfortaa', ui-rounded, 'Segoe UI', system-ui, sans-serif;
  --font-heading: 'Comfortaa', ui-rounded, 'Segoe UI', system-ui, sans-serif;
  --font-body: 'Comfortaa', ui-rounded, 'Segoe UI', system-ui, sans-serif;

  /* Effects */
  --shadow-card: 0 2px 4px rgba(20,48,36,0.04), 0 18px 40px rgba(20,48,36,0.07);
  --shadow-card-hover: 0 4px 8px rgba(20,48,36,0.06), 0 28px 56px rgba(20,48,36,0.12);
  --shadow-float: 0 8px 30px rgba(18,53,36,0.10);

  --ease-standard: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 120ms;
  --dur-base: 200ms;
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; background: #F5F3EC; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 500;
  color: var(--text-primary);
  background: transparent;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ---------- Scroll-drevet baggrundslag ----------
   Ét fast lag bag alt indhold. main.js interpolerer dets grundfarve ud fra
   scroll-positionen, så hele sidens tone skifter blødt — uden synlig kant
   mellem sektioner. Den faste lime-kiss i toppen giver brandet varme. */
.mw-bg { position: fixed; inset: 0; z-index: -1; pointer-events: none;
  background-color: #F5F3EC;
  background-image:
    radial-gradient(60% 45% at 6% -4%, rgba(188,213,68,0.16) 0%, transparent 60%),
    radial-gradient(55% 38% at 100% 0%, rgba(188,213,68,0.09) 0%, transparent 55%); }
img, video { max-width: 100%; display: block; }
a { color: inherit; }
h1, h2, h3, h4 { font-family: var(--font-heading); }
:focus-visible { outline: 3px solid var(--lime-400); outline-offset: 2px; border-radius: 6px; }

.mw-container { max-width: 1600px; margin: 0 auto; padding: 0 40px; }
.mw-h2 { font-weight: 700; font-size: 36px; letter-spacing: -0.02em; color: var(--forest-800); margin: 0; }
.mw-skip { position: absolute; left: -9999px; top: 0; background: var(--forest-800); color: #fff;
  padding: 12px 18px; border-radius: 0 0 10px 0; z-index: 9999; font-weight: 700; }
.mw-skip:focus { left: 0; }

/* ---------- Pills ---------- */
.mw-pill { display: inline-flex; align-items: center; gap: 8px; padding: 7px 15px; border-radius: 999px;
  background: #fff; border: 1px solid var(--border); box-shadow: var(--shadow-card); white-space: nowrap;
  font-weight: 600; font-size: 14px; color: var(--ink-700); }
.mw-pill__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lime-400); }
.mw-pill--soft { background: var(--lime-200); border: none; box-shadow: none; color: var(--forest-700);
  font-size: 15px; font-weight: 700; letter-spacing: 0; text-transform: none; padding: 8px 17px; }

.mw-underline { position: relative; white-space: nowrap; padding-bottom: 0.14em;
  background: url("../assets/doodle-underline.svg") no-repeat left bottom; background-size: 100% 0.5em; }

/* ---------- NAV (Saphe-style frosted bar) ---------- */
.mw-nav2 { position: fixed; top: 18px; left: 0; right: 0; z-index: 100; padding: 0 24px; }
.mw-nav2__bar { max-width: 1600px; margin: 0 auto; }
.mw-nav2__inner { display: flex; align-items: center; gap: 28px; border-radius: 28px; padding: 15px 18px 15px 30px;
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(22px) saturate(1.4); -webkit-backdrop-filter: blur(22px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.20);
  box-shadow: 0 1px 0 rgba(255,255,255,0.14) inset, 0 14px 44px rgba(6,20,14,0.20);
  transition: background var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard); }
.mw-nav2__brand { display: inline-flex; align-items: center; gap: 11px; flex: none; text-decoration: none; }
.mw-nav2__mark { height: 34px; width: auto; }
.mw-nav2__word { font-family: var(--font-heading); font-weight: 700; font-size: 22px; letter-spacing: -0.02em; color: #fff;
  transition: color var(--dur-base) var(--ease-standard); }
.mw-nav2__word sup { font-size: 0.5em; font-weight: 600; opacity: 0.75; margin-left: 1px; }
.mw-nav2__logo { height: 30px; width: auto; flex: none; display: block; }
.mw-nav2__logo--dark { display: none; }
.mw-nav2.is-white .mw-nav2__logo--light, .mw-nav2--solid .mw-nav2__logo--light { display: none; }
.mw-nav2.is-white .mw-nav2__logo--dark, .mw-nav2--solid .mw-nav2__logo--dark { display: block; }
.mw-nav2__inner > nav { flex: 1; display: flex; justify-content: center; }
.mw-nav2__links { display: flex; align-items: center; gap: 32px; margin: 0; list-style: none; padding: 0; }
.mw-nav2__right { margin-left: auto; }
.mw-nav2__links a { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; font-size: 16px;
  color: rgba(255,255,255,0.86); text-decoration: none; white-space: nowrap; transition: color var(--dur-fast) var(--ease-standard); }
.mw-nav2__links a:hover, .mw-nav2__links a[aria-current="page"] { color: #fff; }
.mw-nav2__right { display: flex; align-items: center; gap: 12px; flex: none; }
.mw-nav2__cta { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-brand); font-weight: 700;
  font-size: 16px; cursor: pointer; white-space: nowrap; text-decoration: none;
  background: var(--lime-400); color: var(--forest-900); border: none; border-radius: 999px; padding: 14px 26px;
  transition: filter var(--dur-fast) var(--ease-standard), transform var(--dur-fast) var(--ease-standard); }
.mw-nav2__cta:hover { filter: brightness(1.05); transform: translateY(-1px); }
.mw-nav2__burger { display: none; width: 46px; height: 46px; border: none; cursor: pointer; border-radius: 12px;
  background: rgba(255,255,255,0.12); color: #fff; align-items: center; justify-content: center; }
.mw-nav2__burger svg { width: 22px; height: 22px; }
/* solid white state */
.mw-nav2.is-white .mw-nav2__inner { background: rgba(255,255,255,0.95); border-color: rgba(18,53,33,0.07); box-shadow: 0 10px 34px rgba(18,53,33,0.12); }
.mw-nav2.is-white .mw-nav2__word { color: var(--forest-800); }
.mw-nav2.is-white .mw-nav2__links a { color: var(--text-secondary); }
.mw-nav2.is-white .mw-nav2__links a:hover, .mw-nav2.is-white .mw-nav2__links a[aria-current="page"] { color: var(--forest-800); }
.mw-nav2.is-white .mw-nav2__burger { background: rgba(18,53,33,0.08); color: var(--forest-800); }
/* pages that are not the immersive hero start in white state immediately */
.mw-nav2--solid .mw-nav2__inner { background: rgba(255,255,255,0.95); border-color: rgba(18,53,33,0.07); box-shadow: 0 10px 34px rgba(18,53,33,0.12); }
.mw-nav2--solid .mw-nav2__word { color: var(--forest-800); }
.mw-nav2--solid .mw-nav2__links a { color: var(--text-secondary); }
.mw-nav2--solid .mw-nav2__burger { background: rgba(18,53,33,0.08); color: var(--forest-800); }

/* mobile drawer */
.mw-drawer { position: fixed; inset: 0; z-index: 130; display: none; }
.mw-drawer.is-open { display: block; }
.mw-drawer__scrim { position: absolute; inset: 0; background: rgba(11,36,24,0.5); }
.mw-drawer__panel { position: absolute; top: 0; right: 0; height: 100%; width: min(86vw, 360px);
  background: var(--forest-800); padding: 26px 24px; display: flex; flex-direction: column; gap: 8px;
  transform: translateX(100%); transition: transform .3s var(--ease-out); }
.mw-drawer.is-open .mw-drawer__panel { transform: none; }
.mw-drawer__close { align-self: flex-end; width: 44px; height: 44px; border: none; background: rgba(255,255,255,0.1);
  color: #fff; border-radius: 12px; font-size: 22px; cursor: pointer; margin-bottom: 12px; }
.mw-drawer__panel a { color: #fff; text-decoration: none; font-weight: 600; font-size: 19px; padding: 12px 6px; border-bottom: 1px solid var(--border-on-dark); }
.mw-drawer__panel a:last-of-type { border-bottom: none; }
.mw-drawer__cta { margin-top: 16px; background: var(--lime-400) !important; color: var(--forest-900) !important;
  text-align: center; border-radius: 999px !important; border-bottom: none !important; }

/* ---------- HERO (immersive video) ---------- */
.mw-hero { position: relative; min-height: 100vh; overflow: hidden; background: #0b2418; }
.mw-hero__photo { position: absolute; inset: 0; background:
    radial-gradient(90% 70% at 75% 15%, rgba(47,115,81,0.5) 0%, transparent 55%),
    linear-gradient(155deg, #1a4a33 0%, #123521 45%, #0b2418 100%); }
.mw-hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 70% center; }
.mw-hero__scrim { position: absolute; inset: 0; background:
    linear-gradient(100deg, rgba(11,36,24,0.93) 0%, rgba(18,53,33,0.74) 38%, rgba(18,53,33,0.30) 66%, rgba(11,36,24,0.36) 100%),
    linear-gradient(180deg, rgba(11,36,24,0.32) 0%, transparent 24%, transparent 46%, rgba(11,36,24,0.84) 100%); }
.mw-hero__inner { position: relative; max-width: 1600px; margin: 0 auto; padding: 120px 40px 56px;
  display: flex; flex-direction: column; justify-content: center; min-height: 100vh; }
.mw-hero__content { max-width: 760px; }

/* ---------- Svævende pris-badge (glas) ---------- */
.mw-pricecard { position: absolute; right: 40px; bottom: 64px; z-index: 3; width: 290px;
  display: flex; flex-direction: column; gap: 4px; padding: 28px 30px 26px;
  border-radius: 26px; background: rgba(11,36,24,0.42); border: 1px solid rgba(199,237,92,0.34);
  backdrop-filter: blur(14px) saturate(120%); -webkit-backdrop-filter: blur(14px) saturate(120%);
  box-shadow: 0 24px 60px -24px rgba(0,0,0,0.7); color: #fff;
  opacity: 0; transform: translateY(26px); animation: mw-pricecard-in .7s var(--ease-standard) 1.1s forwards; }
@keyframes mw-pricecard-in { to { opacity: 1; transform: translateY(0); } }
.mw-pricecard__label { font-size: 15px; font-weight: 600; letter-spacing: .02em; color: rgba(244,240,232,0.8); }
.mw-pricecard__amount { display: flex; align-items: baseline; gap: 7px; font-family: var(--font-heading);
  font-weight: 700; font-size: 60px; line-height: 1; letter-spacing: -0.03em; color: var(--lime-400); margin-top: 2px; }
.mw-pricecard__amount span { font-size: 22px; font-weight: 600; color: rgba(244,240,232,0.72); letter-spacing: 0; }
.mw-pricecard__meta { font-size: 14px; font-weight: 500; color: rgba(244,240,232,0.68); margin-top: 5px; }
.mw-pricecard__rule { height: 1px; background: rgba(255,255,255,0.13); margin: 17px 0 14px; }
.mw-pricecard__foot { display: flex; align-items: center; gap: 10px; font-size: 14.5px; font-weight: 600; color: #fff; }
.mw-pricecard__dot { width: 9px; height: 9px; border-radius: 50%; background: var(--lime-400); flex: none;
  box-shadow: 0 0 0 4px rgba(188,213,68,0.18); animation: mw-pricecard-pulse 2.4s ease-in-out infinite; }
@keyframes mw-pricecard-pulse { 0%,100% { box-shadow: 0 0 0 4px rgba(188,213,68,0.18); } 50% { box-shadow: 0 0 0 7px rgba(188,213,68,0.06); } }
@media (prefers-reduced-motion: reduce) { .mw-pricecard { animation: none; opacity: 1; transform: none; } .mw-pricecard__dot { animation: none; } }
@media (max-width: 980px) { .mw-pricecard { right: 24px; bottom: 24px; width: 248px; padding: 22px 24px; } .mw-pricecard__amount { font-size: 50px; } }
@media (max-width: 700px) { .mw-pricecard { display: none; } }
.mw-hero__title { font-weight: 700; font-size: 66px; line-height: 1.0; letter-spacing: -0.025em; color: #fff; margin: 0; }
.mw-hero__sub { font-family: 'Comfortaa', var(--font-brand); font-weight: 600; font-size: 40px; line-height: 1.2;
  color: #efe2c5; margin: 12px 0 0; letter-spacing: -0.01em; }
.mw-hero__checks { list-style: none; padding: 0; margin: 32px 0 0; display: flex; flex-direction: column; gap: 7px; }
.mw-hero__eyebrow { display: inline-block; font-weight: 700; font-size: 13px; letter-spacing: .16em;
  text-transform: none; color: var(--lime-400); margin: 0 0 18px; }
.mw-hero__checks li { display: flex; align-items: center; gap: 12px; font-size: 19px; font-weight: 600; color: #fff; }
.mw-hcheck { color: var(--lime-400); font-size: 18px; font-weight: 700; flex: none; }

.mw-knownfrom { display: flex; align-items: center; flex-wrap: wrap; gap: 10px 16px; margin: 30px 0 0; }
.mw-knownfrom__label { font-size: 12.5px; font-weight: 700; letter-spacing: 0; text-transform: none;
  color: rgba(244,240,232,0.55); }
.mw-knownfrom__chips { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.mw-knownfrom__chip { display: inline-flex; align-items: center; gap: 8px; padding: 8px 16px 8px 13px;
  border-radius: 999px; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.16);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  font-family: var(--font-brand); font-weight: 700; font-size: 15px; color: #fff; }
.mw-knownfrom__chip svg { width: 18px; height: 18px; flex: none; opacity: 0.92; }

.mw-hero__cta { margin-top: 34px; }
.mw-hero__cta .mw-btn span { transition: transform var(--dur-base) var(--ease-standard); }
.mw-hero__cta .mw-btn:hover span { transform: translateX(3px); }
.mw-hero__lead { font-size: 19px; line-height: 1.55; color: rgba(244,240,232,0.86); margin: 26px 0 0; max-width: 44ch; font-weight: 500; text-wrap: pretty; }
.mw-hero__lead strong { color: #fff; font-weight: 700; }
.mw-hero--about .mw-hero__lead { max-width: 60ch; }
.mw-hero--about .mw-hero__lead:first-of-type { margin-top: 30px; }
.mw-hero__note { font-style: italic; font-size: 18px; color: rgba(244,240,232,0.82); margin: 34px 0 0; }
.mw-hero__cards { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; max-width: 880px; margin-top: 56px; }

/* Floating hero note — kobler til baggrundsvideoen (manden der leder efter en pool i ørkenen) */
.mw-heromsg { position: absolute; z-index: 4; bottom: 8%; right: clamp(28px, 6vw, 96px); max-width: 312px;
  padding: 20px 22px; border-radius: 20px 20px 6px 20px;
  background: rgba(11,36,24,0.58); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(199,237,92,0.45); box-shadow: 0 28px 64px -30px rgba(0,0,0,0.78);
  transform: rotate(-1.6deg); transform-origin: bottom right;
  animation: mwHeromsgIn 0.75s var(--ease-standard) both 5s; }
.mw-heromsg__tag { display: inline-block; font-size: 11.5px; font-weight: 700; letter-spacing: 0.05em;
  text-transform: none; color: var(--lime-400); margin: 0 0 8px; }
.mw-heromsg__text { font-family: var(--font-brand); font-weight: 700; font-size: 19px; line-height: 1.3;
  color: #fff; margin: 0; text-wrap: balance; }
.mw-heromsg__sub { font-size: 13.5px; line-height: 1.5; color: rgba(244,240,232,0.82); margin: 9px 0 0; text-wrap: pretty; }
.mw-heromsg__link { display: inline-flex; align-items: center; gap: 6px; margin-top: 13px;
  font-family: var(--font-brand); font-weight: 700; font-size: 13px; color: var(--lime-400); text-decoration: none; }
.mw-heromsg__link:hover { color: #fff; }
.mw-heromsg__link span { transition: transform var(--dur-base) var(--ease-standard); }
.mw-heromsg__link:hover span { transform: translateX(3px); }
.mw-heromsg::after { content: ""; position: absolute; right: 26px; bottom: -8px; width: 16px; height: 16px;
  background: rgba(11,36,24,0.58); border-right: 1px solid rgba(199,237,92,0.45); border-bottom: 1px solid rgba(199,237,92,0.45);
  transform: rotate(45deg); display: none; }
@keyframes mwHeromsgIn { from { opacity: 0; transform: translateY(60px) rotate(-1.6deg); } to { opacity: 1; transform: translateY(0) rotate(-1.6deg); } }
@media (prefers-reduced-motion: reduce) { .mw-heromsg { animation: none; } }
@media (max-width: 1100px) { .mw-heromsg { display: none; } }

.mw-hcard { position: relative; background: linear-gradient(155deg, #f4f6e6 0%, #e7eece 100%); border-radius: 24px;
  padding: 32px 26px 24px; transition: transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-hcard:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }
.mw-hcard__num { position: absolute; top: -16px; left: 24px; display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 50%; font-weight: 700; font-size: 15px; }
.mw-hcard__num--dark { background: var(--forest-800); color: #fff; }
.mw-hcard__num--lime { background: var(--lime-400); color: var(--forest-900); }
.mw-hcard__pre { display: block; font-size: 15px; color: var(--text-secondary); margin: 4px 0 8px; }
.mw-hcard__title { font-weight: 700; font-size: 26px; color: var(--forest-800); margin: 0 0 4px; }
.mw-hcard__sub { font-size: 14px; color: var(--text-muted); margin: 0 0 24px; }
.mw-hcard__row { display: flex; align-items: center; justify-content: space-between; }
.mw-minibtn { font-weight: 700; font-size: 15px; text-decoration: none; padding: 12px 24px; border-radius: 999px; }
.mw-minibtn--dark { background: var(--forest-800); color: #fff; }
.mw-minibtn--lime { background: var(--lime-400); color: var(--forest-900); }
.mw-arrowbtn { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px;
  border-radius: 50%; background: #fff; border: none; color: var(--forest-800); font-size: 18px; box-shadow: var(--shadow-card); text-decoration: none; }

/* ---------- Hero buy box (frosted dark offer card, bottom of hero) ---------- */
.mw-herobuy { position: absolute; right: 40px; bottom: clamp(12px, 2.5vh, 26px); z-index: 4;
  width: clamp(300px, 25vw, 372px);
  background: rgba(12,34,22,0.25);
  backdrop-filter: blur(22px) saturate(1.3); -webkit-backdrop-filter: blur(22px) saturate(1.3);
  border: 1px solid rgba(255,255,255,0.14); border-radius: 20px; padding: 18px 20px 16px;
  box-shadow: 0 30px 70px rgba(6,20,14,0.5); }
.mw-herobuy__top { display: flex; gap: 14px; align-items: center; }
.mw-herobuy__info { flex: 1; min-width: 0; }
.mw-herobuy__media { flex: none; width: clamp(118px, 13vw, 166px); display: flex; align-items: center; }
.mw-herobuy__media img { width: 100%; height: auto; object-fit: contain; display: block; }
.mw-herobuy__tag { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: none;
  color: var(--forest-900); background: var(--lime-400); padding: 5px 11px; border-radius: 999px; margin-bottom: 14px; }
.mw-herobuy__title { font-weight: 700; font-size: 15px; line-height: 1.25; color: #fff; margin: 0 0 5px; letter-spacing: -0.01em; text-wrap: balance; }
.mw-herobuy__sub { font-size: 12.5px; line-height: 1.45; color: rgba(244,240,232,0.7); margin: 0 0 13px; }
.mw-herobuy__list { list-style: none; margin: 0 0 4px; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.mw-herobuy__list li { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; color: rgba(244,240,232,0.92); }
.mw-herobuy__chk { display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; flex: none; border-radius: 50%; background: var(--lime-400); color: var(--forest-900); font-size: 10px; font-weight: 700; }
.mw-herobuy__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  margin-top: 14px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.16); }
.mw-herobuy__price { display: flex; align-items: baseline; gap: 3px; color: #fff; }
.mw-herobuy__price b { font-size: 32px; font-weight: 700; letter-spacing: -0.03em; }
.mw-herobuy__price span { font-size: 14px; font-weight: 600; color: rgba(244,240,232,0.7); }
.mw-herobuy__btn { display: inline-flex; align-items: center; gap: 7px; background: var(--lime-400); color: var(--forest-900);
  font-family: var(--font-brand); font-weight: 700; font-size: 14px; text-decoration: none; padding: 12px 18px; border-radius: 999px;
  transition: filter var(--dur-fast) var(--ease-standard), transform var(--dur-fast) var(--ease-standard); }
.mw-herobuy__btn:hover { filter: brightness(1.06); transform: translateY(-1px); }
@media (max-width: 1460px) {
  .mw-herobuy { position: static; transform: none; width: 100%; max-width: 460px; margin: 32px 0 0; }
}
@media (max-width: 460px) {
  .mw-herobuy__top { flex-direction: column; }
  .mw-herobuy__media { width: 100%; height: 150px; }
}

/* ---------- SECTIONS ---------- */
/* Ét fælles lodret sektions-rul, så ALLE sektioner har ens top/bund-padding */
.mw-section { padding: clamp(72px, 8vw, 112px) 0; }
.mw-section--white { background: #fff; }
.mw-section--cream { background: var(--cream-200); }
.mw-center { text-align: center; max-width: 620px; margin: 0 auto 44px; }
.mw-center .mw-pill, .mw-center .mw-pill--soft { margin-bottom: 18px; }
.mw-center__sub { font-size: 17px; color: var(--text-secondary); margin: 14px 0 0; line-height: 1.55; }
.mw-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }

/* ===== Scroll-drevet trinflow ("De simple skridt") ===== */
.mw-steps { padding: clamp(72px, 8vw, 112px) 0; }
.mw-steps.is-enhanced { padding: 0; }
.mw-steps__inner { position: relative; }
/* Pin-længde: kort nok til at hvert trin skifter efter et lille scroll (≈30vh/trin),
   så sektionen ikke "fanger" scrollen i flere skærmhøjder. */
.mw-steps.is-enhanced .mw-steps__inner { height: 200vh; }

.mw-steps__sticky { padding: 0; }
.mw-steps.is-enhanced .mw-steps__sticky { position: sticky; top: 0; height: 100vh; min-height: 600px;
  padding: clamp(72px, 8vw, 112px) 0 0; display: flex; align-items: flex-start; overflow: hidden; }
/* Træk kunde-sektionen op så den døde nederste halvdel af den frigivne
   sticky ikke efterlader et stort tomt mellemrum før portrætterne. */
.mw-steps.is-enhanced + .mw-section { margin-top: clamp(-130px, -7vh, -48px); }
.mw-steps__stage { width: 100%; }

.mw-steps__head { text-align: center; margin-bottom: clamp(24px, 4.5vh, 52px); }
.mw-steps__eyebrow { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14.5px; letter-spacing: 0;
  text-transform: none; color: var(--lime-600); margin-bottom: 10px; }
.mw-steps__eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--lime-500); flex: none; }

.mw-steps__body { display: grid; grid-template-columns: 54px 1fr; gap: clamp(28px, 5vw, 72px); align-items: center; }

/* lodret trin-indikator */
.mw-steps__rail { display: none; list-style: none; margin: 0; padding: 0; flex-direction: column; align-items: center; }
.mw-steps.is-enhanced .mw-steps__rail { display: flex; }
.mw-steps__rail li { position: relative; width: 46px; height: 46px; border-radius: 50%; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-heading); font-weight: 700; font-size: 14px; color: var(--text-muted);
  background: var(--cream-200);
  transition: background var(--dur-base) var(--ease-standard), color var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-steps__rail li:not(:last-child) { margin-bottom: 46px; }
.mw-steps__rail li:not(:last-child)::after { content: ""; position: absolute; top: calc(100% + 2px); left: 50%;
  transform: translateX(-50%); width: 3px; height: 42px; background: var(--cream-300); border-radius: 2px;
  transition: background var(--dur-base) var(--ease-standard); }
.mw-steps__rail li.is-done { background: var(--forest-800); color: #fff; }
.mw-steps__rail li.is-done::after { background: var(--lime-400); }
.mw-steps__rail li.is-active { background: var(--lime-400); color: var(--forest-900);
  transform: scale(1.12); box-shadow: 0 8px 20px rgba(11,36,24,0.18); }

/* trin-slides */
.mw-steps__slides { position: relative; }
.mw-steps__slide { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 64px);
  align-items: center; margin-bottom: 64px; }
.mw-steps__slide:last-child { margin-bottom: 0; }
.mw-steps.is-enhanced .mw-steps__slides { min-height: clamp(360px, 58vh, 560px); }
.mw-steps.is-enhanced .mw-steps__slide { position: absolute; inset: 0; margin: 0;
  opacity: 0; will-change: opacity, transform; backface-visibility: hidden; }

.mw-steps__count { display: inline-block; font-weight: 700; font-size: 13.5px; letter-spacing: 0;
  text-transform: none; color: var(--lime-600); margin-bottom: 14px; }
.mw-steps__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(32px, 4vw, 52px);
  letter-spacing: -0.02em; color: var(--forest-800); margin: 0 0 18px; }
.mw-steps__desc { font-size: clamp(16px, 1.25vw, 19px); line-height: 1.6; color: var(--text-secondary); margin: 0; max-width: 44ch; }
.mw-steps__more { display: inline-block; margin-top: 26px; font-weight: 700; font-size: 15px;
  color: var(--forest-800); text-decoration: none; }
.mw-steps__more:hover { color: var(--lime-600); }

.mw-steps__media { position: relative; aspect-ratio: 4 / 3; border-radius: 24px; overflow: hidden;
  box-shadow: var(--shadow-card);
  background: radial-gradient(120% 100% at 50% 0%, var(--lime-200) 0%, var(--cream-100) 72%); }
.mw-steps__media img { width: 100%; height: 100%; object-fit: contain; display: block; padding: 22px; }
.mw-steps__media--anim { background: #F4F0E8; }
.mw-steps__anim { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; object-fit: cover; }

@media (max-width: 860px) {
  .mw-steps.is-enhanced .mw-steps__inner { height: auto; }
  .mw-steps.is-enhanced .mw-steps__sticky { position: static; height: auto; min-height: 0; padding: 56px 0; overflow: visible; }
  .mw-steps__body { grid-template-columns: 1fr; gap: 0; }
  .mw-steps__rail, .mw-steps.is-enhanced .mw-steps__rail { display: none; }
  .mw-steps.is-enhanced .mw-steps__slides { min-height: 0; }
  .mw-steps__slide, .mw-steps.is-enhanced .mw-steps__slide { position: relative; inset: auto; margin: 0 0 52px;
    opacity: 1; visibility: visible; transform: none; pointer-events: auto; grid-template-columns: 1fr; gap: 24px; }
  .mw-steps__slide:last-child, .mw-steps.is-enhanced .mw-steps__slide:last-child { margin-bottom: 0; }
  .mw-steps__media { order: -1; }
}

/* Testimonials — clickable browser-frame cards.
   Transparent: the scroll-driven backdrop (.mw-bg) leans gently toward a soft
   lime-cream right around this section, so the white cards still lift off it —
   but seamlessly, with no section edge. */
.mw-testi { position: relative; background: transparent; }
.mw-testi__eyebrow { display: inline-block; font-weight: 600; font-size: 14.5px; letter-spacing: 0;
  text-transform: none; color: var(--lime-600); margin-bottom: 12px; }

/* Testimonials header — calm, uniform scattered portraits framing the headline */
.mw-testi__head { position: relative; overflow: hidden; margin: 0 0 6px;
  min-height: clamp(500px, 43vw, 640px); padding: 0; }
.mw-testi__intro { position: relative; z-index: 3; text-align: center; max-width: 560px; margin: 0 auto;
  padding: clamp(208px, 24vw, 312px) 18px clamp(40px, 5vw, 72px); }
.mw-testi__intro > .mw-pill--soft { margin-bottom: 20px; }
.mw-testi__title { font-weight: 700; font-size: clamp(34px, 4.6vw, 60px); line-height: 1.05;
  letter-spacing: -0.03em; color: var(--forest-800); margin: 0; text-wrap: balance; }
.mw-testi__title span { color: var(--ink-300); }
.mw-testi__sub { font-size: clamp(15px, 1.35vw, 18px); color: var(--text-secondary); line-height: 1.6;
  margin: 18px auto 0; max-width: 470px; text-wrap: pretty; }
.mw-testi__rating { display: inline-flex; align-items: center; gap: 10px; margin-top: 24px;
  font-size: 14px; font-weight: 600; color: var(--text-muted); }
.mw-testi__rating b { color: var(--forest-700); font-weight: 700; }
.mw-stars { display: inline-flex; gap: 2px; color: var(--lime-600); font-size: 17px; line-height: 1; }

/* calm, uniform portrait frame (no ghost cards, consistent treatment, gently dimmed) */
.mw-testi__scatter { position: absolute; inset: 0; pointer-events: none;
  -webkit-mask-image: radial-gradient(60% 70% at 50% 46%, transparent 0, transparent 30%, #000 54%);
          mask-image: radial-gradient(60% 70% at 50% 46%, transparent 0, transparent 30%, #000 54%); }
.mw-tscat { position: absolute; left: var(--x); top: var(--y); width: clamp(84px, 8vw, 108px); margin: 0;
  background: #fff; padding: 5px; border-radius: 16px; opacity: 1;
  box-shadow: 0 16px 34px -18px rgba(18,53,36,0.22); }
.mw-tscat img { width: 100%; aspect-ratio: 3 / 4; object-fit: cover; display: block; border-radius: 11px; }

/* mobile: drop the wall, show a compact overlapping avatar row */
.mw-testi__avatars { display: none; justify-content: center; margin: 20px 0 0; }
.mw-testi__avatars img { width: 50px; height: 50px; border-radius: 50%; object-fit: cover;
  border: 3px solid #fff; box-shadow: var(--shadow-float); margin-left: -12px; }
.mw-testi__avatars img:first-child { margin-left: 0; }
@media (max-width: 860px) {
  .mw-testi__head { min-height: 0; padding: clamp(8px, 4vw, 20px) 0; }
  .mw-testi__scatter { display: none; }
  .mw-testi__intro { padding: 0 6px; }
  .mw-testi__avatars { display: flex; }
}

.mw-testi__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 16px; }

.mw-tcard { display: flex; flex-direction: column; height: 100%;
  background: linear-gradient(180deg, #ffffff 0%, var(--cream-100) 100%); border-radius: 26px;
  border: 1px solid rgba(18,53,33,0.07); box-shadow: 0 1px 2px rgba(20,48,36,0.04), 0 18px 42px -18px rgba(20,48,36,0.16);
  overflow: hidden; text-decoration: none; color: inherit;
  transition: box-shadow .35s var(--ease-standard), transform .35s var(--ease-standard), border-color .35s var(--ease-standard); }
.mw-tcard:hover { transform: translateY(-6px); box-shadow: 0 34px 64px -24px rgba(31,90,55,0.34); border-color: rgba(188,213,68,0.55); }
.mw-tcard:focus-visible { outline: 3px solid var(--lime-400); outline-offset: 3px; }

/* screenshot floats as an inset frame (no flat square edge) */
.mw-tcard__shot { position: relative; margin: 15px 15px 0; border-radius: 16px; aspect-ratio: 16 / 10;
  overflow: hidden; background: var(--cream-200); box-shadow: 0 12px 26px -14px rgba(6,20,14,0.45), inset 0 0 0 1px rgba(18,53,33,0.06); }
.mw-tcard__shot img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block;
  transition: transform .6s var(--ease-standard); }
.mw-tcard:hover .mw-tcard__shot img { transform: scale(1.045); }
.mw-tcard__shot::after { content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(11,36,24,0) 56%, rgba(11,36,24,0.34) 100%); }
.mw-tcard__domain { position: absolute; left: 12px; bottom: 12px; z-index: 1; display: inline-flex; align-items: center; gap: 6px;
  max-width: calc(100% - 24px); padding: 7px 13px; border-radius: 999px;
  background: rgba(255,255,255,0.94); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  font-size: 12.5px; font-weight: 700; letter-spacing: -0.01em; color: var(--forest-800);
  box-shadow: 0 4px 14px rgba(6,20,14,0.18); white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  transition: gap .2s var(--ease-standard); }
.mw-tcard__domain svg { width: 13px; height: 13px; flex: none; opacity: .65; }
.mw-tcard:hover .mw-tcard__domain { gap: 9px; }

.mw-tcard__body { display: flex; flex-direction: column; flex: 1; padding: 26px 24px 22px; position: relative; }
.mw-tcard__quote { font-size: 15.5px; line-height: 1.62; color: var(--forest-800); font-weight: 500;
  margin: 0 0 22px; flex: 1; text-wrap: pretty; position: relative; padding-top: 26px; }
.mw-tcard__quote::before { content: "\201C"; position: absolute; top: -8px; left: -2px;
  font-family: var(--font-heading); font-weight: 700; font-size: 56px; line-height: 1; color: var(--lime-500); opacity: .9; }
.mw-tcard__foot { display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding-top: 18px; border-top: 1px solid rgba(18,53,33,0.08); }
.mw-tcard__foot::after { content: "\2605\2605\2605\2605\2605"; font-size: 13px; letter-spacing: 1px; color: var(--lime-500); flex: none; }
.mw-tcard__person { display: flex; align-items: center; gap: 11px; min-width: 0; }
.mw-tcard__avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex: none;
  border: 2px solid var(--lime-300); background: var(--cream-200); }
.mw-tcard__meta { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.mw-tcard__meta strong { font-weight: 700; font-size: 14.5px; color: var(--forest-800); }
.mw-tcard__meta span { font-size: 12.5px; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* (browser-chrome + redundant "Besøg" link removed — domain chip lives on the screenshot now) */

@media (max-width: 980px) { .mw-testi__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .mw-testi__grid { grid-template-columns: 1fr; } }

/* Best at */
.mw-bestgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.mw-feature { background: #fff; border-radius: 24px; box-shadow: var(--shadow-card); padding: 34px; }
.mw-feature__icon { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px;
  border-radius: 14px; background: var(--cream-200); color: var(--forest-800); margin-bottom: 20px; }
.mw-feature__icon svg { width: 26px; height: 26px; }
.mw-feature__title { font-weight: 700; font-size: 23px; color: var(--forest-800); margin: 0 0 12px; }
.mw-feature__body { font-size: 15.5px; color: var(--text-secondary); line-height: 1.6; margin: 0; }
.mw-feature__divider { height: 1px; background: var(--border); margin: 22px 0; }
.mw-checklist { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.mw-checklist li { display: flex; align-items: center; gap: 11px; font-size: 15px; font-weight: 600; color: var(--text-secondary); }
.mw-check { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; flex: none;
  border-radius: 50%; background: var(--lime-400); color: var(--forest-800); font-size: 12px; font-weight: 700; }

/* Fundament */
.mw-fund-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 32px; }
.mw-fund-doodle { position: relative; display: inline-flex; flex-direction: column; align-items: center; }
.mw-fund-doodle img { width: 90px; height: 22px; }
.mw-fund-doodle em { font-style: italic; font-size: 13px; color: var(--text-muted); margin-top: 2px; }
.mw-fcard { background: #fff; border-radius: 22px; box-shadow: var(--shadow-card); padding: 28px; }
.mw-fcard__icon { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px;
  border-radius: 50%; background: var(--lime-200); color: var(--forest-700); margin-bottom: 18px; }
.mw-fcard__icon svg { width: 22px; height: 22px; }
.mw-fcard__title { font-weight: 700; font-size: 21px; color: var(--forest-800); margin: 0 0 8px; }
.mw-fcard__body { font-size: 15px; color: var(--text-secondary); line-height: 1.55; margin: 0; }
.mw-fcard--dark { background: var(--forest-800); }
.mw-fcard--dark .mw-fcard__icon { background: var(--lime-400); color: var(--forest-900); }
.mw-fcard--dark .mw-fcard__title { color: var(--lime-400); }
.mw-fcard--dark .mw-fcard__body { color: var(--on-forest-muted); }

/* About */
.mw-about__title { margin-top: 16px; max-width: 14ch; }
.mw-about__lead { font-size: 16px; color: var(--text-secondary); line-height: 1.6; max-width: 52ch; margin: 16px 0 40px; }
.mw-about__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 28px; align-items: stretch; }
.mw-photo { position: relative; border-radius: 22px; overflow: hidden; min-height: 320px;
  background: linear-gradient(150deg, #2c4636, #16301f); box-shadow: var(--shadow-card); }
.mw-photo__ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: rgba(244,240,232,0.4); }
.mw-photo__name { position: absolute; left: 16px; bottom: 16px; right: 16px; background: rgba(245,243,236,0.92);
  backdrop-filter: blur(6px); border-radius: 12px; padding: 12px 16px; }
.mw-photo__name strong { display: block; font-weight: 700; font-size: 16px; color: var(--forest-800); }
.mw-photo__name span { font-size: 13px; color: var(--text-muted); }
.mw-dedication { background: var(--cream-200); border-radius: 22px; padding: 34px; }
.mw-dedication__title { font-weight: 700; font-size: 24px; color: var(--forest-800); margin: 0 0 12px; }
.mw-dedication__body { font-size: 15px; color: var(--text-secondary); line-height: 1.6; margin: 0 0 24px; }
.mw-statgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.mw-statbox { background: #fff; border-radius: 14px; padding: 20px; text-align: center; }
.mw-statbox__num { display: block; font-weight: 700; font-size: 32px; letter-spacing: -0.02em; color: var(--forest-800); }
.mw-statbox__label { font-size: 11px; font-weight: 700; letter-spacing: .06em; color: var(--text-muted); }

/* CTA band */
.mw-cta { background: var(--forest-800); border-radius: 32px; margin: 40px 24px; padding: 64px 24px; }
.mw-cta__inner { text-align: center; max-width: 620px; margin: 0 auto; }
.mw-cta__title { font-weight: 700; font-size: 38px; letter-spacing: -0.02em; color: #fff; margin: 18px 0 0; }
.mw-cta__sub { font-size: 17px; color: var(--on-forest-muted); margin: 14px 0 28px; line-height: 1.55; }
.mw-cta__row { display: flex; align-items: center; justify-content: center; gap: 22px; flex-wrap: wrap; }
.mw-cta__mail { font-weight: 600; color: var(--lime-400); text-decoration: none; }

/* Footer */
.mw-footer { background: var(--forest-900); color: var(--on-forest-muted); padding: 64px 0 36px; }
.mw-footer__top { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.1fr 1.25fr; gap: 40px; align-items: start; padding-bottom: 40px; border-bottom: 1px solid var(--border-on-dark); }
.mw-footer__logo { height: 30px; width: auto; }
.mw-footer__tag { font-size: 15px; line-height: 1.6; max-width: 340px; margin: 18px 0 0; }
.mw-footer__usps { list-style: none; margin: 20px 0 0; padding: 0; display: flex; flex-direction: column; align-items: flex-start; gap: 11px; }
.mw-footer__usps li { display: flex; align-items: center; gap: 9px; font-weight: 700; font-size: 14.5px; color: var(--on-forest-muted); }
.mw-footer__check { display: grid; place-items: center; width: 20px; height: 20px; border-radius: 6px;
  background: var(--lime-400); color: var(--forest-900); flex: none; }
.mw-footer__check svg { width: 13px; height: 13px; }
.mw-footer__map { border-radius: 16px; overflow: hidden; border: 1px solid var(--border-on-dark); align-self: stretch; min-height: 180px; }
.mw-footer__map iframe { width: 100%; height: 100%; min-height: 180px; border: 0; display: block; }
@media (max-width: 1100px) { .mw-footer__map { min-height: 200px; } }
/* Betalingsmetoder */
.mw-footer__pay { margin: 24px 0 0; }
.mw-footer__paylabel { display: block; font-size: 12.5px; letter-spacing: 0; text-transform: none;
  color: var(--on-forest-faint); margin-bottom: 10px; }
.mw-footer__paylogos { height: 30px; width: auto; display: block; border-radius: 5px; }
/* Google Maps — Hørsholm (kompakt højre kolonne, balanceret med rækken) */
.mw-footer__map { position: relative; display: block; width: 100%; height: 150px;
  border-radius: 16px; overflow: hidden; border: 1px solid var(--border-on-dark);
  box-shadow: 0 18px 40px -22px rgba(0,0,0,0.6); }
.mw-footer__map iframe { width: 100%; height: 100%; border: 0; display: block;
  filter: grayscale(0.4) contrast(1.02); transition: filter var(--dur-base) var(--ease-standard); }
.mw-footer__map:hover iframe { filter: grayscale(0) contrast(1); }
.mw-footer__mappin { position: absolute; left: 12px; bottom: 12px; display: inline-flex; align-items: center; gap: 6px;
  background: rgba(11,30,20,0.82); color: #fff; font-size: 13px; font-weight: 600;
  padding: 6px 11px; border-radius: 999px; backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); }
.mw-footer__col { display: flex; flex-direction: column; gap: 12px; }
.mw-footer__h { font-weight: 700; font-size: 14px; color: var(--on-forest-strong); margin-bottom: 4px; }
.mw-footer__link { color: var(--on-forest-muted); font-size: 15px; text-decoration: none; }
.mw-footer__link:hover { color: var(--lime-400); }
.mw-footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 26px; font-size: 14px; color: var(--on-forest-faint); gap: 16px; flex-wrap: wrap; }
.mw-footer__legal { display: flex; gap: 22px; flex-wrap: wrap; }
.mw-footer__legal a { color: var(--on-forest-faint); text-decoration: none; }
.mw-footer__legal a:hover { color: var(--on-forest-muted); }
.mw-footer__social { display: flex; gap: 10px; }
.mw-footer__social a { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 10px;
  background: rgba(255,255,255,0.08); color: #fff; transition: background var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard); }
.mw-footer__social a:hover { background: var(--lime-400); color: var(--forest-900); }
.mw-footer__social svg { width: 19px; height: 19px; }

/* ---------- Karriere ---------- */
.mw-karriere { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch; }
.mw-karriere__card { background: #fff; border: 1px solid rgba(18,53,33,0.08); border-radius: 28px;
  padding: clamp(32px, 4vw, 52px); display: flex; flex-direction: column; justify-content: center; box-shadow: var(--shadow-card); }
.mw-karriere__icon { display: grid; place-items: center; width: 60px; height: 60px; border-radius: 16px;
  background: var(--lime-200); color: var(--forest-700); margin-bottom: 24px; }
.mw-karriere__icon svg { width: 30px; height: 30px; }
.mw-karriere__card h2 { font-family: var(--font-heading); font-weight: 700; font-size: clamp(24px, 2.6vw, 32px);
  letter-spacing: -0.02em; color: var(--forest-800); margin: 0 0 14px; text-wrap: balance; }
.mw-karriere__card > p { font-size: 16.5px; line-height: 1.65; color: var(--text-secondary); margin: 0 0 28px; text-wrap: pretty; }
.mw-karriere__card .mw-btn { align-self: flex-start; }
.mw-karriere__note { font-size: 14px; color: var(--text-muted); margin: 16px 0 0 !important; }
.mw-karriere__photo { position: relative; margin: 0; border-radius: 28px; overflow: hidden; background: var(--forest-800);
  box-shadow: var(--shadow-card-hover); min-height: 100%; }
.mw-karriere__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 28%; }
.mw-karriere__photo figcaption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 1; padding: 30px 28px;
  background: linear-gradient(180deg, transparent 0%, rgba(11,36,24,0.5) 45%, rgba(11,36,24,0.94) 100%); color: #fff; font-weight: 700; font-size: 18px; }
.mw-karriere__photo figcaption span { display: block; font-weight: 500; font-size: 14.5px; color: rgba(244,240,232,0.84); margin-top: 6px; }
@media (max-width: 860px) { .mw-karriere { grid-template-columns: 1fr; } .mw-karriere__photo { min-height: 360px; } }

/* ---------- Buttons (generic) ---------- */
.mw-btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-family: var(--font-brand);
  font-weight: 700; font-size: 16px; cursor: pointer; text-decoration: none; border: 1px solid transparent;
  border-radius: 999px; padding: 14px 26px; transition: filter var(--dur-fast) var(--ease-standard), transform var(--dur-fast) var(--ease-standard); }
.mw-btn--lime { background: var(--lime-400); color: var(--forest-900); }
.mw-btn--forest { background: var(--forest-800); color: #fff; }
.mw-btn--ghost { background: transparent; color: var(--forest-800); border-color: var(--forest-800); }
.mw-btn:hover { filter: brightness(1.04); transform: translateY(-1px); }
.mw-btn[disabled] { opacity: .55; cursor: not-allowed; transform: none; }
.mw-btn svg { width: 18px; height: 18px; flex: none; }

/* ---------- Milestone toast ---------- */
.mw-mtoast { position: fixed; right: 24px; bottom: 24px; z-index: 60; display: flex; align-items: center; gap: 12px;
  padding: 14px 20px 14px 16px; border-radius: 16px; background: var(--forest-900);
  border: 1px solid rgba(199,237,92,0.4); box-shadow: 0 22px 50px -22px rgba(0,0,0,0.7);
  font-family: var(--font-brand); color: #fff; max-width: calc(100vw - 48px);
  opacity: 0; transform: translateY(16px); pointer-events: none;
  transition: opacity .5s var(--ease-standard), transform .5s var(--ease-standard); }
.mw-mtoast.is-visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.mw-mtoast__icon { display: grid; place-items: center; width: 34px; height: 34px; flex: none;
  border-radius: 50%; background: var(--lime-400); color: var(--forest-900); }
.mw-mtoast__icon svg { width: 19px; height: 19px; }
.mw-mtoast__text { font-size: 16px; font-weight: 600; line-height: 1.2; }
.mw-mtoast__text strong { font-weight: 800; }
@media (max-width: 600px) { .mw-mtoast { right: 16px; left: 16px; bottom: 16px; } }

/* ---------- Page header (non-hero pages) ---------- */
.mw-pagehead { padding: 150px 0 30px; }
.mw-pagehead h1 { font-weight: 700; font-size: 52px; letter-spacing: -0.025em; color: var(--forest-800); margin: 16px 0 0; }
.mw-pagehead p { font-size: 18px; color: var(--text-secondary); max-width: 56ch; margin: 16px 0 0; line-height: 1.6; }

/* ---------- Contact page ---------- */
.mw-cp { padding: 140px 0 80px; }
.mw-cp-grid { display: grid; grid-template-columns: 1fr 1.15fr; gap: 48px; align-items: start; }
.mw-cp-info { background: var(--forest-800); border-radius: 28px; padding: 44px; }
.mw-cp-eyebrow { font-weight: 700; font-size: 12px; letter-spacing: .08em; color: var(--lime-400); }
.mw-cp-title { font-weight: 700; font-size: 38px; letter-spacing: -0.02em; color: #fff; margin: 14px 0 16px; }
.mw-cp-lead { font-size: 16px; line-height: 1.6; color: var(--on-forest-muted); margin: 0 0 30px; }
.mw-cp-details { display: flex; flex-direction: column; gap: 18px; padding: 24px 0; border-top: 1px solid var(--border-on-dark); border-bottom: 1px solid var(--border-on-dark); }
.mw-cp-detail { display: flex; flex-direction: column; gap: 3px; }
.mw-cp-detail__label { font-size: 13px; color: var(--on-forest-faint); }
.mw-cp-detail__value { font-weight: 600; font-size: 18px; color: #fff; text-decoration: none; }
a.mw-cp-detail__value:hover { color: var(--lime-400); }
.mw-cp-proof { display: flex; align-items: center; gap: 14px; margin-top: 26px; }
.mw-cp-proof__img { height: 50px; width: auto; }
.mw-cp-proof__text { font-weight: 600; font-size: 14px; line-height: 1.3; color: #fff; }
/* team photo inside contact panel (home "Er Moneyweb noget for mig?") */
.mw-cp-photo { margin: 30px 0 0; }
.mw-cp-photo img { width: 100%; border-radius: 18px; aspect-ratio: 3 / 2; object-fit: cover;
  object-position: center; box-shadow: 0 18px 44px rgba(6,20,14,0.30); display: block; }
.mw-cp-photo figcaption { display: flex; align-items: center; gap: 9px; font-size: 13.5px;
  font-weight: 600; color: var(--on-forest-muted); margin-top: 15px; }
.mw-cp-photo figcaption::before { content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--lime-400); flex: none; }
.mw-cp-form { background: #fff; border-radius: 28px; box-shadow: var(--shadow-card); padding: 36px; display: flex; flex-direction: column; gap: 18px; }
.mw-form-row { display: flex; gap: 16px; }
.mw-field { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.mw-field label { font-weight: 600; font-size: 14px; color: var(--text-secondary); }
.mw-field input, .mw-field textarea, .mw-field select { font-family: var(--font-body); font-weight: 500; font-size: 15px;
  color: var(--text-primary); background: var(--cream-50); border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; width: 100%; }
.mw-field textarea { resize: vertical; line-height: 1.55; }
.mw-field input:focus, .mw-field textarea:focus, .mw-field select:focus { outline: none; border-color: var(--forest-700); box-shadow: 0 0 0 3px rgba(188,213,68,0.35); }
.mw-checkrow { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--text-secondary); }
.mw-checkrow input { width: 18px; height: 18px; margin-top: 2px; accent-color: var(--lime-500); flex: none; }
.mw-formnote { font-size: 13px; color: var(--text-muted); margin: 0; }
.mw-formstatus { font-size: 15px; font-weight: 600; padding: 12px 16px; border-radius: 12px; display: none; }
.mw-formstatus.is-ok { display: block; background: #E1EFE6; color: #27623E; }
.mw-formstatus.is-err { display: block; background: #F4DFD6; color: #8C3A1E; }

/* ---------- Contact page — enhanced ---------- */
.mw-cp-info { position: relative; overflow: hidden; }
.mw-cp-glow { position: absolute; pointer-events: none; width: 360px; height: 360px; border-radius: 50%;
  top: -150px; right: -120px; background: radial-gradient(circle, rgba(47,115,81,0.6) 0%, transparent 70%); }
.mw-cp-info > * { position: relative; z-index: 1; }
.mw-cp-eyebrow { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14.5px; letter-spacing: 0; color: var(--lime-400); }
.mw-cp-eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--lime-400); flex: none; }
.mw-cp-rows { display: flex; flex-direction: column; gap: 4px; padding: 14px 0; margin: 24px 0;
  border-top: 1px solid var(--border-on-dark); border-bottom: 1px solid var(--border-on-dark); }
.mw-cp-row { display: flex; align-items: center; gap: 16px; padding: 12px 0; text-decoration: none; }
.mw-cp-row__icon { flex: none; display: grid; place-items: center; width: 46px; height: 46px; border-radius: 13px;
  background: rgba(188,213,68,0.16); color: var(--lime-400); }
.mw-cp-row__icon svg { width: 22px; height: 22px; }
.mw-cp-row__txt { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mw-cp-row__label { font-size: 13px; color: var(--on-forest-faint); }
.mw-cp-row__value { font-weight: 600; font-size: 17.5px; color: #fff; white-space: nowrap; }
a.mw-cp-row:hover .mw-cp-row__value { color: var(--lime-400); }
.mw-cp-hours { display: flex; align-items: center; gap: 12px; font-size: 14.5px; color: var(--on-forest-muted); }
.mw-cp-hours svg { width: 19px; height: 19px; color: var(--lime-400); flex: none; }
.mw-cp-hours strong { color: #fff; font-weight: 700; }
.mw-cp-people { display: flex; align-items: center; gap: 14px; margin-top: 30px; padding-top: 26px; border-top: 1px solid var(--border-on-dark); }
.mw-cp-people__imgs { display: flex; }
.mw-cp-people__imgs img { width: 50px; height: 50px; border-radius: 50%; object-fit: cover;
  border: 2px solid var(--forest-800); box-shadow: 0 0 0 2px var(--lime-400); }
.mw-cp-people__imgs img:not(:first-child) { margin-left: -14px; }
.mw-cp-people span { font-weight: 600; font-size: 14.5px; line-height: 1.4; color: #fff; }
.mw-cp-people span b { color: var(--lime-400); font-weight: 700; }
.mw-cp-janek { display: flex; align-items: center; gap: 18px; margin-top: 30px; padding-top: 26px; border-top: 1px solid var(--border-on-dark); }
.mw-cp-janek img { width: 112px; height: 112px; border-radius: 18px; object-fit: cover; object-position: center 22%;
  flex: none; box-shadow: 0 14px 30px rgba(6,20,14,0.4); }
.mw-cp-janek figcaption { font-size: 15.5px; line-height: 1.5; color: var(--on-forest-muted); margin: 0; }
.mw-cp-janek figcaption strong { color: #fff; font-weight: 700; }
.mw-cp-janek figcaption span { display: block; margin-top: 6px; color: var(--on-forest-faint); }
.mw-cp-map { margin-top: 28px; border-radius: 24px; overflow: hidden; box-shadow: var(--shadow-card);
  border: 1px solid rgba(18,53,33,0.08); }
.mw-cp-map iframe { width: 100%; height: 380px; border: 0; display: block; }
@media (max-width: 560px) { .mw-cp-map iframe { height: 280px; } }

/* ---------- Contact form — photo card + iconed form (home) ---------- */
.mw-cf { display: grid; grid-template-columns: 1.3fr 1fr; gap: 32px; align-items: stretch; }

/* left: photo card with overlay CTA */
.mw-cf__photo { position: relative; border-radius: 28px; overflow: hidden; min-height: 520px;
  box-shadow: var(--shadow-card); }
.mw-cf__photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.mw-cf__photo::after { content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg,
    rgba(11,36,24,0) 0%,
    rgba(11,36,24,0.04) 42%,
    rgba(18,53,33,0.52) 70%,
    rgba(11,36,24,0.94) 100%); }
.mw-cf__overlay { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: clamp(26px, 3vw, 42px); }
.mw-cf__ptitle { font-weight: 700; font-size: clamp(22px, 2.4vw, 30px); letter-spacing: -0.02em; color: #fff; margin: 0 0 12px; }
.mw-cf__psub { font-size: 15px; line-height: 1.55; color: rgba(244,240,232,0.86); margin: 0 0 24px; max-width: 38ch; }
.mw-cf__call { display: inline-flex; align-items: center; gap: 12px; background: #fff; color: var(--forest-900);
  font-family: var(--font-brand); font-weight: 700; font-size: 15px; padding: 9px 9px 9px 22px; border-radius: 999px;
  text-decoration: none; box-shadow: 0 12px 28px rgba(6,20,14,0.30);
  transition: transform var(--dur-fast) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-cf__call:hover { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(6,20,14,0.36); }
.mw-cf__callarrow { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px;
  border-radius: 50%; background: var(--forest-900); color: #fff; flex: none; }
.mw-cf__callarrow svg { width: 16px; height: 16px; }

/* right: form card */
.mw-cf__form { background: var(--cream-100); border-radius: 28px; padding: clamp(26px, 3vw, 40px);
  box-shadow: var(--shadow-card); display: flex; flex-direction: column; gap: 18px; }
.mw-cf__row { display: flex; gap: 16px; }
.mw-cf__field { display: flex; flex-direction: column; gap: 8px; flex: 1; min-width: 0; }
.mw-cf__field > label { font-weight: 700; font-size: 13.5px; color: var(--forest-800); }
.mw-cf__input { position: relative; display: flex; align-items: center; background: #fff;
  border: 1px solid var(--cream-300); border-radius: 14px;
  transition: border-color var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-cf__input:focus-within { border-color: var(--forest-700); box-shadow: 0 0 0 3px rgba(188,213,68,0.35); }
.mw-cf__input > svg { width: 18px; height: 18px; margin-left: 16px; color: var(--ink-300); flex: none; }
.mw-cf__input input, .mw-cf__input select { flex: 1; min-width: 0; border: none; background: transparent; outline: none;
  font-family: var(--font-body); font-weight: 500; font-size: 15px; color: var(--text-primary); padding: 14px 16px; }
.mw-cf__input select { appearance: none; -webkit-appearance: none; cursor: pointer; padding-right: 42px; }
.mw-cf__input select:has(option[value=""]:checked) { color: var(--ink-300); }
.mw-cf__chev { position: absolute; right: 16px; width: 18px; height: 18px; color: var(--ink-500); pointer-events: none; }
.mw-cf__input input::placeholder, .mw-cf__form textarea::placeholder { color: var(--ink-300); }
.mw-cf__form textarea { background: #fff; border: 1px solid var(--cream-300); border-radius: 14px; padding: 14px 16px;
  font-family: var(--font-body); font-weight: 500; font-size: 15px; color: var(--text-primary); line-height: 1.55;
  resize: vertical; outline: none; transition: border-color var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-cf__form textarea:focus { border-color: var(--forest-700); box-shadow: 0 0 0 3px rgba(188,213,68,0.35); }
.mw-cf__submit { align-self: flex-start; margin-top: 2px; }
.mw-cf__submit svg { width: 17px; height: 17px; }

@media (max-width: 880px) {
  .mw-cf { grid-template-columns: 1fr; }
  .mw-cf__photo { min-height: 340px; }
}
@media (max-width: 520px) { .mw-cf__row { flex-direction: column; } }

/* ---------- Cookie banner ---------- */
.mw-cookie { position: fixed; left: 24px; bottom: 24px; right: auto; max-width: 420px; z-index: 300;
  background: #fff; border-radius: 20px; box-shadow: var(--shadow-card-hover); padding: 24px; display: none; }
.mw-cookie.is-visible { display: block; }
.mw-cookie h3 { font-weight: 700; font-size: 18px; color: var(--forest-800); margin: 0 0 8px; }
.mw-cookie p { font-size: 14px; color: var(--text-secondary); line-height: 1.55; margin: 0 0 18px; }
.mw-cookie p a { color: var(--forest-700); font-weight: 600; }
.mw-cookie__row { display: flex; gap: 10px; flex-wrap: wrap; }
.mw-cookie__row .mw-btn { padding: 11px 20px; font-size: 14px; }

/* ---------- Intro animation ---------- */
#mw-intro { position: fixed; inset: 0; z-index: 9999; background: #123521; display: flex; align-items: center; justify-content: center; cursor: pointer; overflow: hidden; }
#mw-intro::after { content: ''; position: absolute; inset: 0; background: radial-gradient(60% 50% at 50% 45%, rgba(188,213,68,0.10) 0%, transparent 70%); pointer-events: none; }
#mw-intro.mw-intro--out { opacity: 0; transform: scale(1.03); transition: opacity .6s var(--ease-out), transform .6s var(--ease-out); pointer-events: none; }
.mw-seq { display: inline-flex; align-items: center; white-space: nowrap; padding: 0 24px; font-size: clamp(28px, 6.2vw, 72px); animation: mwSeqIn .7s var(--ease-out) both; }
.mw-seq img { display: block; }
.mw-seq__icon { height: 1.15em; max-width: 1.5em; opacity: 1; margin-right: .14em; overflow: hidden;
  transition: max-width .55s var(--ease-standard), opacity .45s var(--ease-standard), margin .55s var(--ease-standard); }
.mw-seq__money { height: .8em; }
.mw-seq__web { height: .76em; }
.mw-seq__less, .mw-seq__better { font-size: 1.38em; }
.mw-seq__txt { font-family: 'Comfortaa', ui-rounded, 'Segoe UI', system-ui, sans-serif; font-weight: 400; font-size: .58em; color: #fff; line-height: 1; overflow: hidden;
  max-width: 0; opacity: 0; white-space: nowrap; transition: max-width .6s var(--ease-out), opacity .5s var(--ease-out) .05s, margin .6s var(--ease-out); }
.mw-seq.is-tagline .mw-seq__icon { max-width: 0; opacity: 0; margin-right: 0; }
.mw-seq.is-tagline .mw-seq__less { max-width: 4em; opacity: 1; margin-right: .42em; }
.mw-seq.is-tagline .mw-seq__dot1 { max-width: .7em; opacity: 1; margin-right: .5em; }
.mw-seq.is-tagline .mw-seq__better { max-width: 5em; opacity: 1; margin-right: .42em; }
.mw-seq.is-tagline .mw-seq__dot2 { max-width: .7em; opacity: 1; }
@keyframes mwSeqIn { from { opacity: 0; transform: translateY(14px) scale(.96); filter: blur(5px); } to { opacity: 1; transform: none; filter: blur(0); } }

/* ---------- Responsive ---------- */
@media (max-width: 1120px) { .mw-nav2__links { gap: 22px; } }

/* Nav dropdown — "Vi tilbyder" */
.mw-nav2__drop { position: relative; }
.mw-nav2__droptoggle { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-brand);
  font-weight: 600; font-size: 16px; color: rgba(255,255,255,0.86); background: none; border: none; padding: 0;
  cursor: pointer; white-space: nowrap; transition: color var(--dur-fast) var(--ease-standard); }
.mw-nav2__droptoggle svg { width: 15px; height: 15px; transition: transform .25s var(--ease-standard); }
.mw-nav2__drop:hover .mw-nav2__droptoggle, .mw-nav2__drop:focus-within .mw-nav2__droptoggle { color: #fff; }
.mw-nav2.is-white .mw-nav2__droptoggle, .mw-nav2--solid .mw-nav2__droptoggle { color: var(--text-secondary); }
.mw-nav2.is-white .mw-nav2__drop:hover .mw-nav2__droptoggle, .mw-nav2.is-white .mw-nav2__drop:focus-within .mw-nav2__droptoggle,
.mw-nav2--solid .mw-nav2__drop:hover .mw-nav2__droptoggle, .mw-nav2--solid .mw-nav2__drop:focus-within .mw-nav2__droptoggle { color: var(--forest-800); }
.mw-nav2__drop:hover .mw-nav2__droptoggle svg, .mw-nav2__drop:focus-within .mw-nav2__droptoggle svg { transform: rotate(180deg); }
.mw-nav2__menu { position: absolute; top: calc(100% + 12px); left: 50%; transform: translateX(-50%) translateY(8px);
  min-width: 236px; background: #fff; border: 1px solid rgba(18,53,33,0.07); border-radius: 16px; padding: 8px;
  box-shadow: 0 22px 54px -18px rgba(18,53,33,0.32); display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden; transition: opacity .2s var(--ease-standard), transform .2s var(--ease-standard), visibility .2s; }
.mw-nav2__menu::before { content: ""; position: absolute; left: 0; right: 0; top: -14px; height: 14px; }
.mw-nav2__drop:hover .mw-nav2__menu, .mw-nav2__drop:focus-within .mw-nav2__menu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.mw-nav2__menu a { display: flex; align-items: center; gap: 11px; padding: 11px 14px; border-radius: 11px;
  color: var(--forest-800) !important; font-weight: 600; font-size: 15px; white-space: nowrap; }
.mw-nav2__menu a svg { width: 19px; height: 19px; flex: none; color: var(--lime-600); }
.mw-nav2__menu a:hover { background: var(--lime-200); }
/* mobil drawer subgroup */
.mw-drawer__sublabel { font-size: 12.5px; font-weight: 700; letter-spacing: .04em; color: var(--lime-600); margin: 6px 0 -2px; }
/* Laptops (15" / 14") — skaler tekst & afstande ned */
@media (max-width: 1536px) {
  .mw-hero__inner { padding-top: 116px; }
  .mw-hero__title { font-size: 56px; }
  .mw-hero__sub { font-size: 34px; }
  .mw-hero__checks li { font-size: 17px; }
  .mw-hero__note { font-size: 16px; }
  .mw-hero__cards { margin-top: 44px; }
  .mw-h2 { font-size: 33px; }
  .mw-hcard__title { font-size: 24px; }
  .mw-pagehead h1 { font-size: 46px; }
}
/* Mindre laptops (13") */
@media (max-width: 1366px) {
  .mw-hero__inner { padding: 110px 40px 48px; }
  .mw-hero__title { font-size: 47px; }
  .mw-hero__sub { font-size: 28px; }
  .mw-hero__checks { margin-top: 24px; }
  .mw-hero__checks li { font-size: 15.5px; }
  .mw-hero__cards { margin-top: 38px; gap: 18px; }
  .mw-hcard { padding: 26px 22px 20px; }
  .mw-hcard__title { font-size: 22px; }
  .mw-hcard__pre { font-size: 14px; }
  .mw-h2 { font-size: 30px; }
  .mw-pagehead { padding: 130px 0 26px; }
  .mw-pagehead h1 { font-size: 40px; }
  .mw-pagehead p { font-size: 16px; }
  .mw-section { padding: clamp(60px, 7vw, 96px) 0; }
}
@media (max-width: 960px) {
  .mw-container { padding: 0 24px; }
  .mw-hero__cards, .mw-bestgrid, .mw-about__grid, .mw-cp-grid { grid-template-columns: 1fr; }
  .mw-steps { grid-template-columns: 1fr 1fr; }
  .mw-grid-3 { grid-template-columns: 1fr; }
  .mw-hero__title { font-size: 42px; }
  .mw-hero__sub { font-size: 30px; }
  .mw-footer__top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  .mw-nav2__links, .mw-nav2__cta { display: none; }
  .mw-nav2__burger { display: inline-flex; }
  .mw-hero__inner { padding-top: 130px; }
}
@media (max-width: 560px) {
  .mw-form-row { flex-direction: column; }
  .mw-steps { grid-template-columns: 1fr; }
  .mw-footer__top { grid-template-columns: 1fr; }
  .mw-cookie { left: 16px; right: 16px; bottom: 16px; max-width: none; }
  .mw-pagehead h1 { font-size: 38px; }
}
@media (prefers-reduced-motion: reduce) {
  #mw-intro { display: none; }
  html { scroll-behavior: auto; }
}
@media (max-width: 600px) {
  #mw-intro { display: none !important; }
}

/* ==========================================================================
   OM OS (About page)
   ========================================================================== */
.mw-omos-eyebrow { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14.5px; letter-spacing: 0;
  text-transform: none; color: var(--lime-600); margin: 0 0 14px; }
.mw-omos-eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--lime-500); flex: none; }

/* ----- Kunder: lille hero ----- */
.mw-khero { padding: 150px 0 8px; text-align: center; }
.mw-khero__inner { max-width: 760px; margin: 0 auto; }
.mw-khero__title { font-family: var(--font-heading); font-weight: 700; letter-spacing: -0.03em;
  font-size: clamp(38px, 5vw, 60px); line-height: 1.02; color: var(--forest-800); margin: 0; text-wrap: balance; }
.mw-khero__title em { font-style: normal; color: var(--lime-600); }
.mw-khero__sub { font-size: 18px; line-height: 1.6; color: var(--text-secondary); margin: 18px auto 0; max-width: 54ch; text-wrap: pretty; }

/* ----- Intro / hero ----- */
.mw-omos-hero { padding: 150px 0 0; }
.mw-omos-hero__grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(32px, 4.5vw, 72px); align-items: center; }
.mw-omos-hero__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(40px, 5.2vw, 64px);
  line-height: 1.02; letter-spacing: -0.03em; color: var(--forest-800); margin: 0; text-wrap: balance; }
.mw-omos-hero__title em { font-style: normal; color: var(--lime-600); }
.mw-omos-hero__lead { font-size: clamp(16px, 1.3vw, 19px); line-height: 1.65; color: var(--text-secondary);
  margin: 24px 0 0; max-width: 50ch; text-wrap: pretty; }
.mw-omos-hero__lead strong { color: var(--forest-700); font-weight: 700; }
.mw-omos-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.mw-omos-hero__photo { position: relative; border-radius: 28px; overflow: hidden; aspect-ratio: 4 / 3;
  box-shadow: var(--shadow-card-hover); background: var(--forest-800); }
.mw-omos-hero__photo img { width: 100%; height: 100%; object-fit: cover; object-position: center 30%; }
.mw-omos-hero__badge { position: absolute; left: 16px; bottom: 16px; display: inline-flex; align-items: center; gap: 9px;
  padding: 9px 16px 9px 13px; border-radius: 999px; background: rgba(255,255,255,0.94);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  font-weight: 700; font-size: 13.5px; color: var(--forest-800); box-shadow: 0 10px 26px rgba(6,20,14,0.22); }
.mw-omos-hero__badge svg { width: 16px; height: 16px; color: var(--lime-600); }

/* ----- Section heading ----- */
.mw-sechead { text-align: center; max-width: 700px; margin: 0 auto clamp(36px, 4vw, 56px); }
.mw-sechead h2 { font-family: var(--font-heading); font-weight: 700; font-size: clamp(28px, 3.4vw, 44px);
  letter-spacing: -0.025em; color: var(--forest-800); margin: 0; text-wrap: balance; }
.mw-sechead p { font-size: 17px; line-height: 1.6; color: var(--text-secondary); margin: 16px auto 0; max-width: 56ch; text-wrap: pretty; }

/* ----- Bento ----- */
.mw-bento { display: grid; grid-template-columns: repeat(12, 1fr); gap: 22px; }
.mw-bento > .span-8 { grid-column: span 8; }
.mw-bento > .span-7 { grid-column: span 7; }
.mw-bento > .span-6 { grid-column: span 6; }
.mw-bento > .span-5 { grid-column: span 5; }
.mw-bento > .span-4 { grid-column: span 4; }
.mw-bento > .row-2 { grid-row: span 2; }
.mw-bcard { position: relative; overflow: hidden; background: #fff; border: 1px solid rgba(18,53,33,0.06);
  border-radius: 24px; padding: clamp(26px, 2.4vw, 36px);
  box-shadow: 0 1px 2px rgba(20,48,36,0.04), 0 16px 38px rgba(20,48,36,0.06);
  transition: transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-bcard--hover:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }
.mw-bcard__icon { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px;
  border-radius: 50%; background: var(--lime-400); color: var(--forest-900); margin-bottom: 20px; }
.mw-bcard__icon svg { width: 23px; height: 23px; }
.mw-bcard__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(20px, 1.7vw, 25px);
  letter-spacing: -0.01em; color: var(--forest-800); margin: 0 0 12px; }
.mw-bcard__body { font-size: 15.5px; line-height: 1.65; color: var(--text-secondary); margin: 0; text-wrap: pretty; }
.mw-bcard__img { margin-top: 24px; border-radius: 14px; overflow: hidden; aspect-ratio: 16 / 9; background: var(--cream-100); }
.mw-bcard__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mw-bcard--dark { background: var(--forest-800); border-color: transparent; }
.mw-bcard--dark .mw-bcard__title { color: #fff; }
.mw-bcard--dark .mw-bcard__body { color: var(--on-forest-muted); }
.mw-bcard--center { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }
.mw-bcard--center .mw-bcard__body { max-width: 30ch; }
.mw-bcard__glow { position: absolute; right: -50px; bottom: -50px; width: 210px; height: 210px; border-radius: 50%;
  background: radial-gradient(circle, rgba(188,213,68,0.45) 0%, transparent 70%); pointer-events: none; }
.mw-bcard__glow--dark { right: -70px; top: -70px; bottom: auto;
  background: radial-gradient(circle, rgba(47,115,81,0.6) 0%, transparent 70%); }
.mw-bcard__cta { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between;
  gap: 22px; flex-wrap: wrap; }
.mw-bcard__cta > div { min-width: 0; }

/* ----- Why choose (portrait + quote + features) ----- */
.mw-why { display: grid; grid-template-columns: 0.82fr 1fr; gap: clamp(40px, 5.5vw, 88px); align-items: center; }
.mw-why__media { position: relative; }
.mw-why__portrait { border-radius: 26px; overflow: hidden; aspect-ratio: 4 / 5;
  box-shadow: var(--shadow-card-hover); background: var(--forest-800); }
.mw-why__portrait img { width: 100%; height: 100%; object-fit: cover; }
.mw-why__quote { position: absolute; right: -20px; bottom: -22px; max-width: 290px;
  background: var(--forest-800); border-radius: 20px; padding: 22px 24px; box-shadow: 0 26px 54px -22px rgba(0,0,0,0.6); }
.mw-why__quote p { font-family: var(--font-heading); font-weight: 700; font-style: italic; font-size: 17px;
  line-height: 1.4; color: #fff; margin: 0 0 10px; text-wrap: pretty; }
.mw-why__quote cite { font-style: normal; font-weight: 700; font-size: 13.5px; color: var(--lime-400); }
.mw-why__lead { font-size: 16.5px; line-height: 1.65; color: var(--text-secondary); margin: 18px 0 32px; max-width: 50ch; text-wrap: pretty; }
.mw-featrow { display: flex; flex-direction: column; gap: 24px; }
.mw-feat { display: flex; gap: 16px; align-items: flex-start; }
.mw-feat__icon { flex: none; display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: 12px; background: var(--lime-200); color: var(--forest-700); }
.mw-feat__icon svg { width: 22px; height: 22px; }
.mw-feat__title { font-family: var(--font-heading); font-weight: 700; font-size: 19px; color: var(--forest-800); margin: 0 0 5px; }
.mw-feat__body { font-size: 15px; line-height: 1.55; color: var(--text-secondary); margin: 0; text-wrap: pretty; }

/* ----- Team ----- */
.mw-team__cards { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.mw-tmember { position: relative; overflow: hidden; border-radius: 24px; background: var(--forest-800);
  box-shadow: var(--shadow-card-hover); aspect-ratio: 5 / 4; }
.mw-tmember img { width: 100%; height: 100%; object-fit: cover; }
.mw-tmember__scrim { position: absolute; inset: 0; background:
    linear-gradient(180deg, transparent 38%, rgba(11,36,24,0.30) 62%, rgba(11,36,24,0.92) 100%); }
.mw-tmember__meta { position: absolute; left: 24px; right: 24px; bottom: 22px; z-index: 1; }
.mw-tmember__name { font-family: var(--font-heading); font-weight: 700; font-size: 24px; color: #fff; margin: 0; }
.mw-tmember__role { font-size: 14.5px; color: rgba(244,240,232,0.86); margin: 4px 0 0; }
.mw-tmember__tag { position: absolute; top: 18px; right: 18px; z-index: 1; padding: 6px 14px; border-radius: 999px;
  background: var(--lime-400); color: var(--forest-900); font-weight: 700; font-size: 12px; letter-spacing: .06em; }
.mw-team__note { display: flex; align-items: center; gap: 14px; margin: 28px 0 0; padding: 22px 26px;
  border-radius: 20px; background: var(--cream-200); font-size: 16px; line-height: 1.55; color: var(--text-secondary); }
.mw-team__note strong { color: var(--forest-800); font-weight: 700; }
.mw-team__note span { font-size: 24px; flex: none; }

/* ----- Team collage (signs photo + grid + center MW badge) ----- */
.mw-collage { position: relative; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1.32fr 1fr;
  gap: 8px; padding: 8px; background: var(--forest-900); border-radius: 28px; overflow: hidden;
  aspect-ratio: 4 / 3; max-width: 920px; margin: 0 auto; box-shadow: var(--shadow-card-hover); }
.mw-collage__cell { position: relative; overflow: hidden; border-radius: 7px; background: var(--forest-800); }
.mw-collage__cell--wide { grid-column: 1 / -1; }
.mw-collage__cell img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mw-collage__badge { position: absolute; left: 50%; top: 57%; transform: translate(-50%, -50%); z-index: 3;
  width: clamp(96px, 11vw, 130px); aspect-ratio: 1; border-radius: 50%; background: var(--forest-900);
  display: grid; place-items: center;
  box-shadow: 0 0 0 9px var(--forest-900), 0 18px 42px rgba(6,20,14,0.55); }
.mw-collage__badge img { width: 58%; height: 58%; object-fit: contain; }
.mw-founders { display: flex; justify-content: center; flex-wrap: wrap; gap: 32px 80px; margin: 8px 0 0; }
.mw-founders__item { display: flex; flex-direction: column; align-items: center; text-align: center; }
.mw-founders__avatar { width: 230px; height: 270px; border-radius: 22px; overflow: hidden; margin-bottom: 20px;
  background: var(--forest-800); box-shadow: 0 0 0 5px #fff, 0 22px 48px -16px rgba(6,20,14,0.55); }
.mw-founders__avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mw-founders__name { font-family: var(--font-heading); font-weight: 700; font-size: 23px; color: var(--forest-800); }
.mw-founders__name span { color: var(--lime-600); }
.mw-founders__role { font-size: 14.5px; color: var(--text-muted); margin-top: 3px; }

/* ----- Team member cards ----- */
.mw-team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin-top: 8px; max-width: 860px; margin-left: auto; margin-right: auto; }
.mw-tmcard { position: relative; border-radius: 24px; overflow: hidden; background: var(--forest-800);
  box-shadow: var(--shadow-card); aspect-ratio: 4 / 5;
  transition: transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard); }
.mw-tmcard:hover { transform: translateY(-5px); box-shadow: 0 26px 56px -22px rgba(31,90,55,0.42); }
.mw-tmcard__photo { position: absolute; inset: 0; }
.mw-tmcard__photo img { width: 100%; height: 100%; object-fit: cover; }
.mw-tmcard__scrim { position: absolute; inset: 0; background:
    linear-gradient(180deg, transparent 42%, rgba(11,36,24,0.28) 64%, rgba(11,36,24,0.9) 100%); }
.mw-tmcard__role-tag { position: absolute; left: 16px; top: 16px; z-index: 2; padding: 6px 13px; border-radius: 999px;
  background: var(--lime-400); color: var(--forest-900); font-weight: 800; font-size: 11.5px; letter-spacing: .08em; }
.mw-tmcard__meta { position: absolute; left: 22px; right: 22px; bottom: 20px; z-index: 2; }
.mw-tmcard__name { font-family: var(--font-heading); font-weight: 700; font-size: 24px; letter-spacing: -0.015em;
  color: #fff; margin: 0; }
.mw-tmcard__role { font-size: 14.5px; font-weight: 600; color: var(--lime-400); margin: 4px 0 0; }
.mw-team-cta { display: flex; align-items: center; justify-content: center; gap: 12px; flex-wrap: wrap; text-align: center;
  margin: 30px auto 0; padding: 18px 28px; border-radius: 18px; background: var(--cream-200, #efe9dd);
  font-size: 16px; color: var(--text-secondary); max-width: 640px; }
.mw-team-cta strong { color: var(--forest-800); font-weight: 700; }
.mw-team-cta a { color: var(--forest-700); font-weight: 700; text-decoration: underline; text-underline-offset: 3px; }
@media (max-width: 540px) { .mw-team-grid { grid-template-columns: 1fr; } }

/* ----- Er Moneyweb noget for mig ----- */
.mw-fit { position: relative; overflow: hidden; border-radius: 28px; background: var(--forest-800);
  padding: clamp(40px, 5vw, 72px); display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.mw-fit__glow { position: absolute; right: -90px; top: -90px; width: 320px; height: 320px; border-radius: 50%;
  background: radial-gradient(circle, rgba(47,115,81,0.55) 0%, transparent 70%); pointer-events: none; }
.mw-fit__intro { position: relative; z-index: 1; }
.mw-fit__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(30px, 3.6vw, 46px);
  line-height: 1.05; letter-spacing: -0.025em; color: #fff; margin: 14px 0 0; text-wrap: balance; }
.mw-fit__title em { font-style: normal; color: var(--lime-400); }
.mw-fit__lead { font-size: 16.5px; line-height: 1.6; color: var(--on-forest-muted); margin: 18px 0 28px; max-width: 42ch; text-wrap: pretty; }
.mw-fit__list { position: relative; z-index: 1; display: flex; flex-direction: column; gap: 14px; margin: 0; padding: 0; list-style: none; }
.mw-fit__item { display: flex; gap: 14px; align-items: flex-start; padding: 16px 20px; border-radius: 14px;
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); }
.mw-fit__check { flex: none; display: grid; place-items: center; width: 28px; height: 28px; border-radius: 50%;
  background: var(--lime-400); color: var(--forest-900); }
.mw-fit__check svg { width: 16px; height: 16px; }
.mw-fit__item p { margin: 0; font-size: 15.5px; line-height: 1.45; color: #fff; }
.mw-fit__item p span { color: var(--on-forest-muted); }
@media (max-width: 860px) { .mw-fit { grid-template-columns: 1fr; } }

/* ----- Featured (split panel) ----- */
.mw-case { display: grid; grid-template-columns: 1fr 1fr; border-radius: 28px; overflow: hidden;
  box-shadow: var(--shadow-card-hover); background: var(--forest-800); }
.mw-case__text { padding: clamp(34px, 4vw, 60px); display: flex; flex-direction: column; justify-content: center; }
.mw-case__eyebrow { font-weight: 600; font-size: 14px; letter-spacing: 0; text-transform: none; color: var(--lime-400); }
.mw-case__title { font-family: var(--font-heading); font-weight: 700; font-size: clamp(26px, 2.7vw, 36px);
  letter-spacing: -0.02em; color: #fff; margin: 14px 0 0; text-wrap: balance; }
.mw-case__body { font-size: 16px; line-height: 1.65; color: var(--on-forest-muted); margin: 18px 0 26px; max-width: 46ch; text-wrap: pretty; }
.mw-case__link { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: 15px;
  color: var(--lime-400); text-decoration: none; }
.mw-case__link span { transition: transform var(--dur-base) var(--ease-standard); }
.mw-case__link:hover { color: #fff; }
.mw-case__link:hover span { transform: translateX(4px); }
.mw-case__media { position: relative; min-height: 320px; background: var(--forest-700); }
.mw-case__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

/* ----- Values ----- */
.mw-values__head { text-align: center; max-width: 640px; margin: 0 auto clamp(36px, 4vw, 52px); }
.mw-values__display { font-family: var(--font-heading); font-weight: 700; letter-spacing: -0.03em;
  font-size: clamp(34px, 5vw, 56px); line-height: 1.0; color: var(--forest-800); margin: 14px 0 0; }
.mw-values__display em { font-style: normal; color: var(--lime-500); }
.mw-vcard { position: relative; background: #fff; border-radius: 22px; border: 1px solid rgba(18,53,33,0.06);
  box-shadow: var(--shadow-card); padding: 28px 26px; }
.mw-vcard__icon { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px;
  border-radius: 50%; background: var(--lime-200); color: var(--forest-700); margin-bottom: 18px; }
.mw-vcard__icon svg { width: 19px; height: 19px; }
.mw-vcard__icon--img { background: transparent; padding: 0; width: 64px; height: 64px; margin-bottom: 14px; }
.mw-vcard__icon--img img { width: 100%; height: 100%; object-fit: contain; border-radius: 11px; }
.mw-vcard__title { font-family: var(--font-heading); font-weight: 700; font-size: 20px; color: var(--forest-800); margin: 0 0 9px; letter-spacing: -0.01em; }
.mw-vcard__body { font-size: 15px; line-height: 1.6; color: var(--text-secondary); margin: 0; text-wrap: pretty; }
.mw-vcard--dark { background: var(--forest-800); border-color: transparent; }
.mw-vcard--dark .mw-vcard__icon { background: var(--lime-400); color: var(--forest-900); }
.mw-vcard--dark .mw-vcard__title { color: #fff; }
.mw-vcard--dark .mw-vcard__body { color: var(--on-forest-muted); }

@media (max-width: 980px) {
  .mw-bento { grid-template-columns: repeat(6, 1fr); }
  .mw-bento > * { grid-column: span 6 !important; grid-row: auto !important; }
  .mw-why, .mw-case, .mw-team__cards { grid-template-columns: 1fr; }
  .mw-case__media { min-height: 260px; order: -1; }
  .mw-why__quote { position: static; max-width: none; right: auto; bottom: auto; margin-top: 18px; }
}
@media (max-width: 560px) {
  .mw-tmember { aspect-ratio: 4 / 3; }
}

/* ==========================================================================
   PRISER (Moderne website)
   ========================================================================== */
.mw-pricing { max-width: 720px; margin: 0 auto; }

/* Domæne add-on — slank sekundær strip under hovedplanen */
.mw-domain { display: flex; align-items: center; gap: 22px; margin: 18px auto 0; max-width: 720px;
  background: #fff; border: 1px solid rgba(18,53,33,0.1); border-radius: 20px; padding: 20px 26px;
  box-shadow: 0 1px 2px rgba(20,48,36,0.04), 0 12px 28px -18px rgba(20,48,36,0.18); }
.mw-domain__icon { flex: none; display: grid; place-items: center; width: 48px; height: 48px; border-radius: 13px;
  background: var(--lime-200); color: var(--forest-700); }
.mw-domain__icon svg { width: 24px; height: 24px; }
.mw-domain__text { flex: 1; min-width: 0; }
.mw-domain__row { display: flex; align-items: center; gap: 11px; flex-wrap: wrap; }
.mw-domain__title { font-family: var(--font-heading); font-weight: 700; font-size: 18.5px; color: var(--forest-800); margin: 0; }
.mw-domain__free { font-size: 12px; font-weight: 700; color: var(--forest-700); background: var(--lime-200); padding: 4px 11px; border-radius: 999px; }
.mw-domain__body { font-size: 14px; line-height: 1.5; color: var(--text-secondary); margin: 6px 0 0; text-wrap: pretty; }
.mw-domain__price { flex: none; text-align: right; display: flex; flex-direction: column; align-items: flex-end; padding-left: 18px; border-left: 1px solid rgba(18,53,33,0.1); }
.mw-domain__amount { font-family: var(--font-heading); font-weight: 700; font-size: 25px; letter-spacing: -0.02em; color: var(--forest-800); line-height: 1; }
.mw-domain__per { font-size: 12.5px; font-weight: 600; color: var(--text-muted); margin-top: 3px; white-space: nowrap; }
.mw-domain__note { font-size: 11.5px; color: var(--text-muted); margin-top: 6px; font-style: italic; white-space: nowrap; }
@media (max-width: 620px) {
  .mw-domain { flex-wrap: wrap; gap: 16px; }
  .mw-domain__price { width: 100%; text-align: left; align-items: flex-start; padding-left: 0; border-left: none;
    padding-top: 14px; border-top: 1px solid rgba(18,53,33,0.1); }
}

/* Sammenligning — Moneyweb vs. andre */
.mw-compare { max-width: 700px; margin: clamp(48px, 6vw, 72px) auto 0; }
.mw-compare__intro { text-align: center; margin-bottom: 26px; }
.mw-compare__intro h3 { font-family: var(--font-heading); font-weight: 700; font-size: clamp(22px, 2.4vw, 30px);
  letter-spacing: -0.02em; color: var(--forest-800); margin: 0; text-wrap: balance; }
.mw-compare__grid { border: 1px solid rgba(18,53,33,0.09); border-radius: 22px; overflow: hidden; background: #fff; }
.mw-compare__head, .mw-compare__row { display: grid; grid-template-columns: 1fr 116px 116px; align-items: center; }
.mw-compare__row { border-top: 1px solid rgba(18,53,33,0.08); }
.mw-compare__feat { font-weight: 700; font-size: 16.5px; color: var(--forest-800); padding: 19px 24px; }
.mw-compare__head .mw-compare__feat { color: var(--text-muted); font-size: 14px; }
.mw-compare__us, .mw-compare__them { display: flex; align-items: center; justify-content: center; align-self: stretch; padding: 17px 0; }
.mw-compare__us { background: rgba(188,213,68,0.16); }
.mw-compare__head .mw-compare__us { padding: 18px 0; }
.mw-compare__brand { display: inline-flex; align-items: center; gap: 7px; }
.mw-compare__brand img { height: 42px; width: auto; display: block; }
.mw-compare__brandtext { font-family: var(--font-heading); font-weight: 700; font-size: 19px; letter-spacing: -0.02em;
  line-height: 1; color: var(--forest-800); }
.mw-compare__brandtext sup { font-size: 0.5em; color: var(--lime-600); font-weight: 700; vertical-align: super; margin-left: 1px; }
.mw-compare__them-label { font-family: var(--font-heading); font-weight: 700; font-size: 16px; color: var(--text-muted); }
.mw-compare__yes { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%;
  background: var(--lime-400); color: var(--forest-900); }
.mw-compare__yes svg { width: 19px; height: 19px; }
.mw-compare__no { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%;
  background: var(--cream-200); color: var(--text-muted); }
.mw-compare__no svg { width: 17px; height: 17px; }
@media (max-width: 520px) {
  .mw-compare__head, .mw-compare__row { grid-template-columns: 1fr 76px 76px; }
  .mw-compare__feat { padding: 16px 16px; font-size: 15px; }
  .mw-compare__brand img { height: 24px; }
  .mw-compare__brandtext { font-size: 15px; }
}
.mw-plan { position: relative; overflow: hidden; border-radius: 28px; background: var(--forest-800);
  color: #fff; padding: clamp(32px, 3.6vw, 48px); display: flex; flex-direction: column; }
.mw-plan__glow { position: absolute; right: -90px; top: -90px; width: 320px; height: 320px; border-radius: 50%;
  background: radial-gradient(circle, rgba(47,115,81,0.6) 0%, transparent 70%); pointer-events: none; }
.mw-plan__name { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font-heading); font-weight: 700; font-size: 21px; color: #fff; margin: 0; }
.mw-plan__name span { display: inline-grid; place-items: center; width: 30px; height: 30px; border-radius: 50%;
  background: var(--lime-400); color: var(--forest-900); }
.mw-plan__name span svg { width: 17px; height: 17px; }
.mw-plan__price { position: relative; z-index: 1; display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin: 22px 0 4px; }
.mw-plan__amount { font-family: var(--font-heading); font-weight: 700; font-size: clamp(46px, 6vw, 62px);
  line-height: 1; letter-spacing: -0.03em; color: var(--lime-400); }
.mw-plan__per { font-size: 16px; font-weight: 600; color: var(--on-forest-muted, rgba(244,240,232,0.7)); }
.mw-plan__alt { position: relative; z-index: 1; display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  font-size: 15.5px; color: rgba(244,240,232,0.82); margin: 0 0 26px; }
.mw-plan__alt strong { color: #fff; font-weight: 700; }
.mw-plan__save { display: inline-block; padding: 4px 11px; border-radius: 999px; background: var(--lime-400);
  color: var(--forest-900); font-size: 12px; font-weight: 800; letter-spacing: .03em; }
.mw-plan__list { position: relative; z-index: 1; list-style: none; margin: 0 0 30px; padding: 22px 0 0;
  border-top: 1px solid rgba(255,255,255,0.12); display: grid; gap: 14px; }
.mw-plan__list li { display: flex; align-items: center; gap: 12px; font-size: 16px; color: #fff; }
.mw-plan__check { flex: none; display: grid; place-items: center; width: 24px; height: 24px; border-radius: 50%;
  background: rgba(188,213,68,0.18); color: var(--lime-400); }
.mw-plan__check svg { width: 14px; height: 14px; }
.mw-plan__cta { position: relative; z-index: 1; margin-top: auto; }
.mw-plan__note { position: relative; z-index: 1; font-size: 13.5px; color: rgba(244,240,232,0.6); margin: 14px 0 0; }

.mw-addon { display: flex; flex-direction: column; border-radius: 28px; background: #fff;
  border: 1px solid rgba(18,53,33,0.07); box-shadow: var(--shadow-card); padding: clamp(28px, 3vw, 40px); }
.mw-addon__tag { display: inline-block; align-self: flex-start; padding: 6px 13px; border-radius: 999px;
  background: var(--cream-200); color: var(--forest-700); font-weight: 800; font-size: 11.5px; letter-spacing: .08em; text-transform: none; }
.mw-addon__title { font-family: var(--font-heading); font-weight: 700; font-size: 24px; color: var(--forest-800); margin: 18px 0 0; text-wrap: balance; }
.mw-addon__body { font-size: 15.5px; line-height: 1.6; color: var(--text-secondary); margin: 12px 0 0; text-wrap: pretty; }
.mw-addon__price { display: flex; align-items: baseline; gap: 9px; margin: auto 0 0; padding-top: 24px; }
.mw-addon__amount { font-family: var(--font-heading); font-weight: 700; font-size: clamp(34px, 4vw, 44px);
  line-height: 1; letter-spacing: -0.02em; color: var(--forest-800); }
.mw-addon__per { font-size: 15px; font-weight: 600; color: var(--text-muted); }
@media (max-width: 860px) { .mw-pricing { grid-template-columns: 1fr; } }

/* to betalingsmuligheder i plan-kortet */
.mw-plan__opts { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 22px 0 26px; }
.mw-popt { border-radius: 16px; padding: 18px 18px 16px; background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1); }
.mw-popt--featured { background: rgba(188,213,68,0.12); border-color: rgba(188,213,68,0.5); }
.mw-popt__label { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-weight: 700; font-size: 13.5px;
  letter-spacing: 0; text-transform: none; color: rgba(244,240,232,0.78); }
.mw-popt--featured .mw-popt__label { color: var(--lime-400); }
.mw-popt__price { display: flex; flex-direction: row; align-items: baseline; gap: 6px; flex-wrap: wrap; margin: 10px 0 14px; }
.mw-popt__price strong { font-family: var(--font-heading); font-weight: 700; font-size: 27px; letter-spacing: -0.02em; color: #fff; white-space: nowrap; }
.mw-popt__price span { font-size: 12.5px; font-weight: 600; color: rgba(244,240,232,0.65); }
.mw-popt__hint { font-size: 13px; line-height: 1.45; color: rgba(244,240,232,0.68); margin: 11px 0 0; }
.mw-popt--featured .mw-popt__hint { color: rgba(244,240,232,0.82); }
.mw-popt__terms { list-style: none; margin: 0; padding: 0; display: grid; gap: 7px; }
.mw-popt__terms li { font-size: 13.5px; line-height: 1.4; color: rgba(244,240,232,0.85); padding-left: 18px; position: relative; }
.mw-popt__terms li::before { content: "✓"; position: absolute; left: 0; color: var(--lime-400); font-weight: 800; font-size: 12px; }
.mw-popt__terms li.is-bind::before { content: "•"; color: rgba(244,240,232,0.55); }
.mw-plan__save { white-space: nowrap; }
@media (max-width: 480px) { .mw-plan__opts { grid-template-columns: 1fr; } }

/* ==========================================================================
   HVAD DU FÅR (Dit nye website)
   ========================================================================== */
.mw-about-web__lead { max-width: 760px; margin: 22px auto 0; }
.mw-about-web__points { list-style: none; margin: 0 auto; padding: 0; max-width: 720px;
  display: grid; gap: 14px; text-align: left; }
.mw-about-web__points li { display: flex; gap: 14px; align-items: flex-start; font-size: 17px;
  line-height: 1.55; color: var(--text-secondary); text-wrap: pretty; }
.mw-about-web__points li strong { color: var(--forest-800); font-weight: 700; }
.mw-about-web__tick { flex: none; display: grid; place-items: center; width: 26px; height: 26px; margin-top: 1px;
  border-radius: 50%; background: var(--lime-400); color: var(--forest-900); }
.mw-about-web__tick svg { width: 15px; height: 15px; }

/* 6 sider-kort */
.mw-pages { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: clamp(40px, 5vw, 60px); }
.mw-pagecard { background: #fff; border: 1px solid rgba(18,53,33,0.07); border-radius: 22px; padding: 30px 28px;
  box-shadow: 0 1px 2px rgba(20,48,36,0.04), 0 16px 36px -20px rgba(20,48,36,0.16);
  transition: transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard); }
.mw-pagecard:hover { transform: translateY(-5px); box-shadow: 0 30px 56px -26px rgba(31,90,55,0.34); border-color: rgba(188,213,68,0.5); }
.mw-pagecard__top { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.mw-pagecard__icon { flex: none; display: block; width: 62px; height: 62px; border-radius: 15px; overflow: hidden; background: var(--cream-100); }
.mw-pagecard__icon img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mw-pagecard__num { margin-left: auto; font-family: var(--font-heading); font-weight: 700; font-size: 15px; color: var(--lime-600); }
.mw-pagecard__title { font-family: var(--font-heading); font-weight: 700; font-size: 21px; letter-spacing: -0.01em;
  color: var(--forest-800); margin: 0 0 8px; }
.mw-pagecard__body { font-size: 14.5px; line-height: 1.6; color: var(--text-secondary); margin: 0; text-wrap: pretty; }

/* Forklaring (forest dark band) */
.mw-explain { position: relative; overflow: hidden; background: var(--forest-800); color: #fff; }
.mw-explain__glow { position: absolute; pointer-events: none; width: 520px; height: 520px; border-radius: 50%;
  background: radial-gradient(circle, rgba(47,115,81,0.55) 0%, transparent 70%); top: -180px; right: -120px; }
.mw-explain__glow--2 { top: auto; right: auto; bottom: -200px; left: -160px;
  background: radial-gradient(circle, rgba(188,213,68,0.16) 0%, transparent 70%); }
.mw-explain .mw-container { position: relative; z-index: 1; }
.mw-explain__head { text-align: center; max-width: 820px; margin: 0 auto; }
.mw-explain__eyebrow { display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14.5px; letter-spacing: 0;
  text-transform: none; color: var(--lime-400); margin-bottom: 20px; }
.mw-explain__eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--lime-400); flex: none; }
.mw-explain__concept { font-family: var(--font-heading); font-weight: 700; letter-spacing: -0.03em;
  font-size: clamp(30px, 4vw, 50px); line-height: 1.08; margin: 0; text-wrap: balance; }
.mw-explain__concept em { font-style: normal; color: var(--lime-400); }
.mw-explain__statement { display: flex; flex-direction: column; gap: 4px; max-width: 640px; margin: 28px auto 0; }
.mw-explain__line { font-size: 18px; line-height: 1.5; color: var(--on-forest-muted, rgba(244,240,232,0.78)); }
.mw-explain__big { font-family: var(--font-heading); font-weight: 700; font-size: clamp(26px, 3.2vw, 40px);
  letter-spacing: -0.02em; line-height: 1.1; color: var(--lime-400); margin: 6px 0; }
.mw-explain__sub { font-size: 18px; line-height: 1.6; color: var(--on-forest-muted, rgba(244,240,232,0.78));
  max-width: 620px; margin: 22px auto 0; text-wrap: pretty; }
.mw-goals { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin: clamp(40px, 5vw, 60px) auto 0; max-width: 920px; }
.mw-goal { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); border-radius: 20px;
  padding: 28px 24px; text-align: center; }
.mw-goal__icon { display: grid; place-items: center; width: 52px; height: 52px; margin: 0 auto 16px; border-radius: 50%;
  background: var(--lime-400); color: var(--forest-900); }
.mw-goal__icon svg { width: 25px; height: 25px; }
.mw-goal__title { font-family: var(--font-heading); font-weight: 700; font-size: 20px; color: #fff; margin: 0 0 7px; }
.mw-goal__body { font-size: 14.5px; line-height: 1.55; color: rgba(244,240,232,0.72); margin: 0; text-wrap: pretty; }

/* To feature-kort (AI + SEO) */
.mw-feat2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-top: clamp(40px, 5vw, 56px); }
.mw-fcard { position: relative; overflow: hidden; background: #fff; border: 1px solid rgba(18,53,33,0.07);
  border-radius: 26px; padding: clamp(30px, 3vw, 42px); display: flex; flex-direction: column;
  box-shadow: 0 1px 2px rgba(20,48,36,0.04), 0 18px 42px -20px rgba(20,48,36,0.16); }
.mw-fcard__glow { position: absolute; right: -70px; bottom: -70px; width: 220px; height: 220px; border-radius: 50%;
  background: radial-gradient(circle, rgba(188,213,68,0.4) 0%, transparent 70%); pointer-events: none; }
.mw-fcard__icon { position: relative; z-index: 1; display: grid; place-items: center; width: 54px; height: 54px;
  border-radius: 15px; background: var(--forest-800); color: var(--lime-400); margin-bottom: 22px; }
.mw-fcard__icon svg { width: 27px; height: 27px; }
.mw-fcard__eyebrow { position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 9px; font-weight: 600; font-size: 14px; letter-spacing: 0;
  text-transform: none; color: var(--lime-600); }
.mw-fcard__eyebrow::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--lime-500); flex: none; }
.mw-fcard__title { position: relative; z-index: 1; font-family: var(--font-heading); font-weight: 700;
  font-size: clamp(23px, 2.2vw, 30px); letter-spacing: -0.02em; color: var(--forest-800); margin: 10px 0 0; text-wrap: balance; }
.mw-fcard__body { position: relative; z-index: 1; font-size: 16px; line-height: 1.6; color: var(--text-secondary);
  margin: 16px 0 0; text-wrap: pretty; }
.mw-fcard__list { position: relative; z-index: 1; list-style: none; margin: 24px 0 0; padding: 22px 0 0;
  border-top: 1px solid rgba(18,53,33,0.08); display: grid; gap: 14px; }
.mw-fcard__list li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; line-height: 1.5; color: var(--forest-800); font-weight: 500; }
.mw-fcard__list svg { flex: none; width: 20px; height: 20px; margin-top: 1px; color: var(--lime-600); }
.mw-fcard__badge { position: relative; z-index: 1; align-self: flex-start; margin-top: 24px; display: inline-flex; align-items: center; gap: 9px;
  padding: 9px 16px; border-radius: 999px; background: var(--lime-200); color: var(--forest-700); font-weight: 700; font-size: 14px; }
.mw-fcard__badge svg { width: 16px; height: 16px; }

@media (max-width: 900px) {
  .mw-pages, .mw-goals { grid-template-columns: 1fr 1fr; }
  .mw-feat2 { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .mw-pages, .mw-goals { grid-template-columns: 1fr; }
}

/* ==========================================================================
   KONTAKT — ny, roligere opsætning (stor Janek + form)
   ========================================================================== */
.mw-cp { padding: 132px 0 96px; }
.mw-cp-head { text-align: center; max-width: 660px; margin: 0 auto clamp(40px, 5vw, 56px); }
.mw-cp-head .mw-pill--soft { margin-bottom: 18px; }
.mw-cp-head h1 { font-family: var(--font-heading); font-weight: 700; font-size: clamp(34px, 4.4vw, 54px);
  letter-spacing: -0.03em; color: var(--forest-800); margin: 0; text-wrap: balance; }
.mw-cp-head p { font-size: 17.5px; line-height: 1.6; color: var(--text-secondary); margin: 16px auto 0; max-width: 52ch; text-wrap: pretty; }

.mw-cp-grid { display: grid; grid-template-columns: 0.8fr 1fr; gap: 30px; align-items: stretch; }

.mw-cp-portrait { position: relative; margin: 0; border-radius: 28px; overflow: hidden; background: var(--forest-800);
  box-shadow: var(--shadow-card-hover); min-height: 100%; }
.mw-cp-portrait img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 70% 16%; }
.mw-cp-portrait figcaption { position: absolute; left: 0; right: 0; bottom: 0; z-index: 1; padding: 32px 30px 28px;
  background: linear-gradient(180deg, transparent 0%, rgba(11,36,24,0.5) 42%, rgba(11,36,24,0.94) 100%); color: #fff; }
.mw-cp-portrait__name { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-heading);
  font-weight: 700; font-size: 23px; letter-spacing: -0.01em; margin: 0 0 7px; }
.mw-cp-portrait__name::before { content: ""; width: 9px; height: 9px; border-radius: 50%; background: var(--lime-400);
  box-shadow: 0 0 0 4px rgba(188,213,68,0.22); flex: none; }
.mw-cp-portrait p { font-size: 15px; line-height: 1.5; color: rgba(244,240,232,0.84); margin: 0; max-width: 34ch; text-wrap: pretty; }

.mw-cp-contactbar { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 28px; }
.mw-cp-cbitem { display: flex; align-items: center; gap: 14px; padding: 20px 22px; background: #fff;
  border: 1px solid rgba(18,53,33,0.08); border-radius: 18px; text-decoration: none; box-shadow: var(--shadow-card);
  transition: transform var(--dur-base) var(--ease-standard), box-shadow var(--dur-base) var(--ease-standard), border-color var(--dur-base) var(--ease-standard); }
a.mw-cp-cbitem:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); border-color: rgba(188,213,68,0.5); }
.mw-cp-cbitem__icon { flex: none; display: grid; place-items: center; width: 46px; height: 46px; border-radius: 13px;
  background: var(--lime-200); color: var(--forest-700); }
.mw-cp-cbitem__icon svg { width: 22px; height: 22px; }
.mw-cp-cbitem__txt { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mw-cp-cbitem__label { font-size: 12.5px; color: var(--text-muted); }
.mw-cp-cbitem__value { font-weight: 700; font-size: 15px; color: var(--forest-800); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

@media (max-width: 860px) {
  .mw-cp-grid { grid-template-columns: 1fr; }
  .mw-cp-portrait { min-height: 440px; }
  .mw-cp-contactbar { grid-template-columns: 1fr; }
}

/* Janek-billedet flugter med containeren (samme kant som kontakt-boksene) */
.mw-cp-portrait img { object-position: 64% 16%; }

/* Telefon med dansk flag + +45 */
.mw-phone { display: flex; align-items: stretch; background: var(--cream-50); border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden; }
.mw-phone:focus-within { border-color: var(--forest-700); box-shadow: 0 0 0 3px rgba(188,213,68,0.35); }
.mw-phone__prefix { display: inline-flex; align-items: center; gap: 8px; padding: 0 12px 0 14px;
  font-weight: 700; font-size: 15px; color: var(--forest-800); background: var(--cream-200);
  border-right: 1px solid var(--border); white-space: nowrap; }
.mw-flag-dk { width: 22px; height: 16px; border-radius: 3px; flex: none; box-shadow: 0 0 0 1px rgba(18,53,33,0.08); }
.mw-phone input { border: none !important; background: transparent !important; box-shadow: none !important; border-radius: 0 !important; }
.mw-phone input:focus { box-shadow: none !important; }

/* "Hvad er du interesseret i" — chip-valg */
.mw-choice { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mw-choice__opt { cursor: pointer; }
.mw-choice__opt input { position: absolute; opacity: 0; pointer-events: none; }
.mw-choice__chip { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-radius: 13px;
  background: var(--cream-50); border: 1.5px solid var(--border); font-weight: 600; font-size: 15px; color: var(--text-secondary);
  transition: border-color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard); }
.mw-choice__chip svg { width: 20px; height: 20px; flex: none; color: var(--text-muted); transition: color var(--dur-fast) var(--ease-standard); }
.mw-choice__opt:hover .mw-choice__chip { border-color: var(--lime-400); }
.mw-choice__opt input:checked + .mw-choice__chip { background: var(--lime-200); border-color: var(--lime-500); color: var(--forest-800); }
.mw-choice__opt input:checked + .mw-choice__chip svg { color: var(--forest-700); }
.mw-choice__opt input:focus-visible + .mw-choice__chip { box-shadow: 0 0 0 3px rgba(188,213,68,0.35); }
@media (max-width: 480px) { .mw-choice { grid-template-columns: 1fr; } }
