/* ============================================================
   AssetCore — Forside (lys, produktnær)
   Matcher det faktiske appen + felt-UI: lyse flater, kort-basert,
   grønn accent, navy primær-action, semantiske statuspiller.
   Schibsted Grotesk gjennomgående · JetBrains Mono kun til ID-er.
   Tokens lånt fra src/styles/v2.css + felt-v2.css.
   ============================================================ */

:root {
  /* Surfaces — warm off-white (Onix-aktig), ikke kald SaaS-grå */
  --bg:        #f6f4f0;
  --bg-2:      #ece8e1;
  --panel:     #ffffff;
  --panel-2:   #f3f1ec;

  /* Borders (varme nøytrale) */
  --border:    #e7e3db;
  --border-2:  #efece6;
  --border-strong: #d8d3c8;
  --hairline:  #f1eee9;

  /* Ink (varm nær-sort) */
  --text:      #1a1714;
  --text-2:    #4c463e;
  --text-3:    #746d62;
  --text-4:    #a39b8d;

  /* Accent — indigo (programvare-klassiker) */
  --green:        #4f46e5;
  --green-2:      #635bf0;
  --green-deep:   #3a33b3;
  --green-soft:   #ebeafd;
  --green-line:   #cdc9f7;

  /* Varm nær-sort ink — felt primær-action + mørke band */
  --navy:      #1c1814;
  --navy-2:    #100d0a;
  --navy-soft: #f3efe9;

  /* Semantiske (fra v2-tokens) */
  --blue: #2e6ee0; --blue-bg: #e6edfb;
  --amber: #b45309; --amber-bg: #fef3c7; --amber-line: #f6e2a6;
  --red: #b91c1c; --red-bg: #fee2e2; --red-line: #f6c9c9;
  --success: #065f46; --success-bg: #d1fae5;

  /* Module colour codes (kun ikoner/dots) */
  --mod-oversikt:#0891a3; --mod-tilbud:#6a64c6; --mod-arbeid:#e8890b;
  --mod-avtale:#0284c7; --mod-utstyr:#16a34a; --mod-utleie:#c81d6b;
  --mod-kontroll:#dc2626; --mod-hms:#ea580c; --mod-vedlikehold:#0d9488;
  --mod-transport:#5852b5; --mod-sporing:#2563eb; --mod-lager:#65a30d;
  --mod-faktura:#be123c; --mod-prosjekt:#6366f1; --mod-kunder:#0891b2;
  --mod-innkjop:#9333ea; --mod-fravar:#3f4860; --mod-opplaring:#ca8a04;

  /* Type */
  --display: "Clash Display", "Schibsted Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --sans:    "General Sans", "Schibsted Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, monospace;

  /* Geometry */
  --radius:    16px;
  --radius-md: 12px;
  --radius-sm: 10px;
  --radius-xs: 7px;
  --shadow-1: 0 1px 2px rgba(15,23,32,.05), 0 1px 1px rgba(15,23,32,.03);
  --shadow-2: 0 2px 6px rgba(15,23,32,.06), 0 12px 30px -12px rgba(15,23,32,.12);
  --shadow-3: 0 30px 70px -34px rgba(15,23,32,.32);

  --s-4:4px; --s-6:6px; --s-8:8px; --s-12:12px; --s-16:16px; --s-20:20px;
  --s-24:24px; --s-32:32px; --s-40:40px; --s-48:48px; --s-64:64px;
  --s-80:80px; --s-96:96px; --s-120:120px;

  --maxw: 1240px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body {
  margin: 0;
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  font-feature-settings: "kern","liga","calt";
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
h1,h2,h3,h4,p { margin: 0; }
button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: pointer; }
::selection { background: var(--green-soft); color: var(--green-deep); }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }

/* ---- Type scale ---- */
.display-1 {
  font-family: var(--display);
  font-weight: 500;
  font-size: clamp(36px, 5vw, 62px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--text);
}
.display-1 em { font-style: normal; color: var(--green); }
.display-2 {
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(26px, 3.1vw, 40px);
  line-height: 1.14;
  letter-spacing: -0.015em;
  color: var(--text);
}
.display-2 em { font-style: normal; color: var(--green); }
.h3 {
  font-family: var(--display);
  font-weight: 600;
  font-size: 20px;
  line-height: 1.28;
  letter-spacing: -0.01em;
  color: var(--text);
}
.lead { font-size: clamp(18px, 1.4vw, 20px); line-height: 1.62; color: var(--text-2); }
.body { font-size: 16.5px; line-height: 1.68; color: var(--text-2); }

/* tiny meta label — uppercase, friendly (matcher app KPI/section-labels) */
.mono {
  font-family: var(--mono);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--text-3);
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 11px;
  font-family: var(--mono);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--green-deep);
}
.eyebrow::before {
  content: ""; width: 20px; height: 1.5px; border-radius: 2px;
  background: var(--green);
}
.eyebrow.is-centered { justify-content: center; }
.index-num {
  display: block;
  font-family: var(--sans);
  font-size: 13px; font-weight: 600; letter-spacing: 0.01em;
  color: var(--green);
  margin-bottom: 18px;
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  height: 46px; padding: 0 22px;
  font-family: var(--sans); font-size: 15px; font-weight: 600;
  letter-spacing: -0.01em;
  border-radius: 10px;
  transition: all .18s var(--ease);
  white-space: nowrap;
}
.btn .arr { transition: transform .25s var(--ease); }
.btn:hover .arr { transform: translateX(3px); }
.btn-primary {
  background: #16181d; color: #fff;
  box-shadow: 0 1px 2px rgba(15,23,32,.16), 0 6px 18px -12px rgba(15,23,32,.45);
}
.btn-primary:hover { background: #282b33; }
.btn-navy { background: var(--navy); color: #fff; box-shadow: 0 1px 2px rgba(58,35,86,.25); }
.btn-navy:hover { background: var(--navy-2); }
.btn-ghost {
  background: var(--panel); color: var(--text);
  box-shadow: inset 0 0 0 1px var(--border-strong);
}
.btn-ghost:hover { box-shadow: inset 0 0 0 1px var(--text-4); }
.btn-outline {
  background: var(--panel); color: var(--text);
  box-shadow: inset 0 0 0 1px var(--border-strong);
}
.btn-outline:hover { box-shadow: inset 0 0 0 1px var(--green); color: var(--green-deep); }

.link-arrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-size: 14.5px; font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--green-deep);
  transition: gap .2s var(--ease);
}
.link-arrow:hover { gap: 12px; color: var(--green); }
.link-arrow .arr { transition: transform .2s var(--ease); }

/* ============================================================
   STATUS BAR (slim, vennlig)
   ============================================================ */
