/* ============================================
   NOEKO – delad designsystem-CSS
   Mockup v1
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Calistoga&family=Sorts+Mill+Goudy:ital@0;1&display=swap');

:root{
  --creme:#EAE6DD;
  --creme-deep:#DDD7C8;
  --orange:#DA5B37;
  --orange-deep:#B14826;
  --yellow:#F0CD5F;
  --blue:#4277B0;
  --blue-deep:#345E8B;
  --ink:#2D2D2A;
  --ink-soft:#4A4A45;
  --paper:#FFFFFF;
  --char:#1A1A18;

  --serif-display:"Calistoga", Georgia, serif;
  --serif-body:"Sorts Mill Goudy", Georgia, serif;

  /* Delad sidomarginal (gutter) – matchar section-paddingen och
     krymper på samma brytpunkter. Används i inline-padding via
     var(--gutter) så att alla sektioner harmonierar på mobil/platta. */
  --gutter:80px;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--serif-body);
  color:var(--ink);
  background:var(--creme);
  line-height:1.55;
  font-size:19px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--orange);color:var(--paper);}

h1,h2,h3,h4{
  font-family:var(--serif-display);
  font-weight:400;
  line-height:1.05;
  letter-spacing:-0.01em;
}
h1{font-size:clamp(48px, 6.4vw, 96px);}
h2{font-size:clamp(36px, 4.8vw, 68px);}
h3{font-size:clamp(24px, 2.4vw, 32px);}
h4{font-size:24px;}
p{font-size:clamp(17px, 1.2vw, 21px);max-width:60ch;}
p + p{margin-top:1em;}
em.accent{color:var(--orange);font-style:normal;}

/* Signaturmarkör – ersätter em-dash i underrubriker */
.mark{
  display:inline-block;
  width:6px;
  height:1em;
  background:var(--orange);
  margin-right:.7em;
  vertical-align:-2px;
  transform:translateY(.05em);
}
.mark--white{background:var(--paper);}
.mark--yellow{background:var(--yellow);}
.mark--ink{background:var(--ink);}

/* ============================================
   SIGNATURGEST – frekvens/EQ-stapelgrafik
   Återkommer som sektionsdivider, marginalmarkör och dekoration.
   Baserad på decibel/spektrum-mätning – ren grafik, inga ord.
   ============================================ */
.eq-bars{
  display:flex;align-items:end;gap:3px;height:32px;
  --eq-color:var(--ink);
}
.eq-bars span{
  display:block;width:3px;background:var(--eq-color);
  border-radius:0;
}
.eq-bars span:nth-child(1){height:30%;}
.eq-bars span:nth-child(2){height:55%;}
.eq-bars span:nth-child(3){height:75%;}
.eq-bars span:nth-child(4){height:92%;}
.eq-bars span:nth-child(5){height:68%;}
.eq-bars span:nth-child(6){height:48%;}
.eq-bars span:nth-child(7){height:82%;}
.eq-bars span:nth-child(8){height:35%;}
.eq-bars span:nth-child(9){height:62%;}
.eq-bars span:nth-child(10){height:90%;}
.eq-bars span:nth-child(11){height:50%;}
.eq-bars span:nth-child(12){height:25%;}
.eq-bars span:nth-child(13){height:70%;}
.eq-bars span:nth-child(14){height:42%;}
.eq-bars span:nth-child(15){height:88%;}
.eq-bars span:nth-child(16){height:30%;}
.eq-bars--light{--eq-color:var(--creme);}
.eq-bars--orange{--eq-color:var(--orange);}
.eq-bars--yellow{--eq-color:var(--yellow);}
.eq-bars--lg{height:64px;gap:4px;}
.eq-bars--lg span{width:4px;}
.eq-bars--xl{height:120px;gap:6px;}
.eq-bars--xl span{width:5px;}

/* EQ-stämpel: signaturmarkör vid bildtexter.
   Liten EQ-stapelgrafik utan platta – ren grafik strax ovanför caption. */
.eq-stamp{
  position:absolute;
  z-index:2;
  display:flex;
  align-items:end;
  gap:3px;
  height:18px;
  pointer-events:none;
}
.eq-stamp--above-caption{
  left:32px;
  bottom:60px;
}
.eq-stamp--corner{
  right:24px;
  bottom:24px;
}
.eq-stamp span{
  display:block;
  width:2px;
  background:var(--yellow);
}
.eq-stamp--orange span{background:var(--orange);}
.eq-stamp--creme span{background:var(--creme);}
.eq-stamp span:nth-child(1){height:30%;}
.eq-stamp span:nth-child(2){height:65%;}
.eq-stamp span:nth-child(3){height:45%;}
.eq-stamp span:nth-child(4){height:90%;}
.eq-stamp span:nth-child(5){height:55%;}
.eq-stamp span:nth-child(6){height:75%;}
.eq-stamp span:nth-child(7){height:35%;}
.eq-stamp span:nth-child(8){height:60%;}

/* Sektionsdivider: tunn linje + mätlinjer + EQ */
.section-divider{
  display:flex;align-items:center;gap:24px;
  padding:32px 0;
  color:var(--ink-soft);
}
.section-divider__rule{flex:1;height:1px;background:currentColor;opacity:.25;}
.section-divider__label{
  font-family:'Courier New',monospace;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;
  opacity:.6;
}

/* Frekvens-skala (numerisk) – diskret marginalmarkör */
.freq-scale{
  display:flex;justify-content:space-between;align-items:end;
  height:24px;
  font-family:'Courier New',monospace;font-size:10px;
  color:var(--ink-soft);opacity:.55;
  letter-spacing:.05em;
  border-bottom:1px solid currentColor;
  padding-bottom:6px;
}
.freq-scale span{position:relative;}
.freq-scale span::after{
  content:"";position:absolute;left:50%;bottom:-7px;
  width:1px;height:6px;background:currentColor;
}

.eyebrow{
  font-size:14px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:24px;
  font-family:var(--serif-body);
  display:inline-flex;
  align-items:center;
}
.eyebrow--lower{
  text-transform:none;
  letter-spacing:.02em;
  font-style:italic;
  font-size:16px;
}

/* ---------- Knappar ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.6em;
  padding:.85em 1.4em .85em 1.1em;
  background:var(--ink);
  color:var(--creme);
  font-family:var(--serif-body);
  font-size:18px;
  border:none;
  cursor:pointer;
  border-left:6px solid var(--orange);
  transition:background .2s ease, transform .2s ease, color .2s ease, border-color .2s ease;
}
.btn:hover{background:var(--orange);color:var(--paper);border-left-color:var(--ink);transform:translateX(2px);}
.btn--ghost{background:transparent;color:var(--ink);border-left-color:var(--orange);}
.btn--ghost:hover{background:var(--ink);color:var(--creme);}
.btn--yellow{background:var(--yellow);color:var(--ink);border-left-color:var(--orange);}
.btn--yellow:hover{background:var(--orange);color:var(--paper);}
.btn--paper{background:var(--paper);color:var(--ink);border-left-color:var(--ink);}
.btn--paper:hover{background:var(--ink);color:var(--paper);border-left-color:var(--paper);}
.btn .arrow{font-size:1.1em;transition:transform .2s ease;}
.btn:hover .arrow{transform:translateX(4px);}

.sticky-cta{
  position:fixed;
  bottom:24px;
  right:24px;
  z-index:50;
  box-shadow:0 6px 22px rgba(0,0,0,.18);
}

/* ---------- Header ---------- */
header.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:30;
  padding:20px 40px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:var(--creme);
  border-bottom:1px solid rgba(0,0,0,.06);
  transition:background .2s ease;
}
.logo{
  display:inline-block;
  height:34px;
}
.logo img{height:100%;width:auto;}
nav.main-nav > ul{
  display:flex;
  gap:32px;
  list-style:none;
  align-items:center;
}
nav.main-nav a{
  font-size:17px;
  padding:8px 0;
  border-bottom:2px solid transparent;
  transition:border-color .2s ease;
  display:inline-block;
}
nav.main-nav > ul > li > a:hover,
nav.main-nav > ul > li > a.is-active{border-bottom-color:var(--orange);}

