@import url('assets/tokens.css');

/* ───────────────────────────────────────────────
   NORDIVÉ — marketing site
   Calm, editorial, Harvey/Legora register on the
   Nordivé tokens. Off-white page, one navy band.
   ─────────────────────────────────────────────── */

*{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:var(--font-body);
  font-weight:400;
  line-height:1.55;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;
}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
a{color:inherit;text-decoration:none}
::selection{background:var(--navy);color:#fff}

/* ── shared rhythm ─────────────────────────── */
.wrap{max-width:var(--container);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}
.wrap-wide{max-width:1320px;margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}
.eye{
  font-family:var(--font-h);font-size:var(--t-eye);font-weight:500;
  letter-spacing:var(--ls-eye);text-transform:uppercase;color:var(--mid);
  display:inline-flex;align-items:center;gap:.7rem;
}
.eye::before{content:"";width:22px;height:1px;background:var(--mid);opacity:.6}
.eye-d{color:rgba(255,255,255,.5)}
.eye-d::before{background:rgba(255,255,255,.4)}

h1,h2,h3{font-family:var(--font-h);font-weight:400;letter-spacing:var(--ls-h2);color:var(--navy)}
em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.015em;color:inherit}

/* reveal — visible by default; only hidden when JS is active */
.fu{opacity:1;transform:none}
html.js .fu{opacity:0;transform:translateY(22px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
html.js .fu.v{opacity:1;transform:none}
.fu-1{transition-delay:.06s}.fu-2{transition-delay:.12s}.fu-3{transition-delay:.18s}.fu-4{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){html.js .fu{opacity:1;transform:none;transition:none}}
@media print{html.js .fu{opacity:1 !important;transform:none !important}}

/* ── buttons ───────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.92rem;font-weight:500;letter-spacing:-.005em;white-space:nowrap;
  padding:.95rem 1.55rem;border-radius:var(--r-btn);
  transition:transform .25s var(--ease),background .2s,border-color .2s,color .2s;
}
.btn svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.btn:hover svg{transform:translateX(3px)}
.btn-primary{background:var(--navy);color:#fff;border:1px solid var(--navy)}
.btn-primary:hover{background:#000;border-color:#000;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--navy);border:1px solid var(--rule)}
.btn-ghost:hover{border-color:var(--navy);transform:translateY(-1px)}
.btn-on-navy{background:#fff;color:var(--navy);border:1px solid #fff}
.btn-on-navy:hover{background:rgba(255,255,255,.88);transform:translateY(-1px)}
.link{
  display:inline-flex;align-items:center;gap:.4rem;
  color:var(--brand);font-size:.92rem;font-weight:500;
  border-bottom:1px solid transparent;padding-bottom:1px;
  transition:color .2s,border-color .2s;
}
.link svg{width:14px;height:14px;transition:transform .2s}
.link:hover{color:var(--brand-h);border-bottom-color:var(--brand-h)}
.link:hover svg{transform:translateX(2px)}

/* ── NAV ───────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:200;height:var(--nav-h);
  background:rgba(250,248,244,.72);
  backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.nav.scrolled{border-bottom-color:var(--rule);background:rgba(250,248,244,.86)}
.nav-in{max-width:1320px;height:100%;margin:0 auto;display:flex;align-items:center;gap:2.5rem;padding:0 var(--pad-x)}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-h);font-size:1.18rem;font-weight:500;letter-spacing:-.02em;color:var(--navy)}
.brand img{width:23px;height:23px}
.nav-links{display:flex;gap:1.9rem}
.nav-link{font-size:.88rem;color:var(--mid);letter-spacing:-.005em;white-space:nowrap;transition:color .2s}
.nav-link:hover{color:var(--navy)}
.nav-actions{margin-left:auto;display:flex;align-items:center;gap:1.4rem}
.nav-login{font-size:.88rem;color:var(--mid);white-space:nowrap;transition:color .2s}
.nav-login:hover{color:var(--navy)}
.nav-cta{font-size:.86rem;font-weight:500;background:var(--navy);color:#fff;padding:.62rem 1.15rem;border-radius:var(--r-btn);letter-spacing:-.005em;white-space:nowrap;transition:background .2s,transform .2s}
.nav-cta:hover{background:#000;transform:translateY(-1px)}
.nav-burger{display:none;flex-direction:column;gap:5px;margin-left:auto;padding:6px}
.nav-burger span{width:22px;height:1.5px;background:var(--navy)}
@media(max-width:920px){
  .nav-links,.nav-login{display:none}
  .nav-burger{display:flex}
  .nav-actions{margin-left:auto}
}
@media(max-width:520px){.nav-cta{display:none}}

/* ── HERO ──────────────────────────────────── */
.hero{position:relative;padding:clamp(56px,9vw,104px) 0 clamp(40px,6vw,72px);overflow:hidden}
.hero-grain{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(circle at 16% 22%,rgba(14,27,51,.035) 0%,transparent 46%),
    radial-gradient(circle at 88% 12%,rgba(41,82,217,.04) 0%,transparent 42%);
}
.hero-in{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(2rem,4.5vw,4.5rem);align-items:center}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;gap:clamp(2.5rem,6vw,3.5rem)}}
.hero-text{min-width:0}
.hero-eye{margin-bottom:1.9rem}
.hero-h{
  font-family:var(--font-h);font-weight:400;
  font-size:clamp(2.3rem,4.4vw,3.95rem);line-height:1.0;letter-spacing:-.04em;
  color:var(--navy);max-width:14ch;margin-bottom:1.6rem;text-wrap:balance;
}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.28rem);line-height:1.55;color:var(--ink-2);max-width:46ch;margin-bottom:2.4rem}
.hero-btns{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:2.1rem}
.trust-line{display:flex;align-items:center;flex-wrap:wrap;gap:.55rem;font-size:.85rem;color:var(--mid);letter-spacing:-.005em}
.trust-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px var(--green-bg)}
.trust-sep{color:var(--rule);margin:0 .15rem}

