/* =====================================================================
   Mobilabonnemangnorrland.se — designsystem "Breddgrad"
   Expeditions-kartografisk minimalism. Snö + polnatt + norrsken-accent.
   Bygger ovanpå Bootstrap 5.3.8. Prefix: .mn-
   ===================================================================== */

:root {
  /* Canvas / snö */
  --mn-snow:      #F4F7F9;
  --mn-snow-2:    #ECF2F5;
  --mn-white:     #FFFFFF;
  /* Polnatt / bläck */
  --mn-ink:       #0E1B2A;
  --mn-ink-2:     #18293B;
  --mn-graphite:  #46586A;
  --mn-graphite-2:#586A7B;
  /* Glaciärblå (logotyp) */
  --mn-blue:      #1862BE;
  --mn-blue-2:    #2585C8;
  --mn-blue-dk:   #0B53A0;
  --mn-wash:      #DCEAF0;
  --mn-wash-2:    #EAF3F7;
  /* Norrsken-accent (CTA / bästa) */
  --mn-aur-1:     #13C29B;
  --mn-aur-2:     #15A8C4;
  --mn-aur-3:     #1B9FD8;
  --mn-aurora:    linear-gradient(100deg, #13C29B 0%, #15A8C4 48%, #1B9FD8 100%);
  --mn-aurora-soft: linear-gradient(100deg, rgba(19,194,155,.14), rgba(27,159,216,.14));
  /* Linjer */
  --mn-line:      #D5E1E8;
  --mn-line-2:    #C4D5DF;
  --mn-line-ink:  rgba(255,255,255,.12);

  --mn-display: 'Hubot Sans', system-ui, sans-serif;
  --mn-body:    'Onest', system-ui, sans-serif;
  --mn-mono:    'Geist Mono', ui-monospace, monospace;

  --mn-radius:   14px;
  --mn-radius-sm: 9px;
  --mn-shadow:   0 1px 2px rgba(14,27,42,.04), 0 10px 30px -18px rgba(14,27,42,.28);
  --mn-shadow-lg:0 24px 60px -28px rgba(14,27,42,.42);
  --mn-maxw:     1180px;
}

/* ------------------------------------------------------------------ base */
html { scroll-behavior: smooth; }
body {
  font-family: var(--mn-body);
  color: var(--mn-ink);
  background: var(--mn-snow);
  font-size: 1.02rem;
  line-height: 1.62;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.mn-wrap { max-width: var(--mn-maxw); margin-inline: auto; padding-inline: 22px; }
@media (max-width: 575px){ .mn-wrap { padding-inline: 16px; } }

h1,h2,h3,h4 { font-family: var(--mn-display); color: var(--mn-ink); letter-spacing: -.018em; line-height: 1.08; font-weight: 800; }
h1 { font-size: clamp(2.1rem, 5.2vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.4vw, 2.35rem); font-weight: 700; }
h3 { font-size: clamp(1.2rem, 2.2vw, 1.5rem); font-weight: 700; }
a { color: var(--mn-blue); text-decoration: none; }
a:hover { color: var(--mn-blue-dk); text-decoration: underline; text-underline-offset: 2px; }
strong { font-weight: 600; color: var(--mn-ink); }
::selection { background: rgba(19,194,155,.24); }

/* coordinate / latitude kicker (map margin motif) */
.mn-coord {
  font-family: var(--mn-mono);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--mn-blue);
  display: inline-flex; align-items: center; gap: .55em;
}
.mn-coord::before {
  content: ""; width: 26px; height: 1px; background: var(--mn-blue); opacity: .7;
}
.mn-coord--ink { color: var(--mn-aur-1); }
.mn-coord--ink::before { background: var(--mn-aur-1); }

/* topographic contour texture (reused as background) */
.mn-topo {
  background-image:
    repeating-radial-gradient(circle at 18% 120%, transparent 0 38px, rgba(27,111,208,.05) 38px 39px),
    repeating-radial-gradient(circle at 90% -10%, transparent 0 46px, rgba(21,168,196,.045) 46px 47px);
}

/* ------------------------------------------------------------------ header */
.mn-head {
  background: var(--mn-white);
  border-bottom: 1px solid var(--mn-line);
  position: sticky; top: 0; z-index: 1030;
  backdrop-filter: saturate(1.2);
}
.mn-head__in { display: flex; align-items: center; gap: 18px; height: 70px; }
.mn-logo { display: inline-flex; align-items: center; }
.mn-logo img { height: 38px; width: auto; display: block; }
.mn-nav { margin-left: auto; display: flex; align-items: center; gap: 4px; }
.mn-nav a {
  font-size: .92rem; font-weight: 600; color: var(--mn-graphite);
  padding: 9px 13px; border-radius: 9px; white-space: nowrap;
}
.mn-nav a:hover { color: var(--mn-ink); background: var(--mn-snow-2); text-decoration: none; }
.mn-nav a.is-active { color: var(--mn-blue); }
.mn-burger { margin-left: auto; border: 1px solid var(--mn-line); background: var(--mn-white);
  width: 44px; height: 40px; border-radius: 10px; display: none; align-items: center; justify-content: center; }
.mn-burger span, .mn-burger span::before, .mn-burger span::after {
  display: block; width: 19px; height: 2px; background: var(--mn-ink); position: relative; border-radius: 2px; }
.mn-burger span::before { content:""; position: absolute; top: -6px; }
.mn-burger span::after  { content:""; position: absolute; top:  6px; }
@media (max-width: 900px){
  .mn-nav { position: fixed; inset: 70px 0 auto 0; flex-direction: column; align-items: stretch;
    background: var(--mn-white); border-bottom: 1px solid var(--mn-line); padding: 10px 16px 16px;
    gap: 2px; transform: translateY(-130%); transition: transform .28s ease; box-shadow: var(--mn-shadow); }
  .mn-nav.open { transform: translateY(0); }
  .mn-nav a { padding: 12px 10px; border-radius: 8px; }
  .mn-burger { display: inline-flex; }
  .mn-head__in { height: 64px; }
  .mn-logo img { height: 32px; }
}

/* ------------------------------------------------------------------ hero */
.mn-hero { position: relative; overflow: hidden; background: var(--mn-snow); border-bottom: 1px solid var(--mn-line); }
.mn-hero__in { position: relative; z-index: 2; padding-top: clamp(46px, 7vw, 86px); padding-bottom: clamp(40px, 5vw, 64px); }
.mn-hero h1 { margin: 16px 0 0; max-width: 14ch; }
.mn-hero__lead { font-size: clamp(1.05rem, 1.6vw, 1.22rem); color: var(--mn-graphite); max-width: 56ch; margin: 18px 0 0; }
.mn-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.mn-hero__meta { display: flex; flex-wrap: wrap; gap: 22px 30px; margin-top: 34px; }
.mn-hero__meta div { display: flex; flex-direction: column; }
.mn-hero__meta b { font-family: var(--mn-display); font-size: 1.45rem; font-weight: 800; color: var(--mn-ink); }
.mn-hero__meta span { font-size: .82rem; color: var(--mn-graphite-2); }
/* aurora ribbon glow top-right of hero */
.mn-hero::after {
  content: ""; position: absolute; z-index: 1; top: -40%; right: -10%;
  width: 60vw; height: 80vh; pointer-events: none;
  background: radial-gradient(60% 50% at 70% 40%, rgba(19,194,155,.20), transparent 70%),
              radial-gradient(50% 50% at 85% 60%, rgba(27,159,216,.18), transparent 72%);
  filter: blur(8px);
}
/* faint latitude ticks down the left */
.mn-hero::before {
  content: ""; position: absolute; z-index: 1; inset: 0; pointer-events: none;
  background-image: repeating-linear-gradient(to bottom, var(--mn-line) 0 1px, transparent 1px 64px);
  width: 1px; left: max(10px, calc((100vw - var(--mn-maxw))/2 + 8px)); opacity: .8;
}

@media (max-width: 640px){
  .mn-hero::before { display: none; } /* dölj latitud-rälsen på mobil (marginalmotiv för desktop) */
}

/* ------------------------------------------------------------------ sections */
.mn-sec { padding: clamp(44px, 6vw, 76px) 0; }
.mn-sec--wash { background: var(--mn-wash-2); border-block: 1px solid var(--mn-line); }
.mn-sec--snow { background: var(--mn-snow); }
.mn-sec--ink {
  background: var(--mn-ink); color: #DCE6EF; position: relative; overflow: hidden;
  border-block: 1px solid #11233a;
}
.mn-sec--ink h2, .mn-sec--ink h3 { color: #fff; }
.mn-sec--ink p { color: #AFC1D2; }
/* kontrast-overrides för mörka sektioner — !important för att slå .mn-prose-reglerna */
.mn-sec--ink a:not(.mn-btn) { color: #67D5EA !important; text-decoration: underline; text-decoration-color: rgba(103,213,234,.5); text-underline-offset: 2px; }
.mn-sec--ink a:not(.mn-btn):hover { color: #fff !important; text-decoration-color: #fff; }
.mn-sec--ink strong, .mn-sec--ink b, .mn-sec--ink .mn-prose strong { color: #fff !important; }
.mn-sec--ink .mn-prose { color: #C2D2E0; }
.mn-sec--ink li { color: #AFC1D2; }
/* komponenter med egen LJUS bakgrund inuti mörka sektioner → behåll mörk text */
.mn-sec--ink .mn-note p, .mn-sec--ink .mn-note li { color: var(--mn-ink-2) !important; }
.mn-sec--ink .mn-note strong, .mn-sec--ink .mn-note b,
.mn-sec--ink .mn-table strong, .mn-sec--ink .mn-table b,
.mn-sec--ink .mn-card strong, .mn-sec--ink .mn-card b,
.mn-sec--ink .mn-tile strong, .mn-sec--ink .mn-tile b,
.mn-sec--ink .mn-deal strong, .mn-sec--ink .mn-deal b { color: var(--mn-ink) !important; }
.mn-sec--ink .mn-note a:not(.mn-btn) { color: var(--mn-blue) !important; text-decoration-color: rgba(24,98,190,.4) !important; }
.mn-sec--ink .mn-card, .mn-sec--ink .mn-card p { color: var(--mn-ink-2); }
/* ghost-knapp i mörk sektion: transparent + mörk text = osynlig → ljus text/kant */
.mn-sec--ink .mn-btn--ghost { color: #fff; border-color: rgba(255,255,255,.42); }
.mn-sec--ink .mn-btn--ghost:hover { color: var(--mn-ink); background: #fff; border-color: #fff; }
/* tabeller (ljus bg) i mörka sektioner → mörk, läsbar text */
.mn-sec--ink .mn-table td, .mn-sec--ink .mn-table th { color: var(--mn-ink-2); }
.mn-sec--ink .mn-table thead th { color: var(--mn-graphite); }
.mn-sec--ink .mn-table td:first-child { color: var(--mn-ink); }
.mn-sec--ink .mn-table a:not(.mn-btn) { color: var(--mn-blue) !important; }
.mn-sec--ink .mn-tile__t { color: var(--mn-ink); }
.mn-sec--ink .mn-tile__d { color: var(--mn-graphite); }
.mn-sec--ink::before {
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background: radial-gradient(50% 60% at 12% 0%, rgba(19,194,155,.16), transparent 60%),
              radial-gradient(46% 60% at 92% 100%, rgba(27,159,216,.18), transparent 64%);
}
.mn-sec__head { max-width: 62ch; margin-bottom: 30px; position: relative; z-index: 2; }
.mn-sec__head h2 { margin: 12px 0 0; }
.mn-sec__head p { margin: 12px 0 0; color: var(--mn-graphite); }
.mn-sec--ink .mn-sec__head p { color: #AFC1D2; }

/* ------------------------------------------------------------------ buttons */
.mn-btn {
  --b: var(--mn-aurora);
  display: inline-flex; align-items: center; justify-content: center; gap: .5em;
  font-family: var(--mn-body); font-weight: 600; font-size: .98rem; line-height: 1;
  padding: 14px 22px; border-radius: 11px; border: 0; cursor: pointer;
  color: #062a26; background-image: var(--b); text-decoration: none;
  box-shadow: 0 8px 22px -10px rgba(21,168,196,.6); transition: transform .14s ease, box-shadow .2s ease, filter .2s ease;
  position: relative;
}
.mn-btn:hover { color: #062a26; transform: translateY(-1px); box-shadow: 0 14px 30px -10px rgba(21,168,196,.72); filter: saturate(1.08); text-decoration: none; }
.mn-btn:active { transform: translateY(0); }
.mn-btn--sm { padding: 10px 15px; font-size: .9rem; border-radius: 9px; }
.mn-btn--lg { padding: 16px 28px; font-size: 1.05rem; }
.mn-btn--ink { background-image: none; background: var(--mn-ink); color: #fff; box-shadow: none; }
.mn-btn--ink:hover { background: var(--mn-ink-2); color: #fff; }
.mn-btn--ghost { background: transparent; background-image: none; color: var(--mn-ink); border: 1.5px solid var(--mn-line-2); box-shadow: none; }
.mn-btn--ghost:hover { background: var(--mn-white); border-color: var(--mn-blue); color: var(--mn-blue); }
.mn-btn--block { width: 100%; }

/* ------------------------------------------------------------------ pills/tags/badges */
.mn-tag {
  font-family: var(--mn-mono); font-size: .7rem; font-weight: 500; letter-spacing: .03em;
  text-transform: uppercase; color: var(--mn-graphite);
  border: 1px solid var(--mn-line); background: var(--mn-white);
  padding: 4px 9px; border-radius: 999px; display: inline-flex; align-items: center; gap: .4em; white-space: nowrap;
}
.mn-tag--data { color: var(--mn-blue-dk); border-color: #bcd6e6; background: var(--mn-wash-2); }
.mn-tag--free { color: #0a7f66; border-color: #bfe7dc; background: #eaf8f3; }
.mn-tag--nobind { color: #0a7f66; border-color: #bfe7dc; background: #eaf8f3; }
.mn-tag--net { color: var(--mn-graphite); }

/* ------------------------------------------------------------------ deal list */
.mn-list { display: grid; gap: 14px; }
.mn-deal {
  position: relative; background: var(--mn-white); border: 1px solid var(--mn-line);
  border-radius: var(--mn-radius); padding: 20px 20px 18px; padding-top: 30px;
  display: grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items: center;
  box-shadow: var(--mn-shadow); transition: border-color .18s ease, box-shadow .2s ease, transform .14s ease;
}
.mn-deal:hover { border-color: var(--mn-line-2); box-shadow: var(--mn-shadow-lg); transform: translateY(-2px); }
.mn-deal--best { border-color: transparent; box-shadow: 0 0 0 2px var(--mn-aur-1), var(--mn-shadow-lg); }

/* jämförpris-badge på topplinjen: mitten desktop, höger mobil */
.mn-deal__jmf {
  position: absolute; top: -1px; left: 50%; transform: translate(-50%, -50%);
  font-family: var(--mn-mono); font-size: .72rem; font-weight: 600; letter-spacing: .02em;
  color: var(--mn-ink); background: var(--mn-wash); border: 1px solid var(--mn-line-2);
  padding: 4px 12px; border-radius: 999px; white-space: nowrap; cursor: help; z-index: 3;
}
.mn-deal__jmf b { color: var(--mn-blue-dk); font-weight: 700; }
@media (max-width: 640px){
  .mn-deal__jmf { left: auto; right: 14px; transform: translateY(-50%); font-size: .66rem; padding: 3px 9px; }
}
.mn-deal__ribbon {
  position: absolute; top: -1px; right: 16px; transform: translateY(-50%);
  font-family: var(--mn-mono); font-size: .66rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: #06322b; background-image: var(--mn-aurora); padding: 4px 11px; border-radius: 999px; z-index: 4;
  box-shadow: 0 6px 16px -6px rgba(19,194,155,.7);
}
.mn-deal--best .mn-deal__jmf { left: 22px; transform: translateY(-50%); }
@media (max-width: 640px){ .mn-deal--best .mn-deal__jmf { left: 14px; } .mn-deal--best .mn-deal__ribbon{ font-size:.6rem; } }

.mn-deal__rank {
  font-family: var(--mn-mono); font-size: 1.15rem; font-weight: 600; color: var(--mn-graphite-2);
  width: 34px; text-align: center; align-self: start; padding-top: 2px;
}
.mn-deal--best .mn-deal__rank { color: #0B7385; }
.mn-deal__body { min-width: 0; }
.mn-deal__logo { height: 30px; width: auto; max-width: 130px; object-fit: contain; object-position: left center; margin-bottom: 9px; }
.mn-deal__name { font-family: var(--mn-display); font-weight: 700; font-size: 1.12rem; line-height: 1.2; }
.mn-deal__name a { color: var(--mn-ink); }
.mn-deal__name a:hover { color: var(--mn-blue); text-decoration: none; }
.mn-deal__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.mn-deal__right { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; text-align: right; min-width: 132px; }
.mn-deal__price { font-family: var(--mn-display); font-weight: 800; font-size: 1.7rem; color: var(--mn-ink); line-height: 1; }
.mn-deal__price small { font-family: var(--mn-body); font-size: .8rem; font-weight: 500; color: var(--mn-graphite-2); }
.mn-deal__campaign { font-size: .76rem; color: var(--mn-graphite-2); margin-top: -2px; }
.mn-stars { display: inline-flex; gap: 1px; }
.mn-stars svg { width: 15px; height: 15px; }
.mn-stars--lg svg { width: 20px; height: 20px; }

@media (max-width: 640px){
  .mn-deal { grid-template-columns: 1fr auto; padding-top: 30px; gap: 12px 14px; }
  .mn-deal__rank { grid-row: 1; grid-column: 1; width: auto; font-size: .9rem; }
  .mn-deal__body { grid-column: 1 / -1; grid-row: 2; }
  .mn-deal__right { grid-column: 1 / -1; grid-row: 3; flex-direction: row; flex-wrap: wrap; align-items: baseline; justify-content: flex-start; gap: 2px 12px; text-align: left; border-top: 1px solid var(--mn-line); padding-top: 12px; }
  .mn-deal__price { order: 1; }
  .mn-deal__campaign { order: 2; }
  .mn-stars { order: 3; flex-basis: 100%; margin-top: 2px; }
  .mn-deal__right .mn-btn { order: 4; flex-basis: 100%; justify-content: center; margin-top: 8px; }
}

/* ------------------------------------------------------------------ operator grid */
.mn-opgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(168px, 1fr)); gap: 14px; }
.mn-opcard {
  background: var(--mn-white); border: 1px solid var(--mn-line); border-radius: var(--mn-radius-sm);
  padding: 20px 16px; display: flex; flex-direction: column; gap: 8px; align-items: flex-start;
  transition: border-color .18s ease, box-shadow .2s ease, transform .14s ease; box-shadow: var(--mn-shadow);
}
.mn-opcard:hover { border-color: var(--mn-blue); box-shadow: var(--mn-shadow-lg); transform: translateY(-2px); text-decoration: none; }
.mn-opcard__rank { font-family: var(--mn-mono); font-size: .68rem; color: var(--mn-graphite-2); letter-spacing: .08em; }
.mn-opcard__logo { height: 30px; max-width: 120px; object-fit: contain; object-position: left center; }
.mn-opcard__name { font-family: var(--mn-display); font-weight: 700; font-size: 1.05rem; color: var(--mn-ink); }
.mn-opcard__more { font-family: var(--mn-mono); font-size: .72rem; color: var(--mn-blue); margin-top: auto; }

/* ------------------------------------------------------------------ tables */
.mn-tablewrap { border: 1px solid var(--mn-line); border-radius: var(--mn-radius); overflow-x: auto; -webkit-overflow-scrolling: touch; background: var(--mn-white); }
.mn-tablewrap table { min-width: 460px; }
table.mn-table { width: 100%; margin: 0; border-collapse: collapse; font-size: .95rem; }
.mn-table th, .mn-table td { padding: 13px 16px; border-bottom: 1px solid var(--mn-line); text-align: left; vertical-align: middle; }
.mn-table thead th { font-family: var(--mn-mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .06em; color: var(--mn-graphite); background: var(--mn-snow-2); font-weight: 500; }
.mn-table tbody tr:last-child td { border-bottom: 0; }
.mn-table td:first-child { font-weight: 600; color: var(--mn-ink); }
.mn-table .yes { color: #0a7f66; font-weight: 600; }
.mn-table .no { color: var(--mn-graphite-2); }
.mn-table tbody tr:hover { background: var(--mn-wash-2); }

/* ------------------------------------------------------------------ scorecard */
.mn-card { background: var(--mn-white); border: 1px solid var(--mn-line); border-radius: var(--mn-radius); padding: 22px; box-shadow: var(--mn-shadow); }
.mn-card__head { display: flex; align-items: center; gap: 14px; padding-bottom: 16px; border-bottom: 1px solid var(--mn-line); margin-bottom: 16px; }
.mn-card__head img { height: 32px; max-width: 130px; object-fit: contain; }
.mn-card__verdict { margin-left: auto; text-align: right; }
.mn-card__grade { font-family: var(--mn-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .06em; color: var(--mn-graphite); margin-top: 4px; }
.mn-score__row { display: grid; grid-template-columns: 7.5em 1fr auto; align-items: center; gap: 12px; margin: 11px 0; }
.mn-score__row .cri { font-size: .86rem; color: var(--mn-graphite); }
.mn-score__bar { height: 7px; border-radius: 999px; background: var(--mn-snow-2); overflow: hidden; }
.mn-score__bar i { display: block; height: 100%; background-image: var(--mn-aurora); border-radius: 999px; }
.mn-score__val { font-family: var(--mn-mono); font-size: .72rem; color: var(--mn-graphite); }
.mn-versus { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px){ .mn-versus { grid-template-columns: 1fr; } .mn-score__row{ grid-template-columns: 6em 1fr auto; } }

/* ------------------------------------------------------------------ prose */
.mn-prose { font-size: 1.04rem; color: var(--mn-ink-2); max-width: 70ch; }
.mn-prose p { margin: 0 0 1.05em; }
.mn-prose h2 { margin: 1.8em 0 .5em; }
.mn-prose h3 { margin: 1.5em 0 .4em; }
.mn-prose ul, .mn-prose ol { margin: 0 0 1.1em; padding-left: 1.25em; }
.mn-prose li { margin: .35em 0; }
.mn-prose a:not(.mn-btn) { color: var(--mn-blue); font-weight: 500; text-decoration: underline; text-decoration-color: rgba(27,111,208,.3); text-underline-offset: 2px; }
.mn-prose a:not(.mn-btn):hover { text-decoration-color: var(--mn-blue); }
.mn-prose strong { color: var(--mn-ink); }

/* article image */
.mn-figure { margin: 0 0 4px; border-radius: var(--mn-radius); overflow: hidden; border: 1px solid var(--mn-line); box-shadow: var(--mn-shadow); }
.mn-figure img { display: block; width: 100%; height: auto; aspect-ratio: 3 / 2; object-fit: cover; }
.mn-figure figcaption { font-size: .8rem; color: var(--mn-graphite-2); padding: 8px 14px; background: var(--mn-white); }
.mn-sec .mn-figure { margin-bottom: 22px; }

/* callout / fact box */
.mn-note {
  border: 1px solid var(--mn-line); border-left: 3px solid var(--mn-aur-1);
  background: var(--mn-white); border-radius: 0 var(--mn-radius-sm) var(--mn-radius-sm) 0;
  padding: 16px 18px; margin: 1.4em 0; box-shadow: var(--mn-shadow);
}
.mn-note__k { font-family: var(--mn-mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .08em; color: #0B7385; display: block; margin-bottom: 5px; }

/* ------------------------------------------------------------------ FAQ */
.mn-faq { display: grid; gap: 10px; }
.mn-faq details { background: var(--mn-white); border: 1px solid var(--mn-line); border-radius: var(--mn-radius-sm); overflow: hidden; }
.mn-faq summary { cursor: pointer; list-style: none; padding: 17px 20px; font-family: var(--mn-display); font-weight: 700; font-size: 1.05rem; color: var(--mn-ink); display: flex; align-items: center; gap: 12px; }
.mn-faq summary::-webkit-details-marker { display: none; }
.mn-faq summary::after { content: "+"; margin-left: auto; font-family: var(--mn-mono); font-size: 1.3rem; color: var(--mn-blue); transition: transform .2s ease; }
.mn-faq details[open] summary::after { transform: rotate(45deg); }
.mn-faq__a { padding: 0 20px 18px; color: var(--mn-ink-2); }
.mn-faq__a p { margin: 0 0 .8em; }
.mn-faq__a :last-child { margin-bottom: 0; }

/* ------------------------------------------------------------------ chips / link tiles */
.mn-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.mn-tile {
  background: var(--mn-white); border: 1px solid var(--mn-line); border-radius: var(--mn-radius-sm);
  padding: 16px 18px; display: flex; flex-direction: column; gap: 4px;
  transition: border-color .16s ease, transform .14s ease, box-shadow .2s ease;
}
.mn-tile:hover { border-color: var(--mn-blue); transform: translateY(-2px); box-shadow: var(--mn-shadow); text-decoration: none; }
.mn-tile__t { font-family: var(--mn-display); font-weight: 700; color: var(--mn-ink); font-size: 1.02rem; }
.mn-tile__d { font-size: .85rem; color: var(--mn-graphite); }
.mn-tile__k { font-family: var(--mn-mono); font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--mn-blue); }

/* ------------------------------------------------------------------ breadcrumbs */
.mn-crumbs { font-family: var(--mn-mono); font-size: .74rem; color: var(--mn-graphite-2); padding: 14px 0 0; letter-spacing: .02em; }
.mn-crumbs a { color: var(--mn-graphite); }
.mn-crumbs a:hover { color: var(--mn-blue); }
.mn-crumbs span { color: var(--mn-line-2); margin: 0 .5em; }

/* ------------------------------------------------------------------ misc */
.mn-mini { font-size: .85rem; color: var(--mn-graphite-2); }
.mn-mt0 { margin-top: 0 !important; }
.mn-divider { height: 1px; background: var(--mn-line); border: 0; margin: 0; }
.mn-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.mn-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 760px){ .mn-grid-2, .mn-grid-3 { grid-template-columns: 1fr; } }
.mn-lead { font-size: 1.12rem; color: var(--mn-graphite); }

/* aurora highlight inline word */
.mn-aur { background-image: var(--mn-aurora); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ------------------------------------------------------------------ footer */
.mn-foot { background: var(--mn-ink); color: #9FB2C4; padding: 54px 0 30px; border-top: 1px solid #11233a; }
.mn-foot a { color: #C4D4E2; }
.mn-foot a:hover { color: #fff; }
.mn-foot__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 30px; }
.mn-foot__grid h4 { color: #fff; font-size: .8rem; font-family: var(--mn-mono); text-transform: uppercase; letter-spacing: .1em; font-weight: 500; margin-bottom: 14px; }
.mn-foot__links { display: flex; flex-direction: column; gap: 8px; font-size: .92rem; }
.mn-foot__logo img { height: 34px; filter: brightness(0) invert(1); opacity: .92; }
.mn-foot__brand { font-size: .9rem; max-width: 34ch; margin-top: 14px; line-height: 1.55; }
.mn-foot__bottom { border-top: 1px solid #1c3247; margin-top: 40px; padding-top: 20px; display: flex; flex-wrap: wrap; gap: 10px 24px; align-items: center; font-size: .82rem; color: #7E93A6; }
.mn-foot__bottom .mn-coord { color: #7E93A6; }
.mn-foot__bottom .mn-coord::before { background: #41566b; }
@media (max-width: 760px){ .mn-foot__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px){ .mn-foot__grid { grid-template-columns: 1fr; } }

/* larger jämförpris tooltip */
.mn-tip { --bs-tooltip-max-width: 320px; --bs-tooltip-bg: var(--mn-ink); --bs-tooltip-opacity: 1; font-family: var(--mn-body); }
.mn-tip .tooltip-inner { font-size: .84rem; line-height: 1.5; padding: 11px 14px; border-radius: 10px; box-shadow: var(--mn-shadow-lg); text-align: left; }

/* CTA band */
.mn-cta-band { display: flex; flex-wrap: wrap; align-items: center; gap: 20px; justify-content: space-between; }
.mn-cta-band h2 { max-width: 22ch; }

/* ============================================================
   QA-fixar 2026-06-03 (granskning)
   ============================================================ */
/* 1) Vita kort i mörka sektioner ska ha mörka rubriker (inte ärva #fff) */
.mn-sec--ink .mn-card h2,
.mn-sec--ink .mn-card h3,
.mn-sec--ink .mn-card .mn-tile__t { color: var(--mn-ink); }
/* 2) Inga eyebrows/kickers (koordinat-etiketter + tile-kickers) */
.mn-coord, .mn-tile__k { display: none !important; }
/* 3) Footer-logo: visa originallogo på en ren vit bricka istället för trasig invert */
.mn-foot__logo { display: inline-block; background: #fff; padding: 9px 13px; border-radius: 10px; line-height: 0; }
.mn-foot__logo img { filter: none !important; opacity: 1 !important; height: 34px !important; width: auto !important; max-width: 210px; display: block; }