/* Dropdown – Lösningar */
nav.main-nav .has-dropdown{position:relative;}
nav.main-nav .has-dropdown > a::after{
  content:"▾";
  font-size:11px;
  margin-left:6px;
  display:inline-block;
  transition:transform .2s ease;
  vertical-align:1px;
}
nav.main-nav .has-dropdown:hover > a::after{transform:rotate(180deg);}
nav.main-nav .dropdown{
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%) translateY(-8px);
  background:var(--paper);
  min-width:280px;
  padding:16px 0;
  box-shadow:0 24px 60px rgba(0,0,0,.12);
  list-style:none;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  border-top:3px solid var(--orange);
}
nav.main-nav .has-dropdown:hover .dropdown,
nav.main-nav .has-dropdown:focus-within .dropdown{
  opacity:1;
  pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
nav.main-nav .dropdown li{display:block;}
nav.main-nav .dropdown a{
  display:block;
  padding:10px 24px;
  font-size:16px;
  border-bottom:none;
  white-space:nowrap;
  color:var(--ink);
  transition:background .15s ease, color .15s ease;
}
nav.main-nav .dropdown a:hover{background:var(--creme); color:var(--orange);}
nav.main-nav .dropdown li + li{border-top:1px solid rgba(0,0,0,.04);}

/* ---------- Mobilmeny (hamburgare + utfällbar panel) ----------
   Knappen och panelen byggs av nav.js. Dolda på desktop,
   aktiveras ≤1024px (se responsiv-blocket längre ned).            */
.nav-toggle{
  display:none;
  width:48px;height:48px;
  align-items:center;justify-content:center;
  background:transparent;border:none;cursor:pointer;
  color:var(--ink);
  -webkit-tap-highlight-color:transparent;
  position:relative;
}
.nav-toggle__bars{position:relative;display:block;width:26px;height:16px;}
.nav-toggle__bars span{
  position:absolute;left:0;right:0;height:2px;background:currentColor;
  transition:transform .3s ease, opacity .2s ease, top .3s ease;
}
.nav-toggle__bars span:nth-child(1){top:0;}
.nav-toggle__bars span:nth-child(2){top:7px;}
.nav-toggle__bars span:nth-child(3){top:14px;}
body.nav-open .nav-toggle__bars span:nth-child(1){top:7px;transform:rotate(45deg);}
body.nav-open .nav-toggle__bars span:nth-child(2){opacity:0;}
body.nav-open .nav-toggle__bars span:nth-child(3){top:7px;transform:rotate(-45deg);}

/* Håll headern (och därmed X-knappen) ovanför overlayn när öppen */
body.nav-open{overflow:hidden;}
body.nav-open header.site-header{z-index:60;}

.mobile-nav{
  position:fixed;inset:0;z-index:40;
  background:rgba(26,26,24,.45);
  opacity:0;transition:opacity .3s ease;
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
}
body.nav-open .mobile-nav{opacity:1;}
.mobile-nav__panel{
  position:absolute;top:0;right:0;
  width:min(420px,86vw);height:100%;
  background:var(--creme);
  box-shadow:-20px 0 60px rgba(0,0,0,.22);
  padding:96px 32px 48px;
  display:flex;flex-direction:column;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.4,0,.12,1);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
body.nav-open .mobile-nav__panel{transform:translateX(0);}
.mobile-nav__list{list-style:none;display:flex;flex-direction:column;}
.mobile-nav__list > li{border-bottom:1px solid rgba(45,45,42,.12);}
.mobile-nav__list > li > a,
.mobile-nav__group-toggle{
  display:flex;align-items:center;justify-content:space-between;width:100%;gap:16px;
  font-family:var(--serif-display);font-size:26px;line-height:1.1;color:var(--ink);
  background:transparent;border:none;cursor:pointer;text-align:left;
  padding:18px 2px;min-height:48px;
  transition:color .2s ease;
}
.mobile-nav__list > li > a:hover,
.mobile-nav__group-toggle:hover{color:var(--orange);}
.mobile-nav__list > li > a.is-active{color:var(--orange);}
.mobile-nav__chev{
  flex:none;width:11px;height:11px;
  border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg);transition:transform .3s ease;margin-right:4px;
}
.mobile-nav__group.is-open .mobile-nav__chev{transform:rotate(-135deg);}
.mobile-nav__sub{list-style:none;padding:0 2px 14px;}
.mobile-nav__sub li a{
  display:flex;align-items:center;min-height:48px;
  padding:9px 0 9px 18px;font-size:18px;color:var(--ink-soft);
  border-left:2px solid var(--creme-deep);
  transition:color .2s ease, border-color .2s ease;
}
.mobile-nav__sub li a:hover{color:var(--orange);border-left-color:var(--orange);}
.mobile-nav__cta{margin-top:36px;align-self:flex-start;font-size:18px;}

/* Body får topp-padding så fixed header inte täcker hero */
body{padding-top:74px;}

/* ---------- Section base ---------- */
section{padding:120px 80px;}
.container{max-width:1320px;margin:0 auto;}
.lede{font-size:clamp(22px, 1.8vw, 28px);line-height:1.45;font-style:italic;color:var(--ink-soft);max-width:32ch;}

/* Anfang – återanvänds i alla case-longforms och intro-paragrafer */
.dropcap::first-letter{
  font-family:var(--serif-display);
  float:left;
  font-size:6.4em;
  line-height:.82;
  padding:6px 14px 0 0;
  color:var(--orange);
  font-weight:400;
}
/* Mörka bakgrunder – byt anfang-färg så den syns mot orange/ink/blå */
.dropcap--yellow::first-letter{color:var(--ink);}
.dropcap--paper::first-letter{color:var(--paper);}