/* hero product visual */
.hero-visual{margin-top:0;position:relative}
.hero-visual.fu{transition-delay:.18s}

/* ── APP MOCK (shared chrome) ──────────────── */
.app{
  background:#fff;border:1px solid var(--rule);border-radius:var(--r-card-lg);
  box-shadow:var(--shadow-xl);overflow:hidden;
}
.app-bar{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--rule-2);background:#fff}
.app-dots{display:flex;gap:6px}
.app-dots i{width:9px;height:9px;border-radius:50%;background:var(--rule);display:block}
.app-url{margin-left:.4rem;font-size:.74rem;color:var(--dim);letter-spacing:-.005em;font-feature-settings:"tnum"}
.app-grid{display:grid;grid-template-columns:200px 1fr;min-height:430px}
@media(max-width:760px){.app-grid{grid-template-columns:1fr}.app-side{display:none}}
.app-side{border-right:1px solid var(--rule-2);padding:1.2rem 1rem;background:linear-gradient(180deg,#fff,#fbfaf6)}
.app-side-brand{display:flex;align-items:center;gap:.5rem;font-family:var(--font-h);font-weight:500;font-size:.95rem;color:var(--navy);margin-bottom:1.4rem;letter-spacing:-.01em}
.app-side-brand img{width:17px;height:17px}
.app-nav{display:flex;flex-direction:column;gap:.15rem}
.app-nav a{display:flex;align-items:center;gap:.6rem;font-size:.84rem;color:var(--mid);padding:.5rem .55rem;border-radius:4px;transition:background .15s,color .15s}
.app-nav a .ico{width:15px;height:15px;color:var(--dim)}
.app-nav a.on{background:var(--off-2);color:var(--navy);font-weight:500}
.app-nav a.on .ico{color:var(--navy)}
.app-main{padding:1.5rem 1.6rem}
.app-greet-eye{font-family:var(--font-h);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);font-weight:500;margin-bottom:.5rem}
.app-greet{font-family:var(--font-h);font-size:1.55rem;font-weight:400;letter-spacing:-.03em;color:var(--navy);margin-bottom:.2rem}
.app-greet em{font-family:var(--font-serif)}
.app-sub{font-size:.84rem;color:var(--mid);margin-bottom:1.3rem}

.app-summary{background:var(--off);border:1px solid var(--rule-2);border-radius:6px;padding:.95rem 1.1rem;margin-bottom:1.4rem}
.app-summary-h{display:flex;align-items:center;gap:.5rem;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);font-weight:500;margin-bottom:.55rem}
.app-summary-b{font-size:.88rem;color:var(--ink-2);line-height:1.5}
.app-summary-b b{color:var(--navy);font-weight:500}

