/* ============================================================================
   AAB — Adaptivt CV · STYLES
   Bas-design + 5 linsteman + adaptiv "chrome" (växel, banner, quiz, terminal)
   ========================================================================== */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --ink:#18181B;--ink-muted:#52525B;--ink-faint:#A1A1AA;
  --paper:#FAFAF9;--surface:#FFFFFF;--surface2:#F4F4F5;
  --blue:#1D4ED8;--blue-light:#DBEAFE;--blue-mid:#3B82F6;
  --teal:#0F766E;--teal-light:#CCFBF1;--teal-mid:#14B8A6;
  --amber:#92400E;--amber-light:#FEF3C7;--amber-mid:#F59E0B;
  --coral:#BE123C;--coral-light:#FFE4E6;--coral-mid:#F43F5E;
  --border:rgba(0,0,0,.08);--border-md:rgba(0,0,0,.14);
  --r:8px;--r-lg:14px;--r-xl:20px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);
  --shadow:0 2px 8px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.04);
  --shadow-lg:0 8px 32px rgba(0,0,0,.10),0 0 0 1px rgba(0,0,0,.04);
  /* lins-styrda */
  --accent:var(--blue);--accent-light:var(--blue-light);--accent-mid:var(--blue-mid);
  --display:'Fraunces',serif;--body:'DM Sans',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

html{scroll-behavior:smooth}
body{
  font-family:var(--body);background:var(--paper);color:var(--ink);
  line-height:1.6;font-size:16px;overflow-x:hidden;
}

/* ── NAV ───────────────────────────────────────────────────────────────── */
nav{position:sticky;top:0;z-index:300;background:color-mix(in srgb,var(--paper) 94%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:.5rem 1.5rem;display:flex;align-items:center;gap:.2rem;overflow-x:auto}
.nav-name{font-family:var(--display);font-size:.95rem;font-weight:600;color:var(--ink);margin-right:auto;white-space:nowrap;flex-shrink:0}
nav a{font-size:.78rem;color:var(--ink-muted);text-decoration:none;white-space:nowrap;padding:.28rem .65rem;border-radius:20px;transition:all .15s;flex-shrink:0}
nav a:hover,nav a.active{color:var(--ink);background:var(--surface2)}

/* lins-växel i navet */
.lens-switch{display:inline-flex;align-items:center;gap:.4rem;margin-left:.5rem;font-size:.76rem;font-weight:600;padding:.3rem .7rem .3rem .55rem;border-radius:20px;background:var(--ink);color:#fff;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .15s,transform .15s;font-family:inherit}
.lens-switch:hover{opacity:.88;transform:translateY(-1px)}
.lens-switch .ls-iris{display:inline-flex;width:15px;height:15px;border-radius:50%;border:2px solid currentColor;position:relative}
.lens-switch .ls-iris::after{content:"";position:absolute;inset:2px;border-radius:50%;background:currentColor;transform:scale(.55);transition:transform .3s}
.lens-switch:hover .ls-iris::after{transform:scale(.2)}

/* ── UTILS ─────────────────────────────────────────────────────────────── */
.sec{padding:5rem 1.5rem;max-width:980px;margin:0 auto;transition:opacity .4s ease}
.sec-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent-mid);font-weight:600;margin-bottom:.6rem}
.sec-title{font-family:var(--display);font-size:2.1rem;font-weight:400;line-height:1.2;margin-bottom:.6rem}
.sec-sub{color:var(--ink-muted);margin-bottom:2.5rem;max-width:540px;font-size:.95rem}
.divider{border:none;border-top:1px solid var(--border);margin:0}
.tag{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:600;padding:.18rem .6rem;border-radius:20px;letter-spacing:.04em}
.tag-blue{background:var(--blue-light);color:#1E40AF}
.tag-teal{background:var(--teal-light);color:#115E59}
.tag-amber{background:var(--amber-light);color:#78350F}
.tag-coral{background:var(--coral-light);color:#9F1239}

/* ── BUTTONS ───────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:var(--r);font-size:.85rem;font-weight:500;cursor:pointer;border:1px solid var(--border-md);background:var(--surface);color:var(--ink);text-decoration:none;transition:all .15s;font-family:inherit}
.btn:hover{background:var(--surface2)}
.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-primary:hover{background:#3F3F46;border-color:#3F3F46}
.btn-blue{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-blue:hover{filter:brightness(.9)}

/* ── HERO ──────────────────────────────────────────────────────────────── */
.hero{background:var(--surface);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-120px;right:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--accent-light) 60%,transparent) 0%,transparent 70%);pointer-events:none}
.hero-inner{max-width:980px;margin:0 auto;padding:5.5rem 1.5rem 4rem;display:grid;grid-template-columns:1fr 280px;gap:4rem;align-items:start}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent-light);color:var(--accent);font-size:.73rem;font-weight:600;padding:.3rem .9rem;border-radius:20px;margin-bottom:1.4rem;letter-spacing:.04em}
.hero h1{font-family:var(--display);font-size:3.4rem;font-weight:400;line-height:1.1;margin-bottom:.9rem;letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--accent-mid)}
.hero-sub{font-size:1rem;color:var(--ink-muted);max-width:440px;line-height:1.7;margin-bottom:.6rem;font-weight:400}
.hero-btns{display:flex;flex-wrap:wrap;gap:.6rem;margin:1.4rem 0 2.8rem}
.proof-strip{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.proof-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:.7rem .9rem;display:flex;align-items:flex-start;gap:.6rem}
.proof-item .pi-num{font-family:var(--display);font-size:1.3rem;font-weight:600;color:var(--accent);line-height:1;flex-shrink:0}
.proof-item .pi-text{font-size:.75rem;color:var(--ink-muted);line-height:1.45}
.hero-portrait{display:flex;flex-direction:column;gap:1rem;padding-top:.5rem}
.portrait-box{width:100%;aspect-ratio:3/4;background:linear-gradient(155deg,var(--blue-light) 0%,var(--teal-light) 60%,var(--amber-light) 100%);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;border:1px solid var(--border)}
.portrait-monogram{font-family:var(--display);font-size:5rem;font-weight:300;color:var(--accent);opacity:.7}
/* roterande porträtt */
.portrait-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.06);transition:opacity 1.1s ease,transform 6s ease}
.portrait-photo.show{opacity:1;transform:scale(1)}
.portrait-dots{position:absolute;left:0;right:0;bottom:12px;z-index:3;display:flex;gap:6px;justify-content:center;pointer-events:none}
.portrait-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.55);box-shadow:0 1px 3px rgba(0,0,0,.3);transition:all .4s}
.portrait-dots i.on{width:20px;border-radius:3px;background:#fff}
.portrait-quote{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1rem 1.1rem;box-shadow:var(--shadow)}
.portrait-quote p{font-family:var(--display);font-style:italic;font-size:.88rem;color:var(--ink-muted);line-height:1.6}
.portrait-quote cite{font-size:.72rem;color:var(--ink-faint);margin-top:.4rem;display:block;font-style:normal}

/* ── RELEVANS-KORT ─────────────────────────────────────────────────────── */
.rel-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.rel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.4rem;transition:all .2s;position:relative;overflow:hidden}
.rel-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r-lg) var(--r-lg) 0 0}
.rel-card:nth-child(1)::before{background:linear-gradient(90deg,var(--blue),var(--blue-mid))}
.rel-card:nth-child(2)::before{background:linear-gradient(90deg,var(--teal),var(--teal-mid))}
.rel-card:nth-child(3)::before{background:linear-gradient(90deg,var(--amber),var(--amber-mid))}
.rel-card:nth-child(4)::before{background:linear-gradient(90deg,var(--coral),var(--coral-mid))}
.rel-card:hover{border-color:var(--border-md);transform:translateY(-2px);box-shadow:var(--shadow)}
.rel-icon{width:38px;height:38px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem;font-size:1.2rem}
.rel-card h3{font-size:.95rem;font-weight:500;margin-bottom:.4rem}
.rel-card p{font-size:.82rem;color:var(--ink-muted);line-height:1.6}

