/* ─────────────────────────────────────────────
   NORDIVÉ — premium legal-tech redesign
   Off-white + navy + subtle blue link accent
   ───────────────────────────────────────────── */

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  background:var(--off);
  color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;
  font-weight:400;
  font-feature-settings:"ss01","cv11";
  line-height:1.55;
}

:root{
  /* Surfaces */
  --off:#FAF8F4;
  --off-2:#F4F1EB;
  --white:#FFFFFF;
  --navy:#0E1B33;
  --navy-2:#162644;
  --navy-3:#1C3057;

  /* Ink */
  --ink:#0E1B33;
  --ink-2:#2A3A5C;
  --mid:#5A6580;
  --dim:#8A93A8;
  --rule:rgba(14,27,51,.10);
  --rule-2:rgba(14,27,51,.06);

  /* Subtle blue accent (links only) */
  --link:#1E3A8A;
  --link-h:#2945A0;

  /* Semantic */
  --red:#B0413E;
  --red-bg:rgba(176,65,62,.06);
  --amber:#A87528;
  --amber-bg:rgba(168,117,40,.07);
  --green:#3F7A52;
  --green-bg:rgba(63,122,82,.07);

  /* Typography */
  --font-h:'Inter Tight',system-ui,sans-serif;
  --font-serif:'Playfair Display',Georgia,serif;
  --font-body:'Inter',system-ui,sans-serif;
}

::selection{background:rgba(30,58,138,.18);color:var(--ink)}

/* ── Reusable ── */
.fu{opacity:0;transform:translateY(20px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.fu.v{opacity:1;transform:translateY(0)}

.btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--navy);color:#fff;
  font-family:var(--font-body);font-size:.92rem;font-weight:500;
  padding:.95rem 1.5rem;border-radius:2px;
  text-decoration:none;letter-spacing:-.005em;
  border:1px solid var(--navy);
  cursor:pointer;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),background .2s;
}
.btn-primary:hover{background:#000;transform:translateY(-1px)}

.btn-link{
  display:inline-flex;align-items:center;gap:.45rem;
  color:var(--link);font-size:.9rem;font-weight:500;
  text-decoration:none;letter-spacing:-.005em;
  border-bottom:1px solid transparent;
  padding-bottom:2px;
  transition:color .2s,border-color .2s;
}
.btn-link:hover{color:var(--link-h);border-bottom-color:var(--link-h)}
.btn-link svg{transition:transform .2s}
.btn-link:hover svg{transform:translateX(2px)}
.btn-link-light{color:rgba(255,255,255,.85)}
.btn-link-light:hover{color:#fff;border-bottom-color:#fff}

/* ── NAV ── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:72px;
  background:rgba(250,248,244,.78);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
#nav.scrolled{border-bottom-color:var(--rule-2);background:rgba(250,248,244,.92)}
.nav-inner{
  max-width:1280px;height:100%;margin:0 auto;
  display:flex;align-items:center;
  padding:0 clamp(20px,4vw,40px);gap:2rem;
}
.nav-logo{
  display:flex;align-items:center;gap:.55rem;
  font-family:var(--font-h);font-size:1.15rem;font-weight:500;
  letter-spacing:-.01em;color:var(--navy);
  text-decoration:none;flex-shrink:0;
}
.logo-mark{
  width:22px;height:22px;
  background:url('assets/logo-blue.png') center/contain no-repeat;
  flex-shrink:0;
}
.logo-mark-light{
  background:url('assets/logo-white.png') center/contain no-repeat;
}

.nav-links{display:flex;gap:2rem;margin-left:1rem}
.nav-link{
  font-size:.88rem;color:var(--mid);text-decoration:none;
  letter-spacing:-.005em;transition:color .2s;
}
.nav-link:hover{color:var(--navy)}

.nav-actions{margin-left:auto;display:flex;align-items:center;gap:1.25rem}
.nav-ghost{
  font-size:.88rem;color:var(--mid);text-decoration:none;
  transition:color .2s;
}
.nav-ghost:hover{color:var(--navy)}
.nav-cta{
  font-size:.88rem;font-weight:500;
  background:var(--navy);color:#fff;
  padding:.6rem 1.1rem;border-radius:2px;
  text-decoration:none;letter-spacing:-.005em;
  transition:background .2s,transform .2s;
}
.nav-cta:hover{background:#000;transform:translateY(-1px)}

.nav-ham{display:none;background:none;border:none;cursor:pointer;padding:.4rem;color:var(--navy)}
.nav-mob{
  display:none;position:fixed;inset:72px 0 0;z-index:199;
  background:var(--off);flex-direction:column;
  padding:2rem 1.5rem;gap:.25rem;
}
.nav-mob.open{display:flex}
.nav-mob-link{
  padding:1rem 0;font-size:1.1rem;color:var(--ink);
  text-decoration:none;border-bottom:1px solid var(--rule-2);
}
.nav-mob-cta{
  margin-top:1.5rem;padding:1rem;text-align:center;
  background:var(--navy);color:#fff;border-radius:2px;
  text-decoration:none;font-weight:500;
}
@media(max-width:880px){
  .nav-links,.nav-actions .nav-ghost,.nav-actions .nav-cta{display:none}
  .nav-actions{margin-left:auto}
  .nav-ham{display:block}
}

/* ── HERO ── */
.hero{
  position:relative;
  min-height:100vh;
  padding:140px clamp(20px,4vw,40px) 60px;
  background:var(--off);
  overflow:hidden;
  display:flex;flex-direction:column;
}
.hero-grain{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%,rgba(14,27,51,.025) 0%,transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(14,27,51,.02) 0%,transparent 60%);
}
.hero-inner{
  max-width:1180px;margin:0 auto;width:100%;
  flex:1;display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:2;
  padding:3rem 0 5rem;
}
.hero-eye{
  display:inline-flex;align-items:center;gap:.85rem;
  font-size:.78rem;letter-spacing:.04em;color:var(--mid);
  margin-bottom:2.25rem;
  font-weight:500;
}
.hero-rule{display:inline-block;width:32px;height:1px;background:var(--mid)}
.hero-h{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(2.4rem,6.5vw,5.6rem);
  line-height:1.02;letter-spacing:-.035em;
  color:var(--navy);
  margin-bottom:2rem;
  max-width:1000px;
}
.hero-h em{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  color:var(--navy);
  letter-spacing:-.02em;
}
.hero-sub{
  font-size:1.1rem;line-height:1.65;
  color:var(--ink-2);
  max-width:560px;
  margin-bottom:2.75rem;
  font-weight:400;
}
.hero-btns{display:flex;align-items:center;gap:1.5rem;margin-bottom:2.5rem;flex-wrap:wrap}
.hero-trust{
  display:flex;align-items:center;flex-wrap:wrap;gap:.6rem;
  font-size:.82rem;color:var(--mid);letter-spacing:-.005em;
}
.ht-dot{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px rgba(63,122,82,.14)}
.ht-sep{width:3px;height:3px;border-radius:50%;background:var(--rule);margin:0 .35rem}

.hero-marquee{
  position:relative;z-index:2;
  margin-top:auto;
  border-top:1px solid var(--rule-2);
  padding-top:2.25rem;
  max-width:1180px;margin-left:auto;margin-right:auto;width:100%;
}
.hm-label{
  text-align:center;font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--dim);
  margin-bottom:1.5rem;font-weight:500;
}
.hm-track-wrap{
  overflow:hidden;
  mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);
}
.hm-track{
  display:flex;align-items:center;gap:2.5rem;
  width:max-content;
  animation:marquee 38s linear infinite;
}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.hm-item{
  font-family:var(--font-h);font-size:.92rem;font-weight:400;
  color:var(--ink-2);letter-spacing:-.005em;white-space:nowrap;
  font-style:italic;
}
.hm-dot{width:4px;height:4px;border-radius:50%;background:var(--rule)}