.app-cards{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.app-card{border:1px solid var(--rule);border-radius:6px;padding:.95rem 1.05rem;background:#fff;transition:border-color .2s,transform .2s}
.app-card:hover{border-color:var(--navy);transform:translateY(-2px)}
.app-card-t{font-family:var(--font-h);font-size:.92rem;font-weight:500;color:var(--navy);margin-bottom:.3rem;letter-spacing:-.01em}
.app-card-d{font-size:.78rem;color:var(--mid);line-height:1.45}
.app-card-tag{display:inline-flex;align-items:center;gap:.35rem;margin-top:.7rem;font-size:.7rem;font-weight:500;padding:.2rem .5rem;border-radius:var(--r-pill);letter-spacing:-.005em;white-space:nowrap}
.tag-red{background:var(--red-bg);color:var(--red)}
.tag-green{background:var(--green-bg);color:var(--green)}
.tag-amber{background:var(--amber-bg);color:var(--amber)}
.tag-blue{background:rgba(41,82,217,.08);color:var(--brand)}

/* ── TRUST STRIP ───────────────────────────── */
.strip{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:2.6rem 0;background:var(--off-2)}
.strip-in{display:flex;align-items:center;gap:2.5rem;flex-wrap:wrap;justify-content:center}
.strip-label{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);font-weight:500}
.strip-items{display:flex;align-items:center;gap:2.6rem;flex-wrap:wrap;justify-content:center}
.strip-item{font-family:var(--font-h);font-size:1.05rem;font-weight:500;color:var(--ink-2);letter-spacing:-.01em;opacity:.78;display:inline-flex;align-items:center;gap:.5rem}
.strip-item .badge{font-size:.62rem;font-weight:600;letter-spacing:.04em;color:var(--mid);border:1px solid var(--rule);border-radius:var(--r-pill);padding:.12rem .5rem}

/* ── SECTION SHELL ─────────────────────────── */
.sec{padding:clamp(5rem,9vw,8rem) 0}
.sec-head{max-width:660px;margin-bottom:clamp(3rem,5vw,4.5rem)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head .eye{margin-bottom:1.3rem}
.sec-head.center .eye::before{display:none}
.sec-h{font-size:var(--t-h2);line-height:1.05;letter-spacing:-.03em;color:var(--navy);margin-bottom:1.2rem;text-wrap:balance}
.sec-p{font-size:1.08rem;line-height:1.6;color:var(--ink-2)}
.sec-dark .sec-h{color:#fff}
.sec-dark .sec-p{color:rgba(255,255,255,.7)}

/* ── CAPABILITIES (editorial rows) ─────────── */
.caps{display:flex;flex-direction:column;gap:clamp(4rem,7vw,7rem)}
.cap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5rem);align-items:center}
.cap.flip .cap-text{order:2}
@media(max-width:860px){.cap,.cap.flip{grid-template-columns:1fr;gap:2.2rem}.cap.flip .cap-text{order:0}}
.cap-num{font-family:var(--font-h);font-size:.72rem;letter-spacing:.18em;color:var(--mid);font-weight:500;margin-bottom:1.1rem}
.cap-h{font-size:clamp(1.6rem,2.6vw,2.15rem);line-height:1.1;letter-spacing:-.025em;color:var(--navy);margin-bottom:1rem}
.cap-b{font-size:1.05rem;line-height:1.6;color:var(--ink-2);max-width:42ch;margin-bottom:1.5rem}
.cap-stat{display:inline-flex;align-items:center;gap:.7rem;font-size:.92rem;padding-top:1.1rem;border-top:1px solid var(--rule);font-feature-settings:"tnum";white-space:nowrap}
.cap-from{color:var(--mid)}
.cap-arrow{color:var(--dim)}
.cap-to{color:var(--green);font-weight:500}
.cap-visual{position:relative}

/* mini product panels inside capability visuals */
.panel{background:linear-gradient(180deg,#fff,#f7f5ef);border:1px solid var(--rule);border-radius:var(--r-card-lg);box-shadow:var(--shadow-lg);padding:1.4rem;min-height:300px;display:flex;flex-direction:column;gap:.65rem}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem}
.panel-title{font-family:var(--font-h);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);font-weight:500}
.live{display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--green);font-weight:500;white-space:nowrap}
.live i{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(63,122,82,.4);animation:pulse 2.4s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(63,122,82,.35)}70%{box-shadow:0 0 0 7px rgba(63,122,82,0)}100%{box-shadow:0 0 0 0 rgba(63,122,82,0)}}

