/* =====================================================================
   Magnus Företagsredovisning - Designsystem v2 ("editorial teal")
   Används tills vidare endast av index.html (startsidan).
   Färg & typografi enligt designbrief ny6.
   ===================================================================== */

:root{
  --teal:      #0d4241;  /* primär - mörka sektioner + rubriker på ljus botten */
  --teal-deep: #0a3332;  /* mörkare teal - hover/footer */
  --sand:      #ebb67a;  /* accent - knappar, eyebrow, highlights */
  --sand-deep: #cf9351;  /* sand hover */
  --cream:     #f7dec1;  /* ljus sektionsbakgrund */
  --cream-50:  #ffeedb;  /* allra ljusaste grädde */
  --gray-bg:   #e8e6e6;  /* ljusgrå botten för innehållssidor */
  --ink:       #2a2a2a;  /* brödtext på ljus botten */
  --ink-soft:  #5f5f5f;  /* sekundär text */
  --line:      #e8e6e6;  /* avgränsare/kanter */
  --white:     #ffffff;

  --serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --sans:  "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --wrap: 1160px;
  --radius: 14px;
  --radius-sm: 10px;
  --shadow: 0 8px 24px rgba(13,66,65,.08);
  --shadow-lg: 0 18px 50px rgba(13,66,65,.14);
  --pad-section: 112px;
}

/* ---------- Reset & bas ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:84px; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--cream-50);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
h1,h2,h3,h4{ margin:0; font-family:var(--serif); font-weight:700; color:var(--teal); line-height:1.12; letter-spacing:-.01em; }
p{ margin:0; }

.wrap{ width:100%; max-width:var(--wrap); margin:0 auto; padding:0 24px; }

/* ---------- Eyebrow / etiketter ---------- */
.eyebrow{
  display:inline-block;
  font-size:13px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--sand-deep);
  margin-bottom:16px;
}
.teal .eyebrow,
.hero .eyebrow,
.site-footer .eyebrow{ color:var(--sand); }

/* ---------- Knappar ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--sans); font-weight:600; font-size:15px;
  padding:14px 26px; border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:transform .15s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn svg{ transition:transform .2s ease; }
.btn:hover svg{ transform:translateX(3px); }
.btn:active{ transform:translateY(1px); }

/* sand-knapp (på teal-sektion) */
.btn--sand{ background:var(--sand); color:var(--teal-deep); }
.btn--sand:hover{ background:var(--sand-deep); box-shadow:0 10px 24px rgba(235,182,122,.3); }

/* teal-knapp (på grädde-sektion) */
.btn--teal{ background:var(--teal); color:var(--white); }
.btn--teal:hover{ background:var(--teal-deep); box-shadow:0 10px 24px rgba(13,66,65,.22); }

/* ghost */
.btn--ghost{ background:transparent; border-color:rgba(255,255,255,.4); color:var(--white); }
.btn--ghost:hover{ border-color:var(--white); background:rgba(255,255,255,.08); }
.cream .btn--ghost,
.section.cream .btn--ghost{ border-color:rgba(13,66,65,.3); color:var(--teal); }
.cream .btn--ghost:hover{ border-color:var(--teal); background:rgba(13,66,65,.05); }

/* ---------- Sektioner ---------- */
.section{ padding:var(--pad-section) 0; }
.section.cream{ background:var(--cream); }
.section.teal{ background:var(--teal); color:var(--cream-50); }
.section.center{ text-align:center; }

.section-head{ max-width:680px; margin:0 auto 56px; }
.section.center .section-head{ text-align:center; }
.section-title{ font-size:38px; }
.teal .section-title{ color:var(--white); }
.section-sub{ margin-top:16px; font-size:17px; color:var(--ink-soft); }
.teal .section-sub{ color:rgba(255,255,255,.82); }

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:60;
  background:transparent;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding:8px 0;
}
.site-header.scrolled{
  background:var(--teal-deep);
  box-shadow:0 6px 24px rgba(10,51,50,.28);
}
.site-header .nav{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

.brand{ display:inline-flex; align-items:center; gap:12px; font-family:var(--serif); font-weight:700; font-size:22px; color:var(--white); line-height:1.05; }
.brand-mark{ width:34px; height:34px; flex:0 0 auto; color:var(--white); }
.brand-mark svg{ width:100%; height:100%; }
.brand small{ display:block; font-family:var(--sans); font-weight:500; font-size:12px; letter-spacing:.02em; color:var(--sand); }

.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-size:15px; font-weight:500; color:rgba(255,255,255,.86);
  padding:9px 14px; border-radius:8px; transition:color .15s ease, background .15s ease;
}
.nav-links a:hover{ color:var(--white); background:rgba(255,255,255,.08); }
.nav-links a.active{ color:var(--sand); }
.nav-links .nav-cta{
  margin-left:8px; background:var(--sand); color:var(--teal-deep); font-weight:600;
  padding:10px 18px; border-radius:999px; display:inline-flex; align-items:center; gap:7px;
}
.nav-links .nav-cta:hover{ background:var(--sand-deep); color:var(--teal-deep); }

