/* =========================================================================
   STUDIO BO ARKITEKTER — designsystem
   Varm nordisk grotesk. Sandfärgat papper, varm bläcksvart, skogsgrön +
   lerig terrakotta-accent. Alla teman/typsnitt/täthet/hero styrs av
   data-attribut på :root (sätts av tweaks.js, läses av CSS nedan).
   ========================================================================= */

/* ---- Tokens : default-tema "Varm sand" -------------------------------- */
:root{
  --paper:        oklch(0.952 0.014 82);   /* varm cream */
  --paper-2:      oklch(0.918 0.018 80);
  --paper-3:      oklch(0.880 0.022 78);
  --ink:          oklch(0.320 0.038 262);  /* djup skiffer-marin */
  --ink-soft:     oklch(0.500 0.030 262);
  --ink-faint:    oklch(0.620 0.022 262);
  --line:         color-mix(in oklab, var(--ink) 16%, transparent);
  --line-soft:    color-mix(in oklab, var(--ink) 8%, transparent);
  --accent:       oklch(0.560 0.115 33);   /* tegelröd */
  --accent-2:     oklch(0.560 0.060 258);  /* skifferblå */
  --accent-3:     oklch(0.700 0.075 108);  /* oliv */
  --on-accent:    oklch(0.96 0.012 85);
  --band:         oklch(0.555 0.060 258);  /* skifferblått färgfält */
  --band-accent:  oklch(0.730 0.080 106);  /* oliv på blått */
  --on-band:      oklch(0.945 0.018 84);   /* cream text */

  /* typografi */
  --font-display: "Schibsted Grotesk", system-ui, sans-serif;
  --font-body:    "Hanken Grotesk", system-ui, sans-serif;
  --tracking-tight:-0.02em;
  --tracking-wide: 0.14em;

  /* rytm / täthet (skrivs över av [data-density]) */
  --section-y: clamp(5rem, 11vw, 10rem);
  --rhythm:    clamp(1rem, 1.4vw, 1.5rem);
  --gap-grid:  clamp(1.5rem, 3vw, 3rem);

  --maxw: 1260px;
  --pad-x: clamp(1.25rem, 5vw, 4.5rem);
  --radius: 3px;
}

/* ---- Tema : Mörk lera (varm, dramatisk) ------------------------------- */
:root[data-theme="lera"]{
  --paper:      oklch(0.255 0.018 40);
  --paper-2:    oklch(0.300 0.020 38);
  --paper-3:    oklch(0.345 0.022 36);
  --ink:        oklch(0.935 0.014 72);
  --ink-soft:   oklch(0.765 0.016 66);
  --ink-faint:  oklch(0.625 0.014 60);
  --line:       color-mix(in oklab, var(--ink) 16%, transparent);
  --line-soft:  color-mix(in oklab, var(--ink) 9%, transparent);
  --accent:     oklch(0.660 0.120 36);   /* ljusare tegel */
  --accent-2:   oklch(0.670 0.065 256);
  --accent-3:   oklch(0.780 0.080 106);
  --on-accent:  oklch(0.20 0.01 40);
  --band:       oklch(0.470 0.110 33);   /* tegelrött fält */
  --band-accent:oklch(0.810 0.075 104);
  --on-band:    oklch(0.955 0.018 82);
}

/* ---- Tema : Sval (kyligt ljust, blått först) -------------------------- */
:root[data-theme="sval"]{
  --paper:      oklch(0.965 0.006 240);
  --paper-2:    oklch(0.935 0.009 240);
  --paper-3:    oklch(0.900 0.011 238);
  --ink:        oklch(0.300 0.030 262);
  --ink-soft:   oklch(0.480 0.025 262);
  --ink-faint:  oklch(0.620 0.018 262);
  --line:       color-mix(in oklab, var(--ink) 14%, transparent);
  --line-soft:  color-mix(in oklab, var(--ink) 7%, transparent);
  --accent:     oklch(0.540 0.080 258);  /* blå primär */
  --accent-2:   oklch(0.560 0.110 33);   /* tegel sekundär */
  --accent-3:   oklch(0.700 0.070 110);
  --on-accent:  oklch(0.97 0.005 240);
  --band:       oklch(0.500 0.075 258);
  --band-accent:oklch(0.880 0.060 100);
  --on-band:    oklch(0.965 0.010 240);
}