/* deadline rows */
.row{display:flex;align-items:center;gap:.8rem;background:#fff;border:1px solid var(--rule);border-radius:6px;padding:.8rem .9rem;box-shadow:var(--shadow-sm)}
.row-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-red{background:var(--red);box-shadow:0 0 0 4px var(--red-bg)}
.dot-amber{background:var(--amber);box-shadow:0 0 0 4px var(--amber-bg)}
.dot-green{background:var(--green);box-shadow:0 0 0 4px var(--green-bg)}
.row-main{flex:1;min-width:0}
.row-t{font-size:.85rem;color:var(--navy);font-weight:500;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row-m{font-size:.72rem;color:var(--mid)}
.row-frist{font-size:.74rem;font-weight:500;font-feature-settings:"tnum";white-space:nowrap}
.frist-red{color:var(--red)}.frist-amber{color:var(--amber)}.frist-green{color:var(--green)}

/* tidslogg list */
.log{display:flex;flex-direction:column;gap:.05rem}
.log-row{display:flex;align-items:center;justify-content:space-between;padding:.55rem .2rem;border-bottom:1px solid var(--rule-2);font-size:.82rem}
.log-row:last-child{border-bottom:none}
.log-l{display:flex;align-items:center;gap:.6rem;color:var(--ink-2)}
.log-time{color:var(--dim);font-feature-settings:"tnum";font-size:.74rem;min-width:42px}
.log-dur{color:var(--navy);font-weight:500;font-feature-settings:"tnum"}
.log-total{display:flex;align-items:center;justify-content:space-between;padding-top:.7rem;margin-top:.3rem;border-top:1px solid var(--rule);font-size:.84rem}
.log-total b{font-family:var(--font-h);font-weight:500;color:var(--navy);font-feature-settings:"tnum"}

/* grid review table */
.greview{width:100%;border-collapse:collapse;font-size:.78rem}
.greview th{text-align:left;font-family:var(--font-h);font-weight:500;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);padding:.4rem .5rem;border-bottom:1px solid var(--rule)}
.greview td{padding:.55rem .5rem;border-bottom:1px solid var(--rule-2);color:var(--ink-2);letter-spacing:-.005em}
.greview td:first-child{color:var(--navy);font-weight:500}
.kilde{display:inline-flex;align-items:center;gap:.25rem;font-size:.64rem;color:var(--brand);background:rgba(41,82,217,.07);border-radius:var(--r-chip);padding:.1rem .35rem;margin-left:.3rem;vertical-align:middle}

/* ── STATS BAND ────────────────────────────── */
.stats{padding:clamp(4.5rem,8vw,7rem) 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.5rem,3vw,3rem)}
@media(max-width:860px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem 2rem}}
@media(max-width:440px){.stats-grid{grid-template-columns:1fr}}
.stat{border-top:1px solid var(--rule);padding-top:1.3rem}
.stat-n{font-family:var(--font-h);font-weight:400;font-size:clamp(2.6rem,4.4vw,3.6rem);letter-spacing:-.04em;color:var(--navy);line-height:1;font-feature-settings:"tnum";margin-bottom:.6rem}
.stat-n .unit{font-size:.42em;color:var(--mid);letter-spacing:-.01em;margin-left:.1em}
.stat-l{font-size:.9rem;color:var(--ink-2);line-height:1.45;max-width:22ch}