.menu-toggle{
  display:none; width:44px; height:44px; border:0; background:transparent; cursor:pointer;
  flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.menu-toggle span{ display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:transform .25s ease, opacity .2s ease; }
.menu-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =====================================================================
   HERO (teal)
   ===================================================================== */
.hero{
  position:relative; background:var(--teal); color:var(--cream-50);
  padding:124px 0 56px; overflow:hidden;
}
.hero::after{ /* subtil ljusgloria, ingen "AI-glow": mjuk radial */
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(900px 420px at 78% -10%, rgba(235,182,122,.12), transparent 60%);
}
.hero .wrap{ position:relative; z-index:1; }
.hero h1{ color:var(--white); font-size:60px; max-width:14ch; }
.hero-sub{ margin-top:22px; max-width:60ch; font-size:18px; color:rgba(255,255,255,.85); }
.hero-actions{ margin-top:32px; display:flex; flex-wrap:wrap; gap:14px; }

/* bransch-väljare (behålls från nya sajten, omstylad) */
.ind-grid{ margin-top:50px; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.ind-card{
  position:relative; display:flex; flex-direction:column; align-items:flex-start;
  background:var(--teal-deep); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius); padding:30px 28px 26px; min-height:240px; color:var(--cream-50);
  transition:transform .2s ease, border-color .25s ease, box-shadow .25s ease;
}
.ind-card:hover{ transform:translateY(-5px); border-color:rgba(235,182,122,.55); box-shadow:0 16px 36px rgba(10,51,50,.45); }
.ind-card .gloss-anim{ width:58px; height:58px; color:var(--sand); }
.ind-card .gloss-anim svg{ width:100%; height:100%; overflow:visible; }
.ind-card h3{ margin-top:18px; color:var(--white); font-family:var(--sans); font-weight:700; font-size:21px; letter-spacing:-.01em; }
.ind-card p{ margin-top:7px; min-height:66px; font-size:14.5px; color:rgba(255,255,255,.78); line-height:1.5; }
.ind-card .go{
  margin-top:auto; padding-top:18px; display:block;
  font-size:13.5px; font-weight:600; color:var(--sand); line-height:1.55;
}
.ind-card .go svg{ vertical-align:middle; margin-left:6px; transition:transform .2s ease; }
.ind-card:hover .go svg{ transform:translateX(4px); }

/* Animerade bransch-ikoner (samma rörelse som tidigare, recoloured till sand) */
.an-bar{ transform-origin:bottom; animation:barRise 2.6s ease-in-out infinite; }
.an-bar.b2{ animation-delay:.25s; }
.an-bar.b3{ animation-delay:.5s; }
@keyframes barRise{ 0%,100%{ transform:scaleY(.45); opacity:.55; } 45%{ transform:scaleY(1); opacity:1; } }
.an-flow{ stroke-dasharray:9 11; animation:flow 2.4s linear infinite; }
@keyframes flow{ to{ stroke-dashoffset:-40; } }
.an-pulse{ animation:pulse 2.4s ease-in-out infinite; transform-origin:center; transform-box:fill-box; }
@keyframes pulse{ 0%,100%{ opacity:.35; transform:scale(.8); } 50%{ opacity:1; transform:scale(1.15); } }
.an-wave{ stroke-dasharray:8 8; animation:wave 2.6s linear infinite; }
@keyframes wave{ to{ stroke-dashoffset:-32; } }
.an-drop{ animation:drop 2.8s ease-in-out infinite; transform-origin:center; transform-box:fill-box; }
@keyframes drop{ 0%,60%,100%{ transform:translateY(0); opacity:0; } 20%{ opacity:1; } 45%{ transform:translateY(10px); opacity:0; } }
.an-doc{ stroke-dasharray:110; stroke-dashoffset:110; animation:docDraw 3s ease-out infinite; }
@keyframes docDraw{ 0%{ stroke-dashoffset:110; } 60%,100%{ stroke-dashoffset:0; } }
.an-line{ stroke-dasharray:16; stroke-dashoffset:16; animation:lineDraw 3s ease-out infinite; }
.an-line.l1{ animation-delay:.5s; }
.an-line.l2{ animation-delay:.9s; }
.an-line.l3{ animation-delay:1.3s; }
@keyframes lineDraw{ 0%,30%{ stroke-dashoffset:16; } 60%,100%{ stroke-dashoffset:0; } }

/* onboarding-remsa */
.onb-strip{
  margin:34px auto 0; display:flex; width:fit-content; max-width:100%; align-items:center; gap:12px;
  background:rgba(235,182,122,.12); border:1px solid rgba(235,182,122,.35);
  color:var(--cream-50); padding:12px 18px; border-radius:999px; font-size:14px;
}
.onb-strip strong{ color:var(--sand); }
.onb-strip .arrow{ color:var(--sand); }

/* hero meta-rad */
.hero-meta{ margin-top:26px; display:flex; flex-wrap:wrap; gap:22px; font-size:14px; color:rgba(255,255,255,.8); }
.hero-meta span{ display:inline-flex; align-items:center; gap:8px; }
.hero-meta .dot{ width:7px; height:7px; border-radius:50%; background:var(--sand); display:inline-block; }

/* =====================================================================
   TRUST-bar (grädde)
   ===================================================================== */
/* Trust-rad ligger på teal (del av hero-zonen) så grädde-sektionen efter blir en tydlig brytning */
.trust{ background:var(--teal); }
.trust .wrap{ display:flex; flex-wrap:wrap; gap:18px 40px; justify-content:center; padding:4px 24px 52px; }
.trust span{ display:inline-flex; align-items:center; gap:10px; font-size:14px; font-weight:500; color:var(--cream-50); }
.trust svg{ color:var(--sand); }

/* =====================================================================
   VARFÖR OSS (grädde, 3 kolumner)
   ===================================================================== */
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.why-card{
  background:var(--white); border-radius:var(--radius); padding:32px 28px;
  box-shadow:var(--shadow); border:1px solid rgba(13,66,65,.05);
}
.why-card .ic{
  width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  background:var(--teal); color:var(--sand); margin-bottom:18px;
}
.why-card .ic svg{ width:24px; height:24px; }
.why-card h3{ font-family:var(--sans); font-weight:600; font-size:21px; color:var(--teal); }
.why-card p{ margin-top:10px; font-size:15.5px; color:var(--ink-soft); line-height:1.6; }

/* =====================================================================
   VAD VI ERBJUDER - blockig grid (teal, signaturelement)
   ===================================================================== */
.offer{ background:var(--teal); }
.offer-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:0;
  border-radius:18px; overflow:hidden; box-shadow:var(--shadow-lg);
}
.offer-block{ padding:38px 32px; min-height:220px; display:flex; flex-direction:column; justify-content:flex-start; }
.offer-block.b-teal{ background:var(--teal-deep); color:var(--cream-50); }
.offer-block.b-cream{ background:var(--cream); color:var(--ink); }
.offer-block.b-lead{ background:var(--teal-deep); justify-content:center; }
.offer-block.b-lead h2{ color:var(--white); font-size:34px; }
.offer-block.b-lead p{ margin-top:14px; color:rgba(255,255,255,.78); font-size:15px; }
.offer-block .tag{ font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.07em; margin-bottom:12px; }
.offer-block.b-teal .tag{ color:var(--sand); }
.offer-block.b-cream .tag{ color:var(--sand-deep); }
.offer-block h3{ font-family:var(--sans); font-weight:700; font-size:20px; }
.offer-block.b-teal h3{ color:var(--white); }
.offer-block.b-cream h3{ color:var(--teal); }
.offer-block p{ margin-top:12px; font-size:15px; line-height:1.6; }
.offer-block.b-teal p{ color:rgba(255,255,255,.78); }
.offer-block.b-cream p{ color:var(--ink-soft); }

/* =====================================================================
   POPULÄRA PRISPAKET - teaser (grädde)
   ===================================================================== */