/* ---- Typsnitt-varianter ----------------------------------------------- */
:root[data-font="serif"]{
  --font-display: "Spectral", Georgia, serif;
  --tracking-tight:-0.01em;
}
:root[data-font="geo"]{
  --font-display: "Manrope", system-ui, sans-serif;
  --font-body:    "Manrope", system-ui, sans-serif;
}

/* ---- Täthet ------------------------------------------------------------ */
:root[data-density="luftigt"]{
  --section-y: clamp(7rem, 15vw, 14rem);
  --rhythm:    clamp(1.25rem, 1.8vw, 2rem);
  --gap-grid:  clamp(2rem, 4vw, 4.5rem);
}
:root[data-density="kompakt"]{
  --section-y: clamp(3.25rem, 7vw, 6rem);
  --rhythm:    clamp(0.75rem, 1vw, 1rem);
  --gap-grid:  clamp(1rem, 2vw, 2rem);
}

/* ---- Reset / bas ------------------------------------------------------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  font-size:clamp(1rem,0.4vw + 0.95rem,1.0625rem);
  line-height:1.7;
  font-feature-settings:"ss01","cv01";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background .45s ease, color .45s ease;
}
img,svg{display:block;max-width:100%}
main{flex:1 0 auto}
a{color:inherit;text-decoration:none}
::selection{background:color-mix(in oklab,var(--accent) 30%,transparent)}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:560;
  line-height:1.04;
  letter-spacing:var(--tracking-tight);
  text-wrap:balance;
  color:var(--ink);
}
:root[data-font="serif"] h1,
:root[data-font="serif"] h2,
:root[data-font="serif"] h3{font-weight:500}
p{text-wrap:pretty}

/* ---- Layout-hjälpare --------------------------------------------------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:calc(var(--section-y) * 0.55)}

/* färgfält — hel sektion i accentfärg med cream text (echo av omslaget).
   Remappar lokala variabler så allt innehåll ärver rätt ton. */
.band{
  background:var(--band);color:var(--on-band);
  --ink:var(--on-band);
  --ink-soft:color-mix(in oklab,var(--on-band) 78%,transparent);
  --ink-faint:color-mix(in oklab,var(--on-band) 60%,transparent);
  --line:color-mix(in oklab,var(--on-band) 24%,transparent);
  --accent:var(--band-accent);
}

.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:var(--tracking-wide);
  text-transform:uppercase;
  color:var(--accent);
}
.lead{
  font-size:clamp(1.1rem,0.6vw + 1rem,1.35rem);
  line-height:1.6;
  color:var(--ink-soft);
  max-width:46ch;
}
.muted{color:var(--ink-soft)}

/* hairline rule */
.rule{height:1px;background:var(--line);border:0;width:100%}

/* ---- Bild-platshållare ------------------------------------------------- */
.ph{
  position:relative;
  background:var(--paper-2);
  overflow:hidden;
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  isolation:isolate;
}
.ph::before{
  content:"";
  position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,
    transparent 0 17px,
    color-mix(in oklab,var(--ink) 5%,transparent) 17px 18px);
  z-index:-1;
}
.ph__tag{
  position:absolute;left:14px;bottom:12px;
  font-family:ui-monospace,"SFMono-Regular",Menlo,monospace;
  font-size:.72rem;letter-spacing:.02em;
  color:var(--ink-faint);
  background:color-mix(in oklab,var(--paper) 70%,transparent);
  padding:3px 8px;border-radius:2px;
  backdrop-filter:blur(2px);
}
.ph--portrait{aspect-ratio:4/5}
.ph--landscape{aspect-ratio:3/2}
.ph--wide{aspect-ratio:16/9}
.ph--square{aspect-ratio:1/1}

/* ---- Länkar (editoriella — inga klassiska knappar) -------------------- */
.link-arrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:600;font-size:.95rem;color:var(--accent);
  border-bottom:1px solid color-mix(in oklab,var(--accent) 35%,transparent);
  padding-bottom:.15em;
  transition:gap .2s ease, border-color .2s ease;
  width:fit-content;
}
.link-arrow svg{transition:transform .2s ease}
.link-arrow:hover{border-color:var(--accent);gap:.75em}
.link-arrow:hover svg{transform:translateX(3px)}

