/* ════════════════════════════════════════════════════════════════════
   Nordivé — Funksjon-faner + Praksisområder
   Claude Design-handoff (faner.css + praksis.css), tilpasset nettsiden:
   - design-tokens scopet lokalt på seksjons-røttene (rører ikke global :root)
   - venstre panel = iframe med de ekte produkt-animasjonene (walkthroughs/)
   ════════════════════════════════════════════════════════════════════ */
.ft-page, .pa-page{
  --off:#FAF8F4; --off-2:#F4F1EB; --white:#FFFFFF; --navy:#0E1B33;
  --ink:#1a2330; --ink-2:#3a4658; --mid:#6c7785; --dim:#98a2b1;
  --rule:rgba(14,27,51,.08); --rule-2:rgba(14,27,51,.05);
  --brand:#2952d9; --brand-h:#2945a0;
  --font-h:'Inter Tight',system-ui,sans-serif;
  --font-serif:'Playfair Display',Georgia,serif;
  --font-body:'Inter Tight',system-ui,sans-serif;
  --ease:cubic-bezier(.2,.7,.2,1); --r-pill:99px;
  --shadow-sm:0 1px 0 rgba(14,27,51,.02);
  --shadow-xl:0 22px 50px -28px rgba(14,27,51,.18);
}

/* ── FUNKSJON-FANER (Newcode-stil) ── */
.ft-page{background:var(--white);font-family:var(--font-body);color:var(--ink);
  padding:84px clamp(24px,5vw,64px) 104px;position:relative;overflow:hidden}
.ft-page::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 84% 88%,rgba(14,27,51,.015),transparent 55%)}
.ft-inner{max-width:1260px;margin:0 auto;position:relative;z-index:1}

.ft-head{text-align:left;max-width:720px;margin:0 0 2rem}
.ft-eye{font-family:var(--font-h);font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-bottom:1rem;display:inline-block}
.ft-h{font-family:var(--font-h);font-weight:400;font-size:clamp(1.9rem,3.2vw,2.7rem);line-height:1.08;letter-spacing:-.03em;color:var(--navy);margin:0}
.ft-h em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.015em}
.ft-lead{font-size:1.02rem;line-height:1.6;color:var(--ink-2);max-width:520px;margin-top:.9rem}

.ft-tabs{display:flex;justify-content:flex-start;flex-wrap:wrap;align-items:flex-end;
  gap:clamp(1.5rem,3vw,3rem);border-bottom:1px solid var(--rule);padding-bottom:1.05rem;margin-bottom:2.8rem;position:relative}
.ft-tab{position:relative;font-family:var(--font-h);font-size:1.32rem;font-weight:500;
  letter-spacing:-.015em;color:var(--dim);cursor:pointer;white-space:nowrap;background:none;border:0;
  transition:color .35s var(--ease);padding:0 0 1px}
.ft-tab:hover{color:var(--ink-2)}
.ft-tab.on{color:var(--navy)}
.ft-prog-wrap{position:absolute;left:0;right:0;bottom:calc(-1.05rem - 1.5px);height:2px;overflow:hidden;border-radius:2px}
.ft-prog{display:block;height:100%;width:0;background:var(--navy)}

.ft-stage{display:grid;grid-template-columns:1.62fr .78fr;gap:clamp(1.8rem,3.2vw,3rem);align-items:center}
.ft-media{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;
  background:linear-gradient(180deg,#ffffff 0%,#f4f1ea 100%);
  border:1px solid var(--rule-2);box-shadow:var(--shadow-xl)}
.ft-frame{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;background:#FAF8F4}

.ft-copy{max-width:450px}
.ft-copy-num{font-family:var(--font-h);font-size:.72rem;font-weight:500;letter-spacing:.18em;color:var(--brand);font-feature-settings:"tnum";margin-bottom:1rem;text-transform:uppercase}
.ft-copy-h{font-family:var(--font-h);font-weight:400;font-size:clamp(1.7rem,2.5vw,2.15rem);line-height:1.13;letter-spacing:-.025em;color:var(--navy);margin:0}
.ft-copy-h em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.012em}
.ft-copy-d{font-size:1rem;line-height:1.62;color:var(--ink-2);margin-top:.95rem}
.ft-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.4rem}
.ft-chip{font-family:var(--font-h);font-size:.8rem;font-weight:500;color:var(--ink-2);
  background:var(--off);border:1px solid var(--rule);padding:.32rem .66rem;border-radius:var(--r-pill);box-shadow:var(--shadow-sm)}