/* ── CUSTOMER STORY ────────────────────────── */
.story{padding:clamp(5rem,9vw,8rem) 0}
.story-card{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:center}
@media(max-width:820px){.story-card{grid-template-columns:1fr;gap:2.5rem}}
.story-quote{font-family:var(--font-h);font-weight:400;font-size:clamp(1.4rem,2.6vw,2.05rem);line-height:1.3;letter-spacing:-.02em;color:var(--navy);text-wrap:balance}
.story-quote em{font-family:var(--font-serif)}
.story-by{display:flex;align-items:center;gap:.9rem;margin-top:2rem}
.story-by img{width:48px;height:48px;border-radius:var(--r-pill);object-fit:cover}
.story-by-n{font-family:var(--font-h);font-weight:500;font-size:.95rem;color:var(--navy);letter-spacing:-.01em}
.story-by-r{font-size:.82rem;color:var(--mid)}
.story-metrics{display:flex;flex-direction:column;gap:1.6rem;border-left:1px solid var(--rule);padding-left:clamp(2rem,4vw,3rem)}
@media(max-width:820px){.story-metrics{border-left:none;border-top:1px solid var(--rule);padding-left:0;padding-top:2rem;flex-direction:row;flex-wrap:wrap;gap:2rem}}
.story-metric .n{font-family:var(--font-h);font-weight:400;font-size:2.1rem;letter-spacing:-.03em;color:var(--navy);line-height:1;font-feature-settings:"tnum"}
.story-metric .l{font-size:.82rem;color:var(--mid);margin-top:.4rem}