.statusbar {
  border-bottom: 1px solid var(--border);
  background: var(--panel);
  font-family: var(--sans);
  font-size: 12.5px;
  color: var(--text-3);
}
.statusbar-row {
  display: flex; align-items: center; gap: 14px;
  height: 38px;
  max-width: var(--maxw); margin: 0 auto; padding: 0 32px;
  overflow: hidden; white-space: nowrap;
}
.statusbar .sb-live { color: var(--text-2); display: inline-flex; align-items: center; gap: 8px; font-weight: 600; }
.statusbar .sb-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--green);
  box-shadow: 0 0 0 3px var(--green-soft); animation: pulse 2.6s var(--ease) infinite;
}
.statusbar .sb-sep { color: var(--border-strong); }
.statusbar .sb-spacer { flex: 1; }
@keyframes pulse { 0%,100% { opacity:1 } 50% { opacity:.4 } }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, box-shadow .3s;
}
.nav.is-stuck { border-bottom-color: var(--border); box-shadow: var(--shadow-1); }
.nav-row { display: flex; align-items: center; height: 120px; gap: 30px; }
.brand { display: inline-flex; align-items: center; gap: 10px; color: var(--text); }
.brand-mark { height: 56px; width: auto; display: block; }
.brand-word { font-family: var(--display); font-weight: 600; font-size: 19px; letter-spacing: -0.025em; }
.brand-img { height: 96px; width: auto; display: block; }
.nav-links { display: flex; gap: 2px; margin-left: 10px; }
.nav-link {
  font-size: 14.5px; font-weight: 500; color: var(--text-2);
  padding: 8px 13px; border-radius: 8px; transition: color .18s, background .18s;
}
.nav-link:hover { color: var(--text); background: var(--panel-2); }
.nav-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.nav-login { font-size: 14.5px; font-weight: 500; color: var(--text-2); padding: 8px 14px; white-space: nowrap; transition: color .18s; }
.nav-login:hover { color: var(--text); }
.nav-cta { height: 40px; padding: 0 18px; font-size: 14px; }
.menu-toggle {
  display: none; font-size: 14px; font-weight: 600; color: var(--text); padding: 8px 13px;
  border-radius: 8px; box-shadow: inset 0 0 0 1px var(--border-strong);
}
.mobile-menu {
  display: none; flex-direction: column; gap: 2px;
  padding: 12px 32px 24px; border-bottom: 1px solid var(--border); background: var(--panel);
}
.mobile-menu a { padding: 12px 4px; font-size: 16px; font-weight: 500; border-bottom: 1px solid var(--border); }
.mobile-menu .btn { margin-top: 12px; }
.mobile-menu.open { display: flex; }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; padding: clamp(56px,8vw,104px) 0 0; overflow: hidden; }
/* animated aurora orbs */
.hero-orbs { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none;
  -webkit-mask-image: radial-gradient(125% 95% at 50% 0%, #000 32%, transparent 80%);
  mask-image: radial-gradient(125% 95% at 50% 0%, #000 32%, transparent 80%); }
.orb { position: absolute; border-radius: 50%; filter: blur(46px); opacity: .55; }
.orb.o1 { width: 540px; height: 540px; background: #c7c3ec; left: -7%; top: -16%; animation: orbFloat1 24s ease-in-out infinite; }
.orb.o2 { width: 480px; height: 480px; background: #e7dcc6; right: -6%; top: -10%; animation: orbFloat2 29s ease-in-out infinite; }
.orb.o3 { width: 600px; height: 600px; background: #dcd9f2; left: 28%; top: -26%; animation: orbFloat3 34s ease-in-out infinite; }
.orb.o4 { width: 360px; height: 360px; background: #d8d4ee; right: 22%; top: 6%; animation: orbFloat1 27s ease-in-out infinite reverse; }
@keyframes orbFloat1 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(70px,46px) scale(1.14); } }
@keyframes orbFloat2 { 0%,100% { transform: translate(0,0) scale(1.05); } 50% { transform: translate(-64px,38px) scale(0.92); } }
@keyframes orbFloat3 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(40px,60px) scale(1.1); } }
@media (prefers-reduced-motion: reduce) { .orb { animation: none !important; } }
/* ambient drifting orbs reused across sections */
.section > .container { position: relative; z-index: 1; }
.sec-orbs { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.sec-orbs .orb { opacity: .38; filter: blur(44px); }
.sec-orbs .s1 { width: 470px; height: 470px; background: #d6d2f0; left: -8%; top: -36%; animation: orbFloat3 36s ease-in-out infinite; }
.sec-orbs .s2 { width: 410px; height: 410px; background: #e7dcc6; right: -7%; bottom: -38%; animation: orbFloat2 41s ease-in-out infinite; }
.sec-orbs.alt .s1 { background: #e1dcef; left: auto; right: -6%; top: -32%; animation: orbFloat1 39s ease-in-out infinite; }
.sec-orbs.alt .s2 { background: #ded9f2; right: auto; left: -7%; bottom: -34%; animation: orbFloat3 44s ease-in-out infinite; }
.hero-bg {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    linear-gradient(var(--border-2) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-2) 1px, transparent 1px);
  background-size: 60px 60px, 60px 60px;
  -webkit-mask-image: radial-gradient(120% 92% at 50% 0%, #000 30%, transparent 72%);
  mask-image: radial-gradient(120% 92% at 50% 0%, #000 30%, transparent 72%);
  opacity: .7;
}
.hero .container { position: relative; z-index: 1; }
.hero-inner { display: grid; grid-template-columns: 1.32fr 0.68fr; gap: clamp(32px,5vw,72px); align-items: end; max-width: var(--maxw); }
.hero .eyebrow { margin-bottom: 22px; }
.hero h1 { margin: 0; max-width: 15ch; }
.hero-ctas { display: flex; gap: 12px; margin-top: 38px; }
.hero-aside { padding-bottom: 9px; }
.hero-sub { font-size: clamp(16px,1.25vw,18px); line-height: 1.6; color: var(--text-2); margin: 0; }
.hero-facts { margin-top: 24px; border-top: 1px solid var(--border); }
.hero-facts li { display: flex; align-items: center; gap: 11px; padding: 11px 1px; border-bottom: 1px solid var(--border); font-size: 14.5px; font-weight: 500; color: var(--text); }
.hero-facts li svg { width: 16px; height: 16px; flex: 0 0 auto; color: var(--green); }

/* Product window */
.hero-shot-wrap { margin-top: clamp(48px,6vw,76px); position: relative; }
.window {
  position: relative; z-index: 1;
  max-width: 1120px; margin: 0 auto;
  background: var(--panel);
  border-radius: 16px;
  box-shadow: var(--shadow-3), inset 0 0 0 1px var(--border);
  overflow: hidden;
}
.window-chrome {
  display: flex; align-items: center; gap: 14px;
  height: 48px; padding: 0 16px;
  border-bottom: 1px solid var(--border);
  background: var(--panel);
}
.window-dots { display: flex; gap: 7px; }
.window-dots span { width: 11px; height: 11px; border-radius: 50%; background: var(--border-strong); }
.window-url {
  font-family: var(--mono); font-size: 12px; color: var(--text-3);
  background: var(--panel-2); padding: 5px 14px; border-radius: 7px; letter-spacing: 0.01em;
}
.window-live {
  margin-left: auto; display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 600; color: var(--green-deep);
}
.window-live::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px var(--green-soft); animation: pulse 2.6s var(--ease) infinite; }
.window-body { background: var(--bg); }

/* ---- Live dashboard panel ---- */
.cmd { padding: 18px; display: grid; gap: 14px; }
.cmd-modnav { display: flex; gap: 6px; flex-wrap: wrap; padding-bottom: 2px; }
.cmd-modnav .mtab {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 12px; border-radius: 8px; font-size: 12.5px; font-weight: 600; color: var(--text-2);
  background: var(--panel); box-shadow: inset 0 0 0 1px var(--border);
}
.cmd-modnav .mtab.active { color: var(--green-deep); background: var(--green-soft); box-shadow: inset 0 0 0 1px var(--green-line); }
.cmd-modnav .mtab i { width: 8px; height: 8px; border-radius: 50%; }
.cmd-kpis { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.kpi {
  padding: 14px 15px 15px; border-radius: 12px;
  background: var(--panel); box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border);
  transition: box-shadow .3s;
}
.kpi.flash { box-shadow: var(--shadow-1), inset 0 0 0 1px var(--green-line); }
.kpi-top { display: flex; align-items: center; gap: 8px; margin-bottom: 11px; }
.kpi-ic { width: 24px; height: 24px; border-radius: 7px; display: grid; place-items: center; flex: 0 0 auto; }
.kpi-ic svg { width: 14px; height: 14px; stroke-width: 1.9; }
.kpi-top .mono { font-family: var(--sans); font-size: 10px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-3); }
.kpi-num { font-family: var(--display); font-weight: 600; font-size: 29px; letter-spacing: -0.03em; color: var(--text); line-height: 1; font-variant-numeric: tabular-nums; }
.kpi-sub { margin-top: 7px; font-size: 11px; color: var(--text-3); display: flex; align-items: center; gap: 7px; }
.kpi-delta { font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 5px; }
.kpi-delta.up { color: var(--success); background: var(--success-bg); }
.kpi-delta.warn { color: var(--amber); background: var(--amber-bg); }

.cmd-lower { display: grid; grid-template-columns: 1.4fr 1fr; gap: 12px; }
.cmd-card { padding: 16px 18px; border-radius: 12px; background: var(--panel); box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border); }
.cmd-card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.cmd-card-head .ttl { font-size: 13px; font-weight: 600; color: var(--text); letter-spacing: -0.01em; }
.cmd-card-head .legend { display: flex; gap: 11px; }
.cmd-card-head .legend span { display: inline-flex; align-items: center; gap: 5px; font-size: 10px; font-weight: 600; color: var(--text-3); }
.cmd-card-head .legend i { width: 8px; height: 8px; border-radius: 3px; }
.cmd-live-pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 600; color: var(--green-deep); }
.cmd-live-pill::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--green); }

/* chart */
.cmd-chart-bars { display: flex; align-items: flex-end; gap: 3px; height: 120px; }
.cmd-bar { flex: 1; border-radius: 4px 4px 0 0; height: 0; transition: height 1.1s var(--ease); align-self: flex-end; min-height: 4px; }
.cmd-chart-x { display: flex; justify-content: space-between; margin-top: 9px; font-size: 9.5px; font-weight: 600; color: var(--text-4); }

/* live feed */
.cmd-feed { position: relative; overflow: hidden; }
.cmd-feed-list { display: grid; gap: 0; }
.feed-item {
  display: flex; align-items: center; gap: 11px; padding: 10px 2px;
  border-bottom: 1px solid var(--hairline);
  animation: feedin .5s var(--ease) both;
}
.feed-item:last-child { border-bottom: 0; }
@keyframes feedin { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
.feed-dot { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; }
.feed-text { flex: 1; min-width: 0; font-size: 12px; line-height: 1.3; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.feed-text b { color: var(--text); font-weight: 600; }
.feed-time { font-size: 10px; font-weight: 600; color: var(--text-4); flex: 0 0 auto; }
.feed-time.now { color: var(--green); }

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section { padding: clamp(64px,8vw,112px) 0; position: relative; }
.section + .section { border-top: 1px solid var(--border); }
.section.band { background: var(--bg-2); }
.sec-head { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; align-items: end; margin-bottom: 64px; }
.sec-head-narrow { align-self: end; }

/* ============================================================
   FØR / ETTER
   ============================================================ */
.swap-grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 26px; align-items: stretch; }
.swap-panel {
  background: var(--panel); border-radius: 16px; padding: 30px;
  box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border);
}
.swap-panel.after { box-shadow: var(--shadow-2), inset 0 0 0 1.5px var(--green-line); }
.swap-label { display: flex; align-items: center; justify-content: space-between; margin-bottom: 22px; }
.swap-label .tag { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-3); }
.swap-panel.after .swap-label .tag.lead-tag { color: var(--green-deep); }
.swap-title { font-family: var(--display); font-weight: 600; font-size: 22px; letter-spacing: -0.015em; }
.swap-chips { display: flex; flex-wrap: wrap; gap: 9px; }
.chip {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 13px; border-radius: 9px;
  background: var(--panel-2); box-shadow: inset 0 0 0 1px var(--border);
  font-size: 14px; font-weight: 500; color: var(--text-3);
}
.chip .x { color: var(--text-4); font-size: 14px; line-height: 1; }
.swap-list { display: grid; gap: 7px; }
.swap-row {
  display: flex; align-items: center; gap: 11px;
  padding: 12px 14px; border-radius: 10px;
  background: var(--green-soft); box-shadow: inset 0 0 0 1px var(--green-line);
  font-size: 14.5px; font-weight: 600; color: var(--green-deep);
}
.swap-row svg { width: 16px; height: 16px; color: var(--green); flex: 0 0 auto; stroke-width: 2.4; }
.swap-arrow { align-self: center; display: flex; flex-direction: column; align-items: center; gap: 10px; color: var(--green); }
.swap-arrow svg { width: 30px; height: 30px; }
.swap-arrow .tag { font-size: 11px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-4); }
.swap-foot { margin-top: 20px; font-size: 14px; color: var(--text-3); }

/* ============================================================
   FAGOMRÅDER
   ============================================================ */
.feature-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.feature-card {
  position: relative; padding: 28px;
  background: var(--panel); border-radius: 16px;
  box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border);
  transition: box-shadow .25s var(--ease), transform .25s var(--ease);
}
.feature-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2), inset 0 0 0 1px var(--border); }
.feature-ic {
  width: 46px; height: 46px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  background: var(--green-soft);
  margin-bottom: 20px;
}
.feature-ic svg { width: 23px; height: 23px; color: var(--green-deep); stroke-width: 1.7; }
.feature-card .index-num { margin-bottom: 12px; color: var(--text-4); }
.feature-card .h3 { margin-bottom: 11px; }
.feature-card p { font-size: 15px; line-height: 1.6; color: var(--text-2); margin-bottom: 20px; }