/* ---------- Hero (homepage variant – split) ---------- */
.hero-split{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  min-height:100vh;
  background:var(--creme);
}
.hero-split__copy{
  padding:80px 80px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-split__sub{
  font-size:clamp(20px, 1.6vw, 26px);
  font-style:italic;
  max-width:34ch;
  margin-bottom:48px;
  color:var(--ink-soft);
  margin-top:28px;
}
.hero-split__ctas{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}
.hero-split__media{
  position:relative;
  overflow:hidden;
  background:#000;
}
.hero-split__media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-split__caption{
  position:absolute;
  left:32px;
  bottom:32px;
  color:var(--creme);
  font-size:13px;
  font-style:italic;
  text-shadow:0 1px 6px rgba(0,0,0,.6);
}

/* ---------- Hero (subpage variant – fullbleed med textblock) ---------- */
.hero-fullbleed{
  position:relative;
  min-height:80vh;
  background:#000;
  color:var(--creme);
  display:flex;
  align-items:flex-end;
  padding:0;
  overflow:hidden;
}
.hero-fullbleed__media{
  position:absolute;inset:0;
}
.hero-fullbleed__media img{
  width:100%;height:100%;object-fit:cover;
  opacity:.7;
}
.hero-fullbleed__overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.3) 50%, rgba(0,0,0,.5) 100%);
}
.hero-fullbleed__copy{
  position:relative;
  padding:60px 80px 100px;
  max-width:900px;
}
.hero-fullbleed h1{color:var(--paper);margin-bottom:24px;}
.hero-fullbleed__sub{
  font-size:clamp(20px, 1.5vw, 24px);
  font-style:italic;
  color:var(--creme);
  max-width:42ch;
  margin-bottom:40px;
  opacity:.95;
}
.hero-fullbleed .eyebrow{color:var(--yellow);}

/* ---------- Hero (subpage variant – split copy/photo asymmetric) ---------- */
.hero-asym{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:90vh;
  background:var(--creme);
}
.hero-asym__copy{
  padding:80px 64px 80px 80px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-asym__media{
  overflow:hidden;
  background:#000;
}
.hero-asym__media img{width:100%;height:100%;object-fit:cover;}
.hero-asym__sub{
  font-size:clamp(20px, 1.5vw, 24px);
  font-style:italic;
  max-width:36ch;
  margin:24px 0 40px;
  color:var(--ink-soft);
}

/* ---------- Manifest section (homepage) ---------- */
.manifest{background:var(--creme);position:relative;overflow:hidden;}
.manifest__grid{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:96px;
  align-items:stretch;
}
.manifest__head{display:flex;flex-direction:column;gap:32px;}
.manifest__head .eyebrow{margin-bottom:0;}
.manifest__media{margin-top:24px;flex:1;display:flex;}
.manifest__img-slot{
  width:100%;flex:1;min-height:480px;
  background:repeating-linear-gradient(135deg,var(--creme-deep) 0 12px,#cfc8b6 12px 13px);
  display:flex;align-items:end;padding:20px;
  color:var(--ink-soft);
}
.manifest__img-slot span{
  font-family:'Courier New',monospace;font-size:12px;
  background:var(--paper);padding:6px 10px;line-height:1.3;
}
.manifest__body{padding-top:24px;border-top:1px solid rgba(45,45,42,0.15);display:flex;flex-direction:column;justify-content:flex-start;}
.manifest__body p{margin-bottom:1.2em;}
.manifest__punch{
  font-family:var(--serif-display);
  font-size:clamp(28px, 2.4vw, 38px) !important;
  color:var(--ink);
  line-height:1.2;
  margin-top:1.5em !important;
  max-width:24ch !important;
}

/* ---------- Cables fullbleed (homepage signature-block) ---------- */
.cables{
  padding:0;
  position:relative;
  height:90vh;
  background:#000;
  overflow:hidden;
}
.cables img{
  width:100%;height:100%;
  object-fit:cover;
  opacity:.55;
  filter:contrast(1.1);
}
.cables__quote{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 60px;
  text-align:center;
  color:var(--creme);
}
.cables__quote h2{
  font-size:clamp(40px, 5.2vw, 84px);
  max-width:18ch;
  line-height:1.05;
}
.cables__quote span{color:var(--yellow);}

/* ---------- Lösningar (homepage) ---------- */
.solutions{background:var(--creme);}
.solutions__intro{
  margin-bottom:80px;
  display:grid;
  grid-template-columns:1fr 1.5fr;
  gap:80px;
  align-items:end;
}

.solution-feature{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:0;
  margin-bottom:24px;
  align-items:stretch;
}
.solution-feature__media{
  aspect-ratio:5/4;
  overflow:hidden;
}
.solution-feature__media img{
  width:100%;height:100%;object-fit:cover;
}
.solution-feature__copy{
  background:var(--orange);
  color:var(--creme);
  padding:80px 64px;
  display:flex;flex-direction:column;justify-content:center;
}
.solution-feature__copy h3{
  color:var(--paper);
  margin-bottom:16px;
  font-size:clamp(28px, 3.4vw, 48px);
}
.solution-feature__sub{
  font-size:18px;
  margin-bottom:28px;
  opacity:.92;
  max-width:36ch;
}
.solution-feature__copy .eyebrow{color:var(--paper);opacity:.85;}

.solution-feature--reverse{grid-template-columns:.9fr 1.1fr;}
.solution-feature--reverse .solution-feature__media{order:2;}
.solution-feature--yellow .solution-feature__copy{background:var(--yellow);color:var(--ink);}
.solution-feature--yellow .solution-feature__copy h3{color:var(--ink);}
.solution-feature--yellow .eyebrow{color:var(--ink);opacity:.7;}
.solution-feature--blue .solution-feature__copy{background:var(--blue);color:var(--paper);}
.solution-feature--blue .solution-feature__copy h3{color:var(--paper);}
.solution-feature--blue .eyebrow{color:var(--yellow);}

/* Mindre lösningar i staggered grid */
.solutions-small{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:24px;
  margin-top:24px;
}
.solution-card{
  position:relative;
  overflow:hidden;
  aspect-ratio:4/5;
  background:var(--ink);
  color:var(--creme);
}
.solution-card img{
  width:100%;height:100%;object-fit:cover;
  opacity:.85;
  transition:opacity .3s ease, transform .6s ease;
}
.solution-card:hover img{opacity:1;transform:scale(1.04);}
.solution-card__overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.2) 50%, transparent 100%);
  padding:32px;
  display:flex;flex-direction:column;justify-content:flex-end;
  pointer-events:none;
}
.solution-card h4{
  font-family:var(--serif-display);
  font-size:24px;
  margin-bottom:6px;
  color:var(--paper);
}
.solution-card p{
  font-size:14px;
  color:var(--creme);
  opacity:.9;
  font-style:italic;
}
.solutions-small .solution-card{aspect-ratio:4/3;}
.solutions-small .solution-card:nth-child(1){grid-column:span 6;}
.solutions-small .solution-card:nth-child(2){grid-column:span 6;}
.solutions-small .solution-card:nth-child(3){grid-column:span 4;}
.solutions-small .solution-card:nth-child(4){grid-column:span 4;}
.solutions-small .solution-card:nth-child(5){grid-column:span 4;}