/* ── STATS ── */
.stats-sec{
  background:var(--off);
  border-top:1px solid var(--rule-2);
  border-bottom:1px solid var(--rule-2);
  padding:5rem clamp(20px,4vw,40px);
}
.stats-inner{
  max-width:1180px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
}
.stat{
  padding:2rem 2.5rem;
  border-right:1px solid var(--rule-2);
}
.stat:first-child{padding-left:0}
.stat:last-child{padding-right:0;border-right:none}
.stat-num{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(2.6rem,5vw,4.2rem);
  line-height:.95;letter-spacing:-.04em;
  color:var(--navy);margin-bottom:.85rem;
  display:flex;align-items:baseline;gap:.45rem;
}
.stat-unit{font-size:.55em;color:var(--mid);font-weight:400;letter-spacing:-.02em}
.stat-lbl{font-size:.95rem;line-height:1.5;color:var(--ink-2);margin-bottom:.85rem;max-width:340px}
.stat-src{font-size:.72rem;color:var(--dim);letter-spacing:.02em}
@media(max-width:760px){
  .stats-inner{grid-template-columns:1fr;gap:1.25rem}
  .stat{padding:1.5rem 0;border-right:none;border-bottom:1px solid var(--rule-2)}
  .stat:last-child{border-bottom:none}
}

/* ── SECTION SHELL ── */
.sec{padding:7rem clamp(20px,4vw,40px)}
.sec-inner{max-width:1180px;margin:0 auto}
.sec-off{background:var(--off)}
.sec-white{background:var(--white)}
.sec-dark{background:var(--navy);color:#fff}
.sec-dark .sec-h{color:#fff}

.sec-head{max-width:680px;margin-bottom:4rem}
.sec-head-c{text-align:center;margin-left:auto;margin-right:auto}
.sec-lbl{
  display:inline-block;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--mid);font-weight:500;
  margin-bottom:1.25rem;
}
.sec-lbl-d{
  display:inline-block;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:500;
  margin-bottom:1.25rem;
}
.sec-h{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.05;letter-spacing:-.03em;
  color:var(--navy);margin-bottom:1.5rem;
}
.sec-h em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.015em;color:var(--navy)}
.sec-h-d{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.05;letter-spacing:-.03em;
  color:#fff;margin-bottom:1.5rem;
}
.sec-h-d em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:#fff}
.sec-p{font-size:1rem;line-height:1.65;color:var(--ink-2);max-width:560px}
.sec-p-d{font-size:1rem;line-height:1.65;color:rgba(255,255,255,.7);max-width:560px}

/* ── PROBLEM / SOLUTION ── */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
@media(max-width:880px){.ba-grid{grid-template-columns:1fr}}
.ba-card{
  background:#fff;border:1px solid var(--rule);
  border-radius:6px;padding:2rem;
  transition:border-color .3s,transform .3s;
}
.ba-card:hover{border-color:rgba(14,27,51,.18);transform:translateY(-2px)}
.ba-bad{background:#fff}
.ba-good{background:#fff}
.ba-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}
.ba-pill{
  font-family:var(--font-h);font-size:.7rem;letter-spacing:.08em;
  text-transform:uppercase;padding:.32rem .65rem;border-radius:2px;font-weight:500;
}
.ba-pill-r{background:var(--red-bg);color:var(--red);border:1px solid rgba(176,65,62,.2)}
.ba-pill-b{background:rgba(14,27,51,.05);color:var(--navy);border:1px solid var(--rule)}
.ba-time{font-size:.78rem;color:var(--dim);letter-spacing:-.005em}

.ms-wrap{display:flex;flex-direction:column;border-top:1px solid var(--rule-2)}
.ms-row{
  display:flex;align-items:baseline;gap:1rem;
  padding:.85rem 0;border-bottom:1px solid var(--rule-2);
}
.ms-clock{
  font-family:var(--font-h);font-feature-settings:"tnum";
  font-size:.78rem;color:var(--mid);min-width:3rem;flex-shrink:0;font-weight:500;
}
.ms-txt{font-size:.88rem;color:var(--ink-2);line-height:1.5}
.ms-alert .ms-txt{color:var(--red);font-weight:500}
.ms-alert .ms-clock{color:var(--red)}

.tl-wrap{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--rule-2)}
.tl-section{border-bottom:1px solid var(--rule-2);padding:.85rem 0}
.tl-section-lbl{
  font-family:var(--font-h);font-size:.66rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mid);
  font-weight:500;margin-bottom:.65rem;
}
.tl-urgent .tl-section-lbl{color:var(--red)}
.tl-amber .tl-section-lbl{color:var(--amber)}
.tl-green .tl-section-lbl{color:var(--green)}
.tl-item{display:flex;align-items:flex-start;gap:.7rem}
.tl-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:.4rem}
.tl-dot-r{background:var(--red);box-shadow:0 0 0 4px var(--red-bg)}
.tl-dot-a{background:var(--amber);box-shadow:0 0 0 4px var(--amber-bg)}
.tl-dot-g{background:var(--green);box-shadow:0 0 0 4px var(--green-bg)}
.tl-t{font-size:.92rem;color:var(--ink);font-weight:500;margin-bottom:.15rem;letter-spacing:-.005em}
.tl-s{font-size:.82rem;color:var(--mid)}

.ba-foot{
  margin-top:1.5rem;padding:.85rem 1rem;
  font-size:.85rem;border-radius:3px;
  font-style:italic;text-align:center;
}
.ba-foot-r{background:var(--red-bg);color:var(--red);border:1px solid rgba(176,65,62,.15)}
.ba-foot-b{background:rgba(63,122,82,.08);color:var(--green);border:1px solid rgba(63,122,82,.18)}

/* ── MORPH ANIMATION (chaos collapses → Nordivé dashboard) ── */
.morph{margin-top:2.5rem;position:relative}
.morph-stage{
  display:grid;grid-template-columns:1fr auto 1fr;gap:1.25rem;
  align-items:stretch;
}
@media(max-width:1000px){
  .morph-stage{grid-template-columns:1fr;gap:2rem}
  .morph-divider{display:none}
}
.morph-side{display:flex;flex-direction:column;gap:.75rem;min-width:0;position:relative;align-self:stretch}
.morph-cap{
  font-family:var(--font-h);font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;font-weight:500;text-align:center;
}
.morph-cap-l{color:var(--red)}
.morph-cap-r{color:var(--green)}

/* RAW INBOX (left side — same data, unfiltered) */
.raw{
  background:#f5f6f9;border:1px solid var(--rule);border-radius:8px;
  overflow:hidden;display:flex;flex-direction:column;
  height:420px!important;min-height:420px!important;max-height:420px!important;
  box-sizing:border-box;
  box-shadow:0 22px 50px -28px rgba(14,27,51,.18);
}
.raw-bar{
  display:flex;align-items:center;gap:.6rem;
  padding:.7rem 1rem;background:#fff;border-bottom:1px solid var(--rule-2);flex-shrink:0;
}
.raw-logo{
  width:18px;height:18px;border-radius:3px;flex-shrink:0;
  background:linear-gradient(135deg,#0072c6 0%,#1a4a8a 100%);
  position:relative;
}
.raw-logo::after{
  content:"";position:absolute;inset:3px;border-radius:1px;
  background:#fff;
  clip-path:polygon(0 0, 100% 0, 100% 100%, 50% 70%, 0 100%);
  opacity:.92;
}
.raw-bar-t{font-family:var(--font-h);font-size:.85rem;color:var(--ink);font-weight:500;letter-spacing:-.01em}
.raw-bar-d{margin-left:auto;font-size:.7rem;color:var(--dim);font-style:italic;font-family:var(--font-italic)}
.raw-body{flex:1;overflow:hidden;padding:1rem;display:flex;flex-direction:column;gap:.85rem;min-height:0}

/* KPI strip — mirrors dash-kpis but with red overload signals */
.raw-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.55rem;flex-shrink:0}
.raw-stat{
  background:#fff;border:1px solid var(--rule-2);border-radius:5px;
  padding:.6rem .7rem;
}
.raw-stat-n{
  font-family:var(--font-h);font-size:1.4rem;font-weight:500;
  color:var(--ink);letter-spacing:-.02em;font-feature-settings:"tnum";line-height:1;
}
.raw-stat-r .raw-stat-n{color:var(--red)}
.raw-stat-l{font-size:.66rem;color:var(--mid);margin-top:.3rem;letter-spacing:-.005em}