/* ============================================================
   MODULER — 18-grid
   ============================================================ */
.modules-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  border: 1px solid var(--border); border-radius: 16px; overflow: hidden;
  background: var(--panel); box-shadow: var(--shadow-1);
}
.module-cell {
  position: relative; padding: 22px 24px 18px;
  border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
  transition: background .18s;
}
.module-cell:hover { background: var(--panel-2); }
.module-head { display: flex; align-items: center; gap: 11px; margin-bottom: 11px; }
.module-dot { width: 11px; height: 11px; border-radius: 50%; flex: 0 0 auto; }
.module-ic { width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; flex: 0 0 auto; }
.module-ic svg { width: 16px; height: 16px; stroke-width: 1.9; }
.module-name { font-family: var(--display); font-weight: 600; font-size: 17px; letter-spacing: -0.015em; }
.module-cell p { font-size: 13.5px; line-height: 1.55; color: var(--text-3); margin-bottom: 14px; }
.module-foot {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11px; font-weight: 600; color: var(--text-4);
}
.module-foot .tag { padding: 2px 8px; border-radius: 5px; background: var(--panel-2); color: var(--text-3); letter-spacing: 0.01em; }
.modules-foot { margin-top: 34px; text-align: center; }

/* ============================================================
   FELT — animert app-skjerm (lys, ekte felt-UI)
   ============================================================ */
.showcase-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.showcase-grid.reverse .showcase-visual { order: 2; }
.showcase-text .index-num { margin-bottom: 16px; color: var(--text-4); }
.showcase-text .eyebrow { margin-bottom: 16px; }
.showcase-text .display-2 { margin-bottom: 18px; }
.showcase-bullets { margin-top: 26px; display: grid; gap: 13px; }
.showcase-bullets li { display: flex; gap: 12px; align-items: flex-start; font-size: 15.5px; color: var(--text-2); }
.showcase-bullets li svg { width: 20px; height: 20px; flex: 0 0 auto; margin-top: 1px; color: var(--green); stroke-width: 2.2; }

