/* ============================================================
   Sitely block-renderer – HTML5 + CSS3, inga bibliotek.
   Alla klasser är prefixade sb- för att inte krocka med editorn.
   Färgtokens (--sb-primary etc) sätts av PageRenderer via inline-style
   eller faller tillbaka på applikationens semantiska tokens.
   ============================================================ */
.sb-root {
  /* Bas-tokens: kan överskridas per block via wrapper-CSS-variabler. */
  --sb-primary: var(--primary, #2f6df5);
  --sb-primary-fg: var(--primary-foreground, #ffffff);
  /* Dämpade defaults — bakgrund/badges/CTA-band ska aldrig vara skrikiga.
     Den rena primärfärgen reserveras för knappar och små accenter. */
  --sb-primary-soft: color-mix(in oklab, var(--sb-primary) 14%, var(--sb-bg, #ffffff));
  --sb-primary-tint: color-mix(in oklab, var(--sb-primary) 8%, var(--sb-bg, #ffffff));
  --sb-accent: var(--accent, color-mix(in oklab, var(--sb-primary) 6%, #f6f7fa));
  --sb-bg: var(--background, #ffffff);
  --sb-fg: var(--foreground, #0b1020);
  --sb-muted: color-mix(in oklab, var(--sb-fg) 58%, transparent);
  --sb-border: color-mix(in oklab, var(--sb-fg) 10%, transparent);
  --sb-card: color-mix(in oklab, var(--sb-fg) 2.5%, var(--sb-bg));
  --sb-radius: 18px;
  --sb-radius-sm: 12px;
  --sb-radius-pill: 999px;
  --sb-shadow-sm: 0 1px 2px rgba(15,23,42,.04);
  --sb-shadow: 0 1px 2px rgba(15,23,42,.04), 0 12px 36px -16px rgba(15,23,42,.18);
  --sb-shadow-lg: 0 1px 2px rgba(15,23,42,.04), 0 30px 60px -24px rgba(15,23,42,.22);
  --sb-container: 1200px;
  --sb-section-py: clamp(72px, 9vw, 128px);
  --sb-font-display: "Plus Jakarta Sans", "Space Grotesk", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --sb-font-body: "Inter", "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  color: var(--sb-fg);
  background: var(--sb-bg);
  min-height: 100vh;
  font-family: var(--sb-font-body);
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  letter-spacing: -0.005em;
}
.sb-root *, .sb-root *::before, .sb-root *::after { box-sizing: border-box; }
html:has(.sb-root) { scroll-behavior: smooth; }
.sb-root [id] { scroll-margin-top: 88px; }
.sb-root img { max-width: 100%; display: block; }
.sb-root a { color: inherit; text-decoration: none; }
.sb-root h1, .sb-root h2, .sb-root h3, .sb-root h4 {
  margin: 0 0 .5em; line-height: 1.12; font-family: var(--sb-font-display);
  letter-spacing: -0.022em; font-weight: 700;
}
.sb-root p { margin: 0 0 1em; }
.sb-root ul { margin: 0; padding: 0; list-style: none; }

/* ============================================================
   PREMIUM-lager — subtila lyx-detaljer (idempotenta)
   ============================================================ */

/* Filmkorn över hela sajten — knappt synligt men ger djup. */
.sb-root::before {
  content: ""; position: fixed; inset: 0; pointer-events: none; z-index: 9998;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");
  background-size: 160px 160px; opacity: .035; mix-blend-mode: overlay;
}
@media (prefers-reduced-motion: reduce) { .sb-root::before { display: none; } }

/* Mjuk färgövergång vid temabyten i live-preview. */
.sb-root, .sb-root .sb-card, .sb-root .sb-btn, .sb-root .sb-feature__icon {
  transition-property: background-color, color, border-color, box-shadow, transform;
  transition-duration: 320ms, 320ms, 320ms, 200ms, 200ms;
  transition-timing-function: cubic-bezier(.22,1,.36,1);
}

/* Hero — Ken Burns loop ovanpå parallax, starkare typografi. */
.sb-root .sb-hero__bg {
  animation: sb-kenburns 28s ease-in-out infinite alternate;
}
@keyframes sb-kenburns {
  from { transform: translate3d(0, var(--sb-par-y,0px), 0) scale(calc(var(--sb-par-s,1) * 1.0)); }
  to   { transform: translate3d(0, var(--sb-par-y,0px), 0) scale(calc(var(--sb-par-s,1) * 1.08)); }
}
@media (prefers-reduced-motion: reduce) {
  .sb-root .sb-hero__bg { animation: none; }
}
.sb-root .sb-hero__title {
  font-size: clamp(40px, 7.2vw, 96px);
  letter-spacing: -.04em; line-height: .98; text-wrap: balance;
}
.sb-root .sb-hero__subtitle { text-wrap: balance; line-height: 1.55; }
.sb-root .sb-hero--image .sb-hero__overlay {
  background:
    radial-gradient(120% 80% at 50% 100%, rgba(0,0,0,.55) 0%, rgba(0,0,0,.15) 50%, rgba(0,0,0,.05) 80%),
    linear-gradient(180deg, rgba(8,10,18,.25) 0%, rgba(8,10,18,.55) 100%);
}

/* Section-titel: balanserad textwrap. */
.sb-root .sb-section__head h2,
.sb-root .sb-section__title,
.sb-root .sb-cta h2 { text-wrap: balance; }

/* Stats — tabulära siffror, något större. */
.sb-root .sb-stat__value {
  font-variant-numeric: tabular-nums;
  font-size: clamp(38px, 5.4vw, 64px);
}

/* Knapp-puls vid hover på lyxtema. */
.sb-root .sb-btn { letter-spacing: 0; padding: 14px 26px; font-weight: 600; }
.sb-root .sb-btn::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  box-shadow: 0 0 0 0 color-mix(in oklab, var(--sb-primary) 40%, transparent);
  transition: box-shadow .5s ease;
}
.sb-root .sb-btn { position: relative; }
.sb-root .sb-btn:hover::after { box-shadow: 0 0 0 8px color-mix(in oklab, var(--sb-primary) 0%, transparent); }

/* Gallery — group-hover-zoom + glansljus över bilden. */
.sb-root .sb-gallery { gap: 18px; }
.sb-root .sb-gallery a, .sb-root .sb-gallery figure, .sb-root .sb-gallery div { position: relative; overflow: hidden; border-radius: var(--sb-radius-sm); }
.sb-root .sb-gallery img {
  transition: transform 1100ms cubic-bezier(.22,1,.36,1), filter .6s ease;
  filter: saturate(.96);
}
.sb-root .sb-gallery img:hover { transform: scale(1.05); filter: saturate(1.08); }

/* Section-bild: subtil zoom på hover. */
.sb-root .sb-section__img {
  transition: transform 900ms cubic-bezier(.22,1,.36,1), box-shadow .5s ease;
}
.sb-root .sb-section__img:hover { transform: scale(1.02); }

/* Features-kort — accentlinje växer från vänster. */
.sb-root .sb-feature { position: relative; }
.sb-root .sb-feature::after {
  content: ""; position: absolute; left: 30px; bottom: 22px; height: 1px; width: 0;
  background: linear-gradient(90deg, var(--sb-primary), transparent);
  transition: width .5s cubic-bezier(.22,1,.36,1);
}
.sb-root .sb-feature:hover::after { width: calc(100% - 60px); }

/* Pricing — featured tier (mittenkortet) får en lugn gloria. */
.sb-root .sb-grid--3 > .sb-tier:nth-child(2),
.sb-root .sb-grid--count-2 > .sb-tier:nth-child(1) {
  background:
    linear-gradient(var(--sb-card), var(--sb-card)) padding-box,
    conic-gradient(from var(--sb-beam-a, 0deg),
      color-mix(in oklab, var(--sb-primary) 60%, transparent),
      color-mix(in oklab, var(--sb-primary) 0%, transparent) 30%,
      color-mix(in oklab, var(--sb-primary) 60%, transparent) 60%,
      color-mix(in oklab, var(--sb-primary) 0%, transparent) 90%) border-box;
  border: 1px solid transparent;
  animation: sb-beam-rotate 9s linear infinite;
}
@property --sb-beam-a { syntax: "<angle>"; inherits: false; initial-value: 0deg; }
@keyframes sb-beam-rotate { to { --sb-beam-a: 360deg; } }
@media (prefers-reduced-motion: reduce) {
  .sb-root .sb-grid--3 > .sb-tier:nth-child(2),
  .sb-root .sb-grid--count-2 > .sb-tier:nth-child(1) { animation: none; }
}

/* Testimonials — stora citattecken som tonas in. */
.sb-root .sb-quote { position: relative; padding-top: 10px; }
.sb-root .sb-quote::before {
  content: "“"; position: absolute; top: -.35em; left: -.1em;
  font-family: var(--sb-font-display); font-style: normal; font-weight: 700;
  font-size: 4.5em; line-height: 1; color: var(--sb-primary);
  opacity: .18; pointer-events: none;
}

/* CTA — subtilt animerad ljuslinje längs översta kanten. */
.sb-root .sb-cta::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in oklab, var(--sb-primary) 70%, transparent), transparent);
  background-size: 50% 100%; background-repeat: no-repeat;
  animation: sb-cta-shine 6s ease-in-out infinite;
}
@keyframes sb-cta-shine {
  0%, 100% { background-position: -50% 0; }
  50%       { background-position: 150% 0; }
}
@media (prefers-reduced-motion: reduce) { .sb-root .sb-cta::before { animation: none; } }

/* Footer — varsam mörkning i botten. */
.sb-root .sb-footer { box-shadow: inset 0 1px 0 color-mix(in oklab, var(--sb-fg) 6%, transparent); }

/* Reveal-curva: lite längre, lyxigare timing. */
.sb-root .sb-reveal { transition-duration: 1.05s, 1.05s; }

/* Reveal-animationer – aktiveras bara inuti .sb-root så att
   editorns enskilda block-preview alltid är synlig. */
.sb-root { scroll-behavior: smooth; }
.sb-root .sb-reveal {
  opacity: 0;
  transform: translate3d(var(--sb-rx, 0), var(--sb-ry, 24px), 0) scale(var(--sb-rs, 1));
  transition:
    opacity .85s cubic-bezier(.22,1,.36,1) var(--sb-rd, 0ms),
    transform .85s cubic-bezier(.22,1,.36,1) var(--sb-rd, 0ms);
  will-change: opacity, transform;
}
.sb-root .sb-reveal.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}
.sb-root .sb-reveal[data-reveal="up"]    { --sb-rx: 0;    --sb-ry: 28px;  --sb-rs: 1; }
.sb-root .sb-reveal[data-reveal="down"]  { --sb-rx: 0;    --sb-ry: -28px; --sb-rs: 1; }
.sb-root .sb-reveal[data-reveal="left"]  { --sb-rx: 32px; --sb-ry: 0;     --sb-rs: 1; }
.sb-root .sb-reveal[data-reveal="right"] { --sb-rx: -32px;--sb-ry: 0;     --sb-rs: 1; }
.sb-root .sb-reveal[data-reveal="scale"] { --sb-rx: 0;    --sb-ry: 0;     --sb-rs: .92; }
.sb-root .sb-reveal[data-reveal="fade"]  { --sb-rx: 0;    --sb-ry: 0;     --sb-rs: 1; }
/* Premium-presets: längre översättning + subtil blur för redaktionell känsla. */
.sb-root .sb-reveal[data-reveal="rise"]   { --sb-rx: 0;    --sb-ry: 42px;  --sb-rs: 1;   --sb-rb: 10px; }
.sb-root .sb-reveal[data-reveal="slide-up"]{ --sb-rx: 0;   --sb-ry: 64px;  --sb-rs: 1;   --sb-rb: 6px; }
.sb-root .sb-reveal[data-reveal="tilt"]   { --sb-rx: 0;    --sb-ry: 36px;  --sb-rs: .96; --sb-rb: 8px; --sb-rr: 1.5deg; }
.sb-root .sb-reveal[data-reveal="blur"]   { --sb-rx: 0;    --sb-ry: 16px;  --sb-rs: 1;   --sb-rb: 14px; }

/* Tillåt blur + lätt rotation som del av reveal-transformen. */
.sb-root .sb-reveal {
  transform: translate3d(var(--sb-rx, 0), var(--sb-ry, 24px), 0)
             scale(var(--sb-rs, 1))
             rotate(var(--sb-rr, 0deg));
  filter: blur(var(--sb-rb, 0px));
  transition:
    opacity .95s cubic-bezier(.22,1,.36,1) var(--sb-rd, 0ms),
    transform .95s cubic-bezier(.22,1,.36,1) var(--sb-rd, 0ms),
    filter .8s cubic-bezier(.22,1,.36,1) var(--sb-rd, 0ms);
}
.sb-root .sb-reveal.is-visible {
  filter: blur(0);
  transform: translate3d(0, 0, 0) scale(1) rotate(0);
}

/* Scroll-progress-bar */
.sb-root .sb-scroll-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px;
  transform-origin: 0 50%; transform: scaleX(0);
  background: linear-gradient(90deg, var(--sb-primary), var(--sb-accent, var(--sb-primary)));
  z-index: 9999; pointer-events: none; will-change: transform;
  transition: transform .08s linear;
}

/* Parallax på hero-bakgrund (drivs av runtime via CSS-variabler) */
.sb-root .sb-hero__bg {
  transform: translate3d(0, var(--sb-par-y, 0px), 0) scale(var(--sb-par-s, 1));
  transition: transform .12s linear;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .sb-root { scroll-behavior: auto; }
  .sb-root .sb-reveal { opacity: 1; transform: none; transition: none; }
  .sb-root .sb-hero__bg { transform: none; }
  .sb-root .sb-scroll-progress { display: none; }
}

/* Container */
.sb-container { width: 100%; max-width: var(--sb-container); margin: 0 auto; padding: 0 24px; }

/* Knappar */
.sb-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  padding: 13px 24px; border-radius: var(--sb-radius-pill);
  font-weight: 600; font-size: 15px; letter-spacing: -0.005em;
  background: var(--sb-primary); color: var(--sb-primary-fg);
  border: 1px solid transparent; cursor: pointer;
  box-shadow: 0 1px 0 rgba(255,255,255,.1) inset, 0 8px 24px -10px color-mix(in oklab, var(--sb-primary) 80%, transparent);
  transition: transform .2s cubic-bezier(.22,1,.36,1), box-shadow .2s ease, opacity .15s ease, background .15s ease;
}
.sb-btn:hover { transform: translateY(-2px); box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 14px 32px -10px color-mix(in oklab, var(--sb-primary) 80%, transparent); }
.sb-btn:focus-visible { outline: none; box-shadow: 0 0 0 4px color-mix(in oklab, var(--sb-primary) 22%, transparent); }
.sb-btn--ghost {
  background: transparent; color: var(--sb-fg);
  border-color: var(--sb-border); box-shadow: none;
}
.sb-btn--ghost:hover { background: color-mix(in oklab, var(--sb-fg) 5%, transparent); }
.sb-btn--on-image { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.4); backdrop-filter: blur(6px); }
.sb-btn--on-image:hover { background: rgba(255,255,255,.22); }

/* Navbar */
.sb-nav {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; padding: 16px 24px;
  border-bottom: 1px solid var(--sb-border);
  background: var(--sb-bg); position: sticky; top: 0; z-index: 40;
}
.sb-nav__brand { display: inline-flex; align-items: center; gap: 12px; font-weight: 700; font-size: 18px; }
.sb-nav__brand img { height: 36px; width: auto; object-fit: contain; }
/* Logotypens placering */
.sb-nav--logo-center { justify-content: center; position: relative; }
.sb-nav--logo-center .sb-nav__brand { position: absolute; left: 50%; transform: translateX(-50%); }
.sb-nav--logo-right { flex-direction: row-reverse; }
.sb-nav--logo-right .sb-nav__list { margin-right: auto; }
.sb-nav__list { display: flex; align-items: center; gap: 28px; font-size: 14px; }
.sb-nav__item { position: relative; }
.sb-nav__link { padding: 6px 0; transition: color .15s ease; }
.sb-nav__link:hover, .sb-nav__link[aria-expanded="true"] { color: var(--sb-primary); }
.sb-nav__caret { display: inline-block; width: 10px; height: 10px; margin-left: 4px;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px); opacity: .7; transition: transform .2s ease; }
.sb-nav__link[aria-expanded="true"] .sb-nav__caret { transform: rotate(-135deg) translateY(0); }
.sb-nav__submenu {
  position: absolute; top: calc(100% + 8px); left: 0; min-width: 220px;
  background: var(--sb-bg); border: 1px solid var(--sb-border);
  border-radius: var(--sb-radius-sm); box-shadow: var(--sb-shadow);
  padding: 6px; display: none; z-index: 50;
}
.sb-nav__submenu.is-open { display: block; }
.sb-nav__submenu a { display: block; padding: 8px 12px; border-radius: 6px; font-size: 14px; }
.sb-nav__submenu a:hover { background: var(--sb-accent); }
.sb-nav__toggle {
  display: none; background: transparent; border: 0; cursor: pointer;
  width: 40px; height: 40px; padding: 0;
}
.sb-nav__toggle span, .sb-nav__toggle::before, .sb-nav__toggle::after {
  content: ""; display: block; width: 22px; height: 2px; margin: 5px auto;
  background: currentColor; transition: transform .2s ease, opacity .2s ease;
}
.sb-nav[data-open="true"] .sb-nav__toggle::before { transform: translateY(7px) rotate(45deg); }
.sb-nav[data-open="true"] .sb-nav__toggle span { opacity: 0; }
.sb-nav[data-open="true"] .sb-nav__toggle::after { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 860px) {
  .sb-nav__toggle { display: block; }
  .sb-nav__list {
    position: absolute; top: 100%; left: 0; right: 0;
    flex-direction: column; align-items: stretch; gap: 4px;
    background: var(--sb-bg); border-bottom: 1px solid var(--sb-border);
    padding: 12px 24px 18px; display: none;
  }
  .sb-nav[data-open="true"] .sb-nav__list { display: flex; }
  .sb-nav__submenu { position: static; box-shadow: none; border: 0; padding: 0 0 0 12px; }
}

/* Hero */
.sb-hero {
  position: relative; overflow: hidden;
  padding: calc(var(--sb-section-py) + 16px) 24px var(--sb-section-py);
  text-align: center;
}
.sb-hero--plain {
  background:
    radial-gradient(60% 80% at 50% 0%, color-mix(in oklab, var(--sb-primary) 12%, transparent) 0%, transparent 70%),
    linear-gradient(180deg, var(--sb-primary-tint) 0%, var(--sb-bg) 60%);
}
.sb-hero--image { color: #fff; }
.sb-hero__bg, .sb-hero__overlay { position: absolute; inset: 0; }
.sb-hero__bg { object-fit: cover; width: 100%; height: 100%; }
.sb-hero__overlay {
  background: linear-gradient(180deg, rgba(8,10,18,.55) 0%, rgba(8,10,18,.35) 60%, rgba(8,10,18,.7) 100%);
}
.sb-hero__inner { position: relative; max-width: 880px; margin: 0 auto; }
.sb-hero__badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px 7px 10px; border-radius: 999px;
  background: color-mix(in oklab, var(--sb-primary) 10%, transparent);
  border: 1px solid color-mix(in oklab, var(--sb-primary) 22%, transparent);
  color: color-mix(in oklab, var(--sb-primary) 80%, var(--sb-fg));
  font-size: 12.5px; font-weight: 600; letter-spacing: .02em;
  margin-bottom: 22px;
}
.sb-hero__badge::before {
  content: ""; width: 6px; height: 6px; border-radius: 999px;
  background: var(--sb-primary); box-shadow: 0 0 0 4px color-mix(in oklab, var(--sb-primary) 25%, transparent);
}
.sb-hero--image .sb-hero__badge { background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25); }
.sb-hero--image .sb-hero__badge::before { background: #fff; box-shadow: 0 0 0 4px rgba(255,255,255,.25); }
.sb-hero__title {
  font-size: clamp(36px, 6vw, 72px); font-weight: 700;
  letter-spacing: -.035em; line-height: 1.02;
}
.sb-hero__subtitle {
  font-size: clamp(17px, 1.6vw, 21px); color: var(--sb-muted);
  max-width: 640px; margin: 20px auto 32px; line-height: 1.55;
}
.sb-hero--image .sb-hero__subtitle { color: rgba(255,255,255,.9); }
.sb-hero__ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Accent-ord (rendrat från `*ord*` i AI-output) */
.sb-root .sb-accent {
  font-style: italic;
  font-family: var(--sb-font-display);
  color: color-mix(in oklab, var(--sb-primary) 70%, #d4a84c);
  font-weight: 500;
}
.sb-root .sb-hero--image .sb-accent {
  color: color-mix(in oklab, var(--sb-primary) 50%, #e8c47a);
}

/* Dekorativ divider mellan titel och subtitle på image-hero */
.sb-root .sb-hero__divider {
  display: block;
  width: 56px;
  height: 1px;
  margin: 20px auto 18px;
  background: color-mix(in oklab, var(--sb-primary) 60%, #d4a84c);
  opacity: .9;
}

/* Scroll-hint längst ned i image-hero */
.sb-root .sb-hero__scroll {
  position: absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  z-index: 3;
  color: rgba(255,255,255,.78);
  font-size: 11px;
  letter-spacing: .28em;
  font-weight: 600;
  text-transform: uppercase;
}
.sb-root .sb-hero__scroll-line {
  width: 1px; height: 36px;
  background: linear-gradient(180deg, rgba(255,255,255,.6), rgba(255,255,255,0));
}

/* Generella sektioner */
.sb-section { padding: var(--sb-section-py) 24px; }
.sb-section--muted { background: color-mix(in oklab, var(--sb-fg) 2.5%, var(--sb-bg)); }
.sb-section__head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.sb-section__head h2 { font-size: clamp(28px, 3.8vw, 44px); font-weight: 700; letter-spacing: -.028em; }
.sb-section__head p { color: var(--sb-muted); font-size: 17px; }

/* Features */
.sb-grid { display: grid; gap: 22px; max-width: var(--sb-container); margin: 0 auto; }
.sb-grid--3 { grid-template-columns: repeat(3, 1fr); }
.sb-grid--4 { grid-template-columns: repeat(4, 1fr); }
/* 1 eller 2 item — centrera horisontellt med begränsad maxbredd så det inte hänger till vänster. */
.sb-grid--count-1 { grid-template-columns: minmax(0, 520px); justify-content: center; max-width: 760px; }
.sb-grid--count-2 { grid-template-columns: repeat(2, minmax(0, 420px)); justify-content: center; max-width: 920px; }
@media (max-width: 720px) { .sb-grid--count-2 { grid-template-columns: 1fr; } }
@media (max-width: 900px) { .sb-grid--3, .sb-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .sb-grid--3, .sb-grid--4 { grid-template-columns: 1fr; } }

.sb-card {
  background: var(--sb-card); border: 1px solid var(--sb-border);
  border-radius: var(--sb-radius); padding: 30px;
  transition: transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s ease, border-color .2s ease;
}
.sb-card:hover { transform: translateY(-3px); box-shadow: var(--sb-shadow); border-color: color-mix(in oklab, var(--sb-fg) 14%, transparent); }
.sb-feature__icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: linear-gradient(135deg,
    color-mix(in oklab, var(--sb-primary) 16%, transparent),
    color-mix(in oklab, var(--sb-primary) 6%, transparent));
  border: 1px solid color-mix(in oklab, var(--sb-primary) 18%, transparent);
  color: var(--sb-primary);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.sb-feature h3 { font-size: 19px; font-weight: 600; letter-spacing: -.015em; }
.sb-feature p { color: var(--sb-muted); font-size: 15.5px; margin: 0; line-height: 1.6; }
.sb-feature__image {
  display: block; width: 100%; aspect-ratio: 4 / 3; border-radius: 16px;
  overflow: hidden; margin-bottom: 18px;
  border: 1px solid color-mix(in oklab, var(--sb-primary) 14%, transparent);
  background: color-mix(in oklab, var(--sb-primary) 4%, transparent);
}
.sb-feature__image img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Stats */
.sb-stats { display: grid; gap: 24px; grid-template-columns: repeat(4, 1fr); text-align: center; max-width: var(--sb-container); margin: 0 auto; }
@media (max-width: 720px) { .sb-stats { grid-template-columns: repeat(2, 1fr); } }
.sb-stat__value {
  font-family: var(--sb-font-display);
  font-size: clamp(34px, 5vw, 56px); font-weight: 700;
  letter-spacing: -.035em;
  background: linear-gradient(135deg, var(--sb-primary), color-mix(in oklab, var(--sb-primary) 60%, var(--sb-fg)));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.sb-stat__label { color: var(--sb-muted); font-size: 14px; margin-top: 6px; }

/* Testimonials */
.sb-quote { font-style: italic; margin: 0 0 14px; }
.sb-quote-author { font-size: 14px; color: var(--sb-muted); }
.sb-quote-author strong { color: var(--sb-fg); font-weight: 600; }

/* Pricing */
.sb-tier { display: flex; flex-direction: column; }
.sb-tier__price { font-size: 36px; font-weight: 800; margin: 8px 0 16px; }
.sb-tier__features { flex: 1; margin-bottom: 20px; }
.sb-tier__features li { padding: 6px 0; display: flex; gap: 8px; font-size: 14px; }
.sb-tier__features li::before { content: "✓"; color: var(--sb-primary); font-weight: 700; }
.sb-tier .sb-btn { width: 100%; }

/* FAQ – egen animation, ingen <details>-default */
.sb-faq { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.sb-faq__item { border: 1px solid var(--sb-border); border-radius: var(--sb-radius-sm); background: var(--sb-card); overflow: hidden; }
.sb-faq__btn {
  width: 100%; text-align: left; background: transparent; border: 0;
  padding: 18px 20px; font: inherit; font-weight: 600; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  color: inherit;
}
.sb-faq__btn::after {
  content: ""; flex: 0 0 12px; width: 12px; height: 12px;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg); transition: transform .25s ease; opacity: .6;
}
.sb-faq__item[data-open="true"] .sb-faq__btn::after { transform: rotate(-135deg); }
.sb-faq__panel {
  max-height: 0; overflow: hidden; transition: max-height .3s ease;
  padding: 0 20px;
}
.sb-faq__panel-inner { padding: 0 0 18px; color: var(--sb-muted); }

/* Galleri */
.sb-gallery { display: grid; gap: 14px; max-width: var(--sb-container); margin: 0 auto; }
.sb-gallery img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--sb-radius-sm); }

/* CTA — som default ett mjukt band, inte en skrikig primärfärg. */
.sb-cta {
  position: relative; padding: var(--sb-section-py) 24px; text-align: center;
  background:
    radial-gradient(60% 80% at 50% 0%, color-mix(in oklab, var(--sb-primary) 14%, transparent) 0%, transparent 70%),
    var(--sb-primary-tint);
  color: var(--sb-fg);
}
.sb-cta > .sb-reveal { position: relative; }
.sb-cta h2 { font-size: clamp(28px, 3.8vw, 42px); font-weight: 700; letter-spacing: -.028em; }
.sb-cta p { color: var(--sb-muted); max-width: 620px; margin: 14px auto 28px; font-size: 17px; }
.sb-cta .sb-btn { background: var(--sb-primary); color: var(--sb-primary-fg); }

/* Text-sektion */
.sb-text { max-width: 760px; margin: 0 auto; padding: 64px 24px; }
.sb-text h2 { font-size: clamp(24px, 3vw, 32px); }
.sb-text__body { white-space: pre-wrap; }

/* Kontakt + Formulär (vanilla JS) */
.sb-contact { padding: 80px 24px; max-width: var(--sb-container); margin: 0 auto; }
.sb-contact__grid { display: grid; gap: 40px; grid-template-columns: 1fr 1fr; }
@media (max-width: 800px) { .sb-contact__grid { grid-template-columns: 1fr; } }
.sb-contact__info ul { display: flex; flex-direction: column; gap: 10px; font-size: 15px; }
.sb-form { display: flex; flex-direction: column; gap: 12px; padding: 28px; border: 1px solid var(--sb-border); border-radius: var(--sb-radius); background: var(--sb-card); }
.sb-form label { display: flex; flex-direction: column; gap: 6px; font-size: 13px; font-weight: 500; }
.sb-form input, .sb-form textarea {
  font: inherit; padding: 11px 13px; border-radius: var(--sb-radius-sm);
  border: 1px solid var(--sb-border); background: var(--sb-bg); color: inherit;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.sb-form input:focus, .sb-form textarea:focus {
  outline: none; border-color: var(--sb-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--sb-primary) 20%, transparent);
}
.sb-form__error { color: #c0392b; font-size: 13px; min-height: 18px; }
.sb-form__success {
  background: color-mix(in oklab, var(--sb-primary) 10%, transparent);
  color: var(--sb-primary); border-radius: var(--sb-radius-sm);
  padding: 12px; font-size: 14px; text-align: center; display: none;
}
.sb-form[data-state="sent"] .sb-form__fields { display: none; }
.sb-form[data-state="sent"] .sb-form__success { display: block; }

/* Video */
.sb-video { padding: 64px 24px; max-width: 960px; margin: 0 auto; }
.sb-video__frame { aspect-ratio: 16/9; border-radius: var(--sb-radius); overflow: hidden; background: #000; }
.sb-video__frame iframe { width: 100%; height: 100%; border: 0; }

/* Footer */
.sb-footer { padding: 56px 24px 32px; border-top: 1px solid var(--sb-border); background: color-mix(in oklab, var(--sb-fg) 2%, var(--sb-bg)); }
.sb-footer__grid { display: grid; gap: 32px; grid-template-columns: 1.4fr repeat(3, 1fr); max-width: var(--sb-container); margin: 0 auto; }
@media (max-width: 800px) { .sb-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .sb-footer__grid { grid-template-columns: 1fr; } }
.sb-footer h4 { font-size: 14px; font-weight: 600; margin-bottom: 12px; }
.sb-footer ul { display: flex; flex-direction: column; gap: 8px; font-size: 14px; color: var(--sb-muted); }
.sb-footer a:hover { color: var(--sb-fg); }
.sb-footer__copy { text-align: center; color: var(--sb-muted); font-size: 12px; margin-top: 32px; }

/* Legacy/utility */
.sb-image { width: 100%; border-radius: var(--sb-radius); margin: 16px 0; }
.sb-heading { font-weight: 700; margin: 16px 0; }
.sb-heading--1 { font-size: clamp(32px, 5vw, 48px); }
.sb-heading--2 { font-size: clamp(24px, 3.5vw, 34px); }
.sb-heading--3 { font-size: 22px; }
.sb-heading--4 { font-size: 18px; }
.sb-columns { display: grid; gap: 24px; max-width: var(--sb-container); margin: 0 auto; }

/* ============================================================
   Custom Section block (sb-section--custom)
   ============================================================ */
.sb-section--custom { position: relative; padding: 72px 24px; }
.sb-section--custom.sb-section--muted { background: var(--sb-accent); }
.sb-section--custom.sb-section--primary { background: var(--sb-primary); color: var(--sb-primary-fg); }
.sb-section--custom.sb-section--primary .sb-section__eyebrow,
.sb-section--custom.sb-section--primary .sb-section__subtitle { color: rgba(255,255,255,.85); }

.sb-section__wrap {
  max-width: var(--sb-container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
}
.sb-section--split .sb-section__wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 64px;
}
.sb-section--split.sb-section--img-left  .sb-section__img     { order: 1; }
.sb-section--split.sb-section--img-left  .sb-section__content { order: 2; }
.sb-section--split.sb-section--img-right .sb-section__content { order: 1; }
.sb-section--split.sb-section--img-right .sb-section__img     { order: 2; }
.sb-section--split .sb-section__img,
.sb-section--split .sb-section__content { min-width: 0; width: 100%; }

.sb-section__content { width: 100%; max-width: 760px; }
.sb-section--split .sb-section__content { max-width: none; }
.sb-section.sb-align-left .sb-section__content { text-align: left; margin: 0; }
.sb-section.sb-align-center .sb-section__content { text-align: center; margin: 0 auto; }
.sb-section.sb-align-right .sb-section__content { text-align: right; margin-left: auto; }

.sb-section__eyebrow {
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--sb-primary);
  margin-bottom: 12px;
}
.sb-section__title { font-size: clamp(28px, 4vw, 40px); margin-bottom: 12px; }
.sb-section__subtitle { font-size: 18px; color: var(--sb-muted); margin-bottom: 16px; }
.sb-section__text { white-space: pre-wrap; font-size: 16px; line-height: 1.7; }
.sb-section__img {
  width: 100%;
  height: auto;
  border-radius: var(--sb-radius);
  box-shadow: var(--sb-shadow);
  object-fit: cover;
}
.sb-section__ctas {
  display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px;
}
.sb-section.sb-align-center .sb-section__ctas { justify-content: center; }
.sb-section.sb-align-right .sb-section__ctas { justify-content: flex-end; }
.sb-section__children { max-width: var(--sb-container); margin: 32px auto 0; }

@media (max-width: 860px) {
  .sb-section--split .sb-section__wrap { grid-template-columns: 1fr !important; }
  .sb-section--split .sb-section__img,
  .sb-section--split .sb-section__content { order: 0 !important; }
}

/* ---- Per-block knapp-justering (override) ---- */
.sb-root .sb-ctas--left   { justify-content: flex-start !important; text-align: left; }
.sb-root .sb-ctas--center { justify-content: center     !important; text-align: center; }
.sb-root .sb-ctas--right  { justify-content: flex-end   !important; text-align: right; }

/* Pricing tier knapp-justering */
.sb-root .sb-tier { align-items: stretch; }
.sb-root .sb-tier--btn-left  .sb-btn { align-self: flex-start; width: auto; }
.sb-root .sb-tier--btn-center .sb-btn { align-self: center;    width: auto; }
.sb-root .sb-tier--btn-right .sb-btn { align-self: flex-end;   width: auto; }

/* CTA-block knapp-justering */
.sb-root .sb-cta--btn-left   { text-align: left; }
.sb-root .sb-cta--btn-center { text-align: center; }
.sb-root .sb-cta--btn-right  { text-align: right; }
.sb-root .sb-cta--btn-left   p,
.sb-root .sb-cta--btn-left   h2 { margin-left: 0; }
.sb-root .sb-cta--btn-right  p,
.sb-root .sb-cta--btn-right  h2 { margin-right: 0; margin-left: auto; }

/* ---- Sektion: bildstorlekar ---- */
.sb-root .sb-section__img--sm   { max-width: 240px; margin-left: auto; margin-right: auto; }
.sb-root .sb-section__img--md   { max-width: 420px; margin-left: auto; margin-right: auto; }
.sb-root .sb-section__img--lg   { max-width: 640px; margin-left: auto; margin-right: auto; }
.sb-root .sb-section__img--full { max-width: 100%; }
/* I split-layout får bilden ta sin kolumn fullt ut oavsett storlek */
.sb-root .sb-section--split .sb-section__img {
  max-width: 100%;
  margin: 0;
  aspect-ratio: 4 / 3;
  height: 100%;
  object-fit: cover;
}

/* ============================================================
   Mallar (varianter) per blocktyp.
   Klassen sb-v--<type>-<id> sitter på en wrapper (display:contents)
   runt blocket, så vi kan styla utan att ändra markup.
   v1 = standard (lämnas orörd).
   ============================================================ */

/* ---- NAVBAR ---- */
.sb-root .sb-v--navbar-v2 .sb-nav { flex-direction: column; gap: 12px; padding-top: 18px; padding-bottom: 12px; }
.sb-root .sb-v--navbar-v2 .sb-nav__list { justify-content: center; }
.sb-root .sb-v--navbar-v3 .sb-nav { padding: 8px 24px; font-size: 13px; }
.sb-root .sb-v--navbar-v3 .sb-nav__list { gap: 18px; font-size: 13px; }
.sb-root .sb-v--navbar-v4 .sb-nav {
  margin: 12px auto; max-width: calc(var(--sb-container) - 32px);
  border: 1px solid var(--sb-border); border-radius: 999px;
  box-shadow: var(--sb-shadow); padding: 10px 22px;
}
.sb-root .sb-v--navbar-v5 .sb-nav { background: #0b0f17; color: #fff; border-color: rgba(255,255,255,.1); }
.sb-root .sb-v--navbar-v5 .sb-nav__link:hover { color: #fff; opacity: .8; }

/* ---- HERO ---- */
.sb-root .sb-v--hero-v2 .sb-hero { text-align: left; }
.sb-root .sb-v--hero-v2 .sb-hero__inner { margin: 0; max-width: 720px; }
.sb-root .sb-v--hero-v2 .sb-hero__subtitle { margin-left: 0; }
.sb-root .sb-v--hero-v2 .sb-hero__ctas { justify-content: flex-start; }
.sb-root .sb-v--hero-v3 .sb-hero { padding: 140px 24px; }
.sb-root .sb-v--hero-v3 .sb-hero__title { font-size: clamp(48px, 8vw, 88px); letter-spacing: -.03em; }
.sb-root .sb-v--hero-v4 .sb-hero { padding: 56px 24px; }
.sb-root .sb-v--hero-v4 .sb-hero__badge { display: none; }
.sb-root .sb-v--hero-v4 .sb-hero__title { font-size: clamp(26px, 4vw, 40px); }
.sb-root .sb-v--hero-v5 .sb-hero { background: #0b0f17; color: #fff; }
.sb-root .sb-v--hero-v5 .sb-hero__subtitle { color: rgba(255,255,255,.85); }
.sb-root .sb-v--hero-v5 .sb-hero__badge { background: rgba(255,255,255,.12); color: #fff; }

/* ---- FEATURES ---- */
.sb-root .sb-v--features-v2 .sb-card { border-width: 2px; }
.sb-root .sb-v--features-v3 .sb-grid { grid-template-columns: 1fr; max-width: 760px; }
.sb-root .sb-v--features-v3 .sb-card { display: flex; gap: 22px; align-items: flex-start; padding: 22px 24px; }
.sb-root .sb-v--features-v3 .sb-feature__icon { margin: 0; flex-shrink: 0; }
.sb-root .sb-v--features-v4 .sb-card { background: transparent; border: 0; padding: 12px; }
.sb-root .sb-v--features-v4 .sb-feature__icon { width: 36px; height: 36px; background: transparent; }
.sb-root .sb-v--features-v5 .sb-card { text-align: center; }
.sb-root .sb-v--features-v5 .sb-feature__icon { margin-left: auto; margin-right: auto; }

/* ---- STATS ---- */
.sb-root .sb-v--stats-v2 .sb-stats { grid-template-columns: repeat(4, auto); justify-content: space-around; }
.sb-root .sb-v--stats-v3 .sb-section__head { text-align: left; max-width: var(--sb-container); margin-left: auto; margin-right: auto; }
.sb-root .sb-v--stats-v4 .sb-stats > div { background: var(--sb-card); border: 1px solid var(--sb-border); padding: 24px 16px; border-radius: var(--sb-radius); }
.sb-root .sb-v--stats-v5 .sb-stat__value { font-size: clamp(40px, 6vw, 64px); }

/* ---- TESTIMONIALS ---- */
.sb-root .sb-v--testimonials-v2 .sb-grid { grid-template-columns: 1fr; max-width: 760px; }
.sb-root .sb-v--testimonials-v2 .sb-card { text-align: center; padding: 40px; }
.sb-root .sb-v--testimonials-v2 .sb-quote { font-size: 22px; }
.sb-root .sb-v--testimonials-v3 .sb-card { border-width: 2px; border-color: var(--sb-primary); }
.sb-root .sb-v--testimonials-v4 .sb-grid { grid-template-columns: 1fr 1fr; }
.sb-root .sb-v--testimonials-v5 .sb-card { background: transparent; border: 0; padding: 12px; }

/* ---- PRICING ---- */
.sb-root .sb-v--pricing-v2 .sb-card { border-width: 2px; }
.sb-root .sb-v--pricing-v3 .sb-grid > :nth-child(2) .sb-card { border: 2px solid var(--sb-primary); transform: scale(1.04); box-shadow: var(--sb-shadow); }
.sb-root .sb-v--pricing-v4 .sb-card { padding: 18px; }
.sb-root .sb-v--pricing-v4 .sb-tier__price { font-size: 28px; }
.sb-root .sb-v--pricing-v5 .sb-card { background: transparent; border: 0; padding: 12px; }

/* ---- FAQ ---- */
.sb-root .sb-v--faq-v2 .sb-faq { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; max-width: var(--sb-container); }
@media (max-width: 720px) { .sb-root .sb-v--faq-v2 .sb-faq { grid-template-columns: 1fr; } }
.sb-root .sb-v--faq-v3 .sb-faq__item { box-shadow: var(--sb-shadow); }
.sb-root .sb-v--faq-v4 .sb-faq { counter-reset: faq; }
.sb-root .sb-v--faq-v4 .sb-faq__item { counter-increment: faq; }
.sb-root .sb-v--faq-v4 .sb-faq__btn::before {
  content: counter(faq, decimal-leading-zero);
  margin-right: 14px; color: var(--sb-primary); font-weight: 700;
}
.sb-root .sb-v--faq-v5 .sb-faq__item { background: transparent; border: 0; border-bottom: 1px solid var(--sb-border); border-radius: 0; }

/* ---- GALLERY ---- */
.sb-root .sb-v--gallery-v2 .sb-gallery > :nth-child(odd) { grid-column: span 2; }
.sb-root .sb-v--gallery-v3 .sb-gallery img { aspect-ratio: auto; height: auto; }
.sb-root .sb-v--gallery-v3 .sb-gallery > :nth-child(3n) img { aspect-ratio: 3/4; }
.sb-root .sb-v--gallery-v4 .sb-gallery img { border: 4px solid var(--sb-bg); box-shadow: var(--sb-shadow); }
.sb-root .sb-v--gallery-v5 .sb-gallery img { border-radius: 50%; aspect-ratio: 1/1; }

/* ---- CTA ---- */
.sb-root .sb-v--cta-v2 .sb-cta { background: transparent; color: var(--sb-fg); }
.sb-root .sb-v--cta-v2 .sb-cta .sb-btn { background: var(--sb-primary); color: var(--sb-primary-fg); }
.sb-root .sb-v--cta-v3 .sb-cta {
  background: var(--sb-card); color: var(--sb-fg);
  max-width: calc(var(--sb-container) - 64px); margin: 32px auto;
  border: 1px solid var(--sb-border); border-radius: var(--sb-radius);
}
.sb-root .sb-v--cta-v3 .sb-cta .sb-btn { background: var(--sb-primary); color: var(--sb-primary-fg); }
.sb-root .sb-v--cta-v4 .sb-cta {
  display: flex; align-items: center; justify-content: space-between; gap: 40px; text-align: left;
  max-width: var(--sb-container); margin: 0 auto;
}
.sb-root .sb-v--cta-v4 .sb-cta p { margin: 8px 0 0; }
@media (max-width: 720px) { .sb-root .sb-v--cta-v4 .sb-cta { flex-direction: column; text-align: center; } }
.sb-root .sb-v--cta-v5 .sb-cta { background: #0b0f17; color: #fff; }
.sb-root .sb-v--cta-v5 .sb-cta .sb-btn { background: #fff; color: #0b0f17; }

/* ---- SECTION ---- */
.sb-root .sb-v--section-v2 .sb-section--custom { text-align: center; }
.sb-root .sb-v--section-v3 .sb-section--custom .sb-section__wrap {
  background: var(--sb-card); border: 1px solid var(--sb-border);
  border-radius: var(--sb-radius); padding: 40px; box-shadow: var(--sb-shadow);
}
.sb-root .sb-v--section-v4 .sb-section--custom { background: #0b0f17; color: #fff; }
.sb-root .sb-v--section-v4 .sb-section--custom .sb-section__subtitle,
.sb-root .sb-v--section-v4 .sb-section--custom .sb-section__text { color: rgba(255,255,255,.85); }
.sb-root .sb-v--section-v5 .sb-section__img { max-width: 100% !important; border-radius: 0; }

/* ---- TEXT ---- */
.sb-root .sb-v--text-v2 .sb-text { max-width: 1080px; }
.sb-root .sb-v--text-v3 .sb-text {
  background: var(--sb-card); border: 1px solid var(--sb-border);
  border-radius: var(--sb-radius); padding: 40px;
}
.sb-root .sb-v--text-v4 .sb-text { background: var(--sb-accent); padding: 64px 40px; }
.sb-root .sb-v--text-v5 .sb-text { text-align: center; }

/* ---- CONTACT ---- */
.sb-root .sb-v--contact-v2 .sb-contact__grid { grid-template-columns: 1fr; max-width: 640px; margin: 0 auto; text-align: center; }
.sb-root .sb-v--contact-v3 .sb-contact {
  background: var(--sb-card); border: 1px solid var(--sb-border);
  border-radius: var(--sb-radius); padding: 40px;
}
.sb-root .sb-v--contact-v4 .sb-form { background: transparent; border: 0; padding: 0; }
.sb-root .sb-v--contact-v5 .sb-contact { max-width: 100%; }

/* ---- VIDEO ---- */
.sb-root .sb-v--video-v2 .sb-video { max-width: 720px; }
.sb-root .sb-v--video-v3 .sb-video__frame { border: 8px solid var(--sb-card); box-shadow: var(--sb-shadow); }
.sb-root .sb-v--video-v4 .sb-video { max-width: 100%; padding: 0; }
.sb-root .sb-v--video-v4 .sb-video__frame { border-radius: 0; }
.sb-root .sb-v--video-v5 .sb-video { padding: 24px; }

/* ---- FOOTER ---- */
.sb-root .sb-v--footer-v2 .sb-footer__grid { display: none; }
.sb-root .sb-v--footer-v2 .sb-footer { padding: 24px; }
.sb-root .sb-v--footer-v3 .sb-footer { background: #0b0f17; color: #fff; border-color: rgba(255,255,255,.1); }
.sb-root .sb-v--footer-v3 .sb-footer a:hover { color: #fff; opacity: .8; }
.sb-root .sb-v--footer-v4 .sb-footer__grid { text-align: center; }
.sb-root .sb-v--footer-v4 .sb-footer ul { align-items: center; }
.sb-root .sb-v--footer-v5 .sb-footer { padding: 96px 24px 32px; }
.sb-root .sb-v--footer-v5 .sb-footer__grid > :first-child { grid-column: 1 / -1; text-align: center; margin-bottom: 24px; }

/* ============================================================
   Mörka varianter – tvinga ljus text på allt innehåll
   ============================================================ */
.sb-root .sb-v--navbar-v5,
.sb-root .sb-v--hero-v5,
.sb-root .sb-v--cta-v5,
.sb-root .sb-v--section-v4,
.sb-root .sb-v--footer-v3 {
  --sb-fg: #ffffff;
  --sb-muted: rgba(255,255,255,.75);
  --sb-border: rgba(255,255,255,.15);
  --sb-card: rgba(255,255,255,.06);
  --sb-accent: rgba(255,255,255,.08);
  --sb-bg: #0b0f17;
}
.sb-root .sb-v--navbar-v5 .sb-nav,
.sb-root .sb-v--navbar-v5 .sb-nav a,
.sb-root .sb-v--navbar-v5 .sb-nav__link,
.sb-root .sb-v--hero-v5 .sb-hero,
.sb-root .sb-v--hero-v5 .sb-hero h1,
.sb-root .sb-v--hero-v5 .sb-hero h2,
.sb-root .sb-v--hero-v5 .sb-hero p,
.sb-root .sb-v--cta-v5 .sb-cta,
.sb-root .sb-v--cta-v5 .sb-cta h2,
.sb-root .sb-v--cta-v5 .sb-cta p,
.sb-root .sb-v--section-v4 .sb-section--custom,
.sb-root .sb-v--section-v4 .sb-section--custom h1,
.sb-root .sb-v--section-v4 .sb-section--custom h2,
.sb-root .sb-v--section-v4 .sb-section--custom h3,
.sb-root .sb-v--section-v4 .sb-section--custom p,
.sb-root .sb-v--section-v4 .sb-section--custom li,
.sb-root .sb-v--section-v4 .sb-section--custom a,
.sb-root .sb-v--footer-v3 .sb-footer,
.sb-root .sb-v--footer-v3 .sb-footer a,
.sb-root .sb-v--footer-v3 .sb-footer li,
.sb-root .sb-v--footer-v3 .sb-footer p { color: #ffffff; }

.sb-root .sb-v--hero-v5 .sb-hero__subtitle,
.sb-root .sb-v--section-v4 .sb-section__subtitle,
.sb-root .sb-v--section-v4 .sb-section__text,
.sb-root .sb-v--footer-v3 .sb-footer p,
.sb-root .sb-v--footer-v3 .sb-footer li,
.sb-root .sb-v--cta-v5 .sb-cta p { color: rgba(255,255,255,.85); }

/* ============================================================
   Drop indicator + drag handle (används av redigeraren)
   ============================================================ */
.sb-dropzone {
  height: 6px; margin: 0; transition: height .15s ease, background .15s ease;
  position: relative;
}
.sb-dropzone--ready { height: 20px; background: color-mix(in oklab, #3b82f6 6%, transparent); }
.sb-dropzone--active { height: 36px; background: color-mix(in oklab, #3b82f6 16%, transparent); }
.sb-dropzone--active::after {
  content: ""; position: absolute; left: 8px; right: 8px; top: 50%;
  height: 3px; background: #3b82f6; border-radius: 2px; transform: translateY(-50%);
}

/* ============================================================
   Per-block "Utseende" (appearance) — bgShade, bgTone, accentStrength.
   Wrappern .sb-blockwrap sätter CSS-variabler och data-attribut.
   ============================================================ */

/* Shade-toner: byter blockets bas-färg och textfärg. Vi cascadar
   CSS-variablerna via wrappern, vilket fungerar även när wrappern
   har display:contents. */
.sb-root .sb-blockwrap[data-shade="light"] {
  --sb-bg: #ffffff;
  --sb-fg: #0b1020;
  --sb-muted: color-mix(in oklab, #0b1020 58%, transparent);
  --sb-border: color-mix(in oklab, #0b1020 10%, transparent);
  --sb-card: color-mix(in oklab, #0b1020 2.5%, #ffffff);
}
.sb-root .sb-blockwrap[data-shade="tinted"] {
  --sb-bg: var(--sb-primary-tint);
  --sb-fg: #0b1020;
  --sb-muted: color-mix(in oklab, #0b1020 55%, transparent);
  --sb-border: color-mix(in oklab, var(--sb-primary) 16%, transparent);
  --sb-card: color-mix(in oklab, var(--sb-primary) 4%, #ffffff);
}
.sb-root .sb-blockwrap[data-shade="muted"] {
  --sb-bg: #f6f7fa;
  --sb-fg: #0b1020;
  --sb-muted: color-mix(in oklab, #0b1020 58%, transparent);
  --sb-border: color-mix(in oklab, #0b1020 8%, transparent);
  --sb-card: #ffffff;
}
.sb-root .sb-blockwrap[data-shade="dark"] {
  --sb-bg: #0b1020;
  --sb-fg: #ffffff;
  --sb-muted: rgba(255,255,255,.72);
  --sb-border: rgba(255,255,255,.12);
  --sb-card: rgba(255,255,255,.05);
  --sb-accent: rgba(255,255,255,.08);
}

/* När shade != standard målar vi det yttersta block-elementet med basfärgen,
   så att färgen syns även för sektioner som annars ärver sidans bakgrund. */
.sb-root .sb-blockwrap[data-paint="1"] > nav,
.sb-root .sb-blockwrap[data-paint="1"] > section,
.sb-root .sb-blockwrap[data-paint="1"] > footer,
.sb-root .sb-blockwrap[data-paint="1"] > div {
  background: var(--sb-bg);
  color: var(--sb-fg);
}

/* Tvinga vit text på alla rubrik-/textbarn vid mörk shade — utan att röra
   befintliga klassnamn. */
.sb-root .sb-blockwrap[data-shade="dark"] h1,
.sb-root .sb-blockwrap[data-shade="dark"] h2,
.sb-root .sb-blockwrap[data-shade="dark"] h3,
.sb-root .sb-blockwrap[data-shade="dark"] h4,
.sb-root .sb-blockwrap[data-shade="dark"] a,
.sb-root .sb-blockwrap[data-shade="dark"] li,
.sb-root .sb-blockwrap[data-shade="dark"] label,
.sb-root .sb-blockwrap[data-shade="dark"] strong { color: #ffffff; }
.sb-root .sb-blockwrap[data-shade="dark"] p,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-section__subtitle,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-section__text,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-hero__subtitle,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-quote,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-feature p,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-tier__features li { color: rgba(255,255,255,.85); }
.sb-root .sb-blockwrap[data-shade="dark"] .sb-card {
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.1);
}
.sb-root .sb-blockwrap[data-shade="dark"] .sb-form input,
.sb-root .sb-blockwrap[data-shade="dark"] .sb-form textarea {
  background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.15); color: #fff;
}

/* ============================================================
   Fler mallar (v6–v8) — moderna alternativ utan att röra markup.
   ============================================================ */

/* Hero v6: gradient mesh + glaspill */
.sb-root .sb-v--hero-v6 .sb-hero {
  background:
    radial-gradient(40% 60% at 20% 10%, color-mix(in oklab, var(--sb-primary) 22%, transparent), transparent 70%),
    radial-gradient(50% 70% at 90% 30%, color-mix(in oklab, var(--sb-primary) 14%, transparent), transparent 70%),
    radial-gradient(40% 50% at 50% 100%, color-mix(in oklab, var(--sb-fg) 8%, transparent), transparent 70%),
    var(--sb-bg);
}
.sb-root .sb-v--hero-v6 .sb-hero__inner { backdrop-filter: blur(2px); }

/* Hero v7: split — text vänster, "stor siffra"-aura höger via ::after */
.sb-root .sb-v--hero-v7 .sb-hero { text-align: left; padding-block: calc(var(--sb-section-py) + 24px); }
.sb-root .sb-v--hero-v7 .sb-hero__inner { margin: 0; max-width: 720px; padding-right: 6vw; }
.sb-root .sb-v--hero-v7 .sb-hero__subtitle { margin-left: 0; }
.sb-root .sb-v--hero-v7 .sb-hero__ctas { justify-content: flex-start; }
.sb-root .sb-v--hero-v7 .sb-hero::after {
  content: ""; position: absolute; top: 50%; right: -10%; width: 60vmin; height: 60vmin;
  border-radius: 50%; transform: translateY(-50%);
  background: radial-gradient(circle at 30% 30%, color-mix(in oklab, var(--sb-primary) 35%, transparent), transparent 65%);
  filter: blur(20px); pointer-events: none;
}

/* Hero v8: editorial serif-känsla */
.sb-root .sb-v--hero-v8 .sb-hero__title { font-family: "Fraunces", "Cormorant Garamond", Georgia, serif; font-weight: 500; letter-spacing: -.04em; }
.sb-root .sb-v--hero-v8 .sb-hero__badge { background: transparent; border-color: var(--sb-border); color: var(--sb-fg); }
.sb-root .sb-v--hero-v8 .sb-hero__badge::before { background: var(--sb-fg); box-shadow: 0 0 0 4px color-mix(in oklab, var(--sb-fg) 18%, transparent); }

/* Navbar v6: glasstreck — flytande och transparent */
.sb-root .sb-v--navbar-v6 .sb-nav {
  background: color-mix(in oklab, var(--sb-bg) 70%, transparent);
  backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid color-mix(in oklab, var(--sb-fg) 6%, transparent);
}
/* Navbar v7: stor logga centrerad, länkar undertill, editorial */
.sb-root .sb-v--navbar-v7 .sb-nav {
  flex-direction: column; gap: 18px; padding-block: 24px;
  border-bottom: 1px solid var(--sb-border);
}
.sb-root .sb-v--navbar-v7 .sb-nav__brand { font-family: "Fraunces", Georgia, serif; font-size: 28px; }
.sb-root .sb-v--navbar-v7 .sb-nav__list { gap: 36px; text-transform: uppercase; font-size: 12.5px; letter-spacing: .14em; }

/* Features v6: bento — varierad cellbredd */
.sb-root .sb-v--features-v6 .sb-grid {
  grid-template-columns: repeat(6, 1fr);
}
.sb-root .sb-v--features-v6 .sb-grid > * { grid-column: span 2; }
.sb-root .sb-v--features-v6 .sb-grid > :first-child { grid-column: span 4; grid-row: span 2; }
@media (max-width: 900px) {
  .sb-root .sb-v--features-v6 .sb-grid { grid-template-columns: 1fr; }
  .sb-root .sb-v--features-v6 .sb-grid > * { grid-column: auto; grid-row: auto; }
}
/* Features v7: numrerade kort */
.sb-root .sb-v--features-v7 .sb-card { position: relative; padding-top: 56px; }
.sb-root .sb-v--features-v7 .sb-feature__icon { display: none; }
.sb-root .sb-v--features-v7 .sb-grid { counter-reset: feat; }
.sb-root .sb-v--features-v7 .sb-card { counter-increment: feat; }
.sb-root .sb-v--features-v7 .sb-card::before {
  content: counter(feat, decimal-leading-zero);
  position: absolute; top: 22px; left: 28px;
  font-family: var(--sb-font-display); font-size: 28px; font-weight: 700;
  color: var(--sb-primary); letter-spacing: -.02em;
}
/* Features v8: glas + gradient */
.sb-root .sb-v--features-v8 .sb-card {
  background: linear-gradient(180deg, color-mix(in oklab, var(--sb-primary) 4%, var(--sb-bg)), var(--sb-card));
  border-color: color-mix(in oklab, var(--sb-primary) 18%, transparent);
}

/* Testimonials v6: stort serif-citat */
.sb-root .sb-v--testimonials-v6 .sb-grid { grid-template-columns: 1fr; max-width: 840px; }
.sb-root .sb-v--testimonials-v6 .sb-card { background: transparent; border: 0; text-align: center; padding: 24px; }
.sb-root .sb-v--testimonials-v6 .sb-quote { font-family: "Fraunces", Georgia, serif; font-size: clamp(22px, 3vw, 32px); font-style: normal; line-height: 1.3; }

/* Pricing v6: två kort centrerade, mittenframhävd via gradient */
.sb-root .sb-v--pricing-v6 .sb-grid > :nth-child(2) .sb-card {
  background: linear-gradient(160deg, color-mix(in oklab, var(--sb-primary) 14%, var(--sb-bg)), var(--sb-card));
  border-color: color-mix(in oklab, var(--sb-primary) 35%, transparent);
  box-shadow: var(--sb-shadow-lg);
}

/* CTA v6: glas-kort med gradient-border */
.sb-root .sb-v--cta-v6 .sb-cta {
  background: var(--sb-bg);
  max-width: calc(var(--sb-container) - 48px); margin: 32px auto;
  border-radius: calc(var(--sb-radius) + 4px);
  padding: 56px 32px;
  position: relative; overflow: hidden;
}
.sb-root .sb-v--cta-v6 .sb-cta::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1.5px;
  background: linear-gradient(135deg, color-mix(in oklab, var(--sb-primary) 70%, transparent), transparent 60%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events: none;
}

/* Section v6: stor numrerad eyebrow */
.sb-root .sb-v--section-v6 .sb-section__eyebrow {
  font-family: var(--sb-font-display); font-size: 64px; font-weight: 700;
  letter-spacing: -.04em; text-transform: none;
  color: color-mix(in oklab, var(--sb-primary) 60%, transparent);
  line-height: 1; margin-bottom: 18px;
}

/* Footer v6: minimal centrerad */
.sb-root .sb-v--footer-v6 .sb-footer { padding: 40px 24px; text-align: center; }
.sb-root .sb-v--footer-v6 .sb-footer__grid { display: flex; flex-direction: column; gap: 16px; }

/* Gallery v6: cinematisk 21:9-rad */
.sb-root .sb-v--gallery-v6 .sb-gallery img { aspect-ratio: 21/9; }

/* FAQ v6: stor serif */
.sb-root .sb-v--faq-v6 .sb-faq__btn { font-family: "Fraunces", Georgia, serif; font-size: 19px; font-weight: 500; }

/* Text v6: dropcap */
.sb-root .sb-v--text-v6 .sb-text__body::first-letter {
  font-family: "Fraunces", Georgia, serif; font-size: 64px; line-height: .9;
  float: left; padding: 4px 14px 0 0; color: var(--sb-primary); font-weight: 600;
}

/* Contact v6: stort split med stor info */
.sb-root .sb-v--contact-v6 .sb-contact__grid { grid-template-columns: 1.4fr 1fr; gap: 80px; }
.sb-root .sb-v--contact-v6 .sb-contact__info h2 { font-size: clamp(32px, 4vw, 48px); }

/* Video v6: rundad och stor */
.sb-root .sb-v--video-v6 .sb-video__frame { border-radius: 24px; box-shadow: var(--sb-shadow-lg); }

/* Stats v6: stor primärfärg, transparent */
.sb-root .sb-v--stats-v6 .sb-stats > div { padding: 32px 8px; }
.sb-root .sb-v--stats-v6 .sb-stat__value { font-size: clamp(48px, 7vw, 80px); }

/* ===== Hero v9 — editorial center (Smörgåskällan-stil) ===== */
.sb-root .sb-hero__kicker {
  display: inline-block;
  font-family: var(--sb-font-body, inherit);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: color-mix(in oklab, var(--sb-accent, #c9a84c) 90%, #fff);
  margin-bottom: 18px;
  opacity: 0.92;
}
.sb-root .sb-v--hero-v9 .sb-hero { padding: clamp(120px, 18vh, 200px) 24px; min-height: 92vh; }
.sb-root .sb-v--hero-v9 .sb-hero__inner { max-width: 880px; }
.sb-root .sb-v--hero-v9 .sb-hero__title {
  font-family: var(--sb-font-display, "Fraunces", "Playfair Display", "Cormorant Garamond", Georgia, serif);
  font-weight: 500;
  font-size: clamp(48px, 7.5vw, 96px);
  line-height: 1.02;
  letter-spacing: -0.02em;
}
.sb-root .sb-v--hero-v9 .sb-hero__subtitle {
  font-family: var(--sb-font-body, inherit);
  text-transform: none;
  font-size: clamp(15px, 1.4vw, 18px);
  letter-spacing: 0.04em;
  max-width: 580px;
  line-height: 1.6;
  opacity: 0.92;
}
.sb-root .sb-v--hero-v9 .sb-hero--image .sb-hero__overlay {
  background: linear-gradient(180deg, rgba(8,8,10,0.55) 0%, rgba(8,8,10,0.78) 60%, rgba(8,8,10,0.85) 100%);
}
.sb-root .sb-v--hero-v9 .sb-hero__divider {
  display: inline-block;
  width: 48px;
  height: 1px;
  margin: 24px auto;
  background: color-mix(in oklab, var(--sb-accent, #c9a84c) 80%, #fff);
  opacity: 0.9;
}
.sb-root .sb-v--hero-v9 .sb-hero__ctas { margin-top: 36px; gap: 14px; }
.sb-root .sb-v--hero-v9 .sb-btn--on-image,
.sb-root .sb-v--hero-v9 .sb-btn--ghost {
  border: 1px solid rgba(255,255,255,0.7);
  background: transparent;
  color: #fff;
  backdrop-filter: blur(4px);
}

/* ===== Navbar v7 — utility bar + centered logo ===== */
.sb-root .sb-nav__utility {
  background: #0c0c0e;
  color: rgba(255,255,255,0.82);
  font-size: 12.5px;
  letter-spacing: 0.04em;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.sb-root .sb-nav__utility-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 8px 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.sb-root .sb-nav__utility-spacer { flex: 1; }
.sb-root .sb-nav__utility-item {
  color: inherit;
  text-decoration: none;
  white-space: nowrap;
}
.sb-root .sb-nav__utility-item:hover { color: #fff; }
.sb-root .sb-nav__brand-text { display: inline-flex; flex-direction: column; align-items: flex-start; line-height: 1.1; }
.sb-root .sb-nav__brand-tagline {
  font-size: 10.5px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  font-weight: 500;
  opacity: 0.7;
  margin-top: 2px;
  font-family: var(--sb-font-body, inherit);
}
.sb-root .sb-v--navbar-v7 .sb-nav { justify-content: center; flex-direction: column; gap: 14px; padding-top: 22px; padding-bottom: 18px; }
.sb-root .sb-v--navbar-v7 .sb-nav__brand { align-items: center; }
.sb-root .sb-v--navbar-v7 .sb-nav__brand-text { align-items: center; text-align: center; }
.sb-root .sb-v--navbar-v7 .sb-nav__list { justify-content: center; gap: 28px; }

/* ============================================================
   MENU block (restaurang / café / bar)
   ============================================================ */
.sb-root .sb-menu { background: var(--sb-bg); }
.sb-root .sb-menu__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: clamp(32px, 5vw, 80px);
  align-items: start;
}
@media (max-width: 900px) {
  .sb-root .sb-menu__layout { grid-template-columns: 1fr; }
}
.sb-root .sb-menu__hero {
  position: relative;
  margin: 0;
  border-radius: 6px;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: color-mix(in oklab, var(--sb-fg) 6%, var(--sb-bg));
}
.sb-root .sb-menu__hero img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.sb-root .sb-menu__badge {
  position: absolute;
  right: 24px; bottom: 24px;
  padding: 14px 22px;
  background: var(--sb-bg);
  color: var(--sb-primary);
  font-family: var(--sb-font-heading, inherit);
  font-size: 13px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  border: 1px solid color-mix(in oklab, var(--sb-primary) 35%, transparent);
  border-radius: 2px;
  white-space: pre-line;
  text-align: center;
  line-height: 1.6;
}
.sb-root .sb-menu__body { padding-top: 8px; }
.sb-root .sb-menu__eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--sb-primary);
  font-weight: 600;
  margin-bottom: 18px;
}
.sb-root .sb-menu__title {
  font-family: var(--sb-font-heading, inherit);
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.05;
  margin: 0 0 18px;
  font-weight: 400;
}
.sb-root .sb-menu__rule {
  display: block;
  width: 64px;
  height: 1px;
  background: color-mix(in oklab, var(--sb-primary) 70%, transparent);
  margin: 0 0 28px;
}
.sb-root .sb-menu__intro {
  opacity: 0.78;
  margin: 0 0 32px;
  max-width: 56ch;
}
.sb-root .sb-menu__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.sb-root .sb-menu__row {
  display: grid;
  grid-template-columns: max-content 1fr max-content;
  align-items: end;
  gap: 14px;
}
.sb-root .sb-menu__name {
  font-family: var(--sb-font-heading, inherit);
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.2;
}
.sb-root .sb-menu__dots {
  display: block;
  height: 1px;
  margin-bottom: 8px;
  background-image: radial-gradient(circle, color-mix(in oklab, var(--sb-primary) 60%, transparent) 1px, transparent 1.5px);
  background-size: 6px 1px;
  background-repeat: repeat-x;
  background-position: 0 center;
  opacity: 0.85;
}
.sb-root .sb-menu__price {
  color: var(--sb-primary);
  font-weight: 600;
  letter-spacing: 0.04em;
  font-size: clamp(15px, 1.3vw, 17px);
}
.sb-root .sb-menu__desc {
  grid-column: 1 / -1;
  opacity: 0.6;
  font-size: 14px;
  margin-top: -4px;
}
.sb-root .sb-menu__phone {
  margin-top: 40px;
  padding: 28px 28px 26px;
  border: 1px solid color-mix(in oklab, var(--sb-primary) 30%, transparent);
  border-radius: 4px;
  max-width: 420px;
}
.sb-root .sb-menu__phone .sb-menu__eyebrow { margin-bottom: 14px; }
.sb-root .sb-menu__phone-text { margin: 0 0 18px; opacity: 0.85; }
.sb-root .sb-menu__phone-num {
  color: var(--sb-primary);
  text-decoration: none;
  font-size: 18px;
  letter-spacing: 0.16em;
  font-weight: 500;
}
.sb-root .sb-menu__phone-num:hover { text-decoration: underline; }

/* Variant v2: card grid */
.sb-root .sb-menu-card { padding: 0; overflow: hidden; }
.sb-root .sb-menu-card__image { display: block; aspect-ratio: 4 / 3; overflow: hidden; }
.sb-root .sb-menu-card__image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.sb-root .sb-menu-card__body { padding: 20px 22px 22px; }
.sb-root .sb-menu-card__desc { opacity: 0.7; margin: 8px 0 0; font-size: 14px; }