/* List — long, mostly-unread, occasional flags */
.raw-list{
  flex:1;background:#fff;border:1px solid var(--rule-2);border-radius:5px;
  overflow:hidden;display:flex;flex-direction:column;min-height:0;
}
.raw-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.5rem;
  padding:.42rem .7rem;border-bottom:1px solid var(--rule-2);
  flex-shrink:0;
}
.raw-row:last-child{border-bottom:none}
.raw-row > :first-child:not(.raw-flag){grid-column:1 / 2}
.raw-row-c{grid-column:2;min-width:0}
.raw-row-t{
  font-size:.7rem;font-weight:500;color:var(--ink);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;
}
.raw-row-s{
  font-size:.62rem;color:var(--mid);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;margin-top:.05rem;
}
.raw-time{font-size:.6rem;color:var(--dim);font-feature-settings:"tnum";grid-column:3}
.raw-attach{font-size:.55rem;color:var(--dim);margin-left:.25rem;font-feature-settings:"tnum"}

/* Unread state — left navy bar + slight tint */
.raw-row-u{background:rgba(14,27,51,.02);position:relative}
.raw-row-u::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--navy);
}
.raw-row-u .raw-row-t{color:var(--ink)}

/* Flagged urgent — red dot, red subject */
.raw-row-flag .raw-flag{
  width:14px;height:14px;border-radius:50%;background:var(--red);
  color:#fff;font-family:var(--font-h);font-weight:600;font-size:.6rem;
  display:flex;align-items:center;justify-content:center;line-height:1;
  flex-shrink:0;
}
.raw-row-flag .raw-row-s{color:var(--red)}

@media(max-width:600px){
  .raw-stats{grid-template-columns:repeat(2,1fr)}
}

/* DASHBOARD (right side — clean) */
.dash{
  background:#f5f6f9;border:1px solid var(--rule);border-radius:8px;
  overflow:hidden;display:flex;flex-direction:column;
  height:470px!important;min-height:470px!important;max-height:470px!important;
  box-sizing:border-box;
  box-shadow:0 22px 50px -28px rgba(14,27,51,.18);
}
.dash-bar{
  display:flex;align-items:center;gap:.6rem;
  padding:.7rem 1rem;background:#fff;border-bottom:1px solid var(--rule-2);flex-shrink:0;
}
.dash-bar-t{font-family:var(--font-h);font-size:.85rem;color:var(--ink);font-weight:500;letter-spacing:-.01em}
.dash-bar-d{margin-left:auto;font-size:.7rem;color:var(--dim);font-style:italic;font-family:var(--font-italic)}
.dash-body{flex:1;overflow:hidden;padding:1rem;display:flex;flex-direction:column;gap:.85rem;min-height:0}

.dash-hi-t{font-family:var(--font-h);font-size:1.45rem;color:var(--ink);letter-spacing:-.02em;font-weight:500;line-height:1.1}
.dash-hi-s{font-size:.78rem;color:var(--mid);margin-top:.18rem}

.dash-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:.55rem}
.dash-kpi{
  background:#fff;border:1px solid var(--rule-2);border-radius:5px;
  padding:.6rem .7rem;
}
.dash-kpi-n{
  font-family:var(--font-h);font-size:1.4rem;font-weight:500;
  color:var(--ink);letter-spacing:-.02em;font-feature-settings:"tnum";line-height:1;
}
.dash-kpi-r .dash-kpi-n{color:var(--red)}
.dash-kpi-l{font-size:.66rem;color:var(--ink);font-weight:500;margin-top:.3rem;letter-spacing:-.005em}
.dash-kpi-d{font-size:.58rem;color:var(--mid);margin-top:.1rem}

.dash-cols{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;flex:1;min-height:0}
.dash-card{
  background:#fff;border:1px solid var(--rule-2);border-radius:5px;
  padding:.6rem .7rem;display:flex;flex-direction:column;gap:.35rem;
  overflow:hidden;
}
.dash-card-h{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:.35rem;border-bottom:1px solid var(--rule-2);
  font-family:var(--font-h);font-size:.7rem;color:var(--ink);font-weight:500;letter-spacing:-.005em;
}
.dash-card-link{color:var(--mid);font-size:.62rem;font-weight:400;cursor:pointer}
.dash-row{
  display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;
  padding:.35rem 0;align-items:center;
}
.dash-av{
  width:24px;height:24px;border-radius:50%;
  background:rgba(14,27,51,.08);color:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-size:.55rem;font-weight:500;letter-spacing:.02em;
  flex-shrink:0;
}
.dash-av-m{background:rgba(14,27,51,.06)}
.dash-row-c{min-width:0}
.dash-row-t{font-size:.7rem;color:var(--ink);font-weight:500;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-row-s{font-size:.62rem;color:var(--mid);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.05rem}
.dash-row-meta{font-size:.6rem;color:var(--dim);font-feature-settings:"tnum";white-space:nowrap;display:flex;align-items:center;gap:.3rem}
.dash-dot-blue{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--navy)}

/* Footer (collapse-good) */
.morph-foot{
  flex-shrink:0;padding:.7rem 1rem;
  display:flex;align-items:center;justify-content:center;gap:.55rem;
  font-size:.78rem;font-style:italic;font-family:var(--font-italic);
}
.morph-foot-bad{
  background:rgba(176,65,62,.08);color:var(--red);
  border-top:1px solid rgba(176,65,62,.18);
}
.morph-foot-good{
  background:rgba(63,122,82,.08);color:var(--green);
  border-top:1px solid rgba(63,122,82,.18);
}
.morph-foot-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:morph-pulse 1.4s ease-in-out infinite}
.morph-foot-dot-g{background:var(--green);animation:none}
@keyframes morph-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}

/* DIVIDER ARROW */
.morph-divider{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:64px;position:relative;
}
.morph-divider-line{
  width:1px;flex:1;background:linear-gradient(180deg,transparent 0%,var(--rule) 20%,var(--rule) 80%,transparent 100%);
}
.morph-divider-arrow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:42px;height:42px;border-radius:50%;
  background:#fff;border:1px solid var(--rule);
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);transition:transform .9s ease, background .9s ease;
}
.morph.is-active .morph-divider-arrow{
  background:var(--navy);color:var(--off);border-color:var(--navy);
  transform:translate(-50%,-50%) scale(1.1);
}
.morph.is-collapsed .morph-divider-arrow{
  transform:translate(-50%,-50%) scale(1.2) rotate(360deg);
}

/* Logo */
.morph-logo{
  width:18px;height:18px;
  flex-shrink:0;object-fit:contain;
}

/* RAIL HINT */
.morph-rail{display:none}
.morph-rail-track{
  width:min(280px,60%);height:2px;background:var(--rule);border-radius:2px;overflow:hidden;
}
.morph-rail-fill{
  height:100%;width:0%;background:var(--navy);transition:width .15s linear;
}
.morph-rail-hint{
  font-family:var(--font-h);font-size:.66rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mid);font-weight:500;
}