/* ── field-flow motion graphic (replaces felt phone) ── */
.flow { position: relative; width: 100%; max-width: 380px; margin: 0 auto; padding: 64px 0 8px; }
.flow-cloud { position: relative; z-index: 2; width: max-content; margin: 0 auto; display: flex; align-items: center; gap: 9px;
  padding: 9px 16px; border-radius: 999px; background: var(--panel); box-shadow: var(--shadow-2), inset 0 0 0 1px var(--border);
  font-size: 13px; font-weight: 600; color: var(--text); }
.flow-cloud svg { width: 19px; height: 19px; color: var(--green); }
.flow-cloud::after { content: ""; position: absolute; inset: -5px; border-radius: 999px; box-shadow: 0 0 0 2px var(--green-line); opacity: 0; animation: flowPulse 8s ease-out infinite; }
@keyframes flowPulse { 0%,50% { opacity: 0; transform: scale(.94); } 58% { opacity: .9; transform: scale(1); } 82% { opacity: 0; transform: scale(1.22); } 100% { opacity: 0; } }
.flow-link { position: absolute; top: 50px; left: 50%; transform: translateX(-50%); width: 2px; height: 60px; z-index: 1;
  background: repeating-linear-gradient(var(--border-strong) 0 4px, transparent 4px 9px); }
.flow-packet { position: absolute; left: 50%; bottom: 0; width: 7px; height: 7px; border-radius: 50%; background: var(--green); transform: translate(-50%,0); opacity: 0; }
.flow-packet.p1 { animation: flowRise 8s ease-in infinite; }
.flow-packet.p2 { animation: flowRise 8s ease-in infinite .28s; }
.flow-packet.p3 { animation: flowRise 8s ease-in infinite .56s; }
@keyframes flowRise { 0%,44% { opacity: 0; transform: translate(-50%,0); } 48% { opacity: 1; } 58% { opacity: 1; transform: translate(-50%,-60px); } 62%,100% { opacity: 0; transform: translate(-50%,-60px); } }
.flow-card { position: relative; z-index: 2; max-width: 340px; margin: 0 auto; padding: 18px;
  background: var(--panel); border-radius: 18px; box-shadow: var(--shadow-2), inset 0 0 0 1px var(--border); }
.flow-card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 15px; }
.flow-eq { font-family: var(--display); font-weight: 600; font-size: 16px; letter-spacing: -0.015em; }
.flow-sub { font-size: 11.5px; color: var(--text-3); margin-top: 2px; }
.flow-qr { position: relative; width: 46px; height: 46px; border-radius: 12px; background: var(--panel-2); box-shadow: inset 0 0 0 1px var(--border);
  display: grid; place-items: center; color: var(--text-2); overflow: hidden; flex: 0 0 auto; }
.flow-qr svg { width: 24px; height: 24px; }
.flow-scan { position: absolute; left: 4px; right: 4px; height: 13px; top: 2px;
  background: linear-gradient(var(--green), transparent); border-top: 1.5px solid var(--green); opacity: .85; animation: flowScan 2.4s ease-in-out infinite; }
@keyframes flowScan { 0% { transform: translateY(0); } 50% { transform: translateY(30px); } 100% { transform: translateY(0); } }
.flow-rows { display: grid; gap: 8px; }
.flow-row { display: flex; align-items: center; gap: 11px; padding: 11px 12px; border-radius: 11px; font-size: 13px; font-weight: 500;
  background: var(--panel-2); color: var(--text-3); box-shadow: inset 0 0 0 1px var(--border); animation: flowRowDone 8s ease infinite; }