.pkg-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; align-items:stretch; }
.pkg-card{
  position:relative; background:var(--white); border-radius:var(--radius);
  padding:28px 24px; box-shadow:var(--shadow); border:1px solid rgba(13,66,65,.06);
  display:flex; flex-direction:column;
}
.pkg-card.popular{ border-color:var(--sand); box-shadow:0 16px 40px rgba(207,147,81,.22); }
.pkg-badge{
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:var(--sand); color:var(--teal-deep); font-size:12px; font-weight:700;
  padding:5px 14px; border-radius:999px; white-space:nowrap;
}
.pkg-name{ font-family:var(--sans); font-weight:700; font-size:14px; text-transform:uppercase; letter-spacing:.05em; color:var(--sand-deep); }
.pkg-price{ margin-top:10px; font-family:var(--serif); font-weight:700; font-size:30px; color:var(--teal); }
.pkg-price small{ font-family:var(--sans); font-size:14px; font-weight:500; color:var(--ink-soft); margin-left:4px; }
.pkg-for{ margin-top:8px; font-size:14px; color:var(--ink-soft); min-height:42px; }
.pkg-list{ list-style:none; margin:16px 0 0; padding:16px 0 0; border-top:1px solid var(--line); display:grid; gap:9px; }
.pkg-list li{ display:flex; gap:9px; font-size:14px; color:var(--ink); line-height:1.45; }
.pkg-list svg{ flex:0 0 auto; color:var(--teal); margin-top:2px; }
.pkg-cta{ margin-top:20px; }
.pkg-card .btn{ width:100%; justify-content:center; }
.pkg-foot{ text-align:center; margin-top:30px; font-size:13px; color:var(--ink-soft); }

/* =====================================================================
   KONTAKTSEKTION (teal) - info vänster, formulär höger
   ===================================================================== */
/* Kontaktsektion på GRÄDDE-botten - samma ljusa ton som övriga ljusa sektioner.
   Mörk text + teal-accenter + vitt formulärkort. Sand används BARA som accent. */
.home-contact{ background:var(--cream); color:var(--ink); }
.contact-inner{ display:grid; grid-template-columns:1fr 1.1fr; gap:48px; align-items:start; }
.contact-info h2{ color:var(--teal); font-size:34px; }
.contact-info .lead{ margin-top:16px; color:var(--ink); font-size:17px; }
.contact-points{ margin-top:28px; display:grid; gap:16px; }
.cpoint{ display:flex; align-items:center; gap:14px; }
.cpoint .ic{ width:42px; height:42px; border-radius:10px; background:var(--teal); color:var(--sand); display:grid; place-items:center; flex:0 0 auto; }
.cpoint strong{ display:block; color:var(--teal); font-size:14px; }
.cpoint span{ color:var(--ink-soft); font-size:14px; }

.contact-card{ background:var(--white); border-radius:18px; padding:30px; box-shadow:var(--shadow-lg); }
.contact-card h3{ font-family:var(--serif); font-size:24px; color:var(--teal); margin-bottom:6px; }
.contact-card .form-intro{ font-size:14px; color:var(--ink-soft); margin-bottom:18px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:13.5px; font-weight:600; color:var(--teal); margin-bottom:6px; }
.field input, .field textarea{
  width:100%; font-family:var(--sans); font-size:15px; color:var(--ink);
  padding:12px 14px; border:1px solid var(--line); border-radius:var(--radius-sm);
  background:#fbfbfb; transition:border-color .15s ease, box-shadow .15s ease;
}
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(13,66,65,.1); background:var(--white);
}
.field textarea{ min-height:110px; resize:vertical; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.consent{ display:flex; gap:10px; align-items:flex-start; margin:6px 0 18px; font-size:13px; color:var(--ink-soft); }
.consent input{ margin-top:3px; accent-color:var(--teal); }
.consent a{ color:var(--teal); text-decoration:underline; }
.contact-card .btn{ width:100%; justify-content:center; }
.form-note{ margin-top:12px; font-size:12.5px; color:var(--ink-soft); text-align:center; }

/* lyckat formulär (ersätter formuläret via JS) */
.form-success{ background:var(--white); border-radius:18px; padding:36px 30px; text-align:center; box-shadow:var(--shadow-lg); }
.form-success .ic{ width:60px; height:60px; border-radius:50%; background:var(--teal); color:var(--sand); display:grid; place-items:center; margin:0 auto 16px; }
.form-success h3{ color:var(--teal); font-size:24px; }
.form-success p{ margin-top:10px; color:var(--ink-soft); font-size:15px; }
.btn-booking{ display:inline-flex; background:var(--sand); color:var(--teal-deep); font-weight:600; padding:12px 24px; border-radius:999px; }
.btn-booking:hover{ background:var(--sand-deep); }

/* =====================================================================
   CTA-band (teal-deep)
   ===================================================================== */
.cta-band{ background:var(--teal-deep); color:var(--cream-50); text-align:center; padding:88px 0; }
.cta-band h2{ color:var(--white); font-size:36px; max-width:18ch; margin:0 auto; }
.cta-band p{ margin:16px auto 0; max-width:54ch; color:rgba(255,255,255,.82); }
.cta-actions{ margin-top:30px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* =====================================================================
   FOOTER (mörk teal)
   ===================================================================== */
.site-footer{ background:var(--teal-deep); color:rgba(255,255,255,.75); padding:64px 0 32px; }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:36px; }
.footer-brand{ display:inline-flex; align-items:center; gap:12px; font-family:var(--serif); font-weight:700; font-size:20px; color:var(--white); }
.footer-about{ margin-top:16px; font-size:14px; line-height:1.7; color:rgba(255,255,255,.65); max-width:34ch; }
.footer-col h5{ margin:0 0 14px; font-family:var(--sans); font-size:13px; text-transform:uppercase; letter-spacing:.06em; color:var(--sand); }
.footer-col a, .footer-col p{ display:block; font-size:14px; color:rgba(255,255,255,.72); margin-bottom:9px; }
.footer-col a:hover{ color:var(--white); }
.footer-bottom{
  margin-top:44px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap;
  font-size:13px; color:rgba(255,255,255,.55);
}

/* =====================================================================
   Scroll-reveal
   ===================================================================== */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
  .an-bar,.an-flow,.an-pulse,.an-wave,.an-drop,.an-doc,.an-line{ animation:none; }
}

/* =====================================================================
   Cookie-banner / modal (omstylad i ny palett)
   ===================================================================== */
