/* ════════════════════════════════════════════════════════
   HJÄRTVIK – REDESIGN (demo)
   Laddas EFTER style.css. Återanvänder samma färgvariabler,
   lägger till modern layout, ikoner och nya sektioner.
   ════════════════════════════════════════════════════════ */


/* Lite mer luftig typografi för demon */
.rd body, body.rd { background: var(--warm-50); }

/* ── SVG-ikonsystem ───────────────────────────────────── */
.icon {
  width: 24px; height: 24px;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  flex-shrink: 0;
}
.ico-tile {
  width: 48px; height: 48px;
  border-radius: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--primary-100);
  color: var(--primary-700);
  margin-bottom: 1.1rem;
}
.ico-tile .icon { width: 24px; height: 24px; }

/* ── NAVBAR: lägg till CTA-knapp ──────────────────────── */
.nav-cta {
  display: inline-flex; align-items: center; gap: 6px;
  margin-left: 12px;
  padding: 8px 16px;
  background: var(--primary-600);
  color: #fff !important;
  border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 600;
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition: all .15s ease;
}
.nav-cta:hover { background: var(--primary-700); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.nav-cta .icon { width: 16px; height: 16px; }

/* ════════════════════════════════════════════════════════
   HERO – asymmetrisk
   ════════════════════════════════════════════════════════ */
.hero-rd {
  position: relative;
  overflow: hidden;
  padding: 8.5rem 2rem 4.5rem;
  background:
    radial-gradient(1100px 540px at 78% -8%, rgba(176,107,92,.13), transparent 60%),
    linear-gradient(180deg, var(--warm-50) 0%, var(--warm-100) 100%);
}
.hero-rd .container {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 4rem;
  align-items: center;
}
.hero-rd-copy { max-width: 600px; }

.hero-badge-rd {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 14px;
  background: rgba(255,255,255,.7);
  border: 1px solid var(--primary-200);
  border-radius: 99px;
  font-size: 12px; font-weight: 600;
  color: var(--primary-700);
  margin-bottom: 1.5rem;
  backdrop-filter: blur(6px);
}
.hero-badge-rd .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 3px rgba(45,134,89,.18);
}
.hero-rd h1 {
  font-size: clamp(2.4rem, 4.6vw, 3.65rem);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.035em;
  color: var(--neutral-950);
  margin-bottom: 1.35rem;
}
.hero-rd h1 .highlight { color: var(--primary-600); }
.hero-rd-lead {
  font-size: 1.075rem;
  line-height: 1.75;
  color: var(--neutral-600);
  margin-bottom: 2rem;
}

/* Två "välj väg"-kort (FIX för det som var trasigt) */
.audience-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 2rem;
}
.audience-card {
  position: relative;
  display: flex; flex-direction: column;
  gap: 4px;
  padding: 1.25rem 1.25rem 1.15rem;
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-lg);
  text-decoration: none;
  box-shadow: var(--shadow-sm);
  transition: all .18s ease;
  overflow: hidden;
}
.audience-card::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--warm-300);
  transition: background .18s ease;
}
.audience-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary-200);
}
.audience-card:hover::before { background: var(--primary-500); }
.audience-card--primary { background: var(--primary-50); border-color: var(--primary-200); }
.audience-card--primary::before { background: var(--primary-600); }
.audience-eyebrow {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .07em;
  color: var(--primary-600);
}
.audience-title {
  font-size: 15px; font-weight: 700;
  color: var(--neutral-950);
  line-height: 1.3;
}
.audience-desc {
  font-size: 12.5px; line-height: 1.55;
  color: var(--neutral-500);
  margin-top: 2px;
}
.audience-link {
  margin-top: 8px;
  font-size: 12.5px; font-weight: 600;
  color: var(--primary-700);
  display: inline-flex; align-items: center; gap: 5px;
}
.audience-card:hover .audience-link { gap: 9px; }

/* Trust-rad under hero */
.trust-row {
  display: flex; flex-wrap: wrap;
  align-items: center; gap: 10px 22px;
}
.trust-row .trust-item {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12.5px; font-weight: 500;
  color: var(--neutral-600);
}
.trust-row .icon { width: 17px; height: 17px; color: var(--primary-600); stroke-width: 2; }

/* Hero-visual (varm panel + flytande kort, inga trasiga bilder) */
.hero-art {
  position: relative;
  aspect-ratio: 1 / 1.04;
  border-radius: 28px;
  background:
    radial-gradient(120% 120% at 30% 18%, var(--primary-100) 0%, var(--primary-200) 42%, var(--primary-300) 100%);
  border: 1px solid var(--primary-200);
  box-shadow: 0 30px 60px -28px rgba(118,63,51,.45);
  overflow: hidden;
}
.hero-art::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(80% 60% at 75% 100%, rgba(61,30,22,.18), transparent 70%);
}
.hero-art-symbol {
  position: absolute;
  width: 78%; right: -12%; bottom: -10%;
  opacity: .22;
  filter: saturate(1.05);
}
.hero-chip {
  position: absolute;
  display: flex; align-items: center; gap: 11px;
  padding: 12px 15px;
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.7);
  border-radius: 16px;
  box-shadow: 0 14px 32px -12px rgba(61,30,22,.4);
  z-index: 2;
}
.hero-chip .chip-ico {
  width: 38px; height: 38px; border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  background: var(--primary-100); color: var(--primary-700);
}
.hero-chip .chip-ico .icon { width: 20px; height: 20px; }
.hero-chip .chip-txt strong { display: block; font-size: 13px; color: var(--neutral-950); font-weight: 700; line-height: 1.2; }
.hero-chip .chip-txt span { font-size: 11.5px; color: var(--neutral-500); }
.hero-chip.c1 { top: 8%; left: -6%; }
.hero-chip.c2 { bottom: 26%; right: -7%; }
.hero-chip.c3 { bottom: 6%; left: 10%; }
.hero-chip .avatar {
  width: 38px; height: 38px; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--primary-300);
}

/* ════════════════════════════════════════════════════════
   STAT / TRUST-BAR
   ════════════════════════════════════════════════════════ */
.statbar {
  background: var(--primary-900);
  background: linear-gradient(120deg, var(--primary-900), var(--primary-800));
  color: #fff;
}
.statbar .container {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  padding: 2.25rem 2rem;
}
.statbar .stat { text-align: center; }
.statbar .stat .n {
  font-size: clamp(1.7rem, 3vw, 2.2rem); font-weight: 800;
  color: var(--primary-100); line-height: 1; letter-spacing: -0.02em;
}
.statbar .stat .l {
  margin-top: 6px; font-size: 12.5px; font-weight: 500;
  color: rgba(255,255,255,.72);
}
.statbar .stat + .stat { border-left: 1px solid rgba(255,255,255,.12); }