/* ── BEVIS ─────────────────────────────────────────────────────────────── */
.evidence-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}
.ev-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem;transition:all .18s}
.ev-item:hover{border-color:var(--accent-mid);background:var(--accent-light)}
.ev-num{font-family:var(--display);font-size:2rem;font-weight:300;line-height:1;margin-bottom:.3rem}
.ev-label{font-size:.78rem;color:var(--ink-muted);line-height:1.45}

/* ── CASES ─────────────────────────────────────────────────────────────── */
.case-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.cf-btn{padding:.32rem .85rem;border-radius:20px;font-size:.78rem;border:1px solid var(--border);background:transparent;color:var(--ink-muted);cursor:pointer;transition:all .15s;font-family:inherit}
.cf-btn:hover{background:var(--surface2)}
.cf-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.case-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.3rem;display:flex;flex-direction:column;gap:.6rem;transition:all .2s;cursor:pointer}
.case-card:hover{border-color:var(--border-md);box-shadow:var(--shadow);transform:translateY(-2px)}
.case-card.hidden{display:none}
.case-card .cc-tags{display:flex;flex-wrap:wrap;gap:.3rem}
.case-card h4{font-size:.92rem;font-weight:500;line-height:1.35}
.case-card .cc-problem{font-size:.8rem;color:var(--ink-muted)}
.case-detail{display:none;margin-top:.6rem;padding-top:.75rem;border-top:1px solid var(--border)}
.case-detail.open{display:block}
.case-row{display:grid;grid-template-columns:auto 1fr;gap:.4rem .75rem;margin-bottom:.45rem;align-items:start}
.cr-label{font-size:.68rem;font-weight:600;padding:.12rem .5rem;border-radius:4px;white-space:nowrap;margin-top:.1rem}
.cr-label.role{background:var(--blue-light);color:#1E40AF}
.cr-label.result{background:var(--teal-light);color:#115E59}
.cr-text{font-size:.8rem;color:var(--ink-muted);line-height:1.55}
.cc-more{font-size:.78rem;font-weight:500;color:var(--accent-mid);margin-top:.3rem;display:inline-flex;align-items:center;gap:.2rem}

/* ── KOMPETENSKARTA ────────────────────────────────────────────────────── */
.comp-map{display:grid;grid-template-columns:repeat(4,1fr);gap:.65rem;margin-bottom:1rem}
.comp-node{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1rem .85rem;cursor:pointer;transition:all .18s;text-align:center}
.comp-node:hover{border-color:var(--accent-mid);background:var(--accent-light)}
.comp-node.active{border-color:var(--accent-mid);background:var(--accent-light);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-mid) 18%,transparent)}
.comp-node .cn-emoji{font-size:1.4rem;margin-bottom:.4rem}
.comp-node h4{font-size:.78rem;font-weight:500;line-height:1.3}
.comp-panel{background:var(--surface);border:1px solid var(--accent-mid);border-radius:var(--r-lg);padding:1.4rem;display:none;box-shadow:var(--shadow)}
.comp-panel.open{display:block;animation:slideDown .2s ease}
.comp-panel h3{font-size:1rem;font-weight:500;margin-bottom:.3rem;color:var(--accent)}
.comp-panel .cp-intro{font-size:.85rem;color:var(--ink-muted);margin-bottom:1rem}
.comp-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.comp-col h5{font-size:.67rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);font-weight:600;margin-bottom:.35rem}
.comp-col p{font-size:.82rem;color:var(--ink-muted);line-height:1.6}