/* primär call-to-action som textlänk */
.cta{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--font-display);font-weight:560;
  font-size:1.1rem;letter-spacing:-0.01em;color:var(--accent);
  background:none;border:0;border-bottom:1.5px solid color-mix(in oklab,var(--accent) 38%,transparent);
  padding:0 0 .22em;cursor:pointer;width:fit-content;
  transition:gap .22s ease, border-color .22s ease, opacity .2s ease;
}
.cta svg{transition:transform .22s ease}
.cta:hover{border-color:var(--accent);gap:.9em}
.cta:hover svg{transform:translateX(4px)}
.cta--lg{font-size:clamp(1.25rem,2vw,1.7rem)}

/* ---- Header / nav ------------------------------------------------------ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:color-mix(in oklab,var(--paper) 86%,transparent);
  backdrop-filter:blur(14px) saturate(150%);
  border-bottom:1px solid var(--line-soft);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:74px;gap:2rem;
}
.nav__links{display:flex;align-items:center;gap:clamp(1.5rem,3vw,2.75rem)}
.nav__link{
  font-size:.95rem;font-weight:500;color:var(--ink-soft);
  position:relative;padding-block:.4em;
  transition:color .2s ease;
}
.nav__link:hover{color:var(--ink)}
.nav__link[aria-current="page"]{color:var(--ink)}
.nav__link[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:var(--accent);
}

/* ---- Wordmark — typografisk logga (studio bo / ARKITEKTER) -------------
   "studio" i tegel, "bo" i skifferblått, "ARKITEKTER" i tegel under.
   Underraden fyller EXAKT samma bredd som "studio bo" via justering —
   mätningsfritt, så det linjerar i alla webbläsare/storlekar. */
.wordmark{
  display:inline-flex;flex-direction:column;width:fit-content;
  line-height:1;text-decoration:none;
  font-family:"Spectral",Georgia,serif;
  --wm-size:1.5rem;
}
.wordmark__name{
  font-weight:500;font-size:var(--wm-size);letter-spacing:0;
  white-space:nowrap;color:var(--accent);
}
.wordmark__name .bo{color:var(--accent-2)}
.wordmark__sub{
  display:flex;justify-content:space-between;
  font-weight:500;font-size:calc(var(--wm-size) * 0.345);
  color:var(--accent);text-transform:uppercase;
  margin-top:calc(var(--wm-size) * 0.16);
}
.wordmark__sub i{font-style:normal}

/* mobil-nav (enkel) */
.nav__toggle{display:none}
@media(max-width:719px){
  .nav__links{display:none}
}

/* hamburgare + meny-overlay (undersidor, byggs av nav.js) */
.nav__burger{
  display:none;align-items:center;justify-content:center;
  width:44px;height:44px;margin-right:-10px;
  background:none;border:0;cursor:pointer;color:var(--ink);
}
.nav__burger-bars{display:inline-flex;flex-direction:column;gap:5px;width:26px}
.nav__burger-bars i{height:1.6px;background:currentColor;width:100%;transition:transform .3s ease,opacity .2s ease}
.nav__burger[aria-expanded="true"] .nav__burger-bars i:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.nav__burger[aria-expanded="true"] .nav__burger-bars i:nth-child(2){opacity:0}
.nav__burger[aria-expanded="true"] .nav__burger-bars i:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}
@media(max-width:719px){
  .nav__burger{display:inline-flex}
}

.mnav{
  position:fixed;inset:0;z-index:300;
  background:var(--band);color:var(--on-band);
  --accent:var(--band-accent);
  display:flex;flex-direction:column;padding:clamp(1.5rem,5vw,2.5rem) var(--pad-x);
  opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease;
}
.mnav.open{opacity:1;visibility:visible}
.mnav__top{display:flex;justify-content:flex-end}
.mnav__close{
  background:none;border:0;color:var(--on-band);cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.6rem 0;
}
.mnav__nav{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.2rem}
.mnav__nav a{
  font-family:"Spectral",Georgia,serif;font-weight:500;
  font-size:clamp(2.3rem,11vw,3.4rem);letter-spacing:-0.01em;line-height:1.18;
  color:var(--on-band);width:fit-content;transition:color .25s ease,padding-left .3s ease;
}
.mnav__nav a:hover,.mnav__nav a[aria-current="page"]{color:var(--band-accent)}
.mnav__foot{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in oklab,var(--on-band) 70%,transparent)}
.mnav__foot a{color:inherit}