.cookie-banner{
  position:fixed; left:18px; right:18px; bottom:18px; z-index:90; max-width:520px; margin:0 auto;
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:var(--shadow-lg); padding:20px 22px; opacity:0; transform:translateY(16px);
  transition:opacity .4s ease, transform .4s ease;
}
.cookie-banner.show{ opacity:1; transform:none; }
.cookie-banner h4{ font-family:var(--sans); font-weight:700; font-size:16px; color:var(--teal); margin-bottom:6px; }
.cookie-banner p{ font-size:13.5px; color:var(--ink-soft); line-height:1.55; }
.cookie-banner a{ color:var(--teal); text-decoration:underline; }
.cookie-banner .actions{ margin-top:14px; display:flex; gap:10px; flex-wrap:wrap; }
.cookie-banner button{ border:0; cursor:pointer; font-weight:600; font-size:14px; padding:10px 18px; border-radius:999px; }
.cookie-banner .accept{ background:var(--teal); color:var(--white); }
.cookie-banner .reject{ background:var(--cream); color:var(--teal); }
.cookie-banner .custom{ background:transparent; color:var(--ink-soft); text-decoration:underline; }
.cookie-modal-backdrop{ position:fixed; inset:0; background:rgba(10,51,50,.45); z-index:95; opacity:0; transition:opacity .3s ease; }
.cookie-modal-backdrop.show{ opacity:1; }
.cookie-modal{
  position:fixed; left:50%; top:50%; transform:translate(-50%,-46%); z-index:96; width:min(560px,92vw);
  max-height:86vh; overflow:auto; background:var(--white); border-radius:var(--radius);
  box-shadow:var(--shadow-lg); padding:30px; opacity:0; transition:opacity .3s ease, transform .3s ease;
}
.cookie-modal.show{ opacity:1; transform:translate(-50%,-50%); }
.cookie-modal h3{ color:var(--teal); font-size:22px; margin-bottom:10px; }
.cookie-modal p{ font-size:14px; color:var(--ink-soft); line-height:1.6; }
.cookie-modal .cat{ margin-top:16px; padding-top:16px; border-top:1px solid var(--line); }
.cookie-modal .cat-head{ display:flex; justify-content:space-between; align-items:center; }
.cookie-modal .cat-head strong{ color:var(--teal); font-size:15px; }
.cookie-modal .state{ font-size:12px; color:var(--teal); font-weight:600; }
.cookie-modal .state.off{ color:var(--ink-soft); }
.cookie-modal code{ background:var(--cream); padding:1px 6px; border-radius:4px; font-size:12px; }
.cookie-modal .modal-actions{ margin-top:22px; text-align:right; }
.cookie-modal .accept{ background:var(--teal); color:var(--white); border:0; cursor:pointer; font-weight:600; padding:11px 22px; border-radius:999px; }

/* =====================================================================
   RESPONSIVT
   ===================================================================== */
@media (max-width:980px){
  :root{ --pad-section:76px; }
  .hero h1{ font-size:46px; }
  .section-title{ font-size:32px; }
  .ind-grid{ grid-template-columns:repeat(2,1fr); }
  .why-grid{ grid-template-columns:1fr; }
  .offer-grid{ grid-template-columns:repeat(2,1fr); }
  .pkg-grid{ grid-template-columns:repeat(2,1fr); }
  .contact-inner{ grid-template-columns:1fr; gap:32px; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:30px; }
}

@media (max-width:720px){
  body{ font-size:16px; }
  /* mobilmeny */
  .menu-toggle{ display:flex; }
  .nav-links{
    position:absolute; top:100%; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:2px;
    background:var(--teal-deep); padding:14px 18px 20px;
    box-shadow:0 16px 30px rgba(10,51,50,.35);
    max-height:0; overflow:hidden; opacity:0; pointer-events:none;
    transition:max-height .3s ease, opacity .25s ease, padding .3s ease;
  }
  .nav-links.open{ max-height:80vh; opacity:1; pointer-events:auto; padding:14px 18px 20px; }
  .nav-links a{ padding:13px 12px; font-size:16px; border-radius:8px; }
  .nav-links .nav-cta{ margin:8px 0 0; justify-content:center; }
  .site-header{ position:fixed; }
  .site-header .nav{ position:relative; }

  .hero{ padding:96px 0 56px; }
  .hero h1{ font-size:38px; max-width:100%; }
  .hero-sub{ font-size:16px; }
  .ind-grid{ grid-template-columns:1fr; gap:14px; }
  .ind-card{ min-height:auto; padding:24px 22px; }
  .section-title{ font-size:27px; }
  .offer-grid{ grid-template-columns:1fr; }
  .offer-block{ min-height:0; padding:28px 24px; }
  .pkg-grid{ grid-template-columns:1fr; }
  .form-row{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
  .cta-band h2{ font-size:28px; }
}

/* =====================================================================
   SUBPAGE-KOMPONENTER (branschsidor, prissida, kontakt)
   ===================================================================== */

/* Ljus sektionsvariant (varfor-vi-mönstret: vita paneler på varm ljus botten) */
.section.soft{ background:var(--cream); }

/* Kontext-medvetna knappar (gamla klassnamn btn-primary / btn-ghost) */
.btn-primary{ background:var(--teal); color:var(--white); }
.btn-primary:hover{ background:var(--teal-deep); box-shadow:0 10px 24px rgba(13,66,65,.22); }
.btn-ghost{ background:transparent; border:1px solid rgba(13,66,65,.3); color:var(--teal); }
.btn-ghost:hover{ border-color:var(--teal); background:rgba(13,66,65,.05); }
.page-hero .btn-primary, .cta-band .btn-primary, .section.teal .btn-primary{ background:var(--sand); color:var(--teal-deep); }
.page-hero .btn-primary:hover, .cta-band .btn-primary:hover, .section.teal .btn-primary:hover{ background:var(--sand-deep); box-shadow:0 10px 24px rgba(235,182,122,.3); }
.page-hero .btn-ghost, .cta-band .btn-ghost, .section.teal .btn-ghost{ border-color:rgba(255,255,255,.4); color:var(--white); }
.page-hero .btn-ghost:hover, .cta-band .btn-ghost:hover, .section.teal .btn-ghost:hover{ border-color:var(--white); background:rgba(255,255,255,.08); }

/* Page-hero (teal) för undersidor */
.page-hero{ position:relative; background:var(--teal); color:var(--cream-50); padding:124px 0 84px; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; inset:0; pointer-events:none; background:radial-gradient(820px 380px at 82% -10%, rgba(235,182,122,.12), transparent 60%); }
.page-hero .wrap{ position:relative; z-index:1; }
.page-hero-bg{ display:none; }
.cta-band-bg{ display:none; }
.page-hero-inner{ display:grid; grid-template-columns:1.25fr .75fr; gap:44px; align-items:center; }
.crumbs{ font-size:13px; color:rgba(255,255,255,.6); margin-bottom:18px; }
.crumbs a{ color:var(--sand); }
.crumbs a:hover{ text-decoration:underline; }
.pill{ display:inline-flex; align-items:center; gap:8px; background:rgba(235,182,122,.14); border:1px solid rgba(235,182,122,.32); color:var(--cream-50); font-size:13px; font-weight:500; padding:7px 15px; border-radius:999px; margin-bottom:18px; }
.pill .dot{ width:7px; height:7px; border-radius:50%; background:var(--sand); display:inline-block; }
.page-hero h1{ color:var(--white); font-size:46px; max-width:18ch; }
.page-hero .lead{ margin-top:18px; max-width:60ch; font-size:18px; color:rgba(255,255,255,.85); }

/* Hero-visual: animerad ikon-panel (recoloured till sand via CSS) */
.hero-visual{ position:relative; aspect-ratio:1/1; width:100%; max-width:300px; margin-left:auto; border-radius:20px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); display:grid; place-items:center; }
.hero-visual .glass-top{ display:none; }
.hero-visual .gloss-anim{ width:120px; height:120px; }
.hero-visual .gloss-anim svg{ width:100%; height:100%; overflow:visible; stroke:var(--sand); }
.hero-visual .gloss-anim circle{ fill:var(--sand); }