/* ---------- Visual pause (homepage – andning mellan manifest och solutions) ---------- */
.visual-pause{padding:0;background:var(--ink);}
.visual-pause__media{
  position:relative;
  width:100%;
  aspect-ratio:21/9;
  background:repeating-linear-gradient(135deg,#222 0 18px,#1a1a18 18px 19px);
  overflow:hidden;
}
.visual-pause__slot{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:48px;
}
.visual-pause__hint{
  font-family:'Courier New',monospace;font-size:13px;
  color:var(--creme);opacity:.55;
  background:rgba(0,0,0,0.4);padding:10px 14px;
  max-width:42ch;text-align:center;line-height:1.5;
}
.visual-pause__caption{
  position:absolute;left:48px;bottom:48px;right:48px;
  display:flex;align-items:end;justify-content:space-between;gap:32px;
  pointer-events:none;
}
.visual-pause__caption p{
  font-family:var(--serif-display);
  font-size:clamp(24px,2vw,34px);
  line-height:1.15;color:var(--paper);
  max-width:24ch;margin:0;
}

/* ---------- Voice cards (editorial testimonials – asymmetrisk) ----------
   Layout:
   ┌─────────────┬─────────────┬───────────────┐
   │  citat A    │  citat B    │  EVA LISA     │
   │  (creme)    │  (ink)      │  HOLTZ —      │
   │             │             │  bild + citat │
   └─────────────┴─────────────┴───────────────┘
   Tre olika sektionsfärger (creme-deep, ink, foto) – ingen
   upprepad mall. Asymmetri via grid 1fr 1fr 1.3fr.        */

.voices__head--editorial{
  display:grid;grid-template-columns:1fr auto;align-items:end;
  gap:48px;margin-bottom:64px;
  border-bottom:1px solid rgba(45,45,42,.18);padding-bottom:40px;
}
.voices__head--editorial h2{margin:0;max-width:14ch;}
.voices__head--editorial .voices__head-meta{
  font-family:'Courier New',monospace;font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);
  text-align:right;line-height:1.6;
}
.voices__head--editorial .voices__head-meta strong{
  display:block;color:var(--ink);font-weight:400;font-size:13px;
  font-family:var(--serif-body);letter-spacing:.05em;text-transform:none;
}

.voice-cards{
  list-style:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:0;
  border-top:1px solid rgba(45,45,42,.18);
}
.voice-card{
  position:relative;
  display:flex;flex-direction:column;
  padding:48px 40px 40px;
  border-right:1px solid rgba(45,45,42,.18);
  min-height:560px;
}
.voice-card:last-child{border-right:none;}

/* — Variant 1: creme-deep, klassisk citat — */
.voice-card--creme{background:var(--creme-deep);color:var(--ink);}

/* — Variant 2: ink, inverterad — */
.voice-card--ink{background:var(--ink);color:var(--creme);border-right-color:rgba(234,230,221,.15);}
.voice-card--ink .voice-card__attrib-name,
.voice-card--ink .voice-card__quote{color:var(--creme);}
.voice-card--ink .voice-card__attrib-role,
.voice-card--ink .voice-card__num{color:rgba(234,230,221,.6);}
.voice-card--ink .voice-card__cta{color:var(--yellow);}
.voice-card--ink .voice-card__cta:hover{color:var(--paper);}
.voice-card--ink .voice-card__cta::after{background:var(--yellow);}

/* — Variant 3: foto + citat (bredare) — */
.voice-card--feature{padding:0;background:var(--ink);color:var(--creme);overflow:hidden;}
/* Creme-variant kombinerad med foto (för att card 01 ska behålla ljus bakgrund med bild) */
.voice-card--feature.voice-card--creme{background:var(--creme-deep);color:var(--ink);}
.voice-card--feature.voice-card--creme .voice-card__quote,
.voice-card--feature.voice-card--creme .voice-card__attrib-name{color:var(--ink);}
.voice-card--feature.voice-card--creme .voice-card__attrib-role,
.voice-card--feature.voice-card--creme .voice-card__num{color:var(--ink-soft);}
.voice-card--feature.voice-card--creme .voice-card__cta{color:var(--ink);}
.voice-card--feature.voice-card--creme .voice-card__cta::after{background:var(--orange);}
.voice-card--feature.voice-card--creme .voice-card__feature-tag{background:var(--ink);color:var(--creme);}
.voice-card--feature .voice-card__media{
  position:relative;height:280px;overflow:hidden;
}
.voice-card--feature .voice-card__media img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.95);
}
.voice-card--feature .voice-card__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(45,45,42,0) 55%,rgba(45,45,42,.55) 100%);
  pointer-events:none;
}
.voice-card--feature .voice-card__feature-tag{
  position:absolute;top:24px;left:24px;
  font-family:'Courier New',monospace;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--paper);
  background:var(--orange);padding:6px 10px;
}
.voice-card--feature .voice-card__body{
  padding:36px 40px 40px;display:flex;flex-direction:column;flex:1;
}
.voice-card--feature .voice-card__quote{color:var(--creme);}
.voice-card--feature .voice-card__attrib-name{color:var(--creme);}
.voice-card--feature .voice-card__attrib-role{color:rgba(234,230,221,.65);}
.voice-card--feature .voice-card__num{color:rgba(234,230,221,.45);}
.voice-card--feature .voice-card__cta{color:var(--yellow);}
.voice-card--feature .voice-card__cta::after{background:var(--yellow);}

/* — Inre delar (delade) — */
.voice-card__num{
  font-family:'Courier New',monospace;font-size:11px;letter-spacing:.18em;
  color:var(--ink-soft);margin-bottom:32px;
}
.voice-card__quote{
  font-family:var(--serif-display);font-style:italic;
  font-size:clamp(20px,1.6vw,26px);line-height:1.3;
  letter-spacing:-0.005em;margin:0;color:var(--ink);
  /* Hängande citationstecken */
  text-indent:-0.4em;
}
.voice-card__attrib{
  margin-top:auto;padding-top:32px;
  display:flex;flex-direction:column;gap:2px;
  font-style:normal;
}
.voice-card__attrib-name{
  font-family:var(--serif-body);font-size:15px;color:var(--ink);
  letter-spacing:.01em;
}
.voice-card__attrib-role{
  font-family:var(--serif-body);font-style:italic;font-size:14px;
  color:var(--ink-soft);
}
.voice-card__cta{
  margin-top:24px;align-self:start;
  font-family:var(--serif-body);font-size:14px;letter-spacing:.04em;
  color:var(--orange);position:relative;padding:0 0 4px;
  display:inline-flex;gap:.5em;align-items:center;
}
.voice-card__cta::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--orange);transform-origin:left;
  transition:transform .3s ease;
}
.voice-card__cta:hover::after{transform:scaleX(1.05);}
.voice-card__cta .arrow{transition:transform .2s ease;}
.voice-card__cta:hover .arrow{transform:translateX(4px);}

@media (max-width:1024px){
  .voice-cards{grid-template-columns:1fr;}
  .voice-card{min-height:0;border-right:none;border-bottom:1px solid rgba(45,45,42,.18);}
  .voice-card--ink{border-bottom-color:rgba(234,230,221,.15);}
  .voices__head--editorial{grid-template-columns:1fr;}
  .voices__head--editorial .voices__head-meta{text-align:left;}
}

/* ---------- Voices (homepage – sammanslagen testimonials + utvalt case) ---------- */
.voices{background:var(--creme-deep);}
.voices__head{margin-bottom:64px;max-width:32ch;}
.voices__head h2{margin-top:16px;}