/* ---- Hero -------------------------------------------------------------- */
.hero{padding-block:clamp(3.5rem,8vw,7rem) var(--section-y)}
.hero__eyebrow{margin-bottom:1.4rem}
.hero h1{
  font-size:clamp(2.7rem,7vw,6rem);
  font-weight:580;
  margin-bottom:1.6rem;
}
.hero__lead{font-size:clamp(1.15rem,0.8vw + 1rem,1.5rem);line-height:1.5;color:var(--ink-soft);max-width:40ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2.4rem}
.hero__media{margin-top:clamp(2.5rem,5vw,4rem)}

/* hero-skiss — linjeteckning som smälter in i papperet */
.hero__sketch{width:100%}
.hero__sketch img{
  display:block;width:100%;height:auto;
  mix-blend-mode:multiply;   /* vit bakgrund släpper igenom cremen */
}
/* i mörkt tema funkar inte multiply på svart bläck — invertera & skärm */
:root[data-theme="lera"] .hero__sketch img{
  mix-blend-mode:screen;filter:invert(1);
}

/* hero — vänsterställd (default) */
:root[data-hero="vanster"] .hero__inner{max-width:62ch}
:root[data-hero="vanster"] .hero__media .ph{aspect-ratio:21/9}

/* hero — centrerad */
:root[data-hero="centrerad"] .hero{text-align:center}
:root[data-hero="centrerad"] .hero__inner{max-width:24ch;margin-inline:auto}
:root[data-hero="centrerad"] .hero__lead{margin-inline:auto}
:root[data-hero="centrerad"] .hero__actions{justify-content:center}
:root[data-hero="centrerad"] .hero__media .ph{aspect-ratio:21/9}

/* hero — delad (text + bild sida vid sida) */
@media(min-width:900px){
  :root[data-hero="delad"] .hero{padding-block:0}
  :root[data-hero="delad"] .hero .container{padding-inline:0;max-width:none}
  :root[data-hero="delad"] .hero__grid{
    display:grid;grid-template-columns:1fr 1fr;min-height:min(82vh,760px);align-items:center;
  }
  :root[data-hero="delad"] .hero__inner{padding:var(--pad-x);max-width:52ch;justify-self:end}
  :root[data-hero="delad"] .hero__media{margin:0;align-self:stretch}
  :root[data-hero="delad"] .hero__media .ph{height:100%;border-radius:0;border:0;border-left:1px solid var(--line)}
  :root[data-hero="delad"] .hero__sketch{height:100%;display:flex;align-items:center;justify-content:center;border-left:1px solid var(--line);padding-left:clamp(1rem,3vw,3rem)}
  :root[data-hero="delad"] .hero__sketch img{height:auto;max-height:78%;width:auto;max-width:100%}
}

/* ---- Sektionsrubrik ---------------------------------------------------- */
.sec-head{
  display:grid;gap:1rem;margin-bottom:var(--gap-grid);
}
@media(min-width:820px){
  .sec-head{grid-template-columns:1fr 1fr;align-items:end;gap:2rem}
}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,3rem)}
.sec-head__aside{color:var(--ink-soft);max-width:42ch}

/* ---- Projekt-rutnät ---------------------------------------------------- */
.projects{display:grid;gap:var(--gap-grid);grid-template-columns:1fr}
@media(min-width:680px){.projects{grid-template-columns:repeat(2,1fr)}}
.project{display:flex;flex-direction:column;gap:1rem;group:project}
.project__media{aspect-ratio:4/3}
.project:nth-child(3n+1) .project__media{aspect-ratio:3/2}
.project .ph{transition:transform .5s cubic-bezier(.2,.7,.3,1)}
.project:hover .ph{transform:scale(1.012)}
.project__meta{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}
.project__name{font-family:var(--font-display);font-weight:560;font-size:1.25rem;letter-spacing:-0.01em}
.project__tag{font-size:.82rem;color:var(--ink-faint);letter-spacing:.02em}
.project__place{font-size:.92rem;color:var(--ink-soft);margin-top:-.4rem}