/* ════════════════════════════════════════════════════════
   TJÄNST- / VÄRDEKORT med SVG-ikoner
   ════════════════════════════════════════════════════════ */
.feature-card {
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-xl);
  padding: 1.75rem 1.6rem;
  box-shadow: var(--shadow-sm);
  transition: all .2s ease;
}
.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary-200);
}
.feature-card h3 {
  font-size: 1.05rem; font-weight: 700;
  color: var(--neutral-950); margin-bottom: .5rem;
  letter-spacing: -0.01em;
}
.feature-card p {
  font-size: 14px; line-height: 1.7; color: var(--neutral-600);
  margin-bottom: 1.1rem;
}
.feature-card .card-link {
  font-size: 13.5px; font-weight: 600; color: var(--primary-700);
  text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
}
.feature-card:hover .card-link { gap: 10px; }
.feature-card .card-link .icon { width: 16px; height: 16px; }

/* Värdekort (4 i rad) */
.value-card-rd {
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-xl);
  padding: 1.75rem 1.5rem;
  box-shadow: var(--shadow-sm);
  transition: all .2s ease;
}
.value-card-rd:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--primary-200); }
.value-card-rd .ico-tile { width: 44px; height: 44px; border-radius: 12px; margin-bottom: 1rem; }
.value-card-rd h3 { font-size: 15px; font-weight: 700; color: var(--neutral-950); margin-bottom: .5rem; }
.value-card-rd p { font-size: 13.5px; line-height: 1.65; color: var(--neutral-500); }

/* ════════════════════════════════════════════════════════
   "SÅ GÅR DET TILL" – process
   ════════════════════════════════════════════════════════ */
.process {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem; position: relative;
}
.process-step {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-xl);
  padding: 1.75rem 1.6rem;
  box-shadow: var(--shadow-sm);
}
.process-step .num {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--primary-600); color: #fff;
  font-weight: 800; font-size: 15px;
  margin-bottom: 1rem;
  box-shadow: 0 6px 14px -4px rgba(168,93,78,.6);
}
.process-step h3 { font-size: 1rem; font-weight: 700; color: var(--neutral-950); margin-bottom: .45rem; }
.process-step p { font-size: 13.5px; line-height: 1.65; color: var(--neutral-600); }
.process-step:not(:last-child)::after {
  content: '';
  position: absolute; top: 38px; right: -0.9rem;
  width: 1.8rem; height: 2px;
  background: repeating-linear-gradient(90deg, var(--primary-300) 0 6px, transparent 6px 11px);
  z-index: 1;
}

/* ════════════════════════════════════════════════════════
   MÖT OSS – team-teaser
   ════════════════════════════════════════════════════════ */
.team-teaser {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 3.5rem; align-items: center;
}
.team-photos { display: flex; gap: 1.25rem; flex-wrap: wrap; }
.team-card {
  flex: 1; min-width: 180px;
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-xl);
  padding: 1.5rem;
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: all .2s ease;
}
.team-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.team-card img {
  width: 92px; height: 92px; border-radius: 50%;
  object-fit: cover; margin: 0 auto .9rem;
  border: 3px solid var(--primary-200); display: block;
}
.team-card .name { font-size: 15px; font-weight: 700; color: var(--neutral-950); }
.team-card .role { font-size: 12.5px; font-weight: 600; color: var(--primary-600); margin-top: 2px; }
.team-card .contact { margin-top: .85rem; display: flex; flex-direction: column; gap: 5px; }
.team-card .contact a {
  font-size: 12.5px; color: var(--neutral-600); text-decoration: none;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
}
.team-card .contact a:hover { color: var(--primary-700); }
.team-card .contact .icon { width: 15px; height: 15px; color: var(--primary-600); }

/* ════════════════════════════════════════════════════════
   RESPONSIVT
   ════════════════════════════════════════════════════════ */
@media (max-width: 940px) {
  .hero-rd .container { grid-template-columns: 1fr; gap: 3rem; }
  .hero-rd-copy { max-width: 640px; }
  .hero-art { max-width: 440px; margin: 0 auto; aspect-ratio: 1 / 0.9; }
  .statbar .container { grid-template-columns: 1fr 1fr; gap: 1.75rem 1rem; }
  .statbar .stat + .stat { border-left: none; }
  .process { grid-template-columns: 1fr; }
  .process-step:not(:last-child)::after { display: none; }
  .team-teaser { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 560px) {
  .audience-split { grid-template-columns: 1fr; }
  .hero-rd { padding-top: 7.5rem; }
  .hero-chip.c1 { left: 2%; }
  .hero-chip.c2 { right: 2%; }
}

/* Visa CTA-knappen i mobilmenyn snyggt */
@media (max-width: 768px) {
  .nav-cta { margin: 6px 0 0; justify-content: center; }
}

/* ════════════════════════════════════════════════════════
   MÅLGRUPPSDELNING – Ungdomar / Vuxna (stora kort)
   ════════════════════════════════════════════════════════ */
.split-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
}
.split-card {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: 22px;
  padding: 2.25rem;
  box-shadow: var(--shadow-sm);
  transition: all .2s ease;
}
.split-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--primary-200); }
.split-card--alt { background: var(--primary-50); border-color: var(--primary-200); }
.split-card .split-wm {
  position: absolute; right: -18px; top: -18px;
  width: 120px; height: 120px; color: var(--primary-600);
  opacity: .07; pointer-events: none;
}
.split-card .split-wm .icon { width: 120px; height: 120px; stroke-width: 1.25; }
.split-head { display: flex; align-items: center; gap: 14px; margin-bottom: 1.1rem; }
.split-ico {
  width: 52px; height: 52px; border-radius: 15px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--primary-100); color: var(--primary-700);
}
.split-ico .icon { width: 28px; height: 28px; }
.age-badge {
  display: inline-block; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--primary-700); background: var(--primary-100);
  padding: 3px 10px; border-radius: 99px; margin-bottom: 5px;
}
.split-card h3 { font-size: 1.3rem; font-weight: 800; color: var(--neutral-950); letter-spacing: -0.02em; line-height: 1.15; }
.split-card > p { font-size: 14px; line-height: 1.7; color: var(--neutral-600); margin-bottom: 1.1rem; }
.split-list { list-style: none; display: grid; gap: 8px; margin-bottom: 1.5rem; }
.split-list li { display: flex; align-items: flex-start; gap: 9px; font-size: 13.5px; color: var(--neutral-700); }
.split-list li .icon { width: 18px; height: 18px; color: var(--primary-600); stroke-width: 2.2; flex-shrink: 0; margin-top: 1px; }
.split-card .card-link {
  margin-top: auto; font-size: 14px; font-weight: 700; color: var(--primary-700);
  text-decoration: none; display: inline-flex; align-items: center; gap: 7px;
}
.split-card:hover .card-link { gap: 11px; }
.split-card .card-link .icon { width: 17px; height: 17px; }