/* ── VERKTYGSLÅDA (Nörd) ───────────────────────────────────────────────── */
#verktyg{display:none}
.tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.5rem}
.tool-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.2rem}
.tool-col h5{font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-mid);margin-bottom:.8rem}
.tool-col ul{list-style:none}
.tool-col li{font-size:.82rem;color:var(--ink-muted);padding:.32rem 0;border-bottom:1px solid var(--border);font-family:var(--mono)}
.tool-col li:last-child{border-bottom:none}
.tool-col li::before{content:"› ";color:var(--accent-mid)}

/* ── PROCESS ───────────────────────────────────────────────────────────── */
.process-steps{display:grid;grid-template-columns:repeat(6,1fr);gap:0;position:relative;margin-top:1.5rem}
.process-steps::before{content:'';position:absolute;top:28px;left:8.3%;right:8.3%;height:1px;background:var(--border-md);z-index:0}
.ps-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.4rem .2rem;cursor:pointer;position:relative;z-index:1}
.ps-dot{width:56px;height:56px;border-radius:50%;background:var(--surface);border:2px solid var(--border-md);display:flex;align-items:center;justify-content:center;margin-bottom:.7rem;transition:all .2s;font-size:1.1rem;font-weight:600;font-family:var(--display);color:var(--ink-muted)}
.ps-item:hover .ps-dot,.ps-item.active .ps-dot{background:var(--ink);color:#fff;border-color:var(--ink)}
.ps-title{font-size:.73rem;font-weight:500;margin-bottom:.25rem;line-height:1.3}
.ps-desc{font-size:.7rem;color:var(--ink-muted);line-height:1.5;max-height:0;overflow:hidden;transition:max-height .3s}
.ps-item.active .ps-desc{max-height:90px}

/* ── TIDSLINJE ─────────────────────────────────────────────────────────── */
.tl-track{position:relative;padding-left:52px}
.tl-spine{position:absolute;left:18px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--accent-light),var(--surface2))}
.tl-item{position:relative;margin-bottom:.75rem;cursor:pointer}
.tl-dot-wrap{position:absolute;left:-52px;top:16px;width:36px;display:flex;justify-content:flex-end}
.tl-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--border-md);background:var(--surface);display:flex;align-items:center;justify-content:center;transition:all .2s;font-size:.65rem;font-weight:600;color:var(--ink-muted);font-family:var(--display)}
.tl-item.open .tl-dot{background:var(--accent);border-color:var(--accent);color:#fff}
.tl-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1rem 1.2rem;transition:all .18s}
.tl-item:hover .tl-card,.tl-item.open .tl-card{border-color:var(--border-md);box-shadow:var(--shadow-sm)}
.tl-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.tl-period{font-size:.7rem;font-weight:600;color:var(--accent-mid);background:var(--accent-light);padding:.15rem .6rem;border-radius:20px;white-space:nowrap;flex-shrink:0}
.tl-meta{flex:1}
.tl-title{font-size:.92rem;font-weight:500;margin:.15rem 0 .1rem}
.tl-org{font-size:.78rem;color:var(--ink-muted)}
.tl-chev{color:var(--ink-faint);transition:transform .2s;margin-top:.15rem;font-size:1rem}
.tl-item.open .tl-chev{transform:rotate(180deg)}
.tl-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.tl-item.open .tl-body{max-height:320px}
.tl-content{border-top:1px solid var(--border);margin-top:.85rem;padding-top:.85rem}
.tl-content p{font-size:.82rem;color:var(--ink-muted);line-height:1.65}
.tl-content .tl-highlight{display:inline-flex;align-items:center;gap:.4rem;background:var(--teal-light);color:#115E59;font-size:.73rem;font-weight:500;padding:.25rem .7rem;border-radius:20px;margin-top:.6rem}

/* ── FRÅGA CV ──────────────────────────────────────────────────────────── */
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem;margin-bottom:1.5rem}
.faq-q{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1rem;cursor:pointer;transition:all .18s;text-align:left;font-family:inherit;font-size:.82rem;color:var(--ink-muted);line-height:1.4}
.faq-q:hover,.faq-q.active{background:var(--accent-light);border-color:var(--accent-mid);color:var(--ink)}
.faq-answer{background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-lg);padding:1.4rem;display:none;box-shadow:var(--shadow-sm)}
.faq-answer.open{display:block;animation:slideDown .2s ease}
.faq-answer h4{font-size:.85rem;font-weight:500;margin-bottom:.5rem;color:var(--accent)}
.faq-answer p{font-size:.85rem;color:var(--ink-muted);line-height:1.7}