/* ---- Approach / split -------------------------------------------------- */
.split{display:grid;gap:var(--gap-grid);align-items:center}
@media(min-width:880px){.split{grid-template-columns:1fr 1fr}.split--text-first>*:first-child{order:-1}
  /* Studion: överkanterna linjerar, bilden lämnas orörd i sitt 4:3-format */
  .studio-split{align-items:start;gap:clamp(2rem,4vw,3.5rem)}
}
.split__body h2{font-size:clamp(1.8rem,3.2vw,2.7rem);margin-bottom:1.2rem}
.split__body p + p{margin-top:1rem}

/* numrerad lista (approach-steg) */
.steps{display:grid;gap:0;margin-top:2rem;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.25rem;padding:1.5rem 0;border-bottom:1px solid var(--line)}
.step__no{font-family:var(--font-display);font-size:.9rem;color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums;padding-top:.2rem}
.step__t{font-family:var(--font-display);font-weight:560;font-size:1.2rem;margin-bottom:.35rem}
.step__d{color:var(--ink-soft);font-size:.97rem}

/* ---- Tjänster ---------------------------------------------------------- */
.services{border-top:1px solid var(--line)}
.service{
  display:grid;grid-template-columns:auto 1fr;gap:1.5rem 2rem;
  padding:clamp(1.75rem,3.5vw,2.75rem) 0;border-bottom:1px solid var(--line);
  align-items:start;
}
@media(min-width:820px){.service{grid-template-columns:5rem 1fr 1fr;gap:2.5rem}}
.service__no{font-family:var(--font-display);color:var(--accent);font-weight:600;font-size:1rem;font-variant-numeric:tabular-nums}
.service__head h3{font-size:clamp(1.4rem,2.4vw,1.9rem);margin-bottom:.5rem}
.service__head .muted{font-size:.95rem}
.service__body{color:var(--ink-soft)}
.service__list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.1rem}
.service__list li{font-size:.85rem;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;padding:.3em .85em}

/* ---- Studio / team ----------------------------------------------------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap-grid);border-top:1px solid var(--line);padding-top:2.5rem}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat__n{font-family:var(--font-display);font-size:clamp(2.2rem,4vw,3.4rem);font-weight:560;letter-spacing:-0.02em}
.stat__l{font-size:.9rem;color:var(--ink-soft);margin-top:.3rem}

.team{display:grid;gap:var(--gap-grid);grid-template-columns:repeat(2,1fr)}
@media(min-width:760px){.team{grid-template-columns:repeat(3,1fr)}}
.member__media{aspect-ratio:4/5;margin-bottom:1rem}
.member__name{font-family:var(--font-display);font-weight:560;font-size:1.15rem}
.member__role{font-size:.9rem;color:var(--ink-soft)}

.values{display:grid;gap:var(--gap-grid);grid-template-columns:1fr}
@media(min-width:760px){.values{grid-template-columns:repeat(3,1fr)}}
.value h3{font-size:1.25rem;margin-bottom:.6rem}
.value p{color:var(--ink-soft);font-size:.97rem}
.value__num{font-family:var(--font-display);color:var(--accent-2);font-size:.85rem;font-weight:600;letter-spacing:.1em;margin-bottom:1rem}

/* ---- Paket (tjänste-undersidor) ---------------------------------------
   Tre breda, numrerade paket-rader. Textdrivet — inga bilder. */