/* Samverkan-remsa under målgrupperna */
.split-strip {
  margin-top: 1.5rem;
  display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap;
  background: linear-gradient(120deg, var(--warm-100), var(--primary-50));
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-xl);
  padding: 1.4rem 1.75rem;
}
.split-strip .strip-ico {
  width: 46px; height: 46px; border-radius: 13px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: #fff; color: var(--primary-700); box-shadow: var(--shadow-sm);
}
.split-strip .strip-ico .icon { width: 24px; height: 24px; }
.split-strip .strip-txt { flex: 1; min-width: 220px; }
.split-strip .strip-txt strong { display: block; font-size: 15px; color: var(--neutral-950); font-weight: 700; }
.split-strip .strip-txt span { font-size: 13px; color: var(--neutral-600); }
.split-strip .card-link { font-size: 13.5px; font-weight: 700; color: var(--primary-700); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }

/* ════════════════════════════════════════════════════════
   TILLSTÅND & KVALITET – förtroendesektion
   ════════════════════════════════════════════════════════ */
.quality-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem;
}
.quality-item {
  display: flex; gap: 14px; align-items: flex-start;
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-xl);
  padding: 1.4rem;
  box-shadow: var(--shadow-sm);
  transition: all .2s ease;
}
.quality-item:hover { box-shadow: var(--shadow-md); border-color: var(--primary-200); transform: translateY(-2px); }
.quality-item .q-ico {
  width: 42px; height: 42px; border-radius: 12px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--primary-100); color: var(--primary-700);
}
.quality-item .q-ico .icon { width: 22px; height: 22px; }
.quality-item h3 { font-size: 14px; font-weight: 700; color: var(--neutral-950); margin-bottom: 3px; }
.quality-item p { font-size: 12.5px; line-height: 1.55; color: var(--neutral-500); }

/* ════════════════════════════════════════════════════════
   FÖRFRÅGAN-FORMULÄR – kryssrutor
   ════════════════════════════════════════════════════════ */