.flow-box { width: 19px; height: 19px; border-radius: 6px; flex: 0 0 auto; display: grid; place-items: center; box-shadow: inset 0 0 0 1.5px var(--border-strong); animation: flowBoxDone 8s ease infinite; }
.flow-box svg { width: 12px; height: 12px; color: #fff; opacity: 0; transform: scale(.4); animation: flowCheckIn 8s ease infinite; }
.flow-row.r2, .flow-row.r2 .flow-box, .flow-row.r2 .flow-box svg { animation-delay: .6s; }
.flow-row.r3, .flow-row.r3 .flow-box, .flow-row.r3 .flow-box svg { animation-delay: 1.2s; }
@keyframes flowRowDone { 0%,5% { background: var(--panel-2); color: var(--text-3); box-shadow: inset 0 0 0 1px var(--border); }
  12%,86% { background: var(--green-soft); color: var(--green-deep); box-shadow: inset 0 0 0 1px var(--green-line); }
  95%,100% { background: var(--panel-2); color: var(--text-3); box-shadow: inset 0 0 0 1px var(--border); } }
@keyframes flowBoxDone { 0%,5% { background: transparent; box-shadow: inset 0 0 0 1.5px var(--border-strong); }
  12%,86% { background: var(--green); box-shadow: inset 0 0 0 1.5px var(--green); }
  95%,100% { background: transparent; box-shadow: inset 0 0 0 1.5px var(--border-strong); } }
@keyframes flowCheckIn { 0%,5% { opacity: 0; transform: scale(.4); } 12%,86% { opacity: 1; transform: scale(1); } 95%,100% { opacity: 0; transform: scale(.4); } }
.flow-status { margin-top: 14px; display: flex; align-items: center; justify-content: center; gap: 8px; height: 40px; border-radius: 11px;
  font-size: 13px; font-weight: 600; background: var(--green-soft); color: var(--green-deep); box-shadow: inset 0 0 0 1px var(--green-line);
  opacity: 0; animation: flowStatus 8s ease infinite; }
.flow-status svg { width: 15px; height: 15px; }
@keyframes flowStatus { 0%,40% { opacity: 0; transform: translateY(6px); } 50%,88% { opacity: 1; transform: none; } 95%,100% { opacity: 0; transform: translateY(6px); } }
@media (prefers-reduced-motion: reduce) {
  .flow-scan, .flow-packet, .flow-cloud::after { animation: none; opacity: 0; }
  .flow-row { animation: none; background: var(--green-soft); color: var(--green-deep); box-shadow: inset 0 0 0 1px var(--green-line); }
  .flow-box { animation: none; background: var(--green); box-shadow: inset 0 0 0 1.5px var(--green); }
  .flow-box svg { animation: none; opacity: 1; transform: none; }
  .flow-status { animation: none; opacity: 1; }
}

.felt-stage { position: relative; display: flex; justify-content: center; align-items: center; min-height: 720px; }
.felt-stage::before {
  content: ""; position: absolute; width: 340px; height: 340px; border-radius: 50%;
  background: radial-gradient(closest-side, rgba(88,82,181,.16), transparent 72%); filter: blur(24px);
}
.felt-phone {
  position: relative; z-index: 2;
  width: 290px; border-radius: 42px; padding: 11px;
  background: #0f1720;
  box-shadow: var(--shadow-3), 0 0 0 1px rgba(15,23,32,.12);
}
.felt-notch { position: absolute; top: 18px; left: 50%; transform: translateX(-50%); width: 96px; height: 22px; background: #0f1720; border-radius: 14px; z-index: 6; }
.felt-screen {
  position: relative; border-radius: 32px; overflow: hidden;
  background: var(--bg); height: 656px;
  display: flex; flex-direction: column;
}
/* felt topbar */
.felt-top { flex: 0 0 auto; display: flex; align-items: center; gap: 10px; padding: 26px 14px 12px; background: var(--panel); border-bottom: 1px solid var(--border); }
.felt-back { width: 26px; height: 26px; display: grid; place-items: center; color: var(--text-2); flex: 0 0 auto; }
.felt-back svg { width: 18px; height: 18px; }
.felt-org { display: inline-flex; align-items: center; gap: 7px; padding: 5px 9px; border-radius: 999px; background: var(--panel); box-shadow: inset 0 0 0 1px var(--border); font-size: 11.5px; font-weight: 600; color: var(--text); }
.felt-org .felt-orgmark { width: 16px; height: 16px; border-radius: 5px; background: var(--green-soft); display: grid; place-items: center; }
.felt-org .felt-orgmark svg { width: 10px; height: 10px; color: var(--green-deep); }
.felt-title { margin-left: auto; font-family: var(--display); font-weight: 600; font-size: 14px; color: var(--text); letter-spacing: -0.01em; }
/* felt body */
.felt-body { flex: 1 1 auto; min-height: 0; padding: 12px; display: grid; gap: 9px; align-content: start; overflow: hidden; }
.felt-banner {
  display: flex; align-items: center; gap: 9px; padding: 11px 13px; border-radius: 12px;
  font-size: 12.5px; font-weight: 600;
  background: var(--amber-bg); color: var(--amber);
  box-shadow: inset 0 0 0 1px var(--amber-line);
  transition: all .4s var(--ease);
}
.felt-banner svg { width: 16px; height: 16px; flex: 0 0 auto; }
.felt-banner .ic-sync, .felt-banner .ic-done { display: none; }
.felt-banner[data-state="syncing"] .ic-off, .felt-banner[data-state="synced"] .ic-off { display: none; }
.felt-banner[data-state="syncing"] .ic-sync { display: block; }
.felt-banner[data-state="synced"] .ic-done { display: block; }
.felt-vtext { flex: 1; }
.felt-banner[data-state="syncing"] { background: var(--green-soft); color: var(--green-deep); box-shadow: inset 0 0 0 1px var(--green-line); }
.felt-banner[data-state="syncing"] .ic-sync { animation: spin .8s linear infinite; }
.felt-banner[data-state="synced"] { background: var(--green-soft); color: var(--green-deep); box-shadow: inset 0 0 0 1px var(--green-line); }

.felt-seclabel { font-size: 10.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-3); padding: 4px 2px 0; }
.felt-checks { display: grid; gap: 8px; }
.felt-check {
  padding: 11px 12px; border-radius: 14px; background: var(--panel);
  box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border);
}
.felt-check-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.felt-check-name { font-size: 13.5px; font-weight: 600; color: var(--text); line-height: 1.25; }
.felt-check-ref { font-size: 10.5px; color: var(--text-3); margin-top: 3px; display: flex; align-items: center; gap: 5px; }
.felt-check-ref svg { width: 11px; height: 11px; }
.felt-crit { font-size: 9.5px; font-weight: 700; padding: 3px 8px; border-radius: 999px; background: var(--red-bg); color: var(--red); box-shadow: inset 0 0 0 1px var(--red-line); flex: 0 0 auto; }
.felt-verdict {
  display: flex; align-items: center; gap: 8px; margin-top: 9px;
  padding: 8px 11px; border-radius: 10px;
  font-size: 12.5px; font-weight: 600;
  box-shadow: inset 0 0 0 1px var(--border); background: var(--panel-2); color: var(--text-4);
  transition: all .35s var(--ease);
}
.felt-verdict .felt-vic { width: 16px; height: 16px; flex: 0 0 auto; display: grid; place-items: center; }
.felt-verdict .felt-vic svg { width: 14px; height: 14px; opacity: 0; transform: scale(.4); transition: all .3s var(--ease); color: var(--green); }
.felt-verdict .felt-vchev { margin-left: auto; color: var(--text-4); }
.felt-verdict .felt-vchev svg { width: 14px; height: 14px; }
.felt-check.done .felt-verdict { background: var(--green-soft); color: var(--green-deep); box-shadow: inset 0 0 0 1px var(--green-line); }
.felt-check.done .felt-verdict .felt-vic svg { opacity: 1; transform: none; }
/* felt bottom actions */
.felt-save {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 2px; height: 46px; border-radius: 999px;
  background: var(--navy); color: #fff; font-size: 14px; font-weight: 700;
}
.felt-save svg { width: 16px; height: 16px; }
/* felt bottom tabbar */
.felt-tabbar { flex: 0 0 auto; height: 60px; display: flex; align-items: center; justify-content: space-around; background: var(--panel); border-top: 1px solid var(--border); }
.felt-tab { display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: 9.5px; font-weight: 600; color: var(--text-4); position: relative; }
.felt-tab svg { width: 21px; height: 21px; stroke-width: 1.9; }
.felt-tab.active { color: var(--green-deep); }
.felt-tab.qr { color: #fff; }
.felt-tab.qr .felt-qrbtn { width: 46px; height: 46px; border-radius: 15px; background: var(--navy); display: grid; place-items: center; margin-top: -18px; box-shadow: 0 8px 18px -6px rgba(58,35,86,.5); }
.felt-tab.qr .felt-qrbtn svg { width: 22px; height: 22px; }

/* floating event chips */
.felt-float { position: absolute; z-index: 4; display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 13px; border-radius: 999px; font-size: 12px; font-weight: 600; color: var(--text);
  background: var(--panel); box-shadow: var(--shadow-2), inset 0 0 0 1px var(--border);
  opacity: 0; transform: translateY(8px) scale(.96); transition: opacity .5s var(--ease), transform .5s var(--ease); }
.felt-float.show { opacity: 1; transform: none; }
.felt-float svg { width: 14px; height: 14px; color: var(--green); }
.felt-float.f1 { top: 12%; left: -8%; }
.felt-float.f2 { top: 44%; right: -12%; }
.felt-float.f3 { bottom: 16%; left: -4%; }
@media (max-width: 980px) {
  .felt-float.f1 { left: 0%; }
  .felt-float.f2 { right: -2%; }
}

/* ============================================================
   TRYGGHET — 6 pillars
   ============================================================ */
.trust-head { text-align: center; max-width: 680px; margin: 0 auto 52px; }
.trust-head .eyebrow { justify-content: center; margin-bottom: 20px; }
.trust-head .body { margin-top: 18px; }
.trust-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.trust-cell {
  padding: 28px; border-radius: 16px; background: var(--panel);
  box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border);
  transition: box-shadow .2s, transform .2s var(--ease);
}
.trust-cell:hover { transform: translateY(-2px); box-shadow: var(--shadow-2), inset 0 0 0 1px var(--border); }
.trust-ic { width: 42px; height: 42px; border-radius: 11px; background: var(--green-soft); display: grid; place-items: center; margin-bottom: 18px; }
.trust-ic svg { width: 21px; height: 21px; color: var(--green-deep); stroke-width: 1.7; }
.trust-num { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 10px; background: var(--green-soft); color: var(--green-deep); font-family: var(--display); font-weight: 700; font-size: 14px; margin-bottom: 16px; }
.trust-cell h4 { font-family: var(--display); font-weight: 600; font-size: 18px; letter-spacing: -0.01em; margin-bottom: 10px; color: var(--text); }
.trust-cell p { font-size: 14.5px; line-height: 1.6; color: var(--text-2); }

/* ============================================================
   PRISER
   ============================================================ */