.voices__quotes{
  list-style:none;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:48px;
  border-top:1px solid rgba(45,45,42,0.18);
  padding-top:48px;
}
.voices__quotes li{
  display:flex;flex-direction:column;gap:20px;
  padding-right:24px;
  border-left:none;
  position:relative;
}
.voices__quotes li::before{
  content:"";position:absolute;left:-24px;top:6px;
  width:2px;height:36px;background:var(--orange);
}
.voices__quotes blockquote{
  font-family:var(--serif-display);
  font-size:clamp(20px,1.5vw,24px);
  line-height:1.25;color:var(--ink);
  letter-spacing:-0.005em;margin:0;
}
.voices__quotes cite{
  font-style:normal;font-size:14px;
  color:var(--ink-soft);line-height:1.4;
  display:flex;flex-direction:column;
}
.voices__quotes cite strong{font-weight:400;color:var(--ink);font-size:15px;display:block;}

.voices__case{
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:64px;align-items:center;
  margin-top:24px;
}
.voices__case-media{aspect-ratio:5/4;overflow:hidden;background:var(--creme);}
.voices__case-media img{width:100%;height:100%;object-fit:cover;}
.voices__case-quote{
  font-family:var(--serif-display);
  font-size:clamp(32px,3vw,48px);
  line-height:1.15;color:var(--ink);
  margin:24px 0;letter-spacing:-0.01em;
}
.voices__case-attrib{margin-bottom:32px;color:var(--ink-soft);}
.voices__case-attrib strong{color:var(--ink);font-weight:400;}

.voices__logos{
  margin-top:96px;padding-top:32px;
  border-top:1px solid rgba(45,45,42,0.18);
  display:flex;align-items:center;justify-content:space-between;
  gap:48px;flex-wrap:wrap;
}
.voices__logos > span{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);font-family:'Courier New',monospace;
}
.voices__logos ul{
  list-style:none;display:flex;gap:48px;flex-wrap:wrap;align-items:center;
  font-family:var(--serif-display);font-size:18px;color:var(--ink-soft);opacity:.75;
}
/* ---------- Process (varianter) ---------- */
.process{
  background:var(--blue);
  color:var(--creme);
}
.process__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.process h2{color:var(--paper);margin-bottom:32px;font-size:clamp(36px, 4vw, 56px);}
.process p{color:var(--creme);opacity:.95;}
.process__media{
  background:var(--paper);
  padding:32px;
  box-shadow:0 30px 80px rgba(0,0,0,.25);
}
.process__media img{width:100%;}
.process__media-caption{
  margin-top:16px;
  font-size:14px;
  font-style:italic;
  color:var(--ink-soft);
  text-align:center;
}
.process .eyebrow{color:var(--yellow);}
.process .btn--yellow{background:var(--yellow);color:var(--ink);border-left-color:var(--orange);}

/* Processsteg-lista */
.steps{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:48px 64px;
  margin-top:60px;
}
.step{
  position:relative;
  padding-left:64px;
}
.step__num{
  position:absolute;
  left:0;
  top:6px;
  width:48px;
  height:48px;
  background:var(--orange);
  color:var(--paper);
  font-family:var(--serif-display);
  font-size:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:0;
}
.step h3{margin-bottom:10px;font-size:24px;}
.step p{font-size:17px;color:var(--ink-soft);}

/* ---------- Case ---------- */
.case-feature{background:var(--creme);}
.case-feature__inner{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:80px;
  align-items:center;
}
.case-feature__media{
  aspect-ratio:4/5;
  overflow:hidden;
}
.case-feature__media img{width:100%;height:100%;object-fit:cover;}
.case-feature blockquote{
  font-family:var(--serif-display);
  font-size:clamp(28px, 2.8vw, 44px);
  line-height:1.18;
  color:var(--ink);
  margin-bottom:32px;
  max-width:22ch;
}
.case-feature__attrib{
  font-size:16px;
  font-style:italic;
  color:var(--ink-soft);
  margin-bottom:32px;
}
.case-feature__attrib strong{font-weight:400;font-style:normal;color:var(--ink);}

/* Case-grid (case-arkivsida) */
.case-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:32px;
}
.case-tile{
  display:block;
  text-decoration:none;
  color:inherit;
}
.case-tile:nth-child(1){grid-column:span 8;}
.case-tile:nth-child(2){grid-column:span 4;}
.case-tile:nth-child(3){grid-column:span 4;}
.case-tile:nth-child(4){grid-column:span 4;}
.case-tile:nth-child(5){grid-column:span 4;}
.case-tile__media{
  aspect-ratio:4/3;
  overflow:hidden;
  margin-bottom:20px;
}
.case-tile__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.case-tile:hover .case-tile__media img{transform:scale(1.04);}
.case-tile h3{margin-bottom:8px;}
.case-tile__meta{font-size:14px;color:var(--ink-soft);font-style:italic;}

/* ---------- Final CTA ---------- */
.final-cta{
  background:var(--ink);
  color:var(--creme);
  text-align:center;
  padding:160px 40px;
}
.final-cta h2{
  color:var(--paper);
  margin-bottom:24px;
  max-width:18ch;
  margin-left:auto;margin-right:auto;
}
.final-cta p{
  color:var(--creme);opacity:.85;
  max-width:48ch;
  margin:0 auto 40px;
  font-size:20px;
}
.final-cta .btn{background:var(--orange);border-left-color:var(--yellow);font-size:20px;padding:1.1em 1.8em;}
.final-cta .btn:hover{background:var(--yellow);color:var(--ink);border-left-color:var(--orange);}

/* ---------- Footer ---------- */
footer.site-footer{
  background:var(--char);
  color:var(--creme);
  padding:80px 80px 40px;
  font-size:15px;
}
.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:60px;
}
.site-footer h5{
  font-family:var(--serif-display);
  font-size:18px;
  color:var(--paper);
  margin-bottom:20px;
  font-weight:400;
}
.site-footer ul{list-style:none;}
.site-footer li{margin-bottom:8px;opacity:.78;}
.site-footer li a:hover{opacity:1;color:var(--orange);}
.footer__brand .logo{height:34px;margin-bottom:18px;}
.footer__brand .logo img{filter:brightness(0) invert(1) saturate(0);}
.footer__brand p{opacity:.7;font-size:15px;max-width:32ch;}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;
  display:flex;justify-content:space-between;
  font-size:13px;opacity:.5;
}

/* ---------- Long-form text (för cases, om, inspiration) ---------- */
.longform{
  max-width:720px;
  margin:0 auto;
  padding:80px 32px 40px;
}
.longform h2{
  font-size:clamp(28px, 2.4vw, 36px);
  margin:48px 0 16px;
}
.longform h3{
  font-size:22px;
  margin:36px 0 14px;
  color:var(--ink);
  font-family:var(--serif-display);
  font-weight:400;
  line-height:1.2;
}
.longform p{
  font-size:21px;
  line-height:1.6;
  margin-bottom:1.2em;
  max-width:none;
}
.longform p.lede{
  font-size:24px;
  font-style:italic;
  color:var(--ink-soft);
  margin:0 0 1.5em;
  max-width:none;
}
.longform blockquote{
  font-family:var(--serif-display);
  font-size:30px;
  line-height:1.2;
  border-left:6px solid var(--orange);
  padding:8px 0 8px 32px;
  margin:48px 0;
  max-width:none;
}
.longform ul{
  margin-bottom:1.2em;
  padding-left:24px;
}
.longform ul li{
  font-size:21px;
  line-height:1.55;
  margin-bottom:.5em;
}
.longform img.figure{
  margin:48px -80px;
  width:calc(100% + 160px);
  max-width:none;
}
.longform .figure-caption{
  font-size:14px;
  color:var(--ink-soft);
  font-style:italic;
  text-align:center;
  margin-top:-32px;
  margin-bottom:48px;
}
.article-meta{
  display:flex;gap:24px;
  font-size:14px;
  color:var(--ink-soft);
  margin-bottom:32px;
  font-style:italic;
}