/* Pris-teaser (pris-pills) */
.pris-teaser{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:8px; text-align:left; }
.pris-pill{ display:flex; flex-direction:column; gap:5px; background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:var(--radius); padding:20px 18px; box-shadow:var(--shadow); transition:transform .18s ease, box-shadow .2s ease; }
.pris-pill:hover{ transform:translateY(-3px); box-shadow:var(--shadow-lg); }
.pris-pill .label{ font-size:12.5px; font-weight:600; text-transform:uppercase; letter-spacing:.04em; color:var(--sand-deep); }
.pris-pill .amount{ font-family:var(--serif); font-weight:700; font-size:23px; color:var(--teal); }
.pris-pill .amount small{ font-family:var(--sans); font-size:12px; font-weight:500; color:var(--ink-soft); margin-left:3px; }
.pris-pill .hint{ font-size:12.5px; color:var(--ink-soft); }
.pris-pill.featured{ border-color:var(--sand); box-shadow:0 14px 34px rgba(207,147,81,.2); }

/* onb-strip på ljus botten */
.onb-wrap-soft{ margin-top:22px; display:flex; justify-content:center; }
.onb-wrap-soft .onb-strip{ background:rgba(13,66,65,.05); border-color:rgba(13,66,65,.12); color:var(--teal); }
.onb-wrap-soft .onb-strip strong{ color:var(--sand-deep); }
.onb-strip .onb-ic{ display:inline-flex; align-items:center; color:var(--sand); }
.onb-wrap-soft .onb-strip .onb-ic{ color:var(--sand-deep); }
.onb-strip .label-short{ display:none; }

/* Numrerad tjänstelista */
.svc-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:30px 44px; text-align:left; }
.svc{ display:flex; gap:18px; }
.svc .num{ font-family:var(--serif); font-weight:700; font-size:26px; color:var(--sand-deep); line-height:1; flex:0 0 auto; min-width:34px; }
.svc h4{ font-family:var(--sans); font-weight:700; font-size:18px; color:var(--teal); }
.svc p{ margin-top:6px; font-size:15px; color:var(--ink-soft); line-height:1.6; }

/* Highlight (text + accent-panel) */
.highlight{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; text-align:left; }
.highlight.flip > *:first-child{ order:2; }
.highlight h2{ font-size:32px; color:var(--teal); margin-top:6px; }
.highlight .body{ margin-top:16px; font-size:16px; color:var(--ink-soft); line-height:1.7; }
.highlight .checks{ list-style:none; margin:22px 0 0; padding:0; display:grid; gap:13px; }
.highlight .checks li{ display:flex; gap:12px; font-size:15px; color:var(--ink); line-height:1.5; }
.highlight .checks svg{ flex:0 0 auto; color:var(--teal); margin-top:2px; }
.panel{ position:relative; background:var(--teal); color:var(--cream-50); border-radius:20px; padding:48px 38px; min-height:230px; display:flex; flex-direction:column; justify-content:center; align-items:flex-start; box-shadow:var(--shadow-lg); overflow:hidden; }
.panel .glass-top{ display:none; }
.panel .big{ font-family:var(--serif); font-weight:700; font-size:54px; color:var(--white); line-height:1; }
.panel .cap{ margin-top:14px; font-size:15px; color:rgba(255,255,255,.82); max-width:34ch; }

/* Innehåll på TEAL-sektioner (växlande rytm på undersidor) - ljus text, sand-accenter.
   Vita kort/paneler (card, typfall, pris-pill) behåller mörk text och poppar mot teal. */
.section.teal .svc h4{ color:var(--white); }
.section.teal .svc p{ color:rgba(255,255,255,.82); }
.section.teal .svc .num{ color:var(--sand); }
.section.teal .highlight h2{ color:var(--white); }
.section.teal .highlight .body{ color:rgba(255,255,255,.82); }
.section.teal .highlight .checks li{ color:rgba(255,255,255,.9); }
.section.teal .highlight .checks svg{ color:var(--sand); }
.section.teal .panel{ background:var(--cream); color:var(--ink); }
.section.teal .panel .big{ color:var(--teal); }
.section.teal .panel .cap{ color:var(--ink-soft); }

/* 3-kort (cards/card) */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; text-align:left; }
.card{ background:var(--white); border-radius:var(--radius); padding:30px 26px; box-shadow:var(--shadow); border:1px solid rgba(13,66,65,.05); }
.card .ic{ width:46px; height:46px; border-radius:11px; display:grid; place-items:center; background:var(--teal); color:var(--sand); margin-bottom:16px; }
.card .ic svg{ width:22px; height:22px; }
.card h4{ font-family:var(--sans); font-weight:600; font-size:19px; color:var(--teal); }
.card p{ margin-top:9px; font-size:15px; color:var(--ink-soft); line-height:1.6; }

