/* pv-d.css — Variant D · Narrativ / cinematisk product page.
   Builds on site.css + product.css (tokens, .panel, .shot-frame, .pc-* explorer). */

.vD-page .wrapw{max-width:1340px;margin:0 auto;padding-left:clamp(28px,4vw,56px);padding-right:clamp(28px,4vw,56px)}

/* ── cinematic hero ─────────────────────────────────────── */
.vD-page .dhero{padding:clamp(3.5rem,6vw,5rem) 0 0}
.dhero-top{max-width:820px}
.dhero .eye{margin-bottom:1.4rem}
.dhero h1{font-family:var(--font-h);font-weight:400;font-size:clamp(2.6rem,5.4vw,4.4rem);line-height:1;letter-spacing:-.04em;color:var(--navy);margin:0 0 1.3rem;text-wrap:balance}
.dhero h1 em{font-family:var(--font-serif);font-style:italic}
.dhero-sub{font-size:1.15rem;line-height:1.55;color:var(--ink-2);max-width:54ch;margin:0}
.dhero-btns{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.9rem}
.dhero-play{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-h);font-size:.95rem;font-weight:500;color:var(--navy);background:none;border:none;cursor:pointer;padding:.5rem 0}
.dhero-play .pp{width:34px;height:34px;border-radius:99px;border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;background:#fff;box-shadow:var(--shadow-sm)}

/* ── app dashboard chrome (shared by Home + Case mocks) ──── */
.d-app{border-radius:12px;overflow:hidden;border:1px solid var(--rule);box-shadow:var(--shadow-xl);background:#fff}
.dhero .d-app{margin-top:clamp(2.5rem,4vw,3.5rem)}
.d-topbar{display:flex;align-items:stretch;border-bottom:1px solid var(--rule);background:#fff}
.d-topbar-brand{width:204px;display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border-right:1px solid var(--rule);font-family:var(--font-h);font-weight:500;color:var(--navy);font-size:1.05rem}
.d-topbar-brand img{height:20px;width:auto}
.d-topbar-main{flex:1;display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.3rem;min-width:0}
.d-topbar-title{font-family:var(--font-h);font-weight:500;font-size:.95rem;color:var(--navy)}
.d-topbar-right{display:flex;align-items:center;gap:.95rem;flex-shrink:0}
.d-logg{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;font-weight:500;color:var(--navy);border:1px solid var(--rule);border-radius:99px;padding:.32rem .7rem;box-shadow:var(--shadow-sm)}
.d-logg svg{width:13px;height:13px;color:var(--mid)}
.d-logg .ct{background:var(--navy);color:#fff;border-radius:99px;font-size:.66rem;padding:.05rem .42rem;font-feature-settings:"tnum"}
.d-avatar{width:28px;height:28px;border-radius:99px;background:var(--off-2);border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:600;color:var(--mid)}
.d-logout{font-size:.8rem;color:var(--mid)}
.d-side{border-right:1px solid var(--rule);padding:1rem .7rem;display:flex;flex-direction:column;gap:.12rem;background:#fff}
.d-nav{display:flex;align-items:center;gap:.7rem;font-size:.88rem;color:var(--ink-2);padding:.55rem .65rem;border-radius:7px}
.d-nav svg{width:17px;height:17px;flex-shrink:0;color:var(--mid)}
.d-nav.on{background:var(--off-2);color:var(--navy);font-weight:500}
.d-nav.on svg{color:var(--navy)}
.d-nav .ct{margin-left:auto;font-size:.68rem;font-weight:500;color:var(--mid);font-feature-settings:"tnum"}

/* ── Home dashboard main ────────────────────────────────── */
.d-grid.home{display:grid;grid-template-columns:204px minmax(0,1fr)}
.h-main{padding:2rem 2.4rem 4.5rem;min-width:0;position:relative}
.h-eye{font-family:var(--font-h);font-size:.72rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mid)}
.h-greet{font-family:var(--font-h);font-weight:500;font-size:clamp(1.9rem,2.6vw,2.4rem);letter-spacing:-.02em;color:var(--navy);margin:0 0 .9rem;line-height:1.04}
.h-greet em{font-family:var(--font-serif);font-style:italic;font-weight:400}
.h-pill{display:inline-flex;align-items:center;gap:.45rem;margin-top:.9rem;font-size:.72rem;font-weight:600;letter-spacing:.04em;color:var(--amber);background:var(--amber-bg);border:1px solid rgba(184,130,28,.22);border-radius:var(--r-pill);padding:.3rem .75rem}
.h-pill .d{width:6px;height:6px;border-radius:99px;background:var(--amber)}
.h-summary{display:flex;align-items:center;gap:1rem;margin:1.6rem 0;padding:.85rem 1.1rem;background:var(--off);border:1px solid var(--rule);border-radius:8px;font-size:.84rem}
.h-summary .lbl{font-family:var(--font-h);font-size:.64rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);white-space:nowrap}
.h-summary .val{font-family:var(--font-serif);font-style:italic;color:var(--navy);flex:1}
.h-summary .ar{color:var(--dim)}
.h-q{font-family:var(--font-serif);font-style:italic;font-size:1.45rem;color:var(--navy);margin:1.9rem 0 1.1rem}
.h-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.h-act{position:relative;background:#fff;border:1px solid var(--rule);border-radius:10px;padding:1.3rem;box-shadow:var(--shadow-sm);min-height:152px;display:flex;flex-direction:column;transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease)}
.h-act:hover{transform:translateY(-2px);border-color:var(--navy);box-shadow:var(--shadow-md)}
.h-act-ic{width:38px;height:38px;border-radius:9px;background:var(--off-2);color:var(--navy);display:flex;align-items:center;justify-content:center}
.h-act-ic svg{width:19px;height:19px}
.h-act-tag{position:absolute;top:1.2rem;right:1.2rem;font-size:.6rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--amber)}
.h-act-t{font-family:var(--font-serif);font-style:italic;font-size:1.25rem;color:var(--navy);margin:1.1rem 0 .35rem}
.h-act-d{font-size:.82rem;line-height:1.45;color:var(--mid)}
.h-stats{display:flex;flex-wrap:wrap;gap:.9rem;margin:1.7rem 0;font-size:.86rem;color:var(--mid)}
.h-stats b{color:var(--navy);font-weight:600;font-feature-settings:"tnum"}
.h-stats .sep{opacity:.4}
.h-lists{display:grid;grid-template-columns:1fr 1fr;gap:2.2rem;border-top:1px solid var(--rule);padding-top:1.6rem}
.h-list-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.h-list-h .t{font-family:var(--font-h);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mid)}
.h-list-h .t b{color:var(--navy)}
.h-list-h .lnk{font-size:.78rem;color:var(--brand);font-weight:500}
.h-frist{display:flex;align-items:center;gap:.9rem;padding:.7rem 0;border-bottom:1px solid var(--rule-2)}
.h-date{text-align:center;flex-shrink:0;width:34px;font-family:var(--font-h)}
.h-date .dd{font-size:1.05rem;font-weight:600;color:var(--navy);font-feature-settings:"tnum";line-height:1}
.h-date .mm{font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mid)}
.h-frist-main{flex:1;min-width:0}
.h-frist-t{font-size:.85rem;color:var(--navy);font-weight:500;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h-frist-m{font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;color:var(--mid);margin-top:.15rem}
.h-when{font-size:.74rem;font-weight:500;white-space:nowrap;font-feature-settings:"tnum"}
.h-when.red{color:var(--red)}.h-when.amber{color:var(--amber)}.h-when.mid{color:var(--mid)}
.h-mail{display:flex;align-items:flex-start;gap:.8rem;padding:.7rem 0;border-bottom:1px solid var(--rule-2)}
.h-mail .dot{width:7px;height:7px;border-radius:99px;background:var(--brand);margin-top:.45rem;flex-shrink:0}
.h-mail .dot.read{background:var(--dim)}
.h-mail-main{flex:1;min-width:0}
.h-mail-t{font-size:.85rem;color:var(--navy);font-weight:500;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h-mail-m{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--mid);margin-top:.18rem}
.h-mail-time{font-size:.72rem;color:var(--dim);font-feature-settings:"tnum";white-space:nowrap}
.h-cmd{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);display:flex;align-items:center;gap:.6rem;width:min(440px,72%);background:#fff;border:1px solid var(--rule);border-radius:99px;box-shadow:var(--shadow-lg);padding:.6rem 1rem;font-size:.85rem;color:var(--mid)}
.h-cmd .star{color:var(--brand)}
.h-cmd .kbd{margin-left:auto;font-size:.66rem;color:var(--dim);border:1px solid var(--rule);border-radius:5px;padding:.12rem .42rem;font-feature-settings:"tnum"}

/* ── Case dashboard main + rail (annotated deep-dive) ───── */
.d-grid{display:grid;grid-template-columns:204px minmax(0,1fr) 236px;min-height:420px}
.d-main{padding:1.4rem 1.6rem;min-width:0;display:flex;flex-direction:column}
.d-crumb{display:flex;align-items:center;gap:.6rem;font-size:.78rem;color:var(--mid)}
.d-crumb .lnk{color:var(--brand)}
.d-crumb .st{font-size:.6rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--green);background:var(--green-bg);border-radius:99px;padding:.12rem .45rem}
.d-edit{margin-left:auto;display:inline-flex;align-items:center;gap:.4rem;font-size:.74rem;font-weight:500;color:#fff;background:var(--navy);border-radius:var(--r-btn);padding:.4rem .7rem}
.d-title{font-family:var(--font-h);font-weight:500;font-size:1.45rem;letter-spacing:-.02em;color:var(--navy);margin:.7rem 0 .2rem;line-height:1.15}
.d-title em{font-family:var(--font-serif);font-style:italic;font-weight:400}
.d-meta{font-size:.8rem;color:var(--mid);margin-bottom:1rem}
.d-tabs{display:flex;gap:1.4rem;border-bottom:1px solid var(--rule);margin-bottom:1.2rem}
.d-tab{font-size:.84rem;color:var(--mid);padding-bottom:.7rem;position:relative}
.d-tab .mini{font-size:.68rem;color:var(--dim)}
.d-tab.on{color:var(--navy);font-weight:500}
.d-tab.on::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--navy)}
.d-pinwrap{position:relative}
.d-pin{position:absolute;top:-13px;left:-13px;width:26px;height:26px;border-radius:99px;background:var(--brand);color:#fff;font-family:var(--font-h);font-size:.78rem;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 4px rgba(41,82,217,.16),var(--shadow-md);z-index:4;font-feature-settings:"tnum"}
.d-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-bottom:1.3rem}
.d-kpi{border:1px solid var(--rule);border-radius:8px;padding:.75rem .85rem;background:linear-gradient(180deg,#fff,#fbf9f5)}
.d-kpi .l{font-size:.64rem;letter-spacing:.09em;text-transform:uppercase;color:var(--mid)}
.d-kpi .v{font-family:var(--font-h);font-weight:500;font-size:1.15rem;color:var(--navy);font-feature-settings:"tnum";margin:.25rem 0 .2rem;line-height:1.1}
.d-kpi .v.red{color:var(--red)}
.d-kpi .s{font-size:.68rem;color:var(--mid);line-height:1.3}
.d-rec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}
.d-rec-h{font-family:var(--font-h);font-size:1.05rem;font-weight:600;letter-spacing:-.01em;color:var(--navy)}
.d-rec-edit{font-size:.72rem;color:var(--mid);border:1px solid var(--rule);border-radius:var(--r-btn);padding:.25rem .6rem}
.d-rec{display:flex;align-items:center;gap:.8rem;background:#fff;border:1px solid var(--rule);border-radius:8px;padding:.7rem .85rem;box-shadow:var(--shadow-sm);margin-bottom:.5rem}
.d-rec .bd{width:6px;height:6px;border-radius:99px;background:var(--navy);flex-shrink:0}
.d-rec .tx{flex:1;min-width:0}
.d-rec .tt{font-size:.85rem;color:var(--navy);font-weight:500;letter-spacing:-.005em}
.d-rec .src{font-size:.7rem;color:var(--mid);margin-top:.15rem}
.d-rec .go{color:var(--dim);flex-shrink:0}
.d-aktivitet{margin-top:1.2rem;padding-top:1rem;border-top:1px solid var(--rule)}
.d-akt-h{font-family:var(--font-h);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:.5rem}
.d-akt-row{display:flex;align-items:center;justify-content:space-between;font-size:.82rem;color:var(--ink-2);background:var(--off);border:1px solid var(--rule);border-radius:8px;padding:.7rem .85rem}
.d-akt-row .lnk{color:var(--brand);font-weight:500}
.d-akt-row b{color:var(--navy)}
.d-rail{border-left:1px solid var(--rule);padding:1.3rem 1.1rem;display:flex;flex-direction:column;gap:1.4rem;background:#fff}
.d-rail-h{font-family:var(--font-h);font-size:.68rem;font-weight:600;letter-spacing:.11em;text-transform:uppercase;color:var(--mid);margin-bottom:.7rem}
.d-act{display:flex;align-items:center;gap:.55rem;font-size:.82rem;color:var(--navy);font-weight:500;border:1px solid var(--rule);border-radius:7px;padding:.55rem .7rem;background:#fff;margin-bottom:.45rem;box-shadow:var(--shadow-sm)}
.d-act svg{width:14px;height:14px;color:var(--mid)}
.d-act .go{margin-left:auto;color:var(--dim)}
.d-doc{display:flex;align-items:center;gap:.55rem;font-size:.82rem;color:var(--ink-2);padding:.4rem 0}
.d-doc svg{width:14px;height:14px;color:var(--brand);flex-shrink:0}
.d-upload{font-size:.78rem;color:var(--brand);font-weight:500;margin-top:.4rem}

/* ── trust strip ────────────────────────────────────────── */
.d-strip{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--off);margin-top:clamp(3rem,5vw,4.5rem)}
.d-strip-in{display:flex;align-items:center;gap:2rem;padding:1.4rem 0;flex-wrap:wrap}
.d-strip-label{font-family:var(--font-h);font-size:.7rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);white-space:nowrap}
.d-strip-items{display:flex;align-items:center;gap:1.8rem;flex-wrap:wrap}
.d-strip-item{font-family:var(--font-h);font-size:.96rem;font-weight:500;color:var(--ink-2);display:inline-flex;align-items:center;gap:.45rem}
.d-strip-item .badge{font-size:.58rem;font-weight:600;letter-spacing:.04em;color:var(--brand);background:rgba(41,82,217,.08);border-radius:var(--r-chip);padding:.1rem .35rem}

/* ── section heads ──────────────────────────────────────── */
.d-sec-head{max-width:680px;margin-bottom:clamp(2.5rem,4vw,3.5rem)}
.d-sec-head .eye{margin-bottom:1.2rem}
.d-sec-head h2{font-family:var(--font-h);font-weight:400;font-size:clamp(1.9rem,3.4vw,2.7rem);line-height:1.06;letter-spacing:-.03em;color:var(--navy);margin:0 0 .9rem;text-wrap:balance}
.d-sec-head h2 em{font-family:var(--font-serif);font-style:italic}
.d-sec-head p{font-size:1.06rem;line-height:1.6;color:var(--ink-2);max-width:52ch;margin:0}

/* ── process story (improved timeline) ──────────────────── */
.d-flow{padding:clamp(4rem,7vw,6rem) 0}
.d-steps{display:flex;flex-direction:column}
.d-step{display:grid;grid-template-columns:56px minmax(0,.95fr) minmax(0,1.18fr);gap:clamp(1.6rem,3vw,3rem);align-items:center;padding:clamp(2.2rem,3.5vw,3.4rem) 0}
.d-gutter{display:flex;flex-direction:column;align-items:center;align-self:stretch;gap:.5rem}
.d-stepnum{width:42px;height:42px;border-radius:99px;background:var(--navy);color:#fff;font-family:var(--font-h);font-weight:500;font-size:1.05rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-feature-settings:"tnum";box-shadow:var(--shadow-md)}
.d-thread{flex:1;width:2px;background:var(--rule);border-radius:2px}
.d-step-eye{font-family:var(--font-h);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--brand);margin-bottom:.6rem}
.d-step-t{font-family:var(--font-h);font-weight:400;font-size:clamp(1.5rem,2.4vw,1.95rem);letter-spacing:-.03em;color:var(--navy);margin:0 0 .7rem;line-height:1.04}
.d-step-t em{font-family:var(--font-serif);font-style:italic}
.d-step-b{font-size:1.02rem;line-height:1.6;color:var(--ink-2);max-width:42ch;margin:0 0 1.2rem}
.d-io{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-h);font-size:.82rem;font-weight:500;padding:.42rem .85rem;border:1px solid var(--rule);border-radius:var(--r-pill);background:#fff;box-shadow:var(--shadow-sm)}
.d-io .from{color:var(--mid)}
.d-io .ar{color:var(--dim)}
.d-io .to{color:var(--green)}
.d-step-keep{display:inline-flex;align-items:center;gap:.45rem;font-size:.92rem;font-weight:500;color:var(--green);margin-top:.2rem}
.d-step-shot{min-width:0}
.d-step-shot .shot-frame{box-shadow:var(--shadow-lg)}

/* ── unified system (interactive explorer wrapper) ──────── */
.d-system{padding:clamp(4rem,7vw,6rem) 0;border-top:1px solid var(--rule)}

/* ── Saker deep-dive (annotated) ────────────────────────── */
.d-saker{padding:clamp(4rem,7vw,6rem) 0;border-top:1px solid var(--rule)}
.d-saker-hint{display:inline-flex;align-items:center;gap:.55rem;font-size:.86rem;color:var(--brand);margin-bottom:2rem}
.d-saker-hint .pl{width:22px;height:22px;border-radius:99px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.d-callouts{display:grid;grid-template-columns:repeat(5,1fr);gap:1.4rem;margin-top:2.6rem}
.d-callout{display:flex;flex-direction:column;gap:.6rem}
.d-callout-n{width:28px;height:28px;border-radius:99px;background:#fff;border:1.5px solid var(--brand);color:var(--brand);font-family:var(--font-h);font-weight:600;font-size:.82rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-feature-settings:"tnum"}
.d-callout-t{font-family:var(--font-h);font-weight:600;font-size:.96rem;color:var(--navy);margin:0 0 .3rem;letter-spacing:-.01em;line-height:1.2}
.d-callout-b{font-size:.86rem;line-height:1.5;color:var(--ink-2);margin:0}
.d-callout-b b{color:var(--navy);font-weight:600}

/* ── navy trust band ────────────────────────────────────── */
.d-trust{background:var(--navy);color:rgba(255,255,255,.72);padding:clamp(4rem,6vw,5.5rem) 0}
.d-trust .eye{color:rgba(255,255,255,.5)}
.d-trust .eye::before{background:rgba(255,255,255,.4)}
.d-trust h2{font-family:var(--font-h);font-weight:300;font-size:clamp(1.8rem,3.2vw,2.5rem);line-height:1.1;letter-spacing:-.03em;color:#fff;margin:1.2rem 0 1rem;max-width:18ch;text-wrap:balance}
.d-trust h2 em{font-family:var(--font-serif);font-style:italic;font-weight:400}
.d-trust p{font-size:1.05rem;line-height:1.6;color:rgba(255,255,255,.62);max-width:50ch;margin:0}
.d-certs{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.d-cert{font-size:.82rem;font-weight:500;color:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-pill);padding:.4rem .9rem}

/* ── cta ────────────────────────────────────────────────── */
.d-cta{padding:clamp(4rem,7vw,6.5rem) 0;text-align:center}
.d-cta h2{font-family:var(--font-h);font-weight:400;font-size:clamp(2.2rem,4.4vw,3.4rem);line-height:1.04;letter-spacing:-.035em;color:var(--navy);margin:0 0 1rem}
.d-cta h2 em{font-family:var(--font-serif);font-style:italic}
.d-cta p{font-size:1.1rem;line-height:1.6;color:var(--ink-2);max-width:48ch;margin:0 auto 2rem}
.d-cta-btns{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}

.d-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-h);font-size:.95rem;font-weight:500;border-radius:var(--r-btn);padding:.75rem 1.3rem;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:transform var(--dur) var(--ease),background var(--dur) var(--ease)}
.d-btn-primary{background:var(--navy);color:#fff}
.d-btn-primary:hover{transform:translateY(-1px);background:#000}
.d-btn-ghost{background:#fff;color:var(--navy);border-color:var(--rule)}
.d-btn-ghost:hover{border-color:var(--navy)}