.paket-intro{max-width:54ch}
.paket-list{border-top:1px solid var(--line);margin-top:var(--gap-grid)}
.paket{
  display:grid;gap:1.1rem 3rem;grid-template-columns:1fr;
  padding:clamp(2rem,4vw,3.4rem) 0;border-bottom:1px solid var(--line);
}
@media(min-width:820px){
  .paket{grid-template-columns:minmax(0,0.82fr) minmax(0,1.18fr);align-items:start}
}
.paket__no{
  font-family:var(--font-display);font-weight:560;font-size:.85rem;
  color:var(--accent);letter-spacing:.12em;font-variant-numeric:tabular-nums;
  margin-bottom:.9rem;
}
.paket__name{
  font-family:var(--font-display);font-weight:560;
  font-size:clamp(1.5rem,2.6vw,2.1rem);letter-spacing:-0.01em;margin-bottom:.7rem;
}
.paket__tagline{color:var(--ink-soft);font-size:1.02rem;line-height:1.55;max-width:30ch}
.paket__desc{color:var(--ink);font-size:1.02rem;line-height:1.7}
.paket__desc p + p{margin-top:.9rem}
.paket__incl-l{
  font-size:.72rem;font-weight:600;letter-spacing:var(--tracking-wide);
  text-transform:uppercase;color:var(--ink-faint);margin:1.4rem 0 .7rem;
}
.paket__incl{list-style:none;display:grid;gap:.6rem}
@media(min-width:560px){.paket__incl{grid-template-columns:1fr 1fr;gap:.6rem 1.5rem}}
.paket__incl li{position:relative;padding-left:1.35rem;color:var(--ink-soft);font-size:.96rem;line-height:1.45}
.paket__incl li::before{
  content:"";position:absolute;left:0;top:.5em;width:.5rem;height:.5rem;
  border:1px solid var(--accent);border-radius:50%;
}

/* avslutande not på undersidorna */
.paket-foot{margin-top:var(--gap-grid);max-width:50ch}
.paket-foot p{color:var(--ink-soft);margin-bottom:1.1rem}

/* tillbaka-länk i sidhuvudet på undersidan */
.backlink{
  display:inline-flex;align-items:center;gap:.45em;
  font-size:.9rem;font-weight:600;color:var(--ink-faint);
  margin-bottom:1.2rem;transition:color .2s ease,gap .2s ease;
}
.backlink:hover{color:var(--accent);gap:.7em}
.backlink svg{transition:transform .2s ease}
.backlink:hover svg{transform:translateX(-3px)}

/* ---- Paket (detaljerad layout) — tjänste-undersidor -------------------
   Intro-prosa, "Varför?", grupperad "Vad ingår?" och "Resultat". */
.intro-prose{max-width:64ch}
.intro-prose p{font-size:clamp(1.05rem,0.5vw + 1rem,1.22rem);line-height:1.7;color:var(--ink)}
.intro-prose p + p{margin-top:1.2rem}

.pkg-list{margin-top:0;border-top:1px solid var(--line)}
.pkg-list .pkg:first-child{padding-top:clamp(1.25rem,2.5vw,2rem)}
.pkg{padding:clamp(1.8rem,3.5vw,3rem) 0;border-bottom:1px solid var(--line)}
.pkg:last-child{border-bottom:0}
.pkg__no{font-family:var(--font-display);font-weight:560;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.55rem}
.pkg__name{font-family:var(--font-display);font-weight:560;font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:-0.01em;margin-bottom:.4rem}
.pkg__tagline{font-size:clamp(1.1rem,0.6vw + 1rem,1.35rem);line-height:1.5;color:var(--ink-soft);max-width:44ch}
.pkg__intro{max-width:62ch;margin-top:clamp(1rem,2vw,1.4rem)}
.pkg__intro p{color:var(--ink);line-height:1.72}
.pkg__intro p + p{margin-top:.8rem}
.pkg__grid{display:grid;gap:clamp(2rem,4vw,3.5rem);margin-top:clamp(1.8rem,3.5vw,2.8rem)}
.pkg__intro + .pkg__incl{margin-top:clamp(1.3rem,2.5vw,1.9rem)}
@media(min-width:900px){.pkg__grid{grid-template-columns:1fr 1fr;align-items:start}}
.pkg__sub-l{font-size:.72rem;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--ink-faint);margin-bottom:.8rem}
.pkg__why p{color:var(--ink-soft);line-height:1.72}
.pkg__why p + p{margin-top:.9rem}