/* ── FÖR ARBETSGIVARE ──────────────────────────────────────────────────── */
.emp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1.5rem}
.emp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.2rem;transition:all .18s}
.emp-card:hover{border-color:var(--border-md);box-shadow:var(--shadow-sm)}
.emp-icon{font-size:1.4rem;margin-bottom:.65rem}
.emp-card h4{font-size:.88rem;font-weight:500;margin-bottom:.3rem}
.emp-card p{font-size:.79rem;color:var(--ink-muted);line-height:1.55}
.emp-summary{background:linear-gradient(135deg,var(--accent-light),var(--surface2));border-radius:var(--r-lg);padding:1.3rem 1.5rem;margin-bottom:1.5rem;border:1px solid color-mix(in srgb,var(--accent-mid) 15%,transparent)}
.emp-summary p{font-size:.9rem;color:var(--ink);line-height:1.7;font-style:italic}

/* ── BAKOM CV ──────────────────────────────────────────────────────────── */
.modes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.2rem}
.mode-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.3rem;transition:all .18s}
.mode-card:hover{border-color:var(--border-md);box-shadow:var(--shadow-sm)}
.mode-emoji{font-size:1.6rem;margin-bottom:.65rem}
.mode-card h4{font-size:.9rem;font-weight:500;margin-bottom:.35rem}
.mode-card p{font-size:.8rem;color:var(--ink-muted);line-height:1.6}

/* ── CV KORTHET ────────────────────────────────────────────────────────── */
.cv-wrap{display:grid;grid-template-columns:1fr 1.7fr;gap:2.5rem;margin-top:1.5rem}
.cv-sec{margin-bottom:1.4rem}
.cv-sec h5{font-size:.67rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);font-weight:600;margin-bottom:.65rem;padding-bottom:.35rem;border-bottom:1px solid var(--border)}
.cv-sec p,.cv-sec li{font-size:.82rem;color:var(--ink-muted);line-height:1.7}
.skill-chip{display:inline-block;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:.15rem .55rem;font-size:.71rem;margin:.18rem .12rem 0 0;font-weight:500;color:var(--ink-muted)}
.job-item{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.job-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.job-period{font-size:.7rem;color:var(--accent-mid);font-weight:600;margin-bottom:.15rem}
.job-item h4{font-size:.88rem;font-weight:500;margin:.1rem 0}
.job-item p{font-size:.79rem;color:var(--ink-muted)}

/* ── KONTAKT ───────────────────────────────────────────────────────────── */
.contact-wrap{background:var(--ink);color:#fff;padding:5rem 1.5rem}
.contact-inner{max-width:980px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:center}
.contact-inner h2{font-family:var(--display);font-size:2rem;font-weight:400;margin-bottom:.75rem;line-height:1.2}
.contact-inner p{color:rgba(255,255,255,.65);font-size:.95rem;line-height:1.7;max-width:440px}
.contact-details{display:flex;flex-direction:column;gap:1rem;flex-shrink:0}
.contact-link{display:flex;align-items:center;gap:.75rem;font-size:.88rem;color:rgba(255,255,255,.75);text-decoration:none;transition:color .15s}
.contact-link:hover{color:#fff}
.contact-link svg{width:18px;height:18px;stroke:rgba(255,255,255,.4);flex-shrink:0}
.contact-btns{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.5rem}
.btn-white{background:#fff;color:var(--ink);border-color:#fff;font-size:.85rem}
.btn-white:hover{background:rgba(255,255,255,.9)}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.3);font-size:.85rem}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5)}

/* ════════════════════════════════════════════════════════════════════════
   ADAPTIV CHROME — banner, växel-panel, nudge, välkomst, quiz, flash
   ════════════════════════════════════════════════════════════════════════ */