.ft-cta{display:inline-flex;align-items:center;gap:.45rem;margin-top:1.7rem;white-space:nowrap;
  font-family:var(--font-h);font-size:.92rem;font-weight:500;color:var(--brand);text-decoration:none;
  border-bottom:1px solid transparent;padding-bottom:2px;transition:color .2s,border-color .2s}
.ft-cta:hover{color:var(--brand-h);border-bottom-color:var(--brand-h)}
.ft-cta svg{width:15px;height:15px;transition:transform .2s var(--ease)}
.ft-cta:hover svg{transform:translateX(3px)}
.ft-fade{animation:ftFade .5s var(--ease) both}
@keyframes ftFade{from{opacity:0;transform:translateY(11px)}to{opacity:1;transform:none}}

@media (max-width:900px){
  .ft-stage{grid-template-columns:1fr;gap:1.8rem}
  .ft-copy{max-width:none}
  .ft-tabs{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}
  .ft-tabs::-webkit-scrollbar{display:none}
}

/* ── PRAKSISOMRÅDER (utvidende carousel) ── */
.pa-page{background:var(--off);font-family:var(--font-body);color:var(--ink);
  padding:84px clamp(24px,5vw,64px) 104px;position:relative;overflow:hidden}
.pa-page::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 18% 16%,rgba(14,27,51,.022),transparent 50%),radial-gradient(circle at 84% 84%,rgba(14,27,51,.018),transparent 55%)}
.pa-inner{max-width:1320px;margin:0 auto;position:relative;z-index:1}
.pa-top{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:2.4rem}
.pa-head{max-width:760px}
.pa-eyebrow{font-family:var(--font-h);font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-bottom:1.1rem}
.pa-title{font-family:var(--font-h);font-weight:400;font-size:clamp(1.9rem,3.2vw,2.7rem);line-height:1.08;letter-spacing:-.03em;color:var(--navy);margin-bottom:1rem}
.pa-title em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.015em}
.pa-lead{font-size:1.05rem;line-height:1.6;color:var(--ink-2);max-width:540px;margin:0}
.pa-nav{display:flex;gap:10px;flex:0 0 auto;padding-bottom:4px}
.pa-navbtn{width:46px;height:46px;border-radius:50%;border:1px solid var(--rule);background:var(--white);
  color:var(--navy);display:flex;align-items:center;justify-content:center;cursor:pointer;
  box-shadow:var(--shadow-sm);transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.pa-navbtn:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-1px)}
.pa-navbtn svg{width:18px;height:18px}

.pa-track{display:flex;gap:14px;height:500px;overflow-x:auto;scroll-behavior:smooth;
  padding:4px 2px 10px;margin:-4px -2px 0;scrollbar-width:none}
.pa-track::-webkit-scrollbar{display:none}
.pa-card{position:relative;flex:0 0 212px;cursor:pointer;display:flex;flex-direction:column;scroll-snap-align:center;
  border-radius:16px;overflow:hidden;color:#fff;box-shadow:0 26px 60px -34px rgba(14,27,51,.5);
  background-color:#0E1B33;
  transition:flex-basis .6s var(--ease), box-shadow .4s var(--ease)}
/* navy duotone-overlay: lett i midten (bildet vises) når kollapset, mørk når aktiv (innhold lesbart) */
.pa-card::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(14,27,51,.66) 0%,rgba(14,27,51,.34) 36%,rgba(14,27,51,.44) 62%,rgba(12,20,42,.92) 100%);
  transition:background .45s var(--ease)}
.pa-card.active::before{background:linear-gradient(180deg,rgba(14,27,51,.85) 0%,rgba(12,20,42,.94) 100%)}
/* bilde i eget lag med FAST bredde (kortets overflow klipper) — bredden endres ikke
   under flex-animasjonen, så bitmappen re-rasteriseres ikke = ingen hakking */