/* "Vad ingår?" — grupperad lista i två kolumner */
.pkg__incl{display:grid;grid-template-columns:1fr 1fr;column-gap:clamp(2rem,4vw,3.4rem);align-items:start}
.pkg__incl > .pkg__sub-l{grid-column:1/-1;margin-bottom:.4rem}
@media(max-width:680px){.pkg__incl{grid-template-columns:1fr}}
.incl-group{break-inside:avoid;-webkit-column-break-inside:avoid;padding-top:.8rem;margin-top:.8rem;border-top:1px solid var(--line-soft)}
.incl-group__l{font-family:var(--font-display);font-weight:560;font-size:1.05rem;color:var(--ink)}
.incl-group ul{list-style:none;margin-top:.5rem;display:grid;gap:.3rem}
/* platt punktlista (paket utan undergrupper) */
.incl-flat{grid-column:1/-1;list-style:none;display:grid;grid-template-columns:1fr 1fr;column-gap:clamp(2rem,4vw,3.4rem);row-gap:.55rem;border-top:1px solid var(--line-soft);padding-top:1rem}
@media(max-width:680px){.incl-flat{grid-template-columns:1fr}}
.incl-flat li{position:relative;padding-left:1.1rem;color:var(--ink-soft);font-size:.94rem;line-height:1.5}
.incl-flat li::before{content:"–";position:absolute;left:0;color:color-mix(in oklab,var(--accent) 70%,transparent)}
.incl-group__d{position:relative;margin-top:.5rem;padding-left:1.1rem;color:var(--ink-soft);font-size:.94rem;line-height:1.5}
.incl-group__d::before{content:"–";position:absolute;left:0;color:color-mix(in oklab,var(--accent) 70%,transparent)}
.incl-group__d a{color:var(--accent);border-bottom:1px solid color-mix(in oklab,var(--accent) 35%,transparent);transition:border-color .2s ease}
.incl-group__d a:hover{border-color:var(--accent)}
.incl-group li{position:relative;padding-left:1.1rem;color:var(--ink-soft);font-size:.94rem;line-height:1.5}
.incl-group li::before{content:"–";position:absolute;left:0;color:color-mix(in oklab,var(--accent) 70%,transparent)}

/* "Resultat" — lugn avslutning, ingen box-trope */
.pkg__result{margin-top:clamp(1.3rem,2.5vw,1.9rem);padding-top:1.1rem;border-top:1px solid var(--line)}
.pkg__result-l{font-size:.72rem;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}
.pkg__result p{font-family:var(--font-display);font-weight:500;font-size:clamp(1.15rem,1.6vw,1.45rem);line-height:1.5;color:var(--ink);max-width:54ch}

/* ---- Kontakt ----------------------------------------------------------- */
.contact-grid{display:grid;gap:var(--gap-grid)}
@media(min-width:880px){.contact-grid{grid-template-columns:0.9fr 1.1fr;gap:clamp(3rem,6vw,6rem)}}
.contact-detail{margin-bottom:2rem}
.contact-detail__l{font-size:.74rem;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--ink-faint);margin-bottom:.5rem}
.contact-detail__v{font-size:1.15rem;font-family:var(--font-display);font-weight:500}
.contact-detail a:hover{color:var(--accent)}

/* formulär */
.form{display:grid;gap:1.4rem}
.field{display:grid;gap:.5rem}
.field label{font-size:.85rem;font-weight:600;color:var(--ink-soft)}
.field input,.field textarea,.field select{
  font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--paper-2);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:.85em 1em;width:100%;resize:vertical;
  transition:border-color .2s ease, background .2s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--accent);background:var(--paper);
}
.field--row{display:grid;gap:1.4rem}
@media(min-width:560px){.field--row{grid-template-columns:1fr 1fr}}
.field.invalid input,.field.invalid textarea{border-color:var(--accent)}
.field__err{font-size:.8rem;color:var(--accent);min-height:1em;display:none}
.field.invalid .field__err{display:block}
.form__note{font-size:.85rem;color:var(--ink-faint)}
.form__success{
  display:none;border:1px solid var(--accent);border-radius:var(--radius);
  padding:1.25rem 1.5rem;background:color-mix(in oklab,var(--accent) 10%,var(--paper));
}
.form__success.show{display:block}
.form__success strong{font-family:var(--font-display)}