/* lins-banner under nav */
.lens-banner{position:sticky;top:0;z-index:250;display:flex;align-items:center;gap:.7rem;padding:.55rem 1.5rem;background:var(--accent);color:#fff;font-size:.8rem;font-weight:500;transform:translateY(-100%);max-height:0;opacity:0;overflow:hidden;transition:transform .4s ease,max-height .4s ease,opacity .3s}
.lens-banner.show{transform:translateY(0);max-height:80px;opacity:1}
.lens-banner .lb-icon{font-size:1rem;flex-shrink:0}
.lens-banner .lb-text{flex:1;min-width:0}
.lens-banner .lb-x{background:rgba(255,255,255,.18);border:none;color:#fff;width:22px;height:22px;border-radius:50%;cursor:pointer;flex-shrink:0;font-size:.8rem;line-height:1}
.lens-banner .lb-x:hover{background:rgba(255,255,255,.3)}

/* växel-panel */
.lens-panel{position:fixed;top:0;right:0;bottom:0;width:340px;max-width:90vw;background:var(--surface);border-left:1px solid var(--border-md);box-shadow:var(--shadow-lg);z-index:700;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;color:var(--ink)}
.lens-panel.open{transform:translateX(0)}
.lp-head{padding:1.4rem 1.4rem 1rem;border-bottom:1px solid var(--border)}
.lp-head .lp-eyebrow{font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent-mid);font-weight:600;margin-bottom:.4rem}
.lp-head h3{font-family:var(--display);font-size:1.3rem;font-weight:400}
.lp-head p{font-size:.8rem;color:var(--ink-muted);margin-top:.3rem;line-height:1.5}
.lp-close{position:absolute;top:1rem;right:1rem;background:var(--surface2);border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1rem;color:var(--ink-muted)}
.lp-close:hover{background:var(--border-md)}
.lp-list{flex:1;overflow-y:auto;padding:1rem}
.lp-opt{display:flex;gap:.85rem;align-items:flex-start;width:100%;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:.9rem 1rem;margin-bottom:.6rem;cursor:pointer;transition:all .15s;font-family:inherit;color:inherit}
.lp-opt:hover{border-color:var(--accent-mid);background:var(--accent-light);transform:translateX(-2px)}
.lp-opt.active{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 25%,transparent)}
.lp-opt .lo-icon{width:34px;height:34px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;color:var(--accent)}
.lp-opt.active .lo-icon{background:var(--accent);color:#fff}
.lp-opt .lo-label{font-size:.9rem;font-weight:600;display:flex;align-items:center;gap:.4rem}
.lp-opt .lo-blurb{font-size:.76rem;color:var(--ink-muted);margin-top:.15rem;line-height:1.45}
.lo-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);background:var(--accent-light);padding:.05rem .4rem;border-radius:10px}
.lp-foot{padding:1rem 1.4rem;border-top:1px solid var(--border)}
.lp-quiz-btn{width:100%;padding:.7rem;border-radius:var(--r);background:var(--ink);color:#fff;border:none;cursor:pointer;font-family:inherit;font-size:.83rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:opacity .15s}
.lp-quiz-btn:hover{opacity:.88}
.lp-hint{font-size:.68rem;color:var(--ink-faint);text-align:center;margin-top:.7rem;line-height:1.4}
.lp-scrim{position:fixed;inset:0;background:rgba(0,0,0,.28);z-index:690;opacity:0;pointer-events:none;transition:opacity .3s}
.lp-scrim.show{opacity:1;pointer-events:auto}

/* nudge / välkomst-toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(140%);z-index:760;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:.9rem 1.1rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.9rem;max-width:min(460px,calc(100vw - 32px));transition:transform .45s cubic-bezier(.34,1.3,.64,1)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast .t-icon{font-size:1.25rem;flex-shrink:0}
.toast .t-text{font-size:.83rem;line-height:1.45;flex:1}
.toast .t-text b{font-weight:600}
.toast .t-btns{display:flex;gap:.4rem;flex-shrink:0}
.toast button{font-family:inherit;font-size:.76rem;font-weight:600;padding:.4rem .7rem;border-radius:var(--r);cursor:pointer;border:none;white-space:nowrap}
.toast .t-yes{background:#fff;color:var(--ink)}
.toast .t-yes:hover{background:rgba(255,255,255,.85)}
.toast .t-no{background:rgba(255,255,255,.14);color:#fff}
.toast .t-no:hover{background:rgba(255,255,255,.25)}

/* QUIZ modal */
.quiz-scrim{position:fixed;inset:0;background:rgba(10,10,15,.55);backdrop-filter:blur(4px);z-index:800;display:none;align-items:center;justify-content:center;padding:1.5rem}
.quiz-scrim.open{display:flex;animation:fadeIn .25s ease}
.quiz-modal{background:var(--surface);color:var(--ink);border-radius:var(--r-xl);width:520px;max-width:100%;max-height:90vh;overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column}
.quiz-head{padding:1.5rem 1.6rem 1.1rem;border-bottom:1px solid var(--border);position:relative}
.quiz-head .qh-eyebrow{font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent-mid);font-weight:600;margin-bottom:.45rem}
.quiz-head h3{font-family:var(--display);font-size:1.5rem;font-weight:400;line-height:1.2}
.quiz-progress{height:3px;background:var(--surface2);border-radius:2px;margin-top:1rem;overflow:hidden}
.quiz-progress span{display:block;height:100%;background:var(--accent);width:0;transition:width .35s ease}
.quiz-close{position:absolute;top:1rem;right:1.1rem;background:var(--surface2);border:none;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:1rem;color:var(--ink-muted)}
.quiz-body{padding:1.6rem;overflow-y:auto}
.quiz-q{font-size:1.05rem;font-weight:500;margin-bottom:1.1rem;line-height:1.4}
.quiz-opts{display:flex;flex-direction:column;gap:.6rem}
.quiz-opt{text-align:left;padding:.85rem 1rem;border:1px solid var(--border-md);border-radius:var(--r-lg);background:var(--surface);cursor:pointer;font-family:inherit;font-size:.9rem;color:var(--ink);transition:all .15s}
.quiz-opt:hover{border-color:var(--accent);background:var(--accent-light);transform:translateX(3px)}
.quiz-result{text-align:center;padding:.5rem 0}
.quiz-result .qr-iris{width:64px;height:64px;border-radius:50%;border:3px solid var(--accent);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--accent);animation:irisPop .5s cubic-bezier(.34,1.5,.6,1)}
.quiz-result h4{font-family:var(--display);font-size:1.6rem;font-weight:400;margin-bottom:.4rem}
.quiz-result p{font-size:.88rem;color:var(--ink-muted);margin-bottom:1.4rem;line-height:1.55}
.quiz-result .qr-actions{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}