/* ── FEATURES ── */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
@media(max-width:900px){.feature-grid{grid-template-columns:1fr}}
.feat-card{
  background:var(--off);border:1px solid var(--rule);
  border-radius:6px;padding:0;
  transition:border-color .3s,transform .3s,background .3s;
  display:flex;flex-direction:column;
  overflow:hidden;
}
.feat-card:hover{border-color:var(--navy);transform:translateY(-3px)}
.feat-card:hover .feat-anim{background:linear-gradient(180deg,#fff 0%,#f4f1ea 100%)}

/* FEAT ANIM container */
.feat-anim{
  position:relative;height:200px;
  background:linear-gradient(180deg,#fff 0%,#f7f5ef 100%);
  border-bottom:1px solid var(--rule-2);
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}

/* ── ANIM 1: Document list — chaotic filenames sliding out, clean B01 sliding in ── */
.fa1-card{
  width:78%;background:#fff;border:1px solid var(--rule);border-radius:6px;
  padding:.8rem .9rem;
  box-shadow:0 1px 0 rgba(14,27,51,.02), 0 18px 40px -22px rgba(14,27,51,.18);
}
.fa1-h{
  font-family:var(--font-h);font-size:.65rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mid);font-weight:500;margin-bottom:.55rem;
}
.fa1-list{display:flex;flex-direction:column;gap:.32rem;position:relative;height:88px;overflow:hidden}
.fa1-row{
  display:flex;align-items:center;gap:.5rem;
  font-size:.74rem;color:var(--ink-2);
  white-space:nowrap;overflow:hidden;
  animation:fa1-cycle 9s ease-in-out infinite;
  opacity:1;
}
.fa1-row:nth-child(1){animation-delay:0s}
.fa1-row:nth-child(2){animation-delay:.5s}
.fa1-row:nth-child(3){animation-delay:1s}
.fa1-row:nth-child(4){animation-delay:1.5s}
.fa1-row-out{
  animation:fa1-clean-in 9s ease-in-out infinite;
  color:var(--navy);font-weight:500;
}
@keyframes fa1-cycle{
  0%,38%{opacity:1;transform:translateX(0)}
  44%,55%{opacity:0;transform:translateX(-12px)}
  56%,100%{opacity:0;transform:translateX(-12px)}
}
@keyframes fa1-clean-in{
  0%,42%{opacity:0;transform:translateX(12px)}
  50%,90%{opacity:1;transform:translateX(0)}
  98%,100%{opacity:0;transform:translateX(12px)}
}
.fa1-icon{
  width:14px;height:16px;flex-shrink:0;border-radius:1px;
  background:#e9d8d6;position:relative;
}
.fa1-icon::after{
  content:"";position:absolute;top:2px;right:-3px;
  width:5px;height:5px;background:#fff;
  clip-path:polygon(0 0,100% 100%,0 100%);
}
.fa1-icon-pdf{background:#e9d8d6}
.fa1-icon-img{background:#dde4ec}
.fa1-icon-doc{background:#dce6dd}
.fa1-icon-clean{background:var(--navy)}
.fa1-t{flex:1;overflow:hidden;text-overflow:ellipsis}
.fa1-t-clean{color:var(--navy);font-weight:500}
.fa1-tag{
  font-family:var(--font-h);font-size:.6rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--green);font-weight:500;
  padding:.15rem .45rem;background:rgba(63,122,82,.08);
  border-radius:2px;
}

/* ── ANIM 2: Calendar with 14 highlighting and pill flying in ── */
.fa2-cal{
  width:75%;background:#fff;border:1px solid var(--rule);border-radius:6px;
  padding:.7rem .85rem;
  box-shadow:0 1px 0 rgba(14,27,51,.02), 0 18px 40px -22px rgba(14,27,51,.18);
}
.fa2-cal-h{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:.5rem;
}
.fa2-cal-mo{
  font-family:var(--font-h);font-size:.72rem;color:var(--navy);font-weight:500;
}
.fa2-cal-arr{font-size:.68rem;color:var(--dim);letter-spacing:.1em}
.fa2-cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:.18rem;
}
.fa2-d{
  font-family:var(--font-h);font-feature-settings:"tnum";
  font-size:.68rem;text-align:center;padding:.22rem 0;
  color:var(--ink-2);font-weight:400;border-radius:2px;
  position:relative;
}
.fa2-d-mute{color:var(--dim)}
.fa2-d-flag{
  color:#fff;background:var(--red);font-weight:500;
  animation:fa2-pulse 3s ease-in-out infinite;
}
.fa2-d-flag::after{
  content:"";position:absolute;inset:-2px;
  border:1px solid var(--red);border-radius:3px;opacity:0;
  animation:fa2-ring 3s ease-out infinite;
}
@keyframes fa2-pulse{
  0%,40%{background:var(--ink-2)}
  50%,100%{background:var(--red)}
}
@keyframes fa2-ring{
  0%,40%{opacity:0;transform:scale(.85)}
  55%{opacity:.6;transform:scale(1)}
  85%,100%{opacity:0;transform:scale(1.6)}
}
.fa2-pill{
  position:absolute;bottom:18px;left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--navy);color:#fff;
  font-size:.7rem;padding:.4rem .7rem;border-radius:3px;
  font-family:var(--font-h);letter-spacing:-.005em;font-weight:500;
  white-space:nowrap;opacity:0;
  animation:fa2-pill-in 6s ease-in-out infinite;
  animation-delay:1.5s;
}
@keyframes fa2-pill-in{
  0%,15%{opacity:0;transform:translateX(-50%) translateY(20px)}
  25%,75%{opacity:1;transform:translateX(-50%) translateY(0)}
  90%,100%{opacity:0;transform:translateX(-50%) translateY(-8px)}
}

/* ── ANIM 3: Inbox bubble in, draft typing out ── */
.feat-anim-3{flex-direction:column;gap:.4rem;padding:1rem 1.5rem}
.fa3-bubble{
  background:#fff;border:1px solid var(--rule);border-radius:8px;
  padding:.55rem .7rem;max-width:80%;
  box-shadow:0 1px 0 rgba(14,27,51,.02), 0 12px 24px -16px rgba(14,27,51,.14);
}
.fa3-bubble-in{align-self:flex-start;animation:fa3-in 5s ease-in-out infinite}
.fa3-bubble-out{
  align-self:flex-end;background:var(--navy);border-color:var(--navy);
  animation:fa3-out 5s ease-in-out infinite;
  animation-delay:1.5s;
}
.fa3-from{
  font-family:var(--font-h);font-size:.6rem;letter-spacing:.1em;
  text-transform:uppercase;font-weight:500;margin-bottom:.18rem;
}
.fa3-bubble-in .fa3-from{color:var(--mid)}
.fa3-bubble-out .fa3-from{color:rgba(255,255,255,.55)}
.fa3-msg{font-size:.78rem;line-height:1.4}
.fa3-bubble-in .fa3-msg{color:var(--ink-2)}
.fa3-bubble-out .fa3-msg{
  color:#fff;
  position:relative;
}
.fa3-bubble-out .fa3-msg::before{
  content:"Med saklig grunn iht. aml. § 15-7…";
  display:inline-block;
  overflow:hidden;white-space:nowrap;
  animation:fa3-type 5s steps(40, end) infinite;
  animation-delay:1.5s;
  vertical-align:bottom;
}
.fa3-cursor{display:none}
@keyframes fa3-in{
  0%,15%{opacity:0;transform:translateY(8px)}
  25%,90%{opacity:1;transform:translateY(0)}
  98%,100%{opacity:0;transform:translateY(8px)}
}
@keyframes fa3-out{
  0%,30%{opacity:0;transform:translateY(8px)}
  40%,90%{opacity:1;transform:translateY(0)}
  98%,100%{opacity:0;transform:translateY(8px)}
}
@keyframes fa3-type{
  0%,30%{max-width:0}
  60%,90%{max-width:240px}
  98%,100%{max-width:240px}
}
.fa3-tag{
  align-self:flex-end;
  font-family:var(--font-h);font-size:.6rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--green);font-weight:500;
  padding:.15rem .45rem;background:rgba(63,122,82,.1);border-radius:2px;
  opacity:0;animation:fa3-tag 5s ease-in-out infinite;
  animation-delay:3s;
}
@keyframes fa3-tag{
  0%,60%{opacity:0;transform:translateY(4px)}
  72%,90%{opacity:1;transform:translateY(0)}
  98%,100%{opacity:0}
}

@media(max-width:900px){
  .feat-anim{height:180px}
}
.feat-num{
  padding:1.5rem 2.25rem 0;
  font-family:var(--font-h);font-feature-settings:"tnum";
  font-size:.78rem;color:var(--mid);
  letter-spacing:.16em;font-weight:500;margin-bottom:2.5rem;
}
.feat-t{
  padding:0 2.25rem;
  font-family:var(--font-h);font-weight:500;
  font-size:1.35rem;line-height:1.2;letter-spacing:-.015em;
  color:var(--navy);margin-bottom:.85rem;
}
.feat-b{padding:0 2.25rem;font-size:.95rem;line-height:1.6;color:var(--ink-2);margin-bottom:2rem;flex:1}
.feat-stat{
  margin:0 2.25rem 2.25rem;
  display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;
  padding-top:1.25rem;border-top:1px solid var(--rule-2);
  font-size:.82rem;
}
.feat-from{color:var(--mid)}
.feat-arrow{color:var(--dim)}
.feat-to{color:var(--navy);font-weight:500}

/* ── DEMO (NAVY) ── */
.sec-dark .sec-lbl-d{color:rgba(255,255,255,.5)}
.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem}
@media(max-width:1000px){.demo-grid{grid-template-columns:1fr}}
.demo-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.1);
  border-radius:8px;padding:2rem;
  transition:border-color .3s,transform .3s;
}
.demo-card:hover{border-color:rgba(255,255,255,.2);transform:translateY(-3px)}
.demo-card-soon{background:rgba(255,255,255,.015)}
.demo-card-hd{margin-bottom:1.75rem}
.demo-status{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-h);font-size:.7rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.3rem .65rem;border-radius:2px;
  margin-bottom:1rem;
}
.demo-status-live{background:rgba(63,122,82,.15);color:#7AC791;border:1px solid rgba(63,122,82,.3)}
.demo-status-soon{background:rgba(168,117,40,.15);color:#D9A85C;border:1px solid rgba(168,117,40,.3)}
.ds-dot{width:6px;height:6px;border-radius:50%}
.ds-dot-live{background:#7AC791;box-shadow:0 0 0 3px rgba(122,199,145,.2);animation:pulse 2s infinite}
.ds-dot-soon{background:#D9A85C;box-shadow:0 0 0 3px rgba(217,168,92,.2)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.demo-card-ttl{font-family:var(--font-h);font-size:1.4rem;font-weight:500;color:#fff;letter-spacing:-.015em;margin-bottom:.4rem}
.demo-card-sub{font-size:.92rem;color:rgba(255,255,255,.55);line-height:1.5}

/* Webapp mockup */
.webapp{
  background:#fff;border-radius:6px;overflow:hidden;
  box-shadow:0 12px 40px rgba(0,0,0,.4),0 2px 6px rgba(0,0,0,.3);
  border:1px solid rgba(255,255,255,.08);
}
.wa-bar{display:flex;align-items:center;gap:.6rem;padding:.55rem .8rem;background:#F4F1EB;border-bottom:1px solid rgba(14,27,51,.06)}
.wa-dots{display:flex;gap:5px}
.wa-dots span{width:9px;height:9px;border-radius:50%;background:rgba(14,27,51,.15)}
.wa-url{flex:1;text-align:center;font-size:.7rem;color:var(--mid);font-family:var(--font-h)}
.wa-body{display:grid;grid-template-columns:120px 1fr;height:330px;background:#f5f6f9}

/* DARK NAVY SIDEBAR */
.wa-side{
  background:var(--navy);padding:.7rem .5rem;
  display:flex;flex-direction:column;gap:.6rem;
}
.wa-logo{
  display:flex;align-items:center;gap:.4rem;
  padding:.3rem .4rem .5rem;
  font-family:var(--font-h);font-size:.78rem;font-weight:600;
  color:#fff;letter-spacing:-.01em;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.wa-logo img{width:14px;height:14px;flex-shrink:0;filter:brightness(0) invert(1);opacity:.95}
.wa-nav{display:flex;flex-direction:column;gap:.05rem}
.wa-nav-item{
  padding:.32rem .5rem;font-size:.65rem;
  color:rgba(255,255,255,.55);
  border-radius:3px;cursor:pointer;
  transition:background .15s,color .15s;
  font-family:var(--font-h);font-weight:500;letter-spacing:-.005em;
}
.wa-nav-item:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.04)}
.wa-nav-item.active{background:rgba(255,255,255,.1);color:#fff}

/* MAIN CONTENT */
.wa-main{padding:.85rem 1rem;overflow:hidden;background:#f5f6f9;display:flex;flex-direction:column;gap:.7rem}
.wa-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}
.wa-greet{
  font-family:var(--font-h);font-size:.95rem;font-weight:500;
  color:var(--ink);letter-spacing:-.02em;line-height:1.1;
}
.wa-date{font-size:.6rem;color:var(--mid);margin-top:.15rem;font-feature-settings:"tnum"}
.wa-search{
  font-size:.55rem;color:var(--mid);
  background:#fff;border:1px solid var(--rule-2);
  padding:.22rem .42rem;border-radius:4px;
  font-family:var(--font-h);letter-spacing:.04em;
}

/* KPI cards (4-up) */
.wa-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem}
.wa-stat{
  padding:.45rem .55rem;background:#fff;border-radius:4px;
  border:1px solid var(--rule-2);
}
.wa-stat-v{
  font-family:var(--font-h);font-size:1.1rem;font-weight:500;
  color:var(--ink);letter-spacing:-.02em;line-height:1;
  font-feature-settings:"tnum";
}
.wa-stat-r .wa-stat-v{color:var(--red)}
.wa-stat-l{font-size:.55rem;color:var(--mid);margin-top:.22rem;letter-spacing:-.005em}

/* Section title */
.wa-section-ttl{
  font-family:var(--font-h);font-size:.65rem;
  color:var(--ink);font-weight:600;letter-spacing:-.005em;
  margin-top:.1rem;
}

/* Case rows */
.wa-cases{display:flex;flex-direction:column;background:#fff;border:1px solid var(--rule-2);border-radius:4px;overflow:hidden;flex:1;min-height:0}
.wa-case{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.5rem;
  padding:.32rem .55rem;border-bottom:1px solid var(--rule-2);
}
.wa-case:last-child{border-bottom:none}
.wa-case-av{
  width:22px;height:22px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.5rem;font-weight:600;color:var(--ink-2);
  background:rgba(14,27,51,.08);flex-shrink:0;
  font-family:var(--font-h);
}
.wa-case-av-2{background:rgba(176,65,62,.12);color:var(--red)}
.wa-case-c{min-width:0}
.wa-case-t{
  font-size:.62rem;font-weight:500;color:var(--ink);
  letter-spacing:-.005em;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.wa-case-s{
  font-size:.56rem;color:var(--mid);margin-top:.06rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.wa-case-meta{
  font-size:.55rem;color:var(--mid);font-weight:500;
  font-feature-settings:"tnum";white-space:nowrap;
}
.wa-case:first-child .wa-case-meta{color:var(--red)}
.wa-c-dot-g{background:var(--green)}
.wa-c-t{font-size:.72rem;font-weight:500;color:var(--navy);letter-spacing:-.005em}
.wa-c-s{font-size:.66rem;color:var(--mid);line-height:1.4;padding-left:1rem}

/* Outlook mockup */
.outlook{
  background:#0a1220;border-radius:6px;overflow:hidden;
  box-shadow:0 12px 40px rgba(0,0,0,.5);
  border:1px solid rgba(255,255,255,.06);
}
.ol-bar{display:flex;align-items:center;gap:.6rem;padding:.55rem .8rem;background:#060d1a;border-bottom:1px solid rgba(255,255,255,.05)}
.ol-dots{display:flex;gap:5px}
.ol-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.1)}
.ol-ttl{flex:1;text-align:center;font-size:.7rem;color:rgba(255,255,255,.4);font-family:var(--font-h)}

.ol-body{display:grid;grid-template-columns:1.5fr 1fr;height:330px}
@media(max-width:760px){
  .ol-body{grid-template-columns:1fr;height:auto}
  .ol-mail-view{padding:1.1rem 1.2rem;gap:.8rem}
  .ol-mv-name{font-size:.92rem}
  .ol-mv-sub{font-size:.78rem;margin-top:.15rem}
  .ol-mv-meta{font-size:.7rem}
  .ol-mv-body p{font-size:.8rem;line-height:1.65}
  .ol-mv-av{width:36px;height:36px;font-size:.72rem}
  .ol-addin{border-top:1px solid var(--rule-2)}
  .ol-addin-hd{padding:.7rem .9rem}
  .ol-addin-logo-mark{width:18px;height:18px}
  .ol-addin-logo{font-size:.85rem}
  .ol-addin-tab{font-size:.65rem;padding:.22rem .5rem}
  .ol-addin-body{padding:1rem .9rem .9rem;gap:.7rem}
  .ol-addin-h{font-size:1rem}
  .ol-addin-actions{gap:.5rem}
  .ol-addin-act{padding:.6rem .7rem;gap:.7rem}
  .ol-addin-icon{width:34px;height:34px}
  .ol-addin-icon svg{width:16px;height:16px}
  .ol-addin-act-t{font-size:.82rem}
  .ol-addin-act-s{font-size:.72rem;margin-top:.12rem}
  .ol-addin-input{padding:.55rem .55rem .55rem .8rem;border-radius:8px}
  .ol-addin-input-p{font-size:.78rem}
  .ol-addin-input-btn{width:26px;height:26px}
  .ol-addin-input-btn svg{width:13px;height:13px}
}

/* Email view (left side) */
.ol-mail-view{
  background:#0a1220;
  border-right:1px solid rgba(255,255,255,.04);
  padding:1rem 1.1rem;
  overflow:hidden;
  display:flex;flex-direction:column;gap:.7rem;
}
.ol-mv-from{display:flex;align-items:center;gap:.7rem}
.ol-mv-av{
  width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:500;color:rgba(255,255,255,.85);
  background:rgba(176,65,62,.3);flex-shrink:0;
}
.ol-mv-name{font-size:.78rem;color:rgba(255,255,255,.92);font-weight:500;letter-spacing:-.005em}
.ol-mv-sub{font-size:.66rem;color:rgba(255,255,255,.5);margin-top:.1rem}
.ol-mv-meta{font-size:.6rem;color:rgba(255,255,255,.35);font-feature-settings:"tnum"}
.ol-mv-body{margin-top:.2rem;display:flex;flex-direction:column;gap:.55rem}
.ol-mv-body p{
  font-size:.66rem;line-height:1.6;color:rgba(255,255,255,.65);
  letter-spacing:-.005em;
}

/* Add-in panel (right side) */
.ol-addin{
  background:#fff;color:var(--ink);
  display:flex;flex-direction:column;
  font-family:var(--font-body);
}
.ol-addin-hd{
  display:flex;align-items:center;gap:.45rem;
  padding:.5rem .65rem;border-bottom:1px solid var(--rule-2);
  background:#fbfbfd;
}
.ol-addin-logo-mark{
  width:14px;height:14px;flex-shrink:0;
  object-fit:contain;
}
.ol-addin-logo{
  font-family:var(--font-h);font-size:.7rem;font-weight:600;
  color:var(--ink);letter-spacing:-.01em;
}
.ol-addin-tab{
  margin-left:auto;font-size:.55rem;font-family:var(--font-h);
  color:var(--mid);background:rgba(14,27,51,.05);
  padding:.18rem .38rem;border-radius:3px;
}
.ol-addin-body{flex:1;display:flex;flex-direction:column;padding:.7rem .65rem .6rem;gap:.55rem;overflow:hidden;min-height:0}
.ol-addin-h{
  font-family:var(--font-h);font-size:.82rem;font-weight:500;
  color:var(--ink);letter-spacing:-.02em;line-height:1.25;margin-bottom:.1rem;
}
.ol-addin-h em{font-family:var(--font-serif);font-style:italic;font-weight:400}
.ol-addin-actions{display:flex;flex-direction:column;gap:.32rem;flex:1;min-height:0}
.ol-addin-act{
  display:flex;align-items:center;gap:.5rem;
  padding:.4rem .5rem;border:1px solid var(--rule-2);
  border-radius:5px;background:#fff;
  transition:border-color .18s,background .18s;
}
.ol-addin-act:hover{border-color:rgba(14,27,51,.18);background:#fbfbfd}
.ol-addin-icon{
  width:24px;height:24px;border-radius:5px;flex-shrink:0;
  background:rgba(14,27,51,.05);color:var(--ink-2);
  display:flex;align-items:center;justify-content:center;
}
.ol-addin-icon svg{width:13px;height:13px}
.ol-addin-act-c{flex:1;min-width:0}
.ol-addin-act-t{
  font-family:var(--font-h);font-size:.66rem;font-weight:600;
  color:var(--ink);letter-spacing:-.01em;line-height:1.2;
}
.ol-addin-act-s{
  font-size:.58rem;color:var(--mid);margin-top:.08rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ol-addin-input{
  display:flex;align-items:center;gap:.35rem;
  padding:.38rem .4rem .38rem .55rem;
  border:1px solid var(--rule);background:#fff;border-radius:6px;
  margin-top:.15rem;
}
.ol-addin-input-p{
  flex:1;font-size:.6rem;color:var(--dim);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ol-addin-input-btn{
  width:20px;height:20px;border-radius:50%;border:none;cursor:pointer;
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.ol-addin-input-btn svg{width:10px;height:10px}

/* ── BEFORE/AFTER value ── */
.ba2{
  display:grid;grid-template-columns:1fr 60px 1fr;gap:0;align-items:stretch;
  background:#fff;border:1px solid var(--rule);border-radius:8px;overflow:hidden;
  margin-bottom:1.25rem;
}
@media(max-width:760px){
  .ba2{grid-template-columns:1fr}
  .ba2-arrow{display:none}
}
.ba2-col{padding:2.5rem 2.25rem}
.ba2-before{background:var(--off-2)}
.ba2-after{background:#fff;border-left:1px solid var(--rule-2)}
@media(max-width:760px){.ba2-after{border-left:none;border-top:1px solid var(--rule-2)}}
.ba2-eye{
  font-family:var(--font-h);font-size:.7rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--mid);font-weight:500;
  margin-bottom:1rem;
}
.ba2-after .ba2-eye{color:var(--navy)}
.ba2-num{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(3rem,7vw,5rem);
  line-height:.9;letter-spacing:-.04em;
  color:var(--ink-2);margin-bottom:.6rem;
  display:flex;align-items:baseline;gap:.3rem;
}
.ba2-after .ba2-num{color:var(--navy)}
.ba2-num-u{font-size:.4em;color:var(--mid);font-weight:400;letter-spacing:0;margin-left:.15em}
.ba2-after .ba2-num-u{color:var(--mid)}
.ba2-lbl{font-size:.92rem;color:var(--ink-2);margin-bottom:1.75rem;line-height:1.5}
.ba2-list{display:flex;flex-direction:column;gap:.6rem}
.ba2-li{font-size:.88rem;color:var(--ink-2);display:flex;gap:.7rem;line-height:1.45}
.ba2-x{color:var(--dim);flex-shrink:0;font-weight:500}
.ba2-c{color:var(--green);flex-shrink:0;font-weight:500}
.ba2-arrow{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--off);border-left:1px solid var(--rule-2);border-right:1px solid var(--rule-2);color:var(--mid)}
.ba2-arrow-line{display:none}
.ba2-arrow-head{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--navy);color:#fff}

.ba2-result{
  display:grid;grid-template-columns:1fr 1px 1fr 1px 1.2fr;gap:0;
  background:#fff;border:1px solid var(--rule);border-radius:8px;overflow:hidden;
}
@media(max-width:760px){
  .ba2-result{grid-template-columns:1fr}
  .ba2-r-div{display:none}
}
.ba2-r-col{padding:1.75rem 2rem}
.ba2-r-col-hi{background:var(--navy);color:#fff}
.ba2-r-l{font-size:.78rem;color:var(--mid);margin-bottom:.45rem;letter-spacing:-.005em}
.ba2-r-col-hi .ba2-r-l{color:rgba(255,255,255,.7)}
.ba2-r-v{font-family:var(--font-h);font-size:1.5rem;font-weight:500;color:var(--navy);letter-spacing:-.02em}
.ba2-r-col-hi .ba2-r-v{color:#fff}
.ba2-r-div{background:var(--rule-2)}

/* ── CASE STUDY ── */
.case-card{
  max-width:880px;margin:0 auto;
  background:#fff;border:1px solid var(--rule);
  border-radius:8px;padding:3rem;
  position:relative;
}
@media(max-width:760px){.case-card{padding:2rem 1.5rem}}
.case-quote-mark{color:var(--rule);margin-bottom:1.25rem}
.case-quote{
  font-family:var(--font-serif);font-style:italic;
  font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.55;
  color:var(--navy);letter-spacing:-.01em;
  margin-bottom:2.5rem;
  text-wrap:pretty;
}
.case-attr{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}
.case-avatar{
  width:52px;height:52px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#1E3A8A,#0E1B33);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-h);font-size:.95rem;font-weight:500;letter-spacing:-.005em;
}
.case-avatar-img{
  object-fit:cover;object-position:center top;
}
.case-attr-info{flex:1;min-width:140px}
.case-name{font-family:var(--font-h);font-size:1rem;font-weight:500;color:var(--navy);margin-bottom:.15rem;letter-spacing:-.005em}
.case-role{font-size:.85rem;color:var(--mid)}
.case-tags{display:flex;gap:.4rem;flex-wrap:wrap}
.case-tag{
  font-size:.7rem;padding:.3rem .6rem;
  border:1px solid var(--rule);color:var(--mid);
  border-radius:99px;font-weight:500;letter-spacing:-.005em;
}
.case-desc{
  font-size:.88rem;color:var(--mid);line-height:1.6;
  padding-bottom:2rem;border-bottom:1px solid var(--rule-2);
  margin-bottom:2rem;
}
.case-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
@media(max-width:760px){.case-stats{grid-template-columns:1fr 1fr;gap:1.5rem}}
.case-stat{padding:0 1rem}
.case-stat:not(:last-child){border-right:1px solid var(--rule-2)}
.case-stat:first-child{padding-left:0}
@media(max-width:760px){.case-stat{padding:0;border-right:none!important}}
.case-stat-v{
  font-family:var(--font-h);font-size:clamp(1.3rem,2vw,1.6rem);font-weight:500;
  color:var(--navy);letter-spacing:-.02em;line-height:1;margin-bottom:.45rem;
}
.case-stat-hi .case-stat-v{color:var(--link)}
.case-stat-l{font-size:.78rem;color:var(--mid);line-height:1.4}

/* ── STEPS ── */
.steps-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  background:#fff;border:1px solid var(--rule);border-radius:8px;overflow:hidden;
}
@media(max-width:880px){.steps-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps-grid{grid-template-columns:1fr}}
.step{padding:2.25rem;border-right:1px solid var(--rule-2);position:relative;transition:background .25s}
.step:last-child{border-right:none}
.step:hover{background:var(--off)}
@media(max-width:880px){
  .step:nth-child(2){border-right:none}
  .step:nth-child(3),.step:nth-child(4){border-top:1px solid var(--rule-2)}
}
@media(max-width:560px){.step{border-right:none;border-bottom:1px solid var(--rule-2)}.step:last-child{border-bottom:none}}
.step-n{
  font-family:var(--font-h);font-size:.7rem;color:var(--link);
  letter-spacing:.16em;font-weight:500;margin-bottom:2rem;
}
.step-t{font-family:var(--font-h);font-size:1.05rem;font-weight:500;color:var(--navy);margin-bottom:.6rem;letter-spacing:-.01em;line-height:1.3}
.step-b{font-size:.88rem;color:var(--mid);line-height:1.55}

/* ── SECURITY (in dark) ── */
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:880px){.trust-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.trust-grid{grid-template-columns:1fr}}
.trust-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:6px;padding:1.85rem 1.65rem;
  transition:border-color .3s,background .3s,transform .3s;
}
.trust-card:hover{border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.05);transform:translateY(-2px)}
.trust-num{
  font-family:var(--font-h);font-size:.7rem;
  color:rgba(255,255,255,.4);letter-spacing:.16em;
  font-weight:500;margin-bottom:1.5rem;
}
.trust-t{font-family:var(--font-h);font-size:1.05rem;font-weight:500;color:#fff;margin-bottom:.6rem;letter-spacing:-.01em}
.trust-s{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.55}
.trust-cta{margin-top:2.5rem;text-align:center}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
@media(max-width:880px){.about-grid{grid-template-columns:1fr;gap:3rem}}
.cred-cards{display:flex;flex-direction:column;gap:1rem}
.cred-card{
  background:var(--off);border:1px solid var(--rule);
  border-radius:6px;padding:1.5rem 1.75rem;
  display:flex;align-items:flex-start;gap:1.25rem;
  transition:border-color .25s,transform .25s;
}
.cred-card:hover{border-color:var(--navy);transform:translateY(-2px)}
.cred-n{font-family:var(--font-h);font-size:.72rem;color:var(--link);letter-spacing:.16em;font-weight:500;flex-shrink:0;padding-top:.15rem}
.cred-t{font-family:var(--font-h);font-size:1rem;font-weight:500;color:var(--navy);margin-bottom:.3rem;letter-spacing:-.005em}
.cred-s{font-size:.88rem;color:var(--mid);line-height:1.55}

/* ── MISSION (Legora-style) ── */
.mission-sec{
  background:var(--navy);color:#fff;
  padding:7rem clamp(20px,4vw,40px);
  position:relative;overflow:hidden;
}
.mission-sec::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 800px 500px at 50% 50%,rgba(30,58,138,.18) 0%,transparent 70%);
  pointer-events:none;
}
.mission-inner{
  max-width:980px;margin:0 auto;text-align:center;position:relative;
}
.mission-inner .sec-lbl{color:rgba(255,255,255,.45);margin-bottom:2rem}
.mission-h{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(1.7rem,3.5vw,2.85rem);
  line-height:1.3;letter-spacing:-.02em;color:#fff;
  text-wrap:balance;
  margin-bottom:3rem;
}
.mission-h em{
  font-family:var(--font-serif);font-style:italic;font-weight:400;
  color:#fff;letter-spacing:-.015em;
}
.mission-sig{display:flex;align-items:center;justify-content:center;gap:1rem;color:rgba(255,255,255,.55);font-size:.85rem}
.mission-sig-line{width:32px;height:1px;background:rgba(255,255,255,.3)}
.mission-sig-text{font-style:italic}

/* ── TEAM ── */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:880px){.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.team-grid{grid-template-columns:1fr}}
.team-card{
  background:#fff;border:1px solid var(--rule);
  border-radius:6px;padding:2rem;
  transition:border-color .25s,transform .25s;
}
.team-card:hover{border-color:var(--navy);transform:translateY(-3px)}
.team-photo{
  width:100%;aspect-ratio:1/1;border-radius:4px;
  margin-bottom:1.5rem;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.team-photo-1{background:linear-gradient(135deg,#1E3A8A,#0E1B33)}
.team-photo-2{background:linear-gradient(135deg,#162644,#0E1B33)}
.team-photo-3{background:linear-gradient(135deg,#1C3057,#0E1B33)}
.team-initial{font-family:var(--font-serif);font-style:italic;font-size:3.5rem;color:rgba(255,255,255,.85);letter-spacing:-.02em}
.team-name{font-family:var(--font-h);font-size:1.15rem;font-weight:500;color:var(--navy);margin-bottom:.3rem;letter-spacing:-.01em}
.team-role{font-size:.85rem;color:var(--link);margin-bottom:.85rem;letter-spacing:-.005em}
.team-bio{font-size:.85rem;color:var(--mid);line-height:1.55}

/* ── FAQ ── */
.faq-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr;gap:3rem}}
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--rule)}
.faq-item{border-bottom:1px solid var(--rule)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.4rem 0;text-align:left;
  font-family:var(--font-body);font-size:1rem;font-weight:500;
  color:var(--navy);letter-spacing:-.005em;
  transition:color .2s;
}
.faq-q:hover{color:var(--link)}
.faq-icon{
  width:18px;height:18px;flex-shrink:0;position:relative;
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.faq-icon::before,.faq-icon::after{
  content:'';position:absolute;background:var(--navy);
  transition:background .25s;
}
.faq-icon::before{top:50%;left:0;right:0;height:1px;margin-top:-.5px}
.faq-icon::after{left:50%;top:0;bottom:0;width:1px;margin-left:-.5px;transition:transform .35s cubic-bezier(.2,.7,.2,1),background .25s}
.faq-item.open .faq-icon::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.2,.7,.2,1)}
.faq-item.open .faq-a{max-height:300px}
.faq-a-inner{padding:0 0 1.4rem;font-size:.92rem;color:var(--ink-2);line-height:1.65;max-width:560px}

/* ── CTA ── */
.cta-sec{
  background:var(--navy);color:#fff;
  padding:8rem clamp(20px,4vw,40px);
  position:relative;overflow:hidden;
}
.cta-sec::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 700px 400px at 50% 0%,rgba(30,58,138,.25) 0%,transparent 70%);
}
.cta-inner{max-width:580px;margin:0 auto;text-align:center;position:relative;z-index:2}
.cta-eye{
  display:inline-block;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(255,255,255,.5);
  margin-bottom:1.5rem;font-weight:500;
}
.cta-h{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(2.2rem,4.5vw,3.6rem);
  line-height:1.05;letter-spacing:-.03em;
  color:#fff;margin-bottom:1.25rem;
}
.cta-h em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:#fff}
.cta-p{font-size:1rem;color:rgba(255,255,255,.65);line-height:1.65;margin-bottom:2.5rem}
.cta-form{display:flex;flex-direction:column;gap:.65rem;margin-bottom:2rem}
.cta-row{display:grid;grid-template-columns:1fr 1fr;gap:.65rem}
@media(max-width:560px){.cta-row{grid-template-columns:1fr}}
.cta-input{
  padding:.95rem 1.1rem;border-radius:3px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.04);
  color:#fff;font-size:.92rem;font-family:inherit;outline:none;
  transition:border-color .2s,background .2s;letter-spacing:-.005em;
}
.cta-input::placeholder{color:rgba(255,255,255,.4)}
.cta-input:focus{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.06)}
.cta-select{cursor:pointer;color:rgba(255,255,255,.5);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(255,255,255,0.5)' stroke-width='1.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 1.1rem center;background-repeat:no-repeat;padding-right:2.2rem}
.cta-select:valid{color:#fff}
.cta-select option{background:var(--navy);color:#fff}
.cta-submit{
  background:#fff;color:var(--navy);
  padding:1rem;border-radius:3px;border:none;cursor:pointer;
  font-family:var(--font-body);font-size:.95rem;font-weight:500;
  transition:transform .2s,background .2s;letter-spacing:-.005em;
}
.cta-submit:hover{transform:translateY(-1px);background:rgba(255,255,255,.92)}
.cta-success{display:none;background:rgba(122,199,145,.1);border:1px solid rgba(122,199,145,.3);color:#9CD9AD;padding:.85rem;border-radius:3px;font-size:.88rem;text-align:center}
.cta-trust{font-size:.78rem;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}
.cta-sep{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.2)}

/* ── FOOTER ── */
footer{background:var(--navy);color:rgba(255,255,255,.65);padding:5rem clamp(20px,4vw,40px) 2rem;border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 2fr;gap:4rem;margin-bottom:4rem}
@media(max-width:760px){.footer-inner{grid-template-columns:1fr;gap:3rem}}
.footer-brand{max-width:280px}
.footer-logo{display:flex;align-items:center;gap:.55rem;font-family:var(--font-h);font-size:1.15rem;font-weight:500;color:#fff;margin-bottom:.85rem;letter-spacing:-.01em}
.footer-tagline{font-size:.88rem;line-height:1.55;color:rgba(255,255,255,.5);font-style:italic;font-family:var(--font-serif)}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media(max-width:560px){.footer-cols{grid-template-columns:1fr 1fr}}
.footer-col{display:flex;flex-direction:column;gap:.6rem}
.footer-col-h{font-family:var(--font-h);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;font-weight:500;margin-bottom:.5rem}
.footer-link{font-size:.88rem;color:rgba(255,255,255,.55);text-decoration:none;transition:color .2s;letter-spacing:-.005em}
.footer-link:hover{color:#fff}
.footer-bottom{max-width:1180px;margin:0 auto;padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:rgba(255,255,255,.35)}

/* ── SECURITY PAGE specifics (used by sikkerhet.html) ── */
.sub-hero{
  background:var(--off);padding:140px clamp(20px,4vw,40px) 5rem;
  border-bottom:1px solid var(--rule-2);
}
.sub-hero-inner{max-width:1180px;margin:0 auto}
.sub-hero-eye{display:inline-flex;align-items:center;gap:.8rem;font-size:.78rem;color:var(--mid);margin-bottom:2rem;letter-spacing:-.005em}
.sub-hero-eye a{color:var(--link);text-decoration:none}
.sub-hero-h{font-family:var(--font-h);font-weight:400;font-size:clamp(2.4rem,5vw,4.2rem);line-height:1.05;letter-spacing:-.035em;color:var(--navy);margin-bottom:1.5rem;max-width:900px}
.sub-hero-h em{font-family:var(--font-serif);font-style:italic;font-weight:400}
.sub-hero-sub{font-size:1.1rem;line-height:1.65;color:var(--ink-2);max-width:620px}

.sec-prose{max-width:780px;margin:0 auto}
.sec-prose h3{font-family:var(--font-h);font-size:1.35rem;font-weight:500;color:var(--navy);margin:3rem 0 1rem;letter-spacing:-.015em;line-height:1.25}
.sec-prose h3:first-child{margin-top:0}
.sec-prose p{font-size:1rem;line-height:1.75;color:var(--ink-2);margin-bottom:1rem}
.sec-prose ul{margin:1rem 0;padding-left:1.2rem}
.sec-prose li{font-size:1rem;line-height:1.7;color:var(--ink-2);margin-bottom:.4rem}
.sec-prose a{color:var(--link);text-decoration:none;border-bottom:1px solid rgba(30,58,138,.3)}
.sec-prose a:hover{color:var(--link-h);border-bottom-color:var(--link-h)}

.cert-row{display:flex;flex-wrap:wrap;gap:1rem;margin:2rem 0}

/* ── VÅRT MÅL + TEAM (kombinert) ── */
.vm-grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:5rem;align-items:center;
}
@media(max-width:900px){
  .vm-grid{grid-template-columns:1fr;gap:3rem}
}
.vm-eye{
  font-family:var(--font-h);font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;font-weight:500;color:var(--ink);display:block;
}
.vm-rule{
  width:48px;height:2px;background:var(--link);margin:1rem 0 1.75rem;
}
.vm-p{
  font-size:1rem;line-height:1.75;color:var(--ink-2);margin-bottom:1rem;
}
.vm-p:last-child{margin-bottom:0}
.vm-photos{
  display:grid;grid-template-columns:1fr 1fr;gap:1rem;
}
@media(max-width:520px){
  .vm-photos{grid-template-columns:1fr}
}
.vm-photo{
  margin:0;display:flex;flex-direction:column;
}
.vm-photo img{
  width:100%;aspect-ratio:3/4;object-fit:cover;object-position:center top;
  border-radius:8px;display:block;
  box-shadow:0 22px 50px -28px rgba(14,27,51,.25);
}
.vm-photo figcaption{
  margin-top:1rem;
}
.vm-name{
  font-family:var(--font-h);font-size:.92rem;font-weight:600;
  color:var(--ink);letter-spacing:-.01em;line-height:1.2;
}
.vm-role{
  font-size:.78rem;color:var(--link);margin-top:.18rem;
  font-family:var(--font-italic);font-style:italic;
}
.cert-item{padding:1rem 1.25rem;background:var(--off);border:1px solid var(--rule);border-radius:4px;font-family:var(--font-h);font-size:.85rem;color:var(--navy);font-weight:500;letter-spacing:-.005em}