/* ---- Footer ------------------------------------------------------------ */
.site-footer{background:var(--paper-2);border-top:1px solid var(--line)}
/* enkel fot: logga + e-post + instagram */
.footer-simple{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding-block:clamp(2.5rem,5vw,4rem)}
.footer-simple__right{display:flex;align-items:center;gap:1.5rem}
.footer-simple__right a{color:var(--ink-soft);font-size:.95rem;display:inline-flex;align-items:center;transition:color .2s ease}
.footer-simple__right a:hover{color:var(--accent)}
.footer-ig svg{display:block}
.footer-grid{display:grid;gap:1.5rem;padding-block:clamp(2rem,3.5vw,3rem);grid-template-columns:1fr}
@media(min-width:760px){.footer-grid{grid-template-columns:1fr auto}.footer-grid .footer__col:last-child{text-align:right}}
/* MOBIL ENDAST: bara mejladressen, vertikalt centrerad mot loggan */
@media(max-width:759px){
  .footer-grid{
    grid-template-columns:1fr auto;
    align-items:center;
    gap:1.75rem 2rem;
    padding-block:2.5rem 1.6rem;
  }
  .footer-grid .footer__col:last-child{text-align:right}
  .footer-grid .footer__col:last-child h4{display:none}
  .footer-grid .footer__col:last-child a{font-size:.85rem;color:var(--ink-faint)}
  .footer-grid .footer__col:last-child a:hover{color:var(--accent)}
}
.footer__col h4{font-size:.74rem;font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--ink-faint);margin-bottom:.5rem}
.footer__col ul{list-style:none;display:grid;gap:.6rem}
.footer__col a{color:var(--ink-soft);font-size:.97rem}
.footer__col a:hover{color:var(--ink)}
.footer__about{color:var(--ink-soft);max-width:34ch;margin-top:1.1rem;font-size:.97rem}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  padding-block:1.1rem;border-top:1px solid var(--line);font-size:.85rem;color:var(--ink-faint)}

/* ---- Entré: medvetet statiskt -----------------------------------------
   Ingen animation — innehållet är alltid synligt. Matchar den lugna
   känslan och garanterar korrekt rendering i print/export/skärmbild. */
.reveal{}

/* ---- Tweaks-panel (vanilla) ------------------------------------------- */
.tbo-panel{
  position:fixed;right:16px;bottom:16px;z-index:2147483646;width:272px;
  display:none;flex-direction:column;max-height:calc(100vh - 32px);
  background:color-mix(in oklab,var(--paper) 80%,transparent);
  color:var(--ink);
  backdrop-filter:blur(22px) saturate(160%);
  border:0.5px solid color-mix(in oklab,var(--ink) 14%,transparent);
  border-radius:14px;
  box-shadow:0 12px 40px rgba(0,0,0,.20);
  font-family:var(--font-body);font-size:12px;line-height:1.4;overflow:hidden;
}
.tbo-panel.open{display:flex}
.tbo-hd{display:flex;align-items:center;justify-content:space-between;padding:11px 9px 11px 15px;cursor:move;user-select:none}
.tbo-hd b{font-size:12.5px;font-weight:600}
.tbo-hd .tbo-sub{font-size:10px;color:var(--ink-faint);font-weight:500;letter-spacing:.04em}
.tbo-x{appearance:none;border:0;background:transparent;color:var(--ink-faint);width:24px;height:24px;border-radius:6px;cursor:pointer;font-size:14px}
.tbo-x:hover{background:color-mix(in oklab,var(--ink) 8%,transparent);color:var(--ink)}
.tbo-body{padding:4px 15px 16px;display:flex;flex-direction:column;gap:12px;overflow-y:auto}
.tbo-sect{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);padding-top:8px}
.tbo-row{display:flex;flex-direction:column;gap:7px}
.tbo-row > span{font-weight:500;color:var(--ink-soft)}
.tbo-seg{display:flex;gap:4px;background:color-mix(in oklab,var(--ink) 7%,transparent);padding:3px;border-radius:9px}
.tbo-seg button{flex:1;appearance:none;border:0;background:transparent;color:var(--ink-soft);font:inherit;font-weight:500;padding:6px 4px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s;line-height:1.15}
.tbo-seg button[aria-pressed="true"]{background:var(--paper);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.12)}
.tbo-chips{display:flex;gap:7px}
.tbo-chip{position:relative;flex:1;height:44px;border:0;border-radius:7px;cursor:pointer;overflow:hidden;box-shadow:0 0 0 .5px color-mix(in oklab,var(--ink) 18%,transparent);transition:box-shadow .15s,transform .12s}
.tbo-chip:hover{transform:translateY(-1px)}
.tbo-chip[aria-pressed="true"]{box-shadow:0 0 0 2px var(--ink)}
.tbo-chip span{position:absolute;inset:0;display:flex}
.tbo-chip span i{flex:1}