/* Typfall */
.typfall{ display:flex; gap:28px; background:var(--white); border-radius:18px; padding:34px; box-shadow:var(--shadow); align-items:flex-start; text-align:left; }
.avatar-big{ width:64px; height:64px; border-radius:50%; background:var(--teal); color:var(--sand); display:grid; place-items:center; font-family:var(--sans); font-weight:700; font-size:20px; flex:0 0 auto; }
.typfall h4{ color:var(--teal); font-size:19px; font-family:var(--sans); font-weight:700; }
.typfall .role{ color:var(--ink-soft); font-size:14px; margin:5px 0 12px; }
.typfall p{ color:var(--ink); font-size:15px; line-height:1.65; }
.marker{ display:inline-block; margin-top:14px; font-size:12px; color:var(--sand-deep); font-weight:600; text-transform:uppercase; letter-spacing:.05em; }

/* Subpage responsivt */
@media (max-width:980px){
  .page-hero-inner{ grid-template-columns:1fr; gap:32px; }
  .hero-visual{ display:none; }
  .pris-teaser{ grid-template-columns:repeat(2,1fr); }
  .svc-list{ grid-template-columns:1fr; }
  .highlight{ grid-template-columns:1fr; gap:32px; }
  .highlight.flip > *:first-child{ order:0; }
  .cards{ grid-template-columns:1fr; }
}
@media (max-width:720px){
  .page-hero{ padding:96px 0 56px; }
  .page-hero h1{ font-size:34px; }
  .pris-teaser{ grid-template-columns:1fr; }
  .typfall{ flex-direction:column; gap:18px; }
  .panel{ padding:36px 28px; min-height:0; }
  .onb-strip .label-full{ display:none; }
  .onb-strip .label-short{ display:inline; }
}

/* =====================================================================
   PRISSIDA-KOMPONENTER
   ===================================================================== */

/* Toolbar (bransch-tabs + bolagsform) - ligger på teal page-hero */
/* Toolbar ligger nu i prissektionen (ljus botten) - centrerad ovanför priskorten */
/* 2-kolumnsgrid: pillarna möts i mitten med samma mellanrum som priskorten (20px),
   så reglagens gap linjerar lodrätt med mellanrummet mellan Bas och Proffs. */
.toolbar{ display:grid; grid-template-columns:1fr 1fr; column-gap:20px; row-gap:14px; align-items:center; margin:0 auto 32px; }
.tabs{ display:inline-flex; gap:5px; background:var(--white); border:1px solid rgba(13,66,65,.12); border-radius:999px; padding:5px; box-shadow:var(--shadow); justify-self:end; }
.tabs .tab{ border:0; background:transparent; color:var(--ink-soft); font-family:var(--sans); font-weight:600; font-size:14px; padding:9px 18px; border-radius:999px; cursor:pointer; transition:background .15s ease, color .15s ease; }
.tabs .tab.active{ background:var(--teal); color:var(--white); }
.seg{ display:inline-flex; gap:4px; background:var(--white); border:1px solid rgba(13,66,65,.12); border-radius:999px; padding:5px; box-shadow:var(--shadow); justify-self:start; }
.seg button{ border:0; background:transparent; color:var(--ink-soft); font-family:var(--sans); font-weight:600; font-size:14px; padding:9px 18px; border-radius:999px; cursor:pointer; transition:background .15s ease, color .15s ease; }
.seg button.active{ background:var(--teal); color:var(--white); }

/* Note-row */
.note-row{ background:var(--cream-50); border-left:3px solid var(--sand); border-radius:10px; padding:16px 20px; font-size:14.5px; color:var(--ink); line-height:1.6; }
.note-row strong{ color:var(--teal); }

/* Pris-kort */
.price-grid{ display:grid; grid-template-columns:repeat(4, minmax(0, 1fr)); gap:20px; align-items:stretch;
  /* Bryt ut bredare än wrappen (centrerat på sidan) så korten får plats */
  position:relative; left:50%; transform:translateX(-50%); width:min(1340px, calc(100vw - 40px)); }
.price-card{ position:relative; background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:var(--radius); padding:28px 24px; box-shadow:var(--shadow); display:flex; flex-direction:column; text-align:center; transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease; }
.price-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.price-card.popular{ border-color:var(--sand); box-shadow:0 16px 40px rgba(207,147,81,.22); }
.price-badge{ display:none; position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--sand); color:var(--teal-deep); font-size:12px; font-weight:700; padding:5px 14px; border-radius:999px; white-space:nowrap; }
.price-card.popular .price-badge{ display:block; }
.price-name{ font-family:var(--sans); font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.04em; color:var(--sand-deep); }
.price-tag{ margin-top:10px; display:flex; align-items:baseline; justify-content:center; gap:5px; }
.price-tag .amount{ font-family:var(--serif); font-weight:700; font-size:33px; color:var(--teal); }
.price-tag .unit{ font-size:14px; color:var(--ink-soft); }
.price-meta{ margin-top:4px; font-size:13px; color:var(--ink-soft); }
.price-passar{ margin-top:14px; min-height:52px; display:flex; align-items:center; justify-content:center; text-align:center; font-size:13px; color:var(--teal); font-weight:600; background:var(--cream); border-radius:8px; padding:8px 12px; }
.price-inc-head{ margin-top:18px; font-size:11.5px; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--ink-soft); text-align:left; }
.price-list{ list-style:none; margin:12px 0 0; padding:0; display:grid; gap:10px; flex:1; text-align:left; }
/* Normalt textflöde (inte flex) så att fet text inte bryts till egen rad.
   Bock-ikonen absolut-positionerad till vänster. */
.price-list li{ position:relative; padding-left:24px; font-size:13.5px; color:var(--ink); line-height:1.5; }
.price-list li svg{ position:absolute; left:0; top:3px; color:var(--teal); }
.price-list li strong{ color:var(--teal); }
.price-cta{ margin-top:20px; width:100%; justify-content:center; background:var(--teal); color:var(--white); }
.price-cta:hover{ background:var(--teal-deep); }
.price-card.popular .price-cta{ background:var(--sand); color:var(--teal-deep); }
.price-card.popular .price-cta:hover{ background:var(--sand-deep); }