.priser-head { text-align: center; max-width: 620px; margin: 0 auto 52px; }
.priser-head .eyebrow { justify-content: center; margin-bottom: 20px; }
.priser-head .body { margin-top: 16px; }
.priser-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 14px; }
.priser-card {
  position: relative; padding: 26px 22px; display: flex; flex-direction: column;
  border-radius: 16px; background: var(--panel);
  box-shadow: var(--shadow-1), inset 0 0 0 1px var(--border);
}
.priser-card.popular { box-shadow: var(--shadow-2), inset 0 0 0 1.5px var(--green); }
.priser-tag {
  position: absolute; top: -11px; left: 22px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.01em;
  color: #fff; padding: 4px 11px; border-radius: 999px; background: var(--green);
}
.priser-name { font-family: var(--display); font-weight: 600; font-size: 20px; letter-spacing: -0.015em; margin-bottom: 9px; }
.priser-aud { font-size: 13.5px; line-height: 1.5; color: var(--text-3); min-height: 60px; }
.priser-users {
  font-size: 12px; font-weight: 600; color: var(--green-deep);
  padding: 10px 0; margin: 12px 0 18px;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
}
.priser-feats { display: grid; gap: 11px; margin-bottom: 22px; flex: 1; }
.priser-feat { display: flex; gap: 10px; align-items: flex-start; font-size: 13.5px; line-height: 1.45; color: var(--text-2); }
.priser-feat svg { width: 15px; height: 15px; color: var(--green); flex: 0 0 auto; margin-top: 2px; stroke-width: 2.6; }
.priser-card .btn { width: 100%; height: 42px; font-size: 14px; }

/* ============================================================
   CTA — navy band (felt primær-farge)
   ============================================================ */