/* ---------- Pull quote ---------- */
.pullquote{
  background:var(--yellow);
  padding:120px 80px;
  text-align:center;
}
.pullquote blockquote{
  font-family:var(--serif-display);
  font-size:clamp(36px, 4vw, 56px);
  line-height:1.15;
  max-width:24ch;
  margin:0 auto 24px;
}
.pullquote cite{
  font-style:italic;
  font-size:16px;
  color:var(--ink-soft);
}

/* ---------- Two-col split (för text + bild) ---------- */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.split--reverse .split__media{order:2;}
.split__media{
  aspect-ratio:4/5;overflow:hidden;
}
.split__media img{width:100%;height:100%;object-fit:cover;}
.split--landscape .split__media{aspect-ratio:4/3;}
.split--full-media .split__media{aspect-ratio:auto;height:100%;}

/* ---------- Inspiration grid ---------- */
.articles-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:48px 32px;
}
.article-tile{
  display:block;
  text-decoration:none;
  color:inherit;
}
.article-tile__media{
  aspect-ratio:16/10;
  overflow:hidden;
  margin-bottom:20px;
}
.article-tile__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.article-tile:hover .article-tile__media img{transform:scale(1.04);}
.article-tile h3{margin-bottom:8px;font-size:28px;}
.article-tile p{font-size:16px;color:var(--ink-soft);font-style:italic;}

/* ---------- Videoplatshållare ---------- */
.video-card{
  position:relative;
  display:block;
  overflow:hidden;
  background:#000;
  cursor:pointer;
  text-decoration:none;
  color:inherit;
}
.video-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.85;
  transition:opacity .3s ease, transform .6s ease;
}
.video-card:hover img{opacity:1; transform:scale(1.02);}
.video-card__play{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}
.video-card__play::before{
  content:"";
  width:84px;
  height:84px;
  border-radius:50%;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(4px);
  border:2px solid rgba(255,255,255,.85);
  transition:background .25s ease, transform .25s ease;
}
.video-card__play::after{
  content:"";
  position:absolute;
  width:0;
  height:0;
  border-style:solid;
  border-width:14px 0 14px 22px;
  border-color:transparent transparent transparent #fff;
  margin-left:6px;
}
.video-card:hover .video-card__play::before{background:var(--orange); transform:scale(1.06);}
.video-card__caption{
  position:absolute;
  left:24px;
  bottom:24px;
  right:24px;
  color:var(--paper);
  font-family:var(--serif-display);
  font-size:22px;
  text-shadow:0 1px 8px rgba(0,0,0,.6);
  z-index:2;
}
.video-card__chip{
  position:absolute;
  top:16px;
  right:16px;
  background:var(--orange);
  color:var(--paper);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:6px 12px;
  z-index:2;
}

/* ---------- Visste du? callout ---------- */
.tip-card{
  background:var(--orange);
  color:var(--creme);
  padding:32px;
  align-self:start;
}
.tip-card h4{
  font-family:var(--serif-display);
  font-size:24px;
  margin-bottom:14px;
  color:var(--paper);
}
.tip-card p{
  font-size:16px;
  color:var(--creme);
  opacity:.95;
}

/* ---------- Komponentkort ---------- */
.component{display:flex; flex-direction:column;}
.component__media{
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--paper);
  margin-bottom:18px;
}
.component__media img{
  width:100%; height:100%; object-fit:cover;
}
.component h4{
  font-family:var(--serif-display);
  font-size:24px;
  margin-bottom:8px;
}
.component p{font-size:15px; line-height:1.5;}