/* Picker (reglage) */
.picker{ background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:18px; padding:30px; box-shadow:var(--shadow); }
.picker-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:20px; flex-wrap:wrap; }
.picker-head h3{ font-family:var(--sans); font-weight:700; font-size:20px; color:var(--teal); }
.picker-head p{ margin-top:6px; font-size:14px; color:var(--ink-soft); }
.rec-block{ text-align:right; background:var(--teal); color:var(--white); border-radius:12px; padding:14px 20px; }
.rec-price strong{ font-family:var(--serif); font-size:26px; }
.rec-price small{ font-size:13px; color:rgba(255,255,255,.8); margin-left:4px; }
.rec-tag{ font-size:12.5px; color:var(--sand); margin-top:2px; }
.picker-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; margin-top:24px; }
.picker-field label{ display:flex; justify-content:space-between; font-size:14px; font-weight:600; color:var(--teal); margin-bottom:10px; }
.picker-field .val{ color:var(--sand-deep); }
.picker-field input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:999px; background:linear-gradient(to right, var(--sand) 0%, var(--sand) var(--p,30%), var(--line) var(--p,30%), var(--line) 100%); outline:none; }
.picker-field input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:22px; height:22px; border-radius:50%; background:var(--teal); border:3px solid var(--white); box-shadow:0 2px 6px rgba(13,66,65,.3); cursor:pointer; }
.picker-field input[type=range]::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background:var(--teal); border:3px solid var(--white); box-shadow:0 2px 6px rgba(13,66,65,.3); cursor:pointer; }
.picker-ticks{ display:flex; justify-content:space-between; font-size:11px; color:var(--ink-soft); margin-top:6px; }
.rec-summary{ margin-top:24px; padding-top:20px; border-top:1px solid var(--line); font-size:14.5px; color:var(--ink-soft); line-height:1.6; }
.rec-summary .why{ color:var(--teal); font-weight:600; }

/* Jämförelsetabell (desktop) */
.cmp-wrap{ margin-top:50px; }
.cmp-head h3{ font-family:var(--sans); font-weight:700; font-size:22px; color:var(--teal); margin-bottom:18px; }
.cmp-scroll{ overflow-x:auto; border-radius:16px; box-shadow:var(--shadow); }
.cmp-table{ width:100%; border-collapse:collapse; background:var(--teal); color:var(--cream-50); min-width:680px; }
.cmp-table th, .cmp-table td{ padding:13px 18px; text-align:left; border-bottom:1px solid rgba(255,255,255,.1); font-size:14px; }
.cmp-table thead th{ background:var(--teal-deep); color:var(--white); font-weight:700; }
.cmp-table thead th.col-popular{ color:var(--sand); }
.cmp-table td.y{ color:var(--sand); font-weight:700; }
.cmp-table td.n{ color:rgba(255,255,255,.38); }
.cmp-table td.v{ color:var(--cream-50); }
.cmp-table tbody tr:hover{ background:rgba(255,255,255,.05); }
.cmp-row-hidden{ display:none; }
.cmp-wrap.expanded .cmp-row-hidden{ display:table-row; }

/* Mobil jämförelse */
.mob-cmp{ display:none; margin-top:40px; }
.mob-cmp-pick{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; justify-content:center; }
.cmp-pick{ border:1px solid rgba(13,66,65,.2); background:var(--white); color:var(--teal); font-weight:600; font-size:14px; padding:8px 16px; border-radius:999px; cursor:pointer; }
.cmp-pick.on{ background:var(--teal); color:var(--white); border-color:var(--teal); }
.mob-cmp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.mob-cmp-grid.single{ grid-template-columns:1fr; }
.mob-cmp-col{ background:var(--white); border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:var(--shadow); }
.mob-cmp-col header{ background:var(--teal); color:var(--white); padding:14px 16px; }
.mob-cmp-col header .n{ font-size:12px; font-weight:700; color:var(--sand); letter-spacing:.06em; text-transform:uppercase; }
.mob-cmp-col header .p{ font-family:var(--serif); font-size:21px; margin-top:3px; }
.mob-cmp-col header .p small{ font-family:var(--sans); font-size:11px; color:rgba(255,255,255,.8); font-weight:500; margin-left:2px; }
.mob-cmp-col dl{ margin:0; padding:8px 16px 14px; }
.mob-cmp-col dl > div{ padding:8px 0; border-bottom:1px solid var(--line); }
.mob-cmp-col dl > div:last-child{ border-bottom:0; }
.mob-cmp-col dt{ font-size:11px; text-transform:uppercase; letter-spacing:.04em; color:var(--ink-soft); }
.mob-cmp-col dd{ margin:3px 0 0; font-size:14px; color:var(--ink); font-weight:600; }
.mob-cmp-col dd.y{ color:var(--teal); }
.mob-cmp-col dd.n{ color:var(--ink-soft); font-weight:400; }

/* Bolagsform-info */
.bolag-info{ display:flex; gap:24px; background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:18px; padding:32px; box-shadow:var(--shadow); margin-top:50px; }
.bolag-info .ic-wrap{ width:56px; height:56px; border-radius:14px; background:var(--teal); color:var(--sand); display:grid; place-items:center; flex:0 0 auto; }
.bolag-info h3{ font-family:var(--sans); font-weight:700; font-size:20px; color:var(--teal); }
.bolag-info .lead{ margin-top:6px; color:var(--ink-soft); font-size:15px; }
.bolag-info dl{ margin:18px 0 0; display:grid; grid-template-columns:auto 1fr; gap:9px 20px; }
.bolag-info dt{ font-weight:600; color:var(--teal); font-size:14px; }
.bolag-info dd{ margin:0; color:var(--ink); font-size:14px; }
.bolag-note{ margin-top:16px; background:var(--cream); border-radius:10px; padding:12px 16px; font-size:13.5px; color:var(--ink); }

/* Tilläggstjänster */
.addons{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:18px; }
.addon{ display:flex; gap:16px; background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow); }
.addon .ic{ width:42px; height:42px; border-radius:10px; background:var(--cream); color:var(--teal); display:grid; place-items:center; flex:0 0 auto; }
.addon h4{ font-family:var(--sans); font-weight:700; font-size:16px; color:var(--teal); }
.addon p{ margin-top:4px; font-size:13px; color:var(--ink-soft); }
.addon .price{ margin-top:8px; font-family:var(--serif); font-weight:700; font-size:20px; color:var(--teal); }
.addon .price small{ font-family:var(--sans); font-size:12px; font-weight:500; color:var(--ink-soft); }
.addon.free{ border-color:var(--sand); }
.addon.free .ic{ background:var(--teal); color:var(--sand); }

/* Regelverk (reg-cards) - vita kort, poppar på teal-sektion */
.reglab{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; text-align:left; }
.reg-card{ background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow); }
.reg-card h3{ display:flex; align-items:center; gap:12px; font-family:var(--sans); font-weight:700; font-size:18px; color:var(--teal); }
.reg-card .icd{ width:38px; height:38px; border-radius:10px; background:var(--teal); color:var(--sand); display:grid; place-items:center; flex:0 0 auto; }
.reg-card p{ margin-top:12px; font-size:14.5px; color:var(--ink-soft); line-height:1.6; }
.reg-card .ex{ margin-top:14px; background:var(--cream); border-radius:10px; padding:14px 16px; font-size:13.5px; color:var(--ink); line-height:1.6; }
.reg-card strong{ color:var(--teal); }