.cta { padding: clamp(72px,9vw,120px) 0; position: relative; overflow: hidden;
  background: linear-gradient(135deg, #281540 0%, #3a2356 46%, #473a7c 100%); }
.cta::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px; z-index: 3;
  background: linear-gradient(90deg, transparent, rgba(160,135,255,.7), transparent); }
.cta-orbs { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.cta-orbs .orb { opacity: .5; filter: blur(50px); }
.cta-orbs .co1 { width: 520px; height: 520px; background: #6f68c4; left: 6%; bottom: -42%; animation: orbFloat2 26s ease-in-out infinite; }
.cta-orbs .co2 { width: 440px; height: 440px; background: #8f8ad6; right: 4%; top: -32%; animation: orbFloat3 31s ease-in-out infinite; }
.cta-bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none;
  background: radial-gradient(760px 440px at 50% -16%, rgba(155,124,255,.30), transparent 60%),
              radial-gradient(620px 380px at 50% 120%, rgba(111,104,196,.26), transparent 60%); }
.cta-grid { position: absolute; inset: -2px; opacity: .5;
  background: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
              linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 48px 48px, 48px 48px; animation: ctaGrid 26s linear infinite; }
@keyframes ctaGrid { from { background-position: 0 0, 0 0; } to { background-position: 0 48px, 48px 0; } }
.cta-sweep { position: absolute; top: -25%; left: -45%; width: 45%; height: 150%;
  background: linear-gradient(100deg, transparent, rgba(170,140,255,.16), transparent);
  transform: skewX(-14deg); animation: ctaSweep 9s ease-in-out infinite; }
@keyframes ctaSweep { 0% { left: -50%; } 55%,100% { left: 125%; } }
.cta-dot { position: absolute; bottom: 0; width: 5px; height: 5px; border-radius: 50%; background: rgba(199,195,236,.55); opacity: 0; animation: ctaFloat 13s linear infinite; }
.cta-dot.d1 { left: 14%; animation-delay: 0s; }
.cta-dot.d2 { left: 32%; animation-delay: 3.4s; }
.cta-dot.d3 { left: 58%; animation-delay: 6.1s; }
.cta-dot.d4 { left: 76%; animation-delay: 1.8s; }
.cta-dot.d5 { left: 89%; animation-delay: 8.5s; }
@keyframes ctaFloat { 0% { transform: translateY(40px); opacity: 0; } 12% { opacity: .7; } 85% { opacity: .35; } 100% { transform: translateY(-180px); opacity: 0; } }
@media (prefers-reduced-motion: reduce) { .cta-grid, .cta-sweep, .cta-dot { animation: none; } .cta-dot { opacity: 0; } }
.cta-inner { position: relative; z-index: 1; text-align: center; max-width: 720px; margin: 0 auto; }
.cta-inner .eyebrow { justify-content: center; margin-bottom: 22px; color: #c7c3ec; }
.cta-inner .eyebrow::before { background: #c7c3ec; }
.cta-inner h2 { font-family: var(--display); font-weight: 550; font-size: clamp(30px,4vw,46px); letter-spacing: -0.02em; line-height: 1.12; color: #fff; }
.cta-inner h2 em { font-style: normal; background: linear-gradient(180deg, #ffffff 0%, #c7c3ec 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: #c7c3ec; }
.cta-inner p { margin: 22px auto 0; max-width: 540px; font-size: 18px; color: rgba(255,255,255,.78); }
.cta-actions { margin-top: 38px; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.cta .btn-primary { background: #fff; color: #241c44; box-shadow: 0 1px 2px rgba(0,0,0,.18), 0 14px 30px -16px rgba(0,0,0,.6); }
.cta .btn-primary:hover { background: #efedf8; }
.cta-meta { font-size: 13.5px; color: rgba(255,255,255,.6); }
.cta-meta a { color: #c7c3ec; font-weight: 600; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { border-top: 1px solid var(--border); padding: 64px 0 40px; background: var(--panel); }
.footer-top { display: grid; grid-template-columns: 1.6fr repeat(4, 1fr); gap: 32px; padding-bottom: 44px; border-bottom: 1px solid var(--border); }
.footer-brand p { margin-top: 16px; font-size: 14px; line-height: 1.6; color: var(--text-3); max-width: 280px; }
.footer-col h4 { font-size: 12px; font-weight: 700; letter-spacing: 0.02em; color: var(--text); margin-bottom: 15px; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { font-size: 14.5px; color: var(--text-2); transition: color .18s; }
.footer-col a:hover { color: var(--green-deep); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 26px; font-size: 12.5px; color: var(--text-4); }

/* ============================================================
   REVEAL — premium blur-in, expo easing
   ============================================================ */
:root { --ease-out: cubic-bezier(0.16, 1, 0.3, 1); }
.reveal { opacity: 1; transform: none; }
.has-js .reveal { opacity: 0; transform: translateY(34px) scale(.985); filter: blur(7px); transition: opacity .9s var(--ease-out), transform 1s var(--ease-out), filter .9s var(--ease-out); }
.reveal.in { opacity: 1; transform: none; filter: none; }
/* directional slide-ins */
.has-js .reveal-left  { opacity: 0; transform: translateX(-46px); filter: blur(7px); transition: opacity .9s var(--ease-out), transform 1s var(--ease-out), filter .9s var(--ease-out); }
.has-js .reveal-right { opacity: 0; transform: translateX(46px);  filter: blur(7px); transition: opacity .9s var(--ease-out), transform 1s var(--ease-out), filter .9s var(--ease-out); }
.reveal-left.in, .reveal-right.in { opacity: 1; transform: none; filter: none; }
.reveal-stagger > * { opacity: 1; transform: none; }
.has-js .reveal-stagger > * { opacity: 0; transform: translateY(30px) scale(.985); filter: blur(6px); transition: opacity .8s var(--ease-out), transform .9s var(--ease-out), filter .8s var(--ease-out); }
.reveal-stagger.in > * { opacity: 1; transform: none; filter: none; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: .08s; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: .16s; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: .24s; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: .32s; }
.reveal-stagger.in > *:nth-child(n+6) { transition-delay: .40s; }

/* ============================================================
   PREMIUM MOTION — hero cascade, window sheen, micro-interactions
   ============================================================ */
/* Hero: neutralise the block-level fade, cascade the children instead. */
.has-js .hero-lead-col.reveal,
.has-js .hero-aside.reveal { opacity: 1; transform: none; filter: none; }
.has-js .hero-lead-col > *,
.has-js .hero-aside > * {
  opacity: 0; transform: translateY(26px); filter: blur(8px);
  transition: opacity .95s var(--ease-out), transform 1.05s var(--ease-out), filter .95s var(--ease-out);
}
.hero-lead-col.in > *, .hero-aside.in > * { opacity: 1; transform: none; filter: none; }
.hero-lead-col.in > *:nth-child(1) { transition-delay: .05s; }
.hero-lead-col.in > *:nth-child(2) { transition-delay: .16s; }
.hero-lead-col.in > *:nth-child(3) { transition-delay: .30s; }
.hero-aside.in > *:nth-child(1) { transition-delay: .40s; }
.hero-aside.in > *:nth-child(2) { transition-delay: .50s; }
/* let the headline's italic accent settle in colour a beat after it lands */
.has-js .hero h1 em { color: var(--text); transition: color .8s var(--ease-out) .55s; }
.hero-lead-col.in h1 em { color: var(--green); }

/* Product window: deeper entrance + a single light sheen sweep on arrival. */
.has-js .hero-shot-wrap.reveal { opacity: 0; transform: translateY(46px) scale(.97); filter: blur(10px); transition: opacity 1.1s var(--ease-out), transform 1.2s var(--ease-out), filter 1.1s var(--ease-out); }
.hero-shot-wrap.reveal.in { opacity: 1; transform: none; filter: none; }
.window { position: relative; }
.window::after {
  content: ""; position: absolute; inset: 0; z-index: 5; pointer-events: none;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.55) 47%, rgba(255,255,255,.0) 64%);
  transform: translateX(-120%); opacity: 0;
}
.hero-shot-wrap.in .window::after { animation: winSheen 1.5s var(--ease-out) .55s 1 both; }
@keyframes winSheen { 0% { transform: translateX(-120%); opacity: 0; } 18% { opacity: 1; } 100% { transform: translateX(120%); opacity: 0; } }

/* Primary button: subtle sheen sweep on hover. */
.btn-primary { position: relative; overflow: hidden; }
.btn-primary::after {
  content: ""; position: absolute; top: 0; bottom: 0; left: 0; width: 45%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.22), transparent);
  transform: translateX(-180%); pointer-events: none;
}
.btn-primary:hover::after { animation: btnSheen .9s var(--ease-out) 1; }
@keyframes btnSheen { to { transform: translateX(320%); } }

/* Card micro-interactions — lift + accent hairline on hover. */
.module-cell, .priser-card, .trust-cell { transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.module-cell:hover, .trust-cell:hover { transform: translateY(-4px); box-shadow: var(--shadow-2), inset 0 0 0 1px var(--green-line); }
.priser-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-2), inset 0 0 0 1px var(--green-line); }
.feature-card { transition: transform .35s var(--ease-out), box-shadow .35s var(--ease-out); }
.feature-card:hover { transform: translateY(-5px); }
.feature-ic, .trust-ic { transition: transform .4s var(--ease-out); }
.feature-card:hover .feature-ic, .trust-cell:hover .trust-ic { transform: scale(1.08) rotate(-3deg); }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-left, .reveal-right, .reveal-stagger > *,
  .hero-lead-col > *, .hero-aside > *, .hero-shot-wrap.reveal { opacity: 1 !important; transform: none !important; filter: none !important; }
  .has-js .hero h1 em { color: var(--green); }
  .window::after, .btn-primary::after { display: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  .feature-grid { grid-template-columns: 1fr; }
  .modules-grid { grid-template-columns: repeat(2,1fr); }
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .priser-grid { grid-template-columns: repeat(2,1fr); }
  .sec-head { grid-template-columns: 1fr; gap: 16px; }
  .hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .hero h1 { max-width: 18ch; }
  .hero-aside { padding-bottom: 0; max-width: 560px; }
}
@media (max-width: 860px) {
  .nav-links, .nav-login { display: none; }
  .menu-toggle { display: inline-block; }
  .nav-cta { display: none; }
  .statusbar-row .sb-hide { display: none; }
  .swap-grid { grid-template-columns: 1fr; }
  .swap-arrow { flex-direction: row; transform: rotate(90deg); margin: 4px 0; }
  .showcase-grid { grid-template-columns: 1fr; gap: 40px; }
  .showcase-grid.reverse .showcase-visual { order: 0; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .cmd-kpis { grid-template-columns: repeat(3,1fr); }
}
@media (max-width: 560px) {
  .container { padding: 0 20px; }
  .nav-row { height: 100px; }
  .brand-mark { height: 50px; }
  .brand-img { height: 80px; }
  .modules-grid, .trust-grid, .priser-grid { grid-template-columns: 1fr; }
  .cmd-kpis { grid-template-columns: repeat(2,1fr); }
  .cmd-lower { grid-template-columns: 1fr; }
  .hero-ctas { flex-direction: column; }
  .hero-ctas .btn { width: 100%; }
  .footer-top { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; gap: 10px; align-items: flex-start; }
  /* tighter, more intentional mobile rhythm */
  .section { padding: 54px 0; }
  .sec-head { margin-bottom: 32px; }
  .hero { padding-top: 40px; }
  .hero h1 { font-size: clamp(30px, 8.4vw, 38px); max-width: none; }
  .hero .eyebrow { margin-bottom: 16px; }
  .hero-ctas { margin-top: 28px; }
  .hero-shot-wrap { margin-top: 36px; }
  .hero-facts { margin-top: 20px; }
  .display-2 { font-size: clamp(23px, 6.6vw, 30px); }
}

/* ============================================================
   REFINEMENT PASS — strip the "AI landing page" tells
   · no floating aurora orbs, no grid-paper, no particle CTA
   · flat confident surfaces, restrained motion, editorial type
   · authentic emerald brand restored in :root
   ============================================================ */

/* 1 — Kill all decorative background layers (purely aria-hidden cruft) */
.hero-orbs, .sec-orbs, .cta-orbs,
.hero-bg, .page-hero .hero-bg, .auth-wrap .hero-bg,
.cta-bg, .cta-grid, .cta-sweep, .cta-dot { display: none !important; }

/* 2 — CTA: deep ink band, flat and quiet (was purple gradient + particles) */
.cta { background: #14132a; }
.cta::before { background: linear-gradient(90deg, transparent, rgba(99,91,240,.6), transparent); }
.cta-inner .eyebrow { color: #a8a2f2; }
.cta-inner .eyebrow::before { background: #a8a2f2; }
.cta-inner h2 em {
  background: none; -webkit-text-fill-color: currentColor;
  color: #a8a2f2;
}
.cta .btn-primary { background: #fff; color: #14132a; box-shadow: 0 1px 2px rgba(0,0,0,.18), 0 14px 30px -16px rgba(0,0,0,.55); }
.cta .btn-primary:hover { background: #eeedfb; }
.cta-meta a { color: #a8a2f2; }

/* 3 — Calm the reveals: a simple, intentional fade + rise (no blur, no scale) */
.has-js .reveal { transform: translateY(20px); filter: none; transition: opacity .7s var(--ease-out), transform .8s var(--ease-out); }
.has-js .reveal-left  { transform: translateX(-26px); filter: none; transition: opacity .7s var(--ease-out), transform .8s var(--ease-out); }
.has-js .reveal-right { transform: translateX(26px);  filter: none; transition: opacity .7s var(--ease-out), transform .8s var(--ease-out); }
.has-js .reveal-stagger > * { transform: translateY(18px); filter: none; transition: opacity .65s var(--ease-out), transform .75s var(--ease-out); }
.has-js .hero-lead-col > *, .has-js .hero-aside > * { filter: none; }
.hero-lead-col.in > *, .hero-aside.in > * { opacity: 1; transform: none; filter: none; }
.has-js .hero-shot-wrap.reveal { transform: translateY(26px) scale(1); filter: none; transition: opacity .8s var(--ease-out), transform .9s var(--ease-out); }

/* 4 — Drop the gimmick sheens (button glint + window glass sweep) */
.btn-primary::after, .window::after { display: none !important; }

/* 5 — Restrained hover: keep the lift, lose the spinning icons */
.feature-card:hover .feature-ic, .trust-cell:hover .trust-ic,
.area-card:hover .area-ic, .value-card:hover .value-ic { transform: none; }
.module-cell:hover, .trust-cell:hover, .priser-card:hover,
.feature-card:hover, .area-card:hover, .mod-detail:hover, .om-module-card:hover {
  box-shadow: var(--shadow-2), inset 0 0 0 1px var(--border);
}
.feature-card:hover { transform: translateY(-3px); }

/* ============================================================
   MOTION PASS — kinetic headline · module ticker · parallax
   Tasteful, intentional movement (not decorative slop).
   ============================================================ */

/* Kinetic headline — words rise from behind a mask, staggered */
.has-js .hero-lead-col > h1.display-1 { opacity: 1; transform: none; filter: none; }
.kinetic .w {
  display: inline-block; overflow: hidden; vertical-align: top;
  padding: 0.14em 0; margin: -0.14em 0.19em -0.14em 0;
}
.kinetic .wi {
  display: inline-block; transform: translateY(118%);
  transition: transform .9s var(--ease-out);
  will-change: transform;
}
.kinetic .w-accent .wi { color: var(--green); }
.kinetic.go .wi { transform: none; }
@media (prefers-reduced-motion: reduce) {
  .kinetic .wi { transform: none !important; transition: none !important; }
}

/* Interactive CTA — cursor-lit oversized wordmark + warm spotlight + magnetic button */
.cta-pro { position: relative; overflow: hidden; --mx: 50%; --my: 42%; }
.cta-pro .container { position: relative; z-index: 2; }
.cta-spot {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(460px 460px at var(--mx) var(--my), rgba(99,91,240,.30), transparent 68%);
}
.cta-ghost {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.cta-ghost span {
  font-family: var(--display); font-weight: 600;
  font-size: clamp(130px, 25vw, 380px); line-height: 1; white-space: nowrap;
  letter-spacing: -0.045em; color: #fff;
  -webkit-mask-image: radial-gradient(300px 300px at var(--mx) var(--my), rgba(0,0,0,.9) 0%, rgba(0,0,0,.32) 46%, transparent 72%);
  mask-image: radial-gradient(300px 300px at var(--mx) var(--my), rgba(0,0,0,.9) 0%, rgba(0,0,0,.32) 46%, transparent 72%);
  opacity: .14;
}
.cta-inner .cta-h .w-accent .wi { color: #a8a2f2; }
.cta-magnet { will-change: transform; }
@media (prefers-reduced-motion: reduce) {
  .cta-ghost span { -webkit-mask-image: none; mask-image: none; opacity: .05; }
}

/* Cool nav — sliding hover indicator + auth cluster */
.nav-links { position: relative; }
.nav-link { position: relative; z-index: 1; white-space: nowrap; }
.nav-link:hover { background: transparent; color: var(--green-deep); }
.nav-ind {
  position: absolute; top: 50%; left: 0; height: 34px; width: 0;
  transform: translateY(-50%);
  border-radius: 9px; background: rgba(79,70,229,0.10);
  box-shadow: inset 0 0 0 1px rgba(79,70,229,0.22);
  opacity: 0; z-index: 0; pointer-events: none;
  transition: transform .32s var(--ease), width .32s var(--ease), height .32s var(--ease), opacity .25s var(--ease);
}
.nav-register { height: 40px; padding: 0 16px; font-size: 14px; }
@media (max-width: 1080px) { .nav-register { display: none; } }
@media (max-width: 980px) {
  .nav-links, .nav-login, .nav-cta { display: none; }
  .menu-toggle { display: inline-block; }
}

/* Module ticker — continuous industrial marquee band */
.marquee {
  position: relative; overflow: hidden;
  border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  background: var(--panel); padding: 16px 0;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
}
.marquee-track {
  display: flex; align-items: center; gap: 14px;
  width: max-content; will-change: transform;
  animation: marqueeScroll 52s linear infinite;
}
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-item {
  display: inline-flex; align-items: center; gap: 11px;
  font-family: var(--display); font-weight: 600; font-size: 19px;
  letter-spacing: -0.01em; color: var(--text); white-space: nowrap;
}
.marquee-item::after { content: "·"; margin-left: 14px; color: var(--text-4); font-weight: 400; }
.marquee-item i { width: 9px; height: 9px; border-radius: 50%; flex: 0 0 auto; }
@keyframes marqueeScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee-track { animation: none; } }

/* Hero product window — gentle scroll parallax (set via JS) */
.hero-shot-wrap { will-change: transform; }

/* ============================================================
   INTRODUKSJONSPRIS — limited launch offer
   ============================================================ */
.introprice-section { padding-top: 0; }
.introprice {
  position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.25fr 1fr; gap: clamp(32px, 5vw, 64px); align-items: center;
  background: var(--green-soft);
  border: 1px solid var(--green-line);
  border-radius: 24px;
  padding: clamp(32px, 4.4vw, 56px);
}
.introprice-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 12px; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--green-deep);
  background: var(--panel);
  border: 1px solid var(--green-line);
  padding: 8px 15px; border-radius: 999px; margin-bottom: 22px;
}
.introprice-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); position: relative; flex: 0 0 auto; }
.introprice-dot::after { content: ""; position: absolute; inset: -4px; border-radius: 50%; border: 1.5px solid var(--green); opacity: .5; animation: ippulse 2.1s ease-out infinite; }
@keyframes ippulse { 0% { transform: scale(.55); opacity: .65; } 100% { transform: scale(1.7); opacity: 0; } }
.introprice h2 { margin-bottom: 12px; }
.introprice-sub { font-family: var(--display); font-weight: 500; font-size: clamp(18px, 2.1vw, 23px); color: var(--text); letter-spacing: -.01em; line-height: 1.25; margin-bottom: 14px; }
.introprice-text { font-size: 16px; line-height: 1.62; color: var(--text-2); max-width: 470px; margin-bottom: 28px; }
.introprice-cta { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.introprice-disclaimer { font-size: 13px; color: var(--text-3); max-width: 200px; line-height: 1.45; }
/* meter */
.introprice-meter { text-align: center; }
.introprice-bignum { font-family: var(--display); font-weight: 600; font-size: clamp(78px, 10vw, 128px); line-height: .9; color: var(--green); letter-spacing: -.04em; }
.introprice-bignum span { display: block; font-size: .19em; color: var(--text-2); font-weight: 500; letter-spacing: 0; margin-top: 12px; }
.introprice-seats { display: flex; justify-content: center; flex-wrap: wrap; gap: 8px; margin-top: 26px; max-width: 240px; margin-left: auto; margin-right: auto; }
.introprice-seat { width: 22px; height: 11px; border-radius: 3px; background: var(--green); }
.introprice-seat.taken { background: var(--green-line); }
@media (max-width: 760px) {
  .introprice { grid-template-columns: 1fr; gap: 30px; padding: 30px 24px; }
  .introprice-meter { order: -1; }
  .introprice-bignum { font-size: clamp(72px, 22vw, 104px); }
}