/* ---------- Skärmstorleksgrafik ---------- */
.screensize-grid{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:32px;
  margin-top:48px;
  flex-wrap:wrap;
}
.screensize-item{
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.screensize-item__svg{
  height:130px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  margin-bottom:24px;
}
.screensize-item__svg svg{
  height:130px;
  width:auto;
  max-width:100%;
  display:block;
}
.screensize-item h4{
  font-family:var(--serif-display);
  font-size:22px;
  margin-bottom:4px;
}
.screensize-item__inches{
  font-family:var(--serif-display);
  font-size:32px;
  color:var(--orange);
}

/* ---------- FAQ accordion ---------- */
.faq{}
.faq details{
  border-top:1px solid rgba(0,0,0,.15);
  padding:20px 0;
}
.faq details:last-child{border-bottom:1px solid rgba(0,0,0,.15);}
.faq summary{
  font-family:var(--serif-display);
  font-size:22px;
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-right:8px;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{
  content:"+";
  font-size:28px;
  font-weight:300;
  transition:transform .2s ease;
}
.faq details[open] summary::after{content:"−";}
.faq details > div{
  padding:16px 0 0;
  font-size:17px;
  line-height:1.6;
  max-width:64ch;
}

/* ---------- Service FAQ (badhus-style) ---------- */
.svc-faq{background:var(--creme);padding:140px 80px;}
.svc-faq__inner{max-width:1100px;margin:0 auto;}
.svc-faq__head{
  display:grid;grid-template-columns:1fr 1.4fr;gap:64px;
  margin-bottom:64px;align-items:end;
}
.svc-faq__head h2{max-width:16ch;}
.svc-faq__head p.lede{margin:0;}
@media (max-width:1024px){
  .svc-faq{padding:80px 40px;}
  .svc-faq__head{grid-template-columns:1fr;gap:24px;}
}

/* ---------- Jonas puff (delad mellan tjänstesidor) ---------- */
.svc-jonas{background:var(--orange);color:var(--creme);padding:0;}
.svc-jonas__inner{display:grid;grid-template-columns:1fr 1.2fr;align-items:center;}
.svc-jonas__photo-wrap{padding:80px 40px 80px 80px;}
.svc-jonas__photo{aspect-ratio:3/4;overflow:hidden;max-width:420px;margin-left:auto;}
.svc-jonas__photo img{width:100%;height:100%;object-fit:cover;}
.svc-jonas__body{padding:80px 80px 80px 40px;}
.svc-jonas__body h2{color:var(--paper);margin-bottom:32px;max-width:18ch;}
.svc-jonas__body .eyebrow{color:var(--yellow);}
.svc-jonas__role{opacity:.95;font-size:21px;margin-bottom:8px;}
.svc-jonas__contact{opacity:.92;}
.svc-jonas__contact a{border-bottom:1px solid var(--yellow);color:var(--paper);}
@media (max-width:1024px){
  .svc-jonas__inner{grid-template-columns:1fr;}
  .svc-jonas__photo-wrap{padding:60px 32px 0;}
  .svc-jonas__photo{margin:0 auto;max-width:320px;}
  .svc-jonas__body{padding:48px 32px 80px;}
}

/* ---------- Mockup-banner ---------- */
.mockup-note{
  background:var(--ink);color:var(--yellow);
  padding:8px 24px;font-size:13px;
  text-align:center;
  font-style:italic;
  letter-spacing:.04em;
}

/* ============================================
   RESPONSIVT — tre nivåer
   Desktop : > 1024px  (full layout, full navigering)
   Platta  : ≤ 1024px  (hamburgermeny, behåller 2-kolumnsrutnät)
   Mobil   : ≤ 640px   (en kolumn, tätare luft, mindre typ)
   ============================================ */

/* ---------- Platta (≤1024px) ---------- */
@media (max-width: 1024px){
  /* Hamburgaren tar över navigeringen */
  nav.main-nav > ul{display:none;}
  .nav-toggle{display:inline-flex;}

  :root{--gutter:40px;}
  section{padding:80px 40px;}
  header.site-header{padding:18px 32px;}

  /* Stora text+bild-block fälls till en kolumn redan här */
  .hero-split{grid-template-columns:1fr;min-height:auto;}
  .hero-split__copy{padding:64px 40px;}
  .hero-split__media{aspect-ratio:16/10;}
  .hero-asym{grid-template-columns:1fr;}
  .hero-asym__copy{padding:64px 40px;}
  .hero-fullbleed__copy{padding:60px 40px 80px;}
  .manifest__grid,.solutions__intro,.process__grid,.case-feature__inner,.split,.voices__case{
    grid-template-columns:1fr;gap:48px;
  }
  .solution-feature,.solution-feature--reverse{grid-template-columns:1fr;}
  .solution-feature--reverse .solution-feature__media{order:0;}
  .solution-feature__copy{padding:48px 40px;}
  .solution-feature__media{aspect-ratio:16/10;}

  /* Rutnät som tål två kolumner på platta */
  .solutions-small{grid-template-columns:repeat(6, 1fr);}
  .solutions-small .solution-card:nth-child(n){grid-column:span 6;aspect-ratio:5/4;}
  .voices__quotes{grid-template-columns:1fr 1fr;gap:40px;padding-top:40px;}
  .case-grid{grid-template-columns:repeat(2,1fr);}
  .case-tile:nth-child(n){grid-column:span 1;}
  .articles-grid{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:1fr 1fr;}
  .footer__grid{grid-template-columns:1fr 1fr;}

  .voices__quotes li{padding-left:20px;}
  .voices__quotes li::before{left:0;}
  .voices__head{margin-bottom:40px;}
  .voices__logos{margin-top:48px;gap:24px;}
  .voices__logos ul{gap:24px;font-size:16px;}
  .visual-pause__media{aspect-ratio:16/9;}
  .visual-pause__caption{left:24px;right:24px;bottom:24px;flex-direction:column;align-items:start;gap:16px;}
  .visual-pause__caption p{font-size:22px;}
  .manifest__img-slot{min-height:320px;}
  .section-divider{flex-wrap:wrap;gap:14px;}
  .sticky-cta{bottom:16px;right:16px;font-size:15px;padding:.7em 1.1em;}
  .longform{padding:60px 32px 40px;}
  .longform img.figure{margin:32px 0;width:100%;}
  .longform blockquote{font-size:24px;padding-left:20px;}
}

/* ---------- Mobil (≤640px) ---------- */
@media (max-width: 640px){
  :root{--gutter:20px;}
  section{padding:56px 20px;}
  header.site-header{padding:14px 20px;}
  h1{font-size:clamp(38px,11vw,52px);}
  h2{font-size:clamp(30px,8.5vw,40px);}

  .hero-split__copy{padding:48px 20px;}
  .hero-split__media{aspect-ratio:4/3;}
  .hero-asym__copy{padding:48px 20px;}
  .hero-fullbleed__copy{padding:48px 20px 64px;}
  .solution-feature__copy{padding:40px 24px;}

  /* Allt till en kolumn */
  .solutions-small{grid-template-columns:1fr;}
  .solutions-small .solution-card:nth-child(n){grid-column:span 1;aspect-ratio:5/4;}
  .voices__quotes{grid-template-columns:1fr;gap:32px;padding-top:32px;}
  .case-grid{grid-template-columns:1fr;}
  .articles-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .footer__grid{grid-template-columns:1fr;}

  .manifest__grid,.solutions__intro,.process__grid,.case-feature__inner,.split,.voices__case{gap:36px;}
  .manifest__img-slot{min-height:240px;}
  .longform{padding:48px 20px 40px;}
  .pullquote{padding:72px 24px;}
  .final-cta{padding:96px 24px;}
  footer.site-footer{padding:56px 24px 32px;}
  .mobile-nav__panel{padding:88px 24px 40px;}
}

/* ============================================
   TEAM-RUTNÄT (kontaktsidan)
   ============================================ */
.team-intro{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:end;
  margin-bottom:80px;
}
.team-intro h2{max-width:14ch;}
.team-intro p{color:var(--ink-soft); max-width:42ch;}

.team-lead{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:64px;
  align-items:center;
  padding:48px;
  background:var(--creme);
  margin-bottom:80px;
  border-left:6px solid var(--orange);
}
.team-lead__photo{
  aspect-ratio:4/5;
  background:repeating-linear-gradient(135deg,var(--creme-deep) 0 12px,#cfc8b6 12px 13px);
  display:flex; align-items:end; padding:20px;
  position:relative;
  overflow:hidden;
}
.team-lead__photo img,
.team-card__photo img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 22%;
}
.team-lead__photo span,
.team-card__photo span{
  font-family:'Courier New',monospace; font-size:11px;
  background:var(--paper); padding:6px 10px; line-height:1.3;
  color:var(--ink-soft); letter-spacing:.02em;
  position:relative; z-index:2;
}
.team-lead__role,
.team-card__role{
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--orange); margin-bottom:20px;
  font-family:var(--serif-body);
  display:inline-flex; align-items:center;
}
.team-lead__role .mark,
.team-card__role .mark{margin-right:.6em;}
.team-lead__body h3{
  font-size:clamp(36px, 3vw, 56px);
  line-height:1.05;
  margin-bottom:16px;
}
.team-lead__body p.team-lead__org{
  font-style:italic;
  color:var(--ink-soft);
  margin-bottom:28px;
  max-width:36ch;
}
.team-lead__contact{
  display:flex; flex-direction:column; gap:6px;
  margin-top:16px;
  padding-top:24px;
  border-top:1px solid rgba(45,45,42,0.15);
}
.team-lead__contact .tel{
  font-family:var(--serif-display);
  font-size:32px;
  line-height:1.2;
}
.team-lead__contact .mail{
  font-size:19px;
  border-bottom:1px solid var(--orange);
  align-self:flex-start;
  padding-bottom:2px;
}

.team-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:64px 48px;
}
.team-card{display:flex; flex-direction:column;}
.team-card__photo{
  width:100%;
  aspect-ratio:4/5;
  background:repeating-linear-gradient(135deg,var(--creme-deep) 0 12px,#cfc8b6 12px 13px);
  display:flex; align-items:end; padding:16px;
  margin-bottom:24px;
  position:relative;
  overflow:hidden;
}
.team-card__role{margin-bottom:12px;}
.team-card h3{
  font-size:28px;
  line-height:1.1;
  margin-bottom:14px;
}
.team-card__contact{
  display:flex; flex-direction:column; gap:6px;
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid rgba(45,45,42,0.12);
}
.team-card__contact .tel{
  font-family:var(--serif-display);
  font-size:22px;
  line-height:1.2;
}
.team-card__contact .tel--missing{
  font-family:'Courier New',monospace;
  font-size:13px;
  color:var(--ink-soft);
  font-style:italic;
}
.team-card__contact .mail{
  font-size:16px;
  border-bottom:1px solid var(--orange);
  align-self:flex-start;
  padding-bottom:2px;
}

@media (max-width: 1024px){
  .team-intro{grid-template-columns:1fr; gap:24px; margin-bottom:56px;}
  .team-lead{grid-template-columns:1fr; gap:32px; padding:32px;}
  .team-grid{grid-template-columns:1fr 1fr; gap:48px 32px;}
}
@media (max-width: 640px){
  .team-grid{grid-template-columns:1fr;}
  .team-lead{padding:24px;}
  .team-lead__body h3{font-size:36px;}
}

/* ============================================
   LEVERANS-BLOCK (.delivery) – "Vad Noeko levererade"
   Delad modul, används i alla case
   ============================================ */
.delivery{
  margin:72px auto 24px;
  padding:48px 56px;
  background:var(--creme-deep);
  border-left:4px solid var(--orange);
}
.delivery h3{
  font-family:var(--serif-display);
  font-size:26px;
  line-height:1.2;
  margin-bottom:8px;
}
.delivery > p.delivery__intro{
  font-size:16px;
  font-style:italic;
  color:var(--ink-soft);
  margin-bottom:32px;
  max-width:48ch;
}
.delivery ol{
  list-style:none;
  padding:0;
  margin:0;
  counter-reset:deliv;
}
.delivery ol li{
  counter-increment:deliv;
  display:grid;
  grid-template-columns:48px 1fr;
  gap:20px;
  padding:20px 0;
  border-top:1px solid rgba(45,45,42,.15);
  align-items:start;
}
.delivery ol li:first-child{border-top:none;}
.delivery ol li::before{
  content:counter(deliv,decimal-leading-zero);
  font-family:'Courier New',monospace;
  font-size:12px;
  color:var(--orange);
  letter-spacing:.12em;
  padding-top:6px;
}
.delivery ol li h4{
  font-family:var(--serif-display);
  font-size:20px;
  margin-bottom:4px;
  line-height:1.25;
}
.delivery ol li p{
  font-size:16px;
  line-height:1.55;
  color:var(--ink-soft);
  margin:0;
  max-width:none;
}

/* ============================================
   DELA-KNAPPAR (.case-share) – case & blogg
   ============================================ */
.case-share-section{background:var(--creme); padding:56px 80px 72px;}
.case-share-section .container{
  border-top:1px solid rgba(45,45,42,.15);
  padding-top:40px;
}
.case-share{
  display:flex; align-items:center; gap:24px;
  flex-wrap:wrap;
}
.case-share__label{
  font-size:13px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft); font-family:var(--serif-body);
}
.case-share__row{display:flex; align-items:center; gap:12px; flex-wrap:wrap;}
.case-share__btn{
  display:inline-flex; align-items:center; justify-content:center;
  width:46px; height:46px; border-radius:50%;
  border:1px solid rgba(45,45,42,.25);
  background:transparent; color:var(--ink);
  cursor:pointer; text-decoration:none;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
.case-share__btn svg{width:19px; height:19px; fill:currentColor; display:block;}
.case-share__btn:hover{background:var(--ink); color:var(--creme); border-color:var(--ink); transform:translateY(-2px);}
.case-share__btn--copy{
  width:auto; border-radius:999px; gap:9px; padding:0 22px;
  font-family:var(--serif-body); font-size:15px; height:46px;
}
.case-share__btn--copy svg{width:17px; height:17px;}
.case-share__btn--copy.is-copied{background:var(--orange); color:var(--paper); border-color:var(--orange);}

/* ============================================
   FÖLJ OSS – sociala ikoner i sidfoten
   ============================================ */
.footer__social{margin-top:24px;}
.footer__social-label{
  display:block; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  opacity:.55; margin-bottom:12px;
}
.footer__social-row{display:flex; gap:12px;}
.footer__social-row a{
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(255,255,255,.2); color:var(--creme);
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
}
.footer__social-row a svg{width:18px; height:18px; fill:currentColor; display:block;}
.footer__social-row a:hover{background:var(--orange); border-color:var(--orange); color:var(--paper); transform:translateY(-2px);}

@media (max-width:1024px){
  .delivery{margin:48px 0 24px; padding:32px 24px;}
  .case-share-section{padding:48px 24px 56px;}
}

/* ============================================
   MOBIL-ÖVERSYN — skyddsnät för inline-layouter
   --------------------------------------------
   Flera sidor (case, process, tjänstesidor) bygger
   rutnät och sektionspadding med inline-style. De
   kollapsar därför inte på mobil, vilket ger två
   trånga spalter, breda sidmarginaler och horisontell
   overflow. Reglerna nedan fångar inline-mönstren
   generellt vid telefonbredd. Inget i HTML behöver
   ändras för att de ska verka.
   ============================================ */

/* Ingen sida ska kunna scrolla i sidled */
html,body{overflow-x:clip;}
/* Grid-/flexbarn ska få krympa istället för att spränga ut */
.container,section,article,.longform,[class*="__grid"],[class*="__inner"]{min-width:0;}

@media (max-width:640px){
  /* 1 ── Alla inline-rutnät fälls till en kolumn */
  [style*="grid-template-columns"]{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  /* Numrerade steg (Process m.fl.): behåll en smal sifferkolumn
     bredvid texten istället för att stapla siffran ovanpå. */
  [style*="120px 1fr"]{
    grid-template-columns:46px 1fr !important;
    gap:18px !important;
    align-items:baseline !important;
  }
  [style*="font-size:80px"]{font-size:42px !important;}

  /* Barn med inline grid-column-spann (t.ex. bildmosaik) ska
     fylla den enda kvarvarande kolumnen istället för att behålla
     sitt gamla spann och bli ojämnt breda. */
  [style*="grid-column"]{grid-column:auto !important;}

  /* 2 ── Inline sektionspadding → smala, jämna sidmarginaler.
     Matchar 80px-/40px-paddade sektioner men lämnar
     full-bleed-sektioner (padding:0) orörda. */
  section[style*="80px"],
  section[style*="40px"]{
    padding-left:20px !important;
    padding-right:20px !important;
  }
  /* Inline-textblock med stor padding (t.ex. orange helbredds-puff) */
  [style*="padding:80px"]{
    padding-top:48px !important;
    padding-bottom:48px !important;
    padding-left:22px !important;
    padding-right:22px !important;
  }

  /* 3 ── Lika spaltbredd: lede ska flöda fullbredd som brödtext */
  .lede{max-width:none !important;}

  /* 4 ── Mindre anfang på mobil (≈3 rader istället för 5) */
  .dropcap::first-letter{
    font-size:3.1em;
    padding:2px 9px 0 0;
  }

  /* 5 ── Video-/bildkort i smala sektioner får andas fullbredd */
  .video-card[style*="max-width"]{max-width:none !important;}
}