/* iris-flash vid linsbyte */
.lens-flash{position:fixed;inset:0;z-index:780;pointer-events:none;background:radial-gradient(circle at center,transparent 0%,var(--accent) 75%);opacity:0;mix-blend-mode:multiply}
.lens-flash.fire{animation:iris .6s ease}

@keyframes iris{0%{opacity:0;transform:scale(1.3)}40%{opacity:.5}100%{opacity:0;transform:scale(1)}}
@keyframes irisPop{0%{transform:scale(0) rotate(-90deg);opacity:0}100%{transform:scale(1) rotate(0);opacity:1}}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}

/* ════════════════════════════════════════════════════════════════════════
   AI-CHATT  (oförändrad från originalet)
   ════════════════════════════════════════════════════════════════════════ */
.ai-float{position:fixed;bottom:24px;right:24px;z-index:400;display:flex;flex-direction:column;align-items:flex-end;gap:.65rem}
.ai-win{width:360px;max-width:calc(100vw - 40px);background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);display:none;flex-direction:column;overflow:hidden;max-height:510px}
.ai-win.open{display:flex;animation:slideUp .2s ease}
.ai-head{background:var(--ink);color:#fff;padding:.85rem 1.1rem;display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.ai-av{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-size:.9rem;font-weight:600}
.ai-info{flex:1;min-width:0}
.ai-info strong{font-size:.83rem;display:block}
.ai-info span{font-size:.7rem;opacity:.6;display:flex;align-items:center;gap:.35rem}
.ai-live{width:6px;height:6px;border-radius:50%;background:#4ADE80;animation:pulse 2s infinite}
.ai-close{background:rgba(255,255,255,.1);border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}
.ai-close:hover{background:rgba(255,255,255,.2)}
.ai-msgs{flex:1;overflow-y:auto;padding:.9rem;display:flex;flex-direction:column;gap:.6rem;min-height:180px}
.ai-msg{max-width:87%;padding:.6rem .85rem;border-radius:var(--r-lg);font-size:.82rem;line-height:1.6}
.ai-msg.bot{align-self:flex-start;background:var(--surface2);border-radius:var(--r-lg) var(--r-lg) var(--r-lg) 3px}
.ai-msg.user{align-self:flex-end;background:var(--ink);color:#fff;border-radius:var(--r-lg) var(--r-lg) 3px var(--r-lg)}
.ai-msg.hint{align-self:center;background:var(--amber-light);color:var(--amber);font-size:.75rem;text-align:center;border-radius:var(--r);padding:.5rem .8rem;max-width:94%}
.ai-chips{padding:.55rem .85rem;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.35rem;flex-shrink:0}
.ai-chip{font-size:.71rem;padding:.25rem .65rem;border-radius:20px;border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--ink-muted);transition:all .13s;white-space:nowrap;font-family:inherit}
.ai-chip:hover{border-color:var(--accent-mid);color:var(--accent);background:var(--accent-light)}
.ai-input-row{padding:.65rem .85rem;border-top:1px solid var(--border);display:flex;gap:.45rem;align-items:center;flex-shrink:0}
.ai-input-row input{flex:1;padding:.5rem .8rem;border:1px solid var(--border);border-radius:var(--r);font-family:inherit;font-size:.82rem;outline:none;transition:border-color .15s;background:var(--surface2);color:var(--ink)}
.ai-input-row input:focus{border-color:var(--accent-mid);background:var(--surface)}
.ai-send{background:var(--ink);color:#fff;border:none;width:34px;height:34px;border-radius:var(--r);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s}
.ai-send:hover{opacity:.85}
.ai-send:disabled{opacity:.35;cursor:default}
.ai-toggle-btn{width:50px;height:50px;border-radius:50%;background:var(--ink);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:all .18s;position:relative}
.ai-toggle-btn:hover{background:#3F3F46;transform:scale(1.06)}
.ai-badge{position:absolute;top:-2px;right:-2px;width:16px;height:16px;border-radius:50%;background:#4ADE80;border:2px solid var(--surface);font-size:.55rem;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}
.dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--ink-faint);margin:0 2px}
.dot:nth-child(1){animation:bounce .9s infinite 0s}
.dot:nth-child(2){animation:bounce .9s infinite .18s}
.dot:nth-child(3){animation:bounce .9s infinite .36s}

/* ════════════════════════════════════════════════════════════════════════
   BRÅTTOM — en skärm, allt det viktigaste
   ════════════════════════════════════════════════════════════════════════ */
#snabb{display:none}
.snabb-wrap{min-height:calc(100vh - 50px);display:flex;align-items:center;justify-content:center;padding:2.5rem 1.5rem}
.snabb-card{width:100%;max-width:820px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:2.4rem 2.6rem;position:relative;overflow:hidden}
.snabb-card::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--accent),var(--accent-mid))}
.snabb-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.6rem}
.snabb-name{font-family:var(--display);font-size:2.4rem;font-weight:400;line-height:1.05}
.snabb-role{font-size:.85rem;color:var(--accent);font-weight:600;margin-top:.35rem;letter-spacing:.02em}
.snabb-timer{display:flex;align-items:center;gap:.5rem;font-size:.72rem;font-weight:600;color:var(--ink-muted);background:var(--surface2);padding:.35rem .75rem;border-radius:20px;flex-shrink:0}
.snabb-ring{width:14px;height:14px;border-radius:50%;border:2px solid var(--accent);border-top-color:transparent;animation:spin 1.4s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.snabb-pitch{font-family:var(--display);font-size:1.45rem;font-weight:400;line-height:1.4;margin-bottom:1.8rem;color:var(--ink);text-wrap:pretty}
.snabb-pitch em{font-style:italic;color:var(--accent)}
.snabb-facts{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem;margin-bottom:1.8rem}
.snabb-fact{border-left:2px solid var(--accent);padding-left:.85rem}
.snabb-fact .sf-k{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);font-weight:600;margin-bottom:.2rem}
.snabb-fact .sf-v{font-size:.9rem;color:var(--ink);line-height:1.4}
.snabb-can{margin-bottom:1.9rem}
.snabb-can h5{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);font-weight:600;margin-bottom:.7rem}
.snabb-can ul{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem .9rem}
.snabb-can li{font-size:.88rem;color:var(--ink);display:flex;gap:.5rem;align-items:flex-start}
.snabb-can li::before{content:"✓";color:var(--accent);font-weight:700;flex-shrink:0}
.snabb-actions{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.snabb-more{font-size:.78rem;color:var(--ink-muted);margin-left:auto;cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.snabb-more:hover{color:var(--ink)}

/* ════════════════════════════════════════════════════════════════════════
   TERMINAL — hemligt läge (skriv "terminal")
   ════════════════════════════════════════════════════════════════════════ */
#terminal{position:fixed;inset:0;z-index:900;background:#05080A;color:#33FF77;font-family:var(--mono);font-size:14px;line-height:1.6;display:none;flex-direction:column;padding:0}
#terminal.open{display:flex}
#terminal::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(rgba(0,0,0,0) 50%,rgba(0,0,0,.18) 50%);background-size:100% 3px;z-index:2;opacity:.5}
.term-bar{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-bottom:1px solid rgba(51,255,119,.2);background:rgba(51,255,119,.05);flex-shrink:0;z-index:3}
.term-dot{width:11px;height:11px;border-radius:50%}
.term-dot.r{background:#FF5F56}.term-dot.y{background:#FFBD2E}.term-dot.g{background:#27C93F}
.term-title{margin-left:.5rem;font-size:.78rem;color:rgba(51,255,119,.65);letter-spacing:.05em;white-space:nowrap}
.term-exit{margin-left:auto;background:none;border:1px solid rgba(51,255,119,.3);color:#33FF77;font-family:inherit;font-size:.72rem;padding:.2rem .6rem;border-radius:4px;cursor:pointer}
.term-exit:hover{background:rgba(51,255,119,.12)}
.term-screen{flex:1;overflow-y:auto;padding:1.1rem 1.2rem;z-index:3;white-space:pre-wrap;word-break:break-word}
.term-screen a{color:#7DF3FF;text-decoration:underline}
.term-line{margin:0}
.term-amber{color:#FFD479}
.term-dim{color:rgba(51,255,119,.5)}
.term-head{color:#7DF3FF;font-weight:700}
.term-input-row{display:flex;align-items:center;gap:.5rem;padding:.4rem 1.2rem 1rem;z-index:3}
.term-prompt{color:#7DF3FF;flex-shrink:0}
.term-input{flex:1;background:none;border:none;outline:none;color:#33FF77;font-family:inherit;font-size:14px;caret-color:#33FF77}
.term-cursor{display:inline-block;width:8px;height:15px;background:#33FF77;animation:blink 1s steps(1) infinite;vertical-align:middle}
@keyframes blink{50%{opacity:0}}

/* ════════════════════════════════════════════════════════════════════════
   LINSTEMAN — body[data-lens]
   ════════════════════════════════════════════════════════════════════════ */

/* under själva linsbytet stängs alla transitions av så färgteman snäpper direkt
   (var()-baserade color/background-transitions kan annars frysa) */
body.lens-swapping *,body.lens-swapping{transition:none!important}

/* flödet är en flex-kolumn så lins-motorn kan ordna om via CSS order */
#flow{display:flex;flex-direction:column}
/* sektionssynlighet + ordning styrs av .lens-hide / order */
.lens-hide{display:none!important}

/* — REKRYTERAREN — strikt, kylig blå, tät — */
body[data-lens="rekryterare"]{
  --accent:#1E3A8A;--accent-light:#E0E7F4;--accent-mid:#2563EB;
  --paper:#F6F7F9;--surface2:#EEF1F5;
  --display:'DM Sans',system-ui,sans-serif;
}
body[data-lens="rekryterare"] .hero h1{letter-spacing:-.01em;font-weight:600}
body[data-lens="rekryterare"] .sec-title{font-weight:600;letter-spacing:-.01em}
body[data-lens="rekryterare"] .sec{padding-top:3.5rem;padding-bottom:3.5rem}

/* — KOLLEGAN — varm teal, generös — */
body[data-lens="kollega"]{
  --accent:#0F766E;--accent-light:#D6F3EE;--accent-mid:#14B8A6;
  --paper:#FBFAF7;--surface2:#F2F1EC;
}
body[data-lens="kollega"] .sec{padding-top:5.5rem;padding-bottom:5.5rem}

/* — BRÅTTOM — gult, stort — */
body[data-lens="brattom"]{
  --accent:#B45309;--accent-light:#FDF1DC;--accent-mid:#D97706;
  --paper:#FFFDF6;
}
body[data-lens="brattom"] nav .nav-name::after{content:" · bråttom-läge";color:var(--accent);font-weight:500}

/* — NÖRDEN — mörkt lab, neon, mono — */
body[data-lens="nord"]{
  --ink:#E6EDF3;--ink-muted:#9BA8B8;--ink-faint:#5C6B7D;
  --paper:#0E1116;--surface:#161B22;--surface2:#1C232D;
  --border:rgba(255,255,255,.09);--border-md:rgba(255,255,255,.16);
  --accent:#36E0C0;--accent-light:rgba(54,224,192,.14);--accent-mid:#5EEAD4;
  --blue:#36E0C0;--blue-light:rgba(54,224,192,.14);--blue-mid:#5EEAD4;
  --teal-light:rgba(125,243,168,.14);
  --shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 1px rgba(255,255,255,.05);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-lg:0 8px 32px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.06);
}
body[data-lens="nord"] .sec-label,
body[data-lens="nord"] .hero-eyebrow{font-family:var(--mono);text-transform:none}
body[data-lens="nord"] .tag{font-family:var(--mono);background:var(--accent-light);color:var(--accent-mid)}
body[data-lens="nord"] .contact-wrap{background:#080B0F}
body[data-lens="nord"] .portrait-box{background:linear-gradient(155deg,#13202b,#0c1620);}
body[data-lens="nord"] .portrait-monogram{color:var(--accent);opacity:.85}
body[data-lens="nord"] .cr-label.role{background:var(--accent-light);color:var(--accent-mid)}
body[data-lens="nord"] .cr-label.result{background:rgba(125,243,168,.14);color:#7DF3A8}
body[data-lens="nord"] .tl-content .tl-highlight{background:rgba(125,243,168,.12);color:#7DF3A8}

/* retro scanlines (terminal-kommandot `retro`) */
body.retro-scan::after{content:"";position:fixed;inset:0;z-index:999;pointer-events:none;background:linear-gradient(rgba(18,16,16,0) 50%,rgba(0,0,0,.12) 50%),linear-gradient(90deg,rgba(255,0,0,.03),rgba(0,255,0,.015),rgba(0,0,255,.03));background-size:100% 3px,3px 100%}

/* ── RESPONSIVE ────────────────────────────────────────────────────────── */
@media(max-width:760px){
  .hero-inner{grid-template-columns:1fr;gap:2rem}
  .hero-portrait{display:none}
  .hero h1{font-size:2.4rem}
  .proof-strip{grid-template-columns:1fr}
  .rel-grid,.path-grid,.faq-grid,.emp-grid,.modes-grid,.tools-grid{grid-template-columns:1fr}
  .case-grid,.comp-map,.evidence-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(3,1fr)}
  .comp-row,.cv-wrap{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr}
  .contact-details{display:none}
  .snabb-facts,.snabb-can ul{grid-template-columns:1fr}
  .snabb-card{padding:1.8rem 1.5rem}
  .snabb-name{font-size:1.9rem}
  nav a:not(.nav-dl){display:none}
  .lens-panel{width:100%}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.1ms!important}
}