.check-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.check-item {
  display: flex; align-items: center; gap: 9px;
  font-size: 13px; color: var(--neutral-700);
  padding: 9px 12px;
  background: var(--surface);
  border: 1px solid var(--warm-300);
  border-radius: var(--radius-sm);
  cursor: pointer; transition: all .15s;
}
.check-item:hover { border-color: var(--primary-300); }
.check-item input { accent-color: var(--primary-600); flex-shrink: 0; }
.form-hint { font-size: 12px; color: var(--neutral-500); margin: -2px 0 12px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

@media (max-width: 768px) {
  .split-grid { grid-template-columns: 1fr; }
  .quality-grid { grid-template-columns: 1fr 1fr; }
  .form-row, .check-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .quality-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════
   OLIVGRÖN ACCENT (komplementfärg, används genomgående)
   Terrakotta = primär · Oliv = accent
   ════════════════════════════════════════════════════════ */
:root {
  --accent-50:  #F4F5EC;
  --accent-100: #E7EBD3;
  --accent-200: #D2D9B4;
  --accent-300: #B6C18C;
  --accent-400: #9AA767;
  --accent-500: #7F8E4E;
  --accent-600: #6C7B40;
  --accent-700: #556231;
  --accent-800: #434D28;
  --accent-900: #363E22;
}

/* 1) Sektionsetiketter (på varje sektion/sida) → oliv */
.section-label {
  color: var(--accent-700);
  background: var(--accent-100);
}

/* 2) Hero-badgens prick → oliv (samma gröna ton genomgående) */
.hero-badge-rd .dot {
  background: var(--accent-600);
  box-shadow: 0 0 0 3px var(--accent-100);
}

/* 3) Positiva "bocka av"-ikoner → oliv (grönt = något som ingår) */
.split-list li .icon { color: var(--accent-600); }

/* 4) Hero: den sekundära vägen ("För dig som ska bo hos oss") → oliv accent */
.audience-card:not(.audience-card--primary) .audience-eyebrow { color: var(--accent-700); }
.audience-card:not(.audience-card--primary) .audience-link { color: var(--accent-700); }
.audience-card:not(.audience-card--primary):hover { border-color: var(--accent-200); }
.audience-card:not(.audience-card--primary):hover::before { background: var(--accent-500); }

/* 5) Målgruppskort: Vuxna → oliv (Ungdom förblir terrakotta) */
.split-card--alt { background: var(--accent-50); border-color: var(--accent-200); }
.split-card--alt:hover { border-color: var(--accent-300); }
.split-card--alt .split-ico { background: var(--accent-100); color: var(--accent-700); }
.split-card--alt .age-badge { color: var(--accent-700); background: var(--accent-100); }
.split-card--alt .split-wm { color: var(--accent-600); }
.split-card--alt .split-list li .icon { color: var(--accent-600); }
.split-card--alt .card-link { color: var(--accent-700); }

/* 6) Samverkansremsan → mjuk oliv touch i ikonen */
.split-strip .strip-ico { color: var(--accent-700); }

/* 7) Formulärens kryssrutor → oliv markering */
.check-item input { accent-color: var(--accent-600); }
.consent-label input[type="checkbox"] { accent-color: var(--accent-600); }
.check-item:hover { border-color: var(--accent-300); }

/* 8) Förfrågan-sidans "Vad händer sedan?"-ikoner → oliv */
.contact-info-card .contact-detail .icon { color: var(--accent-700); }

/* ════════════════════════════════════════════════════════
   LIV & LJUS — vitalitetspass (ljusare, varmare, mer färg)
   ════════════════════════════════════════════════════════ */
:root {
  /* Varma, ljusare pop-färger inom jordtonsfamiljen */
  --amber-50:#FDF3E2; --amber-100:#FBE7C9; --amber-200:#F6D29B;
  --amber-500:#E0A04A; --amber-600:#C7843A; --amber-700:#A6641D;
  --rose-50:#FCEEEA; --rose-100:#F8DCD4; --rose-200:#F0BEB1;
  --rose-500:#D77A66; --rose-600:#C25E4A; --rose-700:#A6432F;
}

/* 1) Ljusare, luftigare grundyta */
body { background: #FCFBF8; }
.section-alt { background: #F7F4ED; }

/* 2) Soligare hero-bakgrund med varm + olivglöd */
.hero-rd {
  background:
    radial-gradient(1000px 520px at 82% -12%, rgba(224,160,74,.18), transparent 60%),
    radial-gradient(820px 480px at 2% 8%, rgba(108,123,64,.10), transparent 62%),
    linear-gradient(180deg, #FDFBF7 0%, #F6F1E8 100%);
}
.hero-rd::before {
  content:''; position:absolute; right:-60px; bottom:-40px;
  width:340px; height:340px; pointer-events:none; z-index:0;
  background: radial-gradient(circle, rgba(194,94,74,.10), transparent 70%);
}
.hero-rd .container { position: relative; z-index: 1; }

/* 3) Livfullare hero-panel (sol → terrakotta → varm) */
.hero-art {
  background:
    radial-gradient(125% 125% at 22% 10%, var(--amber-100) 0%, var(--primary-200) 44%, var(--primary-400) 100%);
}
.hero-chip.c2 .chip-ico { background: var(--amber-100); color: var(--amber-700); }
.hero-chip.c1 .chip-ico { background: var(--rose-100); color: var(--rose-700); }

/* Mjuk rörelse — ger liv */
@keyframes floaty { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-7px); } }
.hero-chip.c1 { animation: floaty 6s ease-in-out infinite; }
.hero-chip.c2 { animation: floaty 6.6s ease-in-out infinite .7s; }
.hero-chip.c3 { animation: floaty 7.2s ease-in-out infinite .3s; }
@media (prefers-reduced-motion: reduce) { .hero-chip { animation: none !important; } }

/* 4) FLERFÄRGADE IKON-RUTOR — störst effekt för "liv"
   Mönster: terrakotta · honung · oliv · korall (roterar) */
.card-grid > *:nth-child(4n+1) .ico-tile,
.value-grid > *:nth-child(4n+1) .ico-tile { background: var(--primary-100); color: var(--primary-700); }
.card-grid > *:nth-child(4n+2) .ico-tile,
.value-grid > *:nth-child(4n+2) .ico-tile { background: var(--amber-100); color: var(--amber-700); }
.card-grid > *:nth-child(4n+3) .ico-tile,
.value-grid > *:nth-child(4n+3) .ico-tile { background: var(--accent-100); color: var(--accent-700); }
.card-grid > *:nth-child(4n+4) .ico-tile,
.value-grid > *:nth-child(4n+4) .ico-tile { background: var(--rose-100); color: var(--rose-700); }

.quality-grid > *:nth-child(4n+1) .q-ico { background: var(--primary-100); color: var(--primary-700); }
.quality-grid > *:nth-child(4n+2) .q-ico { background: var(--amber-100); color: var(--amber-700); }
.quality-grid > *:nth-child(4n+3) .q-ico { background: var(--accent-100); color: var(--accent-700); }
.quality-grid > *:nth-child(4n+4) .q-ico { background: var(--rose-100); color: var(--rose-700); }

/* Färgad kant-glöd vid hover för extra liv */
.card-grid > *:nth-child(4n+2):hover, .value-grid > *:nth-child(4n+2):hover { border-color: var(--amber-200); }
.card-grid > *:nth-child(4n+4):hover, .value-grid > *:nth-child(4n+4):hover { border-color: var(--rose-200); }

/* 5) Ljusare, livfullare stat-bar (solnedgång istället för mörkbrunt) */
.statbar {
  background: linear-gradient(115deg, var(--primary-600) 0%, var(--primary-500) 48%, var(--amber-500) 118%);
}
.statbar .stat .n { color: #FFF6E8; }
.statbar .stat .l { color: rgba(255,255,255,.85); }
.statbar .stat + .stat { border-left-color: rgba(255,255,255,.18); }

/* 6) Varm mörkbrun footer istället för kall svartblå */
.footer { background: linear-gradient(180deg, #3A241C 0%, #2A1712 100%); }
.footer-bottom { border-top-color: rgba(255,255,255,.12); }
.footer h3 { color: var(--amber-200); }
.footer-brand p, .footer-links li:not(:has(a)) { color: rgba(245,235,225,.7); }
.footer-links a { color: rgba(245,235,225,.92); }
.footer-links a:hover { color: #fff; }

/* 7) Lite färg på CTA-sektionen så den känns levande */
.cta-section {
  background: linear-gradient(125deg, var(--primary-600) 0%, var(--primary-700) 55%, var(--rose-600) 130%);
}

/* 8) Sektionsavdelare lite varmare */
.section-divider { background: linear-gradient(90deg, transparent, var(--warm-300) 20%, var(--warm-300) 80%, transparent); }

/* ════════════════════════════════════════════════════════
   GRÖNT TEMA  —  skogsgrön (primär) · terrakotta (accent)
   guld · gräddvit · Fraunces serif-rubriker
   (ligger sist → styr om hela paletten)
   ════════════════════════════════════════════════════════ */
:root {
  --serif: 'Lora', Georgia, 'Times New Roman', serif;

  /* PRIMÄR = skogsgrön */
  --primary-50:#EEF3EF; --primary-100:#DBE6DF; --primary-200:#BCD0C4;
  --primary-300:#93B2A0; --primary-400:#5F8670; --primary-500:#456A53;
  --primary-600:#3A5A47; --primary-700:#2C4636; --primary-800:#27402F;
  --primary-900:#21362A; --primary-950:#172619;

  /* ACCENT = terrakotta */
  --accent-50:#FBF1EB; --accent-100:#F4DDD0; --accent-200:#ECC4B0;
  --accent-300:#DEA088; --accent-400:#D08060; --accent-500:#C66E48;
  --accent-600:#C16A45; --accent-700:#A2502F; --accent-800:#7F3F26; --accent-900:#5E2F1D;

  /* GULD (ersätter "amber") */
  --amber-50:#FBF3E2; --amber-100:#F6E7C8; --amber-200:#EBD09A;
  --amber-500:#C99A3F; --amber-600:#B5862F; --amber-700:#8C6520;

  /* Varma textnyanser (ink) */
  --neutral-950:#262420; --neutral-900:#2B2823; --neutral-800:#3A362F;
  --neutral-700:#4C4842; --neutral-600:#5C564D; --neutral-500:#736C62; --neutral-400:#9A938A;

  /* Varm gräddvit + linjer */
  --warm-50:#FDFBF7; --warm-100:#F2ECE1; --warm-200:#ECE3D4; --warm-300:#E7DECF;
}

/* Typografi: serif-rubriker */
body { background:#FBF8F3; }
h1, h2, h3, h4, h5, h6 { font-family: var(--serif) !important; font-weight: 600 !important; letter-spacing: -.01em; }
.section-alt { background:#F2ECE1; }

/* Hero — gräddvit med grön + terrakotta-glöd */
.hero-rd {
  background:
    radial-gradient(900px 480px at 86% -10%, rgba(193,106,69,.10), transparent 60%),
    radial-gradient(820px 480px at 0% 6%, rgba(58,90,71,.11), transparent 62%),
    linear-gradient(180deg,#FCFAF5 0%,#F3EDE2 100%);
}
.hero-rd::before { background: radial-gradient(circle, rgba(58,90,71,.09), transparent 70%); }
.hero-rd h1 .highlight { color: var(--accent-600); }
.trust-row .icon { color: var(--primary-600); }

/* Hero-panel i mjuk salvia → grön */
.hero-art {
  background: radial-gradient(125% 125% at 24% 12%, #E9F0EA 0%, var(--primary-200) 46%, var(--primary-400) 100%);
}
.hero-chip.c1 .chip-ico { background: var(--accent-100); color: var(--accent-700); }
.hero-chip.c2 .chip-ico { background: var(--amber-100); color: var(--amber-700); }

/* Positiva bockar → grön */
.split-list li .icon,
.split-card--alt .split-list li .icon { color: var(--primary-600); }
.split-strip .strip-ico { color: var(--primary-700); }

/* Ikon-rutor: grön · terrakotta · guld (roterar, cohesivt) */
.card-grid > *:nth-child(4n+1) .ico-tile, .value-grid > *:nth-child(4n+1) .ico-tile,
.quality-grid > *:nth-child(4n+1) .q-ico { background: var(--primary-100); color: var(--primary-700); }
.card-grid > *:nth-child(4n+2) .ico-tile, .value-grid > *:nth-child(4n+2) .ico-tile,
.quality-grid > *:nth-child(4n+2) .q-ico { background: var(--accent-100); color: var(--accent-700); }
.card-grid > *:nth-child(4n+3) .ico-tile, .value-grid > *:nth-child(4n+3) .ico-tile,
.quality-grid > *:nth-child(4n+3) .q-ico { background: var(--amber-100); color: var(--amber-700); }
.card-grid > *:nth-child(4n+4) .ico-tile, .value-grid > *:nth-child(4n+4) .ico-tile,
.quality-grid > *:nth-child(4n+4) .q-ico { background: var(--primary-100); color: var(--primary-700); }
.card-grid > *:nth-child(4n+2):hover, .value-grid > *:nth-child(4n+2):hover { border-color: var(--accent-200); }
.card-grid > *:nth-child(4n+4):hover, .value-grid > *:nth-child(4n+4):hover { border-color: var(--primary-200); }

/* Stat-bar → djupgrön med guldsiffror */
.statbar { background: linear-gradient(160deg, var(--primary-700) 0%, var(--primary-900) 100%); }
.statbar .stat .n { color: var(--amber-200); }
.statbar .stat .l { color: rgba(255,255,255,.82); }
.statbar .stat + .stat { border-left-color: rgba(255,255,255,.15); }

/* CTA-band → terrakotta (varm kontrast mot grönt) */
.cta-section { background: linear-gradient(135deg, var(--accent-600) 0%, var(--accent-700) 100%); }

/* Footer → djupgrön med guldrubriker */
.footer { background: linear-gradient(180deg, var(--primary-800) 0%, var(--primary-950) 100%); }
.footer h3 { color: var(--amber-200); }
.footer-brand p, .footer-links li:not(:has(a)) { color: rgba(244,238,228,.7); }
.footer-links a { color: rgba(244,238,228,.9); }
.footer-links a:hover { color:#fff; }
.footer-bottom { border-top-color: rgba(255,255,255,.14); }

/* Formulär & kontakt → gröna detaljer */
.check-item input, .consent-label input[type="checkbox"] { accent-color: var(--primary-600); }
.contact-info-card .contact-detail .icon { color: var(--primary-700); }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  box-shadow: 0 0 0 3px rgba(58,90,71,.14);
}

/* Processnummer → terrakotta-pop på grön sajt */
.process-step .num { background: var(--accent-600); box-shadow: 0 6px 14px -4px rgba(193,106,69,.5); }

/* ════════════════════════════════════════════════════════
   GRÖNT GENOMGÅENDE  —  grönt som bärande färg på hela sidan
   (terrakotta/guld tonas ner till minimala spår; grönt + grädd­vit råder)
   ════════════════════════════════════════════════════════ */
:root {
  /* Accent → grön (ingen terrakotta i gränssnittet) */
  --accent-50: var(--primary-50);   --accent-100: var(--primary-100);
  --accent-200: var(--primary-200); --accent-300: var(--primary-300);
  --accent-400: var(--primary-400); --accent-500: var(--primary-500);
  --accent-600: var(--primary-600); --accent-700: var(--primary-700);
  --accent-800: var(--primary-800); --accent-900: var(--primary-900);
}

/* Hero-glöd → grön (ingen varm terrakotta-glöd) */
.hero-rd {
  background:
    radial-gradient(900px 480px at 86% -10%, rgba(58,90,71,.13), transparent 60%),
    radial-gradient(820px 480px at 0% 6%, rgba(58,90,71,.10), transparent 62%),
    linear-gradient(180deg,#FCFAF5 0%,#F1ECE1 100%);
}
.hero-chip.c1 .chip-ico,
.hero-chip.c2 .chip-ico { background: var(--primary-100); color: var(--primary-700); }

/* Ikon-rutor → enhetligt gröna (ingen terrakotta/guld-rotation) */
.card-grid > * .ico-tile,
.value-grid > * .ico-tile,
.quality-grid > * .q-ico { background: var(--primary-100) !important; color: var(--primary-700) !important; }
.card-grid > *:hover, .value-grid > *:hover { border-color: var(--primary-200); }

/* Processnummer → grön */
.process-step .num { background: var(--primary-600); box-shadow: 0 6px 14px -4px rgba(58,90,71,.5); }

/* CTA-band → grön (istället för terrakotta) */
.cta-section { background: linear-gradient(135deg, var(--primary-600) 0%, var(--primary-800) 100%); }
.cta-section .btn-primary { color: var(--primary-700); }

/* Mörka ytor: siffror & rubriker i varm gräddvit (ingen guld) */
.statbar .stat .n { color: #F1ECE1; }
.footer h3 { color: rgba(244,238,228,.72); }

/* ════════════════════════════════════════════════════════
   DAMMIG ROSA  —  genomgående varm accent (grönt råder)
   ════════════════════════════════════════════════════════ */
:root { --terra:#C5897A; --terra-deep:#9E5142; --terra-soft:#F4DED6; }

/* Kickers/etiketter → rosa (på varje sektion, alla sidor) */
.section-label { color: var(--terra-deep); background: var(--terra-soft); }

/* Rubrikordet i hero → rosa */
.hero-rd h1 .highlight { color: var(--terra); }

/* Hero-pricken → rosa */
.hero-badge-rd .dot { background: var(--terra); box-shadow: 0 0 0 3px var(--terra-soft); }

/* En varm hjärt-accent i hero ("med hjärta") */
.hero-chip.c2 .chip-ico { background: var(--terra-soft); color: var(--terra-deep); }

/* Länk-pilar → rosa (grön text kvar) */
.card-link .icon,
.audience-link .icon,
.split-card .card-link .icon,
.split-strip .card-link .icon { color: var(--terra); }

/* Varannan ikon-ruta → rosa (resten gröna) */
.card-grid > *:nth-child(2n) .ico-tile,
.value-grid > *:nth-child(2n) .ico-tile,
.quality-grid > *:nth-child(2n) .q-ico { background: var(--terra-soft) !important; color: var(--terra-deep) !important; }

/* ════ RIKTIG WORDMARK-LOGOTYP ════ */
.nav-container { height: 98px; }            /* högre meny så loggan får plats */
.nav-logo-wordmark { height: 74px; width: auto; display: block; }
.footer-brand .nav-logo-wordmark { height: 64px; }
@media (max-width: 768px) {
  .nav-container { height: 78px; }          /* nättare på mobil */
  .nav-logo-wordmark { height: 56px; }
  .nav-links { top: 78px; }                 /* mobilmenyn under navbaren */
}

/* ════════════════════════════════════════════════════════
   MODERN 2.0  —  premiumkänsla (samma färger & innehåll)
   ════════════════════════════════════════════════════════ */

/* ── Filmkornstextur över hela sidan (subtilt djup) ── */
body::after {
  content:''; position:fixed; inset:0; z-index:9998; pointer-events:none; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Större, mer dramatisk display-typografi ── */
.hero-rd h1 { font-size: clamp(2.7rem, 5.4vw, 4.4rem); line-height: 1.07; letter-spacing: -0.012em; }
.hero-rd-lead { font-size: 1.18rem; line-height: 1.7; max-width: 30ch; }
.section-header h2, .page-header h1 { font-size: clamp(2.1rem, 4vw, 3.1rem); letter-spacing: -0.012em; }
.section-header { max-width: 720px; }

/* Stäng av ligaturer + lufta serif-rubrikerna (annars ser t.ex. "fi" konstigt ut) */
h1, h2, h3, h4, h5, h6, .pullquote, .marquee-track .m {
  font-variant-ligatures: none;
  font-feature-settings: "liga" 0, "clig" 0, "dlig" 0;
  letter-spacing: -0.01em;
}

/* ── Pill-knappar med rörelse ── */
.btn { border-radius: 999px; padding: 12px 24px; font-weight: 600; font-size: 14.5px; }
.btn .icon { transition: transform .25s cubic-bezier(.22,.61,.36,1); }
.btn:hover .icon { transform: translateX(4px); }
.btn-primary { box-shadow: 0 12px 26px -10px rgba(58,90,71,.55); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 20px 34px -12px rgba(58,90,71,.6); }
.nav-cta { border-radius: 999px; padding: 11px 20px; }
.card-link .icon, .audience-link .icon { transition: transform .25s cubic-bezier(.22,.61,.36,1); }

/* ── Rundare, djupare, mer levande kort ── */
.feature-card, .value-card-rd, .quality-item, .process-step, .split-card, .card, .contact-info-card, .team-card, .stat-item {
  border-radius: 24px;
}
.feature-card, .value-card-rd {
  box-shadow: 0 2px 5px rgba(38,36,32,.03), 0 22px 48px -28px rgba(38,36,32,.22);
}
.feature-card:hover, .value-card-rd:hover, .quality-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 34px 64px -30px rgba(38,36,32,.30);
}

/* ── Krympande navbar vid scroll ── */
.navbar { transition: background .3s ease, box-shadow .3s ease; }
.nav-container, .nav-logo-wordmark { transition: height .3s cubic-bezier(.22,.61,.36,1); }
.navbar.shrink { background: rgba(251,248,243,.9); box-shadow: 0 6px 24px -10px rgba(38,36,32,.16); }
.navbar.shrink .nav-container { height: 70px; }
.navbar.shrink .nav-logo-wordmark { height: 52px; }

/* ── Animerad gradient-mesh i hero (levande blobbar) ── */
.hero-rd::after {
  content:''; position:absolute; z-index:0; pointer-events:none;
  width:560px; height:560px; left:52%; top:-14%;
  background: radial-gradient(circle, rgba(147,178,160,.55), transparent 64%);
  filter: blur(46px); border-radius:50%;
  animation: heroDriftA 19s ease-in-out infinite alternate;
}
.hero-rd::before { animation: heroDriftB 23s ease-in-out infinite alternate; }
@keyframes heroDriftA {
  0%   { transform: translate(0,0) scale(1); }
  50%  { transform: translate(-70px,46px) scale(1.18); }
  100% { transform: translate(48px,-26px) scale(1.06); }
}
@keyframes heroDriftB {
  0%   { transform: translate(0,0) scale(1); }
  100% { transform: translate(-60px,-30px) scale(1.2); }
}

/* ── Marquee-rad (rullande nyckelord) ── */
.marquee {
  overflow: hidden; background: #fff;
  border-top: 1px solid var(--warm-300); border-bottom: 1px solid var(--warm-300);
  padding: 16px 0; position: relative;
}
.marquee::before, .marquee::after {
  content:''; position:absolute; top:0; bottom:0; width:90px; z-index:2; pointer-events:none;
}
.marquee::before { left:0; background:linear-gradient(90deg,#fff,transparent); }
.marquee::after { right:0; background:linear-gradient(270deg,#fff,transparent); }
.marquee-track { display:flex; align-items:center; width:max-content; animation: marquee 34s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track .m { font-family: var(--serif); font-weight: 500; font-size: 1.12rem; color: var(--neutral-800); padding: 0 30px; white-space: nowrap; }
.marquee-track .d { width:7px; height:7px; border-radius:50%; background: var(--terra); flex:none; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── Stat-bar: mjuk ljussken för djup ── */
.statbar { position: relative; overflow: hidden; }
.statbar::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(60% 130% at 82% -10%, rgba(255,255,255,.10), transparent 60%);
}
.statbar .container { position: relative; z-index: 1; }

/* ── Mjukare, mer dramatisk intoning ── */
.fade-in {
  transform: translateY(26px) scale(.985);
  transition: opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1);
}
.fade-in.visible { transform: translateY(0) scale(1); }

/* ── Större sektionsluft ── */
.section { padding: 6.5rem 2rem; }
.hero-rd { padding-top: 9rem; }

/* ── Robust tangentbordsfokus — syns på både ljus och mörk bakgrund ── */
:focus-visible {
  outline: 3px solid #243a2d;
  outline-offset: 2px;
  box-shadow: 0 0 0 5px rgba(255, 255, 255, .7);
  border-radius: 4px;
}
/* Galleribilder klipper halo (overflow:hidden) → använd inre ring istället */
.gallery-item:focus-visible { outline-offset: -3px; box-shadow: none; }

/* ── Laddnings-spinner i knappar (skicka-feedback) ── */
.btn-spinner {
  display: inline-block; width: 1em; height: 1em; margin-right: .5em; vertical-align: -2px;
  border: 2px solid currentColor; border-top-color: transparent; border-radius: 50%;
  animation: btnspin .6s linear infinite;
}
@keyframes btnspin { to { transform: rotate(360deg); } }

/* ── Respektera reducerad rörelse ── */
@media (prefers-reduced-motion: reduce) {
  .hero-rd::before, .hero-rd::after, .marquee-track, .hero-chip { animation: none !important; }
  .fade-in { transform: none; }
  .btn-spinner { animation-duration: 1.4s; }
  html { scroll-behavior: auto; }
}

@media (max-width: 768px) {
  .section { padding: 4rem 1.25rem; }
  .hero-rd h1 { font-size: clamp(2.3rem, 8vw, 3rem); }
}

/* ════════════════════════════════════════════════════════
   FAS 1 — bildspråk, scroll-berättelse, konvertering
   ════════════════════════════════════════════════════════ */

/* Hero-illustration / foto (fyller panelen, kort flyter ovanpå) */
.hero-scene { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 0; }
.hero-photo { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 0; }
.hero-art { background: #EAF0EB; }   /* fallback bakom bilden */

/* ── Bildkomponenter (foton på undersidor) ── */
.media-frame {
  border-radius: 24px; overflow: hidden; line-height: 0;
  box-shadow: 0 24px 50px -28px rgba(38,36,32,.30);
  border: 1px solid var(--warm-300); background: var(--warm-100);
}
.media-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }
.page-banner { max-width: 1200px; margin: -2.2rem auto 0; padding: 0 2rem; position: relative; z-index: 2; }
.page-banner .media-frame { aspect-ratio: 24 / 9; }
.section-photo { margin: 0 auto; }
.section-photo .media-frame { aspect-ratio: 16 / 8; }
.two-col .media-frame { aspect-ratio: 4 / 3; }
.photo-caption { text-align: center; font-size: 12.5px; color: var(--neutral-500); margin-top: .9rem; }
@media (max-width: 768px) {
  .page-banner { margin-top: -1.2rem; padding: 0 1.25rem; }
  .page-banner .media-frame, .section-photo .media-frame { aspect-ratio: 16 / 10; }
}

/* ── Scroll-berättelse: mörkgrön "Vägen mot självständighet" ── */
.journey {
  background:
    linear-gradient(165deg, rgba(39,64,47,.91) 0%, rgba(23,38,25,.95) 100%),
    url('../images/foton/vagen.jpg') center/cover no-repeat;
  color: #fff; padding: 7rem 2rem; position: relative; overflow: hidden;
}
.journey .container { position: relative; z-index: 1; }
.pullquote {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(1.5rem, 3.1vw, 2.4rem); line-height: 1.32; letter-spacing: -.015em;
  color: #fff; max-width: 900px; margin: 0 auto 4rem; text-align: center;
}
.pullquote em { color: var(--terra); font-style: normal; }
.journey-head { text-align: center; margin-bottom: 3.2rem; }
.journey-head .section-label { background: rgba(255,255,255,.12); color: var(--terra-soft); }
.journey-head h2 { color: #fff; }
.journey-track { max-width: 660px; margin: 0 auto; position: relative; padding-left: 46px; }
.journey-line { position: absolute; left: 10px; top: 6px; bottom: 6px; width: 4px; background: rgba(255,255,255,.16); border-radius: 99px; overflow: hidden; }
.journey-line-fill { position: absolute; left: 0; top: 0; width: 100%; height: calc(var(--jp, 0) * 100%); background: linear-gradient(180deg, var(--accent-500), var(--terra)); border-radius: 99px; }
.journey-step { position: relative; padding-bottom: 2.6rem; }
.journey-step:last-child { padding-bottom: 0; }
.jdot { position: absolute; left: -43px; top: 3px; width: 22px; height: 22px; border-radius: 50%; background: var(--primary-700); border: 3px solid rgba(255,255,255,.28); box-shadow: 0 0 0 5px rgba(255,255,255,.04); }
.journey-step h3 { font-family: var(--serif); color: #fff; font-size: 1.3rem; margin-bottom: .45rem; }
.journey-step p { color: rgba(255,255,255,.8); font-size: 15px; line-height: 1.72; }

/* ── Fast "Skicka förfrågan" på mobil ── */
.sticky-cta { display: none; }
@media (max-width: 768px) {
  .sticky-cta {
    display: flex; position: fixed; left: 14px; right: 14px; bottom: 14px; z-index: 900;
    align-items: center; justify-content: center; gap: 8px;
    background: var(--primary-600); color: #fff; text-decoration: none;
    font-weight: 700; font-size: 15px; padding: 15px; border-radius: 999px;
    box-shadow: 0 12px 30px -8px rgba(58,90,71,.6);
  }
  .sticky-cta .icon { width: 18px; height: 18px; }
  .footer { padding-bottom: 6rem; }   /* plats för knappen */
}

/* ── Galleri: Våra boendemiljöer (riktiga lägenhetsbilder) ── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
.gallery-item {
  position: relative; padding: 0; border: 1px solid var(--warm-300);
  border-radius: 18px; overflow: hidden; cursor: pointer; background: var(--warm-100);
  aspect-ratio: 3 / 2; box-shadow: var(--shadow-sm);
  transition: transform .25s cubic-bezier(.22,.61,.36,1), box-shadow .25s ease;
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s cubic-bezier(.22,.61,.36,1); }
.gallery-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(38,36,32,.28));
  opacity: 0; transition: opacity .25s ease;
}
.gallery-item:hover::after { opacity: 1; }
.gallery-item .zoom {
  position: absolute; right: 12px; bottom: 12px; z-index: 2;
  width: 34px; height: 34px; border-radius: 50%;
  background: rgba(255,255,255,.92); color: var(--primary-700);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(.8); transition: all .25s ease;
}
.gallery-item:hover .zoom { opacity: 1; transform: scale(1); }
.gallery-item .zoom .icon { width: 18px; height: 18px; }
.gallery-note { text-align: center; margin-top: 1.5rem; font-size: 13px; color: var(--neutral-500); }
.gallery-item.is-extra { display: none; }
.gallery-more-wrap { text-align: center; margin-top: 1.8rem; }
.gallery-more { gap: 8px; }

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 3000; display: none;
  align-items: center; justify-content: center;
  background: rgba(26,21,18,.92); backdrop-filter: blur(6px);
  padding: 4vh 4vw;
}
.lightbox.open { display: flex; }
.lightbox img { max-width: 100%; max-height: 90vh; border-radius: 14px; box-shadow: 0 30px 80px rgba(0,0,0,.5); }
.lightbox .lb-btn {
  position: absolute; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.25);
  color: #fff; width: 52px; height: 52px; border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center; transition: background .15s ease;
}
.lightbox .lb-btn:hover { background: rgba(255,255,255,.24); }
.lightbox .lb-btn .icon { width: 24px; height: 24px; }
.lb-prev { left: 3vw; } .lb-next { right: 3vw; }
.lb-close { top: 3vh; right: 3vw; width: 46px; height: 46px; }
.lb-count { position: absolute; bottom: 3vh; left: 0; right: 0; text-align: center; color: rgba(255,255,255,.75); font-size: 14px; }
@media (max-width: 640px) {
  .lb-prev { left: 8px; } .lb-next { right: 8px; }
  .lightbox .lb-btn { width: 44px; height: 44px; }
}

/* ════════════════════════════════════════════════════════
   FLERSTEGSFORMULÄR (placeringsförfrågan)
   ════════════════════════════════════════════════════════ */
/* Säkerställ att hidden-attributet alltid döljer (även .btn med display:inline-flex) */
[hidden] { display: none !important; }
.wiz-steps { list-style: none; display: flex; gap: 6px; padding: 0; margin: 0 0 12px; }
.wiz-steps li { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; color: var(--neutral-400); text-align: center; }
.wiz-dot { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; background: var(--warm-200); color: var(--neutral-500); font-weight: 700; font-size: 13px; transition: all .25s; }
.wiz-steps li.is-active { color: var(--primary-700); }
.wiz-steps li.is-active .wiz-dot { background: var(--primary-600); color: #fff; }
.wiz-steps li.is-done { color: var(--primary-700); }
.wiz-steps li.is-done .wiz-dot { background: var(--primary-100); color: var(--primary-700); }
.wiz-bar { height: 5px; border-radius: 99px; background: var(--warm-200); overflow: hidden; margin-bottom: 1.8rem; }
.wiz-bar span { display: block; height: 100%; width: 25%; background: linear-gradient(90deg, var(--primary-500), var(--primary-700)); border-radius: 99px; transition: width .35s cubic-bezier(.22,.61,.36,1); }
.fstep { animation: wizIn .35s ease; }
.fstep[hidden] { display: none; }
@keyframes wizIn { from { opacity: 0; transform: translateX(12px); } to { opacity: 1; transform: none; } }
.fstep-title { font-family: var(--serif); font-size: 1.25rem; color: var(--neutral-950); margin-bottom: .3rem; }
.fstep-hint { font-size: 13px; color: var(--neutral-500); margin-bottom: 1.4rem; }
.opt { font-weight: 500; color: var(--neutral-400); font-size: .82em; }
.wiz-nav { display: flex; align-items: center; gap: 10px; margin-top: 1.6rem; }
.wiz-spacer { flex: 1; }
.wiz-autosave { font-size: 12px; color: var(--accent-700); margin-top: .8rem; min-height: 1em; opacity: 0; transition: opacity .3s; }
.wiz-autosave.show { opacity: 1; }
.wiz-summary { background: var(--warm-50); border: 1px solid var(--warm-300); border-radius: 14px; padding: .4rem 1.25rem; margin-bottom: 1.2rem; }
.wiz-summary .row { display: flex; justify-content: space-between; gap: 1rem; padding: 9px 0; border-bottom: 1px solid var(--warm-200); font-size: 13.5px; }
.wiz-summary .row:last-child { border-bottom: 0; }
.wiz-summary .k { color: var(--neutral-500); flex: none; }
.wiz-summary .v { color: var(--neutral-900); font-weight: 500; text-align: right; }
.wiz-summary .v.empty { color: var(--neutral-400); font-weight: 400; font-style: italic; }
.wiz-success { text-align: center; padding: 2.6rem 1.5rem; background: var(--primary-50); border: 1px solid var(--primary-200); border-radius: 18px; }
.wiz-success-ico { width: 60px; height: 60px; border-radius: 50%; background: var(--primary-600); color: #fff; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.wiz-success h3 { font-family: var(--serif); font-size: 1.3rem; color: var(--neutral-950); margin-bottom: .4rem; }
.wiz-success p { color: var(--neutral-600); font-size: 14px; }
@media (max-width: 560px) { .wiz-lbl { display: none; } }

/* Passiv samtyckesnotis + felmarkering */
.consent-note { font-size: 12.5px; color: var(--neutral-500); line-height: 1.6; margin: .2rem 0 0; }
.consent-note a { color: var(--primary-700); text-decoration: underline; }
.form-group.is-invalid input, .form-group.is-invalid select, .form-group.is-invalid textarea {
  border-color: #D64545; box-shadow: 0 0 0 3px rgba(214,69,69,.13);
}
.form-group.is-invalid label { color: #C0392B; }

/* ── Hoppa till innehåll (a11y) ── */
.skip-link {
  position: absolute; left: 12px; top: -60px; z-index: 2000;
  background: var(--primary-700); color: #fff; padding: 10px 16px; border-radius: 10px;
  font-weight: 600; font-size: 14px; text-decoration: none; transition: top .2s ease;
}
.skip-link:focus { top: 12px; outline: 2px solid #fff; outline-offset: 2px; }