.pa-bg{position:absolute;top:0;left:0;height:100%;width:560px;z-index:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;transform:translateZ(0)}
.pa-card.active{flex-basis:560px;cursor:default}
.pa-card:not(.active):hover{filter:brightness(1.12)}
.pa-card::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  background:radial-gradient(130% 80% at 50% -10%,rgba(255,255,255,.06),transparent 55%)}
.pa-chead{flex:0 0 auto;position:relative;z-index:3;padding:22px 22px 0}
.pa-name{font-family:var(--font-h);font-size:.78rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:#fff;line-height:1.25;padding-right:46px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 12px rgba(8,15,33,.55)}
.pa-spine{font-family:var(--font-h);font-size:.66rem;font-weight:500;letter-spacing:.05em;line-height:1.5;color:rgba(255,255,255,.5);text-transform:uppercase;margin-top:10px;padding-right:46px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .3s var(--ease)}
.pa-card.active .pa-spine{opacity:0;height:0;margin:0;overflow:hidden}
.pa-arrow{position:absolute;top:20px;right:20px;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.9);transition:background .3s var(--ease),transform .4s var(--ease)}
.pa-arrow svg{width:16px;height:16px}
.pa-card:hover .pa-arrow{background:rgba(255,255,255,.2)}
.pa-card.active .pa-arrow{background:rgba(255,255,255,.14);transform:rotate(90deg)}
.pa-ghost{position:absolute;left:22px;bottom:22px;z-index:2;color:#fff;opacity:.14;transition:opacity .35s var(--ease)}
.pa-ghost svg{width:88px;height:88px;stroke-width:1.1}
.pa-card.active .pa-ghost{opacity:0}
.pa-exp{flex:1;min-height:0;position:relative;z-index:2;display:flex;flex-direction:column;padding:18px 28px 26px;opacity:0;transition:opacity .4s var(--ease)}
.pa-card.active .pa-exp{opacity:1;transition-delay:.2s}
.pa-card:not(.active) .pa-exp{pointer-events:none}
.pa-exp-eye{display:flex;align-items:center;gap:9px;font-family:var(--font-h);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px}
.pa-exp-eye svg{width:17px;height:17px;stroke-width:1.7}
.pa-h{font-family:var(--font-h);font-weight:400;font-size:1.5rem;line-height:1.13;letter-spacing:-.025em;color:#fff;margin:0 0 9px}
.pa-h em{font-family:var(--font-serif);font-style:italic;font-weight:400;letter-spacing:-.012em}
.pa-desc{font-size:.92rem;line-height:1.5;color:rgba(255,255,255,.66);max-width:480px;margin-bottom:15px}
.pa-label{font-family:var(--font-h);font-size:.66rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.42);padding-bottom:10px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}
.pa-list{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;list-style:none;margin:0 0 15px;padding:0}
.pa-item{display:flex;align-items:flex-start;gap:9px;font-size:.9rem;line-height:1.4;color:rgba(255,255,255,.86)}
.pa-check{flex:0 0 auto;width:18px;height:18px;border-radius:50%;margin-top:1px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16)}
.pa-check svg{width:10px;height:10px;stroke-width:2.6}
.pa-laws{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:auto}
.pa-law{font-family:var(--font-h);font-size:.74rem;font-weight:500;color:rgba(255,255,255,.78);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.13);padding:.28rem .6rem;border-radius:var(--r-pill);white-space:nowrap}
.pa-law.pa-integ{display:inline-flex;align-items:center;gap:.34rem;font-weight:600;background:rgba(255,255,255,.07);box-shadow:0 0 0 1px rgba(255,255,255,.04) inset}
.pa-law.pa-integ svg{width:13px;height:13px;stroke-width:1.8}
.pa-cta{display:inline-flex;align-items:center;gap:.45rem;align-self:flex-start;margin-top:14px;white-space:nowrap;font-family:var(--font-h);font-size:.9rem;font-weight:500;color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:3px;transition:border-color .25s var(--ease)}
.pa-cta:hover{border-bottom-color:#fff}
.pa-cta svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.pa-cta:hover svg{transform:translateX(3px)}
@media (max-width:900px){
  .pa-top{flex-direction:column;align-items:flex-start}
  .pa-track{height:auto;flex-direction:column}
  .pa-card{flex:none;min-height:92px}
  .pa-bg{width:100%}
  .pa-card.active{flex:none;min-height:470px}
  .pa-list{grid-template-columns:1fr}
  .pa-ghost svg{width:64px;height:64px}
}