/* Steps */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:left; }
.step{ background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:var(--radius); padding:26px; box-shadow:var(--shadow); }
.step-num{ width:40px; height:40px; border-radius:50%; background:var(--teal); color:var(--sand); display:grid; place-items:center; font-family:var(--serif); font-weight:700; font-size:18px; margin-bottom:16px; }
.step h4{ font-family:var(--sans); font-weight:700; font-size:17px; color:var(--teal); }
.step p{ margin-top:8px; font-size:14px; color:var(--ink-soft); line-height:1.6; }

/* Duo (vad ingår / vad skickar du in) */
.duo{ display:grid; grid-template-columns:1fr 1fr; gap:24px; text-align:left; }
.duo-card{ background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:18px; padding:30px; box-shadow:var(--shadow); }
.duo-card h4{ display:flex; align-items:center; gap:12px; font-family:var(--sans); font-weight:700; font-size:18px; color:var(--teal); }
.duo-card h4 .ic{ width:38px; height:38px; border-radius:10px; background:var(--teal); color:var(--sand); display:grid; place-items:center; flex:0 0 auto; }
.bullets{ list-style:none; margin:18px 0 0; padding:0; display:grid; gap:12px; }
.bullets li{ display:flex; gap:11px; font-size:14.5px; color:var(--ink); line-height:1.5; }
.bullets li svg{ flex:0 0 auto; color:var(--teal); margin-top:2px; }
.trust-card{ display:flex; gap:22px; background:var(--teal-deep); color:var(--cream-50); border-radius:18px; padding:30px; margin-top:24px; box-shadow:var(--shadow-lg); text-align:left; }
.trust-card .ic{ width:48px; height:48px; border-radius:12px; background:rgba(235,182,122,.16); color:var(--sand); display:grid; place-items:center; flex:0 0 auto; }
.trust-card h4{ color:var(--white); font-family:var(--sans); font-weight:700; font-size:18px; }
.trust-card p{ margin-top:8px; color:rgba(255,255,255,.84); font-size:14.5px; line-height:1.6; }
.trust-card .pills{ margin-top:14px; display:flex; flex-wrap:wrap; gap:8px; }
.trust-card .pills span{ background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); color:var(--cream-50); font-size:12.5px; padding:5px 12px; border-radius:999px; }

/* FAQ */
.faq{ max-width:760px; margin:0 auto; display:grid; gap:12px; text-align:left; }
.faq details{ background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:12px; padding:0 22px; box-shadow:var(--shadow); }
.faq summary{ list-style:none; cursor:pointer; padding:18px 0; font-family:var(--sans); font-weight:600; font-size:16px; color:var(--teal); display:flex; justify-content:space-between; align-items:center; gap:12px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-size:24px; line-height:1; color:var(--sand-deep); font-weight:400; }
.faq details[open] summary::after{ content:"\2212"; }
.faq details > p{ padding:0 0 20px; font-size:14.5px; color:var(--ink-soft); line-height:1.7; }
.faq details strong{ color:var(--teal); }

/* Konsult/hantverk-växling (ordagrant från gamla CSS - JS-styrd via body.is-konsult-mode) */
.konsult-only{ display:none; }
.is-konsult-mode .hantverk-only{ display:none !important; }
.is-konsult-mode .konsult-only{ display:list-item; }
.is-konsult-mode tr.konsult-only{ display:table-row; }
.is-konsult-mode div.konsult-only,
.is-konsult-mode section.konsult-only,
.is-konsult-mode p.konsult-only,
.is-konsult-mode span.konsult-only{ display:block; }

/* Prissida responsivt */
@media (max-width:980px){
  .price-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .addons{ grid-template-columns:1fr; }
  .reglab{ grid-template-columns:1fr; }
  .duo{ grid-template-columns:1fr; }
  .picker-grid{ grid-template-columns:1fr; }
  .toolbar{ grid-template-columns:1fr; justify-items:center; }
  .tabs, .seg{ justify-self:center; }
}
@media (max-width:720px){
  .price-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .cmp-wrap{ display:none; }
  .mob-cmp{ display:block; }
  .bolag-info{ flex-direction:column; gap:18px; }
  .trust-card{ flex-direction:column; gap:16px; }
}

/* =====================================================================
   KONTAKTSIDA
   ===================================================================== */
.contact-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:start; }
.form{ background:var(--white); border:1px solid rgba(13,66,65,.08); border-radius:18px; padding:34px; box-shadow:var(--shadow-lg); }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field select{ width:100%; font-family:var(--sans); font-size:15px; color:var(--ink); padding:12px 14px; border:1px solid var(--line); border-radius:var(--radius-sm); background:#fbfbfb; cursor:pointer; transition:border-color .15s ease, box-shadow .15s ease; }
.field select:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(13,66,65,.1); background:var(--white); }
.required-note{ font-size:13px; color:var(--ink-soft); margin-bottom:18px; }
.req{ color:var(--sand-deep); }
.opt{ color:var(--ink-soft); font-weight:400; font-size:12px; }
.field-hint{ margin-top:6px; font-size:12.5px; color:var(--ink-soft); }

@media (max-width:980px){
  .contact-grid{ grid-template-columns:1fr; gap:32px; }
}
@media (max-width:720px){
  .form .row{ grid-template-columns:1fr; }
  .form{ padding:24px; }
}

/* =====================================================================
   INTEGRITET / prosa  + crumbs på ljus botten
   ===================================================================== */
.section.cream .crumbs, .section.soft .crumbs{ color:var(--ink-soft); }
.section.cream .crumbs a, .section.soft .crumbs a{ color:var(--teal); }
.policy{ max-width:760px; }
.policy h1{ font-size:40px; color:var(--teal); }
.policy h2{ font-size:23px; color:var(--teal); margin-top:36px; }
.policy p{ margin-top:14px; font-size:16px; color:var(--ink); line-height:1.7; }
.policy ul{ margin:14px 0 0; padding-left:20px; }
.policy li{ margin-top:10px; font-size:15px; color:var(--ink); line-height:1.7; }
.policy strong{ color:var(--teal); }
.policy code{ background:var(--cream); padding:2px 6px; border-radius:4px; font-size:13px; }
.policy address{ font-style:normal; margin-top:16px; font-size:15px; color:var(--ink); line-height:1.7; background:var(--white); border-radius:12px; padding:20px; box-shadow:var(--shadow); }
.policy .updated{ margin-top:28px; font-size:13px; color:var(--ink-soft); }