/* ── SECURITY (navy band) ──────────────────── */
.sec-dark{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.sec-dark .sec-grain{position:absolute;inset:0;background:radial-gradient(circle at 80% 0%,rgba(41,82,217,.16) 0%,transparent 45%);pointer-events:none}
.sec-dark > .wrap{position:relative;z-index:2}
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:920px){.sgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.sgrid{grid-template-columns:1fr}}
.scard{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:1.9rem 1.6rem;transition:border-color .3s,transform .3s,background .3s}
.scard:hover{border-color:rgba(255,255,255,.22);transform:translateY(-3px);background:rgba(255,255,255,.05)}
.scard-n{font-family:var(--font-h);font-size:.7rem;letter-spacing:.16em;color:rgba(255,255,255,.4);font-weight:500;margin-bottom:1.5rem}
.scard-t{font-family:var(--font-h);font-size:1.08rem;font-weight:500;color:#fff;letter-spacing:-.01em;margin-bottom:.6rem}
.scard-d{font-size:.88rem;color:rgba(255,255,255,.6);line-height:1.55}
.certs{display:flex;align-items:center;gap:1.8rem;flex-wrap:wrap;margin-top:3rem;padding-top:2.4rem;border-top:1px solid rgba(255,255,255,.1)}
.cert{display:inline-flex;align-items:center;gap:.6rem;font-size:.84rem;color:rgba(255,255,255,.8);font-weight:500}
.cert svg{width:30px;height:30px;color:rgba(255,255,255,.55)}
.certs-note{font-size:.8rem;color:rgba(255,255,255,.45);line-height:1.55;max-width:48ch;margin-left:auto}
@media(max-width:760px){.certs-note{margin-left:0;margin-top:1rem;flex-basis:100%}}

/* ── VISION ────────────────────────────────── */
.vision{padding:clamp(5rem,9vw,8rem) 0}
.vision-grid{display:grid;grid-template-columns:1fr 360px;gap:clamp(3rem,6vw,6rem);align-items:start}
@media(max-width:900px){.vision-grid{grid-template-columns:1fr;gap:3rem}}
.vision-lead{font-family:var(--font-h);font-weight:400;font-size:clamp(1.5rem,2.6vw,2.05rem);line-height:1.32;letter-spacing:-.02em;color:var(--navy);margin-bottom:1.6rem;text-wrap:balance}
.vision-lead em{font-family:var(--font-serif)}
.vision-p{font-size:1.02rem;line-height:1.65;color:var(--ink-2);margin-bottom:1.1rem;max-width:54ch}
.founders{display:flex;flex-direction:column;gap:1.1rem;background:var(--off-2);border:1px solid var(--rule);border-radius:var(--r-card-lg);padding:1.6rem}
.founder{display:flex;align-items:center;gap:.95rem}
.founder img{width:52px;height:52px;border-radius:var(--r-pill);object-fit:cover;flex-shrink:0}
.founder-meta{display:flex;flex-direction:column;gap:3px;min-width:0}
.founder-n{font-family:var(--font-h);font-weight:500;font-size:.96rem;color:var(--navy);letter-spacing:-.01em;line-height:1.2}
.founder-r{font-size:.8rem;color:var(--mid);line-height:1.2}
.founders-sep{height:1px;background:var(--rule)}

/* ── CTA ───────────────────────────────────── */
.cta{background:var(--navy);color:#fff;position:relative;overflow:hidden;padding:clamp(5rem,9vw,8rem) 0}
.cta-grain{position:absolute;inset:0;background:radial-gradient(circle at 50% 120%,rgba(41,82,217,.22) 0%,transparent 50%);pointer-events:none}
.cta-in{position:relative;z-index:2;text-align:center;max-width:680px;margin:0 auto}
.cta-h{font-family:var(--font-h);font-weight:400;font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.05;letter-spacing:-.035em;color:#fff;margin-bottom:1.3rem}
.cta-h em{font-family:var(--font-serif)}
.cta-p{font-size:1.1rem;line-height:1.6;color:rgba(255,255,255,.72);margin-bottom:2.3rem;max-width:50ch;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.8rem}
.cta-trust{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.55rem;font-size:.84rem;color:rgba(255,255,255,.5)}
.cta-trust .sep{color:rgba(255,255,255,.25);margin:0 .15rem}

/* ── FOOTER ────────────────────────────────── */
.footer{background:var(--navy-2);color:#fff;padding:clamp(3.5rem,6vw,5rem) 0 2.2rem}
.footer-in{display:grid;grid-template-columns:1.3fr 2.4fr;gap:3rem}
@media(max-width:760px){.footer-in{grid-template-columns:1fr;gap:2.5rem}}
.footer-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-h);font-size:1.18rem;font-weight:500;letter-spacing:-.02em;color:#fff;margin-bottom:1rem}
.footer-brand img{width:22px;height:22px}
.footer-tag{font-size:.92rem;color:rgba(255,255,255,.55);line-height:1.55;max-width:30ch}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media(max-width:480px){.footer-cols{grid-template-columns:1fr 1fr}}
.footer-h{font-family:var(--font-h);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.45);margin-bottom:1.1rem}
.footer-link{display:block;font-size:.9rem;color:rgba(255,255,255,.72);padding:.32rem 0;transition:color .2s}
.footer-link:hover{color:#fff}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:3.2rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.1);font-size:.8rem;color:rgba(255,255,255,.45)}
