/* =========================================================================
   Billigamobilabonnemang.net — "Prislapp"
   Warm, trustworthy budget-comparison aesthetic.
   Gabarito (display) · Instrument Sans (body) · DM Mono (price figures)
   Palette: periwinkle band · deep indigo ink · savings-green · brass/gold
   Prefix: bm-
   ========================================================================= */

/* ---------- Fonts (self-hosted woff2) ---------- */
@font-face{font-family:'Gabarito';font-style:normal;font-weight:400;font-display:swap;src:url('/media/font/Gabarito-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:400;font-display:swap;src:url('/media/font/Gabarito-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:600;font-display:swap;src:url('/media/font/Gabarito-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:600;font-display:swap;src:url('/media/font/Gabarito-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:700;font-display:swap;src:url('/media/font/Gabarito-latin-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:700;font-display:swap;src:url('/media/font/Gabarito-latin-ext-700.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:800;font-display:swap;src:url('/media/font/Gabarito-latin-800.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:800;font-display:swap;src:url('/media/font/Gabarito-latin-ext-800.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:900;font-display:swap;src:url('/media/font/Gabarito-latin-900.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Gabarito';font-style:normal;font-weight:900;font-display:swap;src:url('/media/font/Gabarito-latin-ext-900.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}

@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/media/font/InstrumentSans-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:400;font-display:swap;src:url('/media/font/InstrumentSans-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:500;font-display:swap;src:url('/media/font/InstrumentSans-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:500;font-display:swap;src:url('/media/font/InstrumentSans-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/media/font/InstrumentSans-latin-600.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:600;font-display:swap;src:url('/media/font/InstrumentSans-latin-ext-600.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:700;font-display:swap;src:url('/media/font/InstrumentSans-latin-700.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:700;font-display:swap;src:url('/media/font/InstrumentSans-latin-ext-700.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}

@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/media/font/DMMono-latin-400.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url('/media/font/DMMono-latin-ext-400.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/media/font/DMMono-latin-500.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:500;font-display:swap;src:url('/media/font/DMMono-latin-ext-500.woff2') format('woff2');unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}

/* ---------- Tokens ---------- */
:root{
  --bm-bg:#F4F2FB;            /* soft lavender white */
  --bm-bg-warm:#FBFAFF;
  --bm-card:#FFFFFF;
  --bm-ink:#1A1538;          /* deep indigo ink */
  --bm-ink-soft:#46406B;
  --bm-muted:#6E688F;
  --bm-line:#E5E1F2;
  --bm-peri:#D7D5F1;         /* periwinkle band */
  --bm-peri-deep:#B6B2E6;
  --bm-violet:#5244C9;       /* primary */
  --bm-violet-deep:#372B97;
  --bm-violet-ink:#2A2073;
  --bm-mint:#14B877;         /* savings / CTA */
  --bm-mint-deep:#0C9760;
  --bm-mint-soft:#E3F7EE;
  --bm-brass:#A9842A;        /* jämförpris highlight */
  --bm-brass-soft:#F6EED6;
  --bm-shadow:0 14px 40px -20px rgba(38,28,110,.42);
  --bm-shadow-sm:0 6px 18px -12px rgba(38,28,110,.40);
  --bm-radius:18px;
  --bm-radius-sm:12px;
  --bm-maxw:1140px;
  --bm-display:'Gabarito',system-ui,sans-serif;
  --bm-body:'Instrument Sans',system-ui,sans-serif;
  --bm-mono:'DM Mono',ui-monospace,monospace;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bm-bg);color:var(--bm-ink);
  font-family:var(--bm-body);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:radial-gradient(60% 38% at 88% -8%,rgba(82,68,201,.10),transparent 70%),radial-gradient(50% 34% at -6% 4%,rgba(20,184,119,.07),transparent 70%);
}
h1,h2,h3,h4,h5{font-family:var(--bm-display);color:var(--bm-ink);font-weight:800;line-height:1.1;letter-spacing:-.018em;margin:0 0 .5em}
h1{font-size:clamp(2.1rem,5.2vw,3.5rem);font-weight:900}
h2{font-size:clamp(1.55rem,3.3vw,2.25rem)}
h3{font-size:clamp(1.2rem,2.2vw,1.5rem)}
h4{font-size:1.12rem;font-weight:700}
p{margin:0 0 1rem}
a{color:var(--bm-violet);text-decoration:none;text-underline-offset:3px;text-decoration-thickness:.08em}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.container{width:100%;max-width:var(--bm-maxw);margin-inline:auto;padding-inline:20px}
.container.narrow{max-width:780px}
strong{font-weight:700}
hr{border:0;border-top:1px solid var(--bm-line);margin:2rem 0}

/* ---------- Header ---------- */
.bm-top{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--bm-line)}
.bm-nav{display:flex;align-items:center;gap:1rem;min-height:72px}
.bm-brand{display:flex;align-items:center;flex:0 0 auto}
.bm-brand img{height:42px;width:auto;display:block}
.bm-menu{display:flex;align-items:center;gap:.35rem;margin:0 0 0 auto;padding:0;list-style:none}
.bm-menu a{display:inline-block;padding:.5rem .8rem;border-radius:999px;color:var(--bm-ink-soft);font-weight:600;font-size:.97rem;letter-spacing:-.01em}
.bm-menu a:hover{background:var(--bm-peri);color:var(--bm-violet-ink);text-decoration:none}
.bm-menu a.active{background:var(--bm-violet);color:#fff}
.bm-burger{display:none;margin-left:auto;border:1px solid var(--bm-line);background:#fff;color:var(--bm-ink);font-family:var(--bm-display);font-weight:700;border-radius:10px;padding:.5rem .85rem;cursor:pointer}

/* ---------- Buttons ---------- */
.bm-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--bm-display);font-weight:700;font-size:1rem;letter-spacing:-.01em;padding:.78rem 1.4rem;border-radius:999px;border:2px solid transparent;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}
.bm-btn:hover{text-decoration:none;transform:translateY(-2px)}
.bm-btn-primary{background:var(--bm-mint);color:#06311f;box-shadow:0 10px 22px -12px rgba(12,151,96,.85)}
.bm-btn-primary:hover{background:var(--bm-mint-deep);color:#fff}
.bm-btn-ghost{background:transparent;color:var(--bm-violet-ink);border-color:var(--bm-peri-deep)}
.bm-btn-ghost:hover{background:var(--bm-violet);color:#fff;border-color:var(--bm-violet)}
.bm-btn-dark{background:var(--bm-violet);color:#fff}
.bm-btn-dark:hover{background:var(--bm-violet-deep);color:#fff}

/* ---------- Hero ---------- */
.bm-hero{position:relative;overflow:hidden;background:linear-gradient(170deg,var(--bm-peri) 0%,#E7E5F8 58%,var(--bm-bg) 100%);border-bottom:1px solid var(--bm-line)}
.bm-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(55,43,151,.10) 1px,transparent 0);background-size:22px 22px;opacity:.5;pointer-events:none}
.bm-hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:2.5rem;align-items:center;padding:clamp(2.4rem,6vw,4.6rem) 0}
.bm-hero h1{margin-bottom:.4em}
.bm-hero h1 .hl{color:var(--bm-violet-deep);position:relative;white-space:nowrap}
.bm-hero h1 .hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.34em;background:var(--bm-mint);opacity:.32;border-radius:3px;z-index:-1}
.bm-hero .lead{font-size:1.16rem;color:var(--bm-ink-soft);max-width:54ch}
.bm-hero-meta{display:inline-flex;align-items:center;gap:.5rem;margin-top:.2rem;font-size:.92rem;color:var(--bm-violet-ink);font-weight:600}
.bm-hero-meta .dot{width:7px;height:7px;border-radius:50%;background:var(--bm-mint);box-shadow:0 0 0 4px var(--bm-mint-soft)}
.bm-hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.6rem}
.bm-hero-list{margin:1.4rem 0 0;padding:0;list-style:none;display:grid;gap:.55rem}
.bm-hero-list li{display:flex;align-items:center;gap:.6rem;font-weight:500;color:var(--bm-ink-soft)}
.bm-hero-list svg{flex:0 0 auto;width:22px;height:22px;color:var(--bm-mint-deep)}

/* Hero price tag card */
.bm-tag{position:relative;background:var(--bm-card);border-radius:var(--bm-radius);box-shadow:var(--bm-shadow);padding:1.6rem 1.6rem 1.5rem;border:1px solid var(--bm-line)}
.bm-tag::before{content:"";position:absolute;top:24px;left:-9px;width:18px;height:18px;border-radius:50%;background:var(--bm-peri);border:1px solid var(--bm-peri-deep)}
.bm-tag-eyebrow{font-family:var(--bm-display);font-weight:700;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--bm-brass)}
.bm-tag-op{font-family:var(--bm-display);font-weight:900;font-size:2.1rem;line-height:1.05;margin:.15rem 0 .1rem;color:var(--bm-ink)}
.bm-tag-price{font-family:var(--bm-mono);font-size:2.5rem;font-weight:500;color:var(--bm-violet-deep);letter-spacing:-.02em}
.bm-tag-price small{font-family:var(--bm-body);font-size:1rem;color:var(--bm-muted);font-weight:500}
.bm-tag-row{display:flex;flex-wrap:wrap;gap:.4rem;margin:.7rem 0 1.1rem}
.bm-tag .bm-btn{width:100%;justify-content:center}
.bm-tag-foot{margin-top:.7rem;font-size:.84rem;color:var(--bm-muted);text-align:center}

/* ---------- Sections ---------- */
.bm-section{padding:clamp(2.4rem,5vw,4rem) 0}
.bm-section.alt{background:var(--bm-bg-warm);border-block:1px solid var(--bm-line)}
.bm-section.tint{background:linear-gradient(180deg,#EEEBFA,var(--bm-bg))}
.bm-sec-head{max-width:64ch;margin-bottom:1.6rem}
.bm-sec-head p{color:var(--bm-muted);font-size:1.05rem;margin:0}
.bm-kicker{display:inline-block;font-family:var(--bm-display);font-weight:700;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bm-violet);background:var(--bm-peri);padding:.3rem .7rem;border-radius:999px;margin-bottom:.7rem}

/* ---------- Pills ---------- */
.bm-pills{display:flex;flex-wrap:wrap;gap:.4rem;margin:.55rem 0}
.bm-pill{font-size:.8rem;font-weight:600;color:var(--bm-ink-soft);background:var(--bm-bg);border:1px solid var(--bm-line);padding:.22rem .6rem;border-radius:999px;line-height:1.4}
.bm-pill.green{color:var(--bm-mint-deep);background:var(--bm-mint-soft);border-color:transparent}
.bm-pill.violet{color:var(--bm-violet-deep);background:var(--bm-peri);border-color:transparent}
.bm-pill.dark{color:#fff;background:var(--bm-ink);border-color:transparent}

/* ---------- Deal list (price-tag cards) ---------- */
.bm-deals{display:grid;gap:1rem;counter-reset:deal}
.bm-deal{position:relative;background:var(--bm-card);border:1px solid var(--bm-line);border-radius:var(--bm-radius);box-shadow:var(--bm-shadow-sm);padding:1rem 1.2rem 1.15rem;transition:box-shadow .16s ease,transform .16s ease,border-color .16s ease}
.bm-deal:hover{box-shadow:var(--bm-shadow);transform:translateY(-2px);border-color:var(--bm-peri-deep)}
.bm-deal.is-top{border-color:var(--bm-mint);box-shadow:0 16px 40px -22px rgba(12,151,96,.6)}

/* top strip: rank (left) · jämförpris (centered desktop / right mobile) */
.bm-deal-top{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.5rem;margin-bottom:.7rem;padding-bottom:.7rem;border-bottom:1px dashed var(--bm-line)}
.bm-rank{justify-self:start;font-family:var(--bm-display);font-weight:800;font-size:.88rem;color:var(--bm-muted);display:inline-flex;align-items:center;gap:.4rem}
.bm-rank b{font-size:1.05rem;color:var(--bm-ink)}
.bm-rank.top{color:var(--bm-mint-deep)}
.bm-badge-best{background:var(--bm-mint);color:#06311f;font-weight:800;font-size:.74rem;letter-spacing:.02em;padding:.2rem .55rem;border-radius:999px;text-transform:uppercase}
.bm-jmf{grid-column:2;justify-self:center;position:relative;display:inline-flex;align-items:center;gap:.4rem;background:var(--bm-brass-soft);color:var(--bm-brass);border:1px solid #E6D8AE;font-family:var(--bm-display);font-weight:700;font-size:.82rem;padding:.28rem .7rem;border-radius:999px;cursor:help;white-space:nowrap}
.bm-jmf b{font-family:var(--bm-mono);font-weight:500}
.bm-jmf .bm-tip{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(4px);width:min(280px,78vw);white-space:normal;text-align:left;background:var(--bm-ink);color:#fff;font-family:var(--bm-body);font-weight:400;font-size:.82rem;line-height:1.5;padding:.7rem .85rem;border-radius:10px;box-shadow:var(--bm-shadow);transition:opacity .16s ease,transform .16s ease;z-index:60;text-transform:none;letter-spacing:0}
.bm-jmf .bm-tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:var(--bm-ink)}
.bm-jmf:hover .bm-tip,.bm-jmf:focus .bm-tip{visibility:visible;opacity:1;transform:translateX(-50%) translateY(0)}

.bm-deal-body{display:grid;grid-template-columns:88px 1fr auto;gap:1rem;align-items:center}
.bm-deal-logo{display:flex;align-items:center;justify-content:center;width:84px;height:56px;background:#fff;border:1px solid var(--bm-line);border-radius:var(--bm-radius-sm);padding:.45rem}
.bm-deal-logo img{max-height:40px;max-width:72px;width:auto;object-fit:contain}
.bm-deal-info h3,.bm-deal-info h4{margin:0 0 .25rem;font-family:var(--bm-display);font-weight:800;font-size:1.12rem;letter-spacing:-.01em}
.bm-deal-price{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;min-width:130px}
.bm-deal-price .now{font-family:var(--bm-mono);font-size:1.7rem;font-weight:500;color:var(--bm-violet-deep);letter-spacing:-.02em;line-height:1}
.bm-deal-price .unit{font-size:.82rem;color:var(--bm-muted)}
.bm-deal-price .camp{font-size:.78rem;color:var(--bm-mint-deep);font-weight:600;max-width:22ch}
.bm-deal-price .bm-btn{margin-top:.5rem;padding:.55rem 1.05rem;font-size:.92rem}

/* stars */
.bm-stars{display:inline-flex;gap:1px;color:var(--bm-brass)}
.bm-stars svg{width:16px;height:16px}
.bm-stars svg.empty{color:#D8D2EC}

/* ---------- Prose ---------- */
.bm-prose{font-size:1.06rem;color:var(--bm-ink-soft);line-height:1.72}
.bm-prose h2{margin-top:2.2rem}
.bm-prose h3{margin-top:1.7rem;color:var(--bm-ink)}
.bm-prose p,.bm-prose li{color:var(--bm-ink-soft)}
.bm-prose ul,.bm-prose ol{padding-left:1.2rem;margin:0 0 1.2rem}
.bm-prose li{margin-bottom:.45rem}
.bm-prose ul li::marker{color:var(--bm-mint-deep)}
.bm-prose a:not(.bm-btn){color:var(--bm-violet);font-weight:600}
.bm-prose strong{color:var(--bm-ink)}
.bm-prose blockquote{margin:1.5rem 0;padding:1rem 1.3rem;background:var(--bm-peri);border-radius:var(--bm-radius-sm);border-left:4px solid var(--bm-violet);color:var(--bm-violet-ink);font-weight:500}
.bm-prose figure{margin:1.6rem 0}
.bm-prose figure img{border-radius:var(--bm-radius);box-shadow:var(--bm-shadow-sm)}
.bm-prose figcaption{font-size:.85rem;color:var(--bm-muted);margin-top:.5rem;text-align:center}

/* highlight callout box */
.bm-note{background:var(--bm-mint-soft);border:1px solid #BDEAD6;border-radius:var(--bm-radius-sm);padding:1.1rem 1.25rem;margin:1.5rem 0}
.bm-note h4{color:var(--bm-mint-deep);margin:0 0 .3rem}
.bm-note p:last-child{margin-bottom:0}

/* ---------- Tables ---------- */
.bm-table-wrap{overflow-x:auto;margin:1.5rem 0;border:1px solid var(--bm-line);border-radius:var(--bm-radius);background:var(--bm-card)}
table.bm-table{width:100%;border-collapse:collapse;font-size:.97rem;min-width:480px}
table.bm-table th,table.bm-table td{padding:.7rem .9rem;text-align:left;border-bottom:1px solid var(--bm-line)}
table.bm-table thead th{background:var(--bm-violet);color:#fff;font-family:var(--bm-display);font-weight:700;letter-spacing:-.01em}
table.bm-table tbody tr:nth-child(even){background:var(--bm-bg-warm)}
table.bm-table tbody tr:last-child td{border-bottom:0}
table.bm-table td:first-child{font-weight:600;color:var(--bm-ink)}

/* ---------- FAQ ---------- */
.bm-faq{display:grid;gap:.6rem}
.bm-faq details{background:var(--bm-card);border:1px solid var(--bm-line);border-radius:var(--bm-radius-sm);overflow:hidden;transition:border-color .14s ease}
.bm-faq details[open]{border-color:var(--bm-peri-deep);box-shadow:var(--bm-shadow-sm)}
.bm-faq summary{cursor:pointer;list-style:none;padding:1rem 1.2rem;font-family:var(--bm-display);font-weight:700;font-size:1.05rem;color:var(--bm-ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.bm-faq summary::-webkit-details-marker{display:none}
.bm-faq summary::after{content:"+";font-size:1.4rem;color:var(--bm-violet);transition:transform .2s ease;line-height:1}
.bm-faq details[open] summary::after{transform:rotate(45deg)}
.bm-faq details>div{padding:0 1.2rem 1.1rem;color:var(--bm-ink-soft)}
.bm-faq details>div p:last-child{margin-bottom:0}
.bm-faq a{color:var(--bm-violet);font-weight:600}

/* ---------- Topic grid ---------- */
.bm-topics{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.9rem}
.bm-topic{display:block;background:var(--bm-card);border:1px solid var(--bm-line);border-radius:var(--bm-radius-sm);padding:1.1rem 1.2rem;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.bm-topic:hover{transform:translateY(-3px);box-shadow:var(--bm-shadow-sm);border-color:var(--bm-peri-deep);text-decoration:none}
.bm-topic .ico{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;background:var(--bm-peri);color:var(--bm-violet-deep);font-family:var(--bm-display);font-weight:800;font-size:1.2rem;margin-bottom:.6rem}
.bm-topic .name{display:block;font-family:var(--bm-display);font-weight:700;font-size:1.06rem;color:var(--bm-ink);margin-bottom:.2rem}
.bm-topic .desc{display:block;font-size:.9rem;color:var(--bm-muted);line-height:1.5}

/* ---------- Tabs (category switch) ---------- */
.bm-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 1.5rem;border-bottom:1px solid var(--bm-line);padding-bottom:.2rem}
.bm-tabs a{padding:.55rem .95rem;border-radius:10px 10px 0 0;font-family:var(--bm-display);font-weight:700;color:var(--bm-muted);position:relative;bottom:-1px}
.bm-tabs a:hover{color:var(--bm-violet-ink);text-decoration:none;background:var(--bm-peri)}
.bm-tabs a.active{color:var(--bm-violet-deep);border-bottom:3px solid var(--bm-mint)}

/* ---------- Breadcrumbs ---------- */
.bm-crumbs{font-size:.88rem;color:var(--bm-muted);padding:.9rem 0 0}
.bm-crumbs a{color:var(--bm-muted);font-weight:500}
.bm-crumbs a:hover{color:var(--bm-violet)}
.bm-crumbs .sep{margin:0 .4rem;color:var(--bm-peri-deep)}

/* ---------- Footer ---------- */
.bm-foot{background:var(--bm-ink);color:#CFC9EC;margin-top:3rem;padding:2.8rem 0 1.6rem}
.bm-foot a{color:#CFC9EC;text-decoration:none}
.bm-foot a:hover{color:#fff;text-decoration:underline}
.bm-foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:1.6rem}
.bm-foot h5{font-family:var(--bm-display);color:#fff;font-size:1rem;font-weight:700;margin:0 0 .8rem}
.bm-foot-col a{display:block;padding:.2rem 0;font-size:.94rem}
.bm-foot-brand img{height:40px;width:auto;background:#fff;border-radius:10px;padding:5px 8px}
.bm-foot-brand p{font-size:.9rem;color:#9B95C4;margin:.9rem 0 0;max-width:34ch}
.bm-foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1.2rem;font-size:.84rem;color:#9B95C4;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between}
.bm-foot-bottom a{color:#9B95C4}

/* ---------- CTA box ---------- */
.bm-cta{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem;justify-content:space-between;background:linear-gradient(135deg,var(--bm-violet) 0%,var(--bm-violet-deep) 100%);color:#fff;border-radius:var(--bm-radius);padding:1.4rem 1.6rem;margin:1.8rem 0;box-shadow:var(--bm-shadow)}
.bm-cta-body{flex:1 1 320px}
.bm-cta h3{color:#fff;margin:0 0 .3rem;font-size:1.25rem}
.bm-cta p{color:#E7E4FA;margin:0;font-size:.98rem;max-width:54ch}
.bm-cta-actions{display:flex;flex-wrap:wrap;gap:.6rem}
.bm-cta .bm-btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.bm-cta .bm-btn-ghost:hover{background:#fff;color:var(--bm-violet-deep);border-color:#fff}

/* ---------- Misc ---------- */
.bm-em{color:var(--bm-violet-ink);font-weight:600}
.bm-anchor{scroll-margin-top:90px}
.bm-disclosure{font-size:.82rem;color:var(--bm-muted);background:var(--bm-bg-warm);border:1px dashed var(--bm-line);border-radius:10px;padding:.6rem .9rem;margin:1rem 0}

/* ---------- Responsive ---------- */
@media (max-width:880px){
  .bm-hero-grid{grid-template-columns:1fr;gap:1.8rem}
  .bm-foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  body{font-size:16px}
  .bm-menu{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:stretch;gap:0;background:#fff;border-bottom:1px solid var(--bm-line);box-shadow:var(--bm-shadow);padding:.5rem}
  .bm-menu.show{display:flex}
  .bm-menu a{border-radius:8px}
  .bm-burger{display:inline-block}
  .bm-top .container{position:relative}

  /* deal card → stacked; jämförpris top-line right-aligned */
  .bm-deal-top{grid-template-columns:auto 1fr;margin-bottom:.6rem}
  .bm-jmf{grid-column:2;justify-self:end}
  .bm-deal-top>.bm-deal-top-spacer{display:none}
  /* tooltip: höger-ankra på mobil så den aldrig sticker ut till höger (gav sid-scroll) */
  .bm-jmf .bm-tip{left:auto;right:0;transform:translateX(0) translateY(4px);width:min(280px,84vw)}
  .bm-jmf:hover .bm-tip,.bm-jmf:focus .bm-tip{transform:translateX(0) translateY(0)}
  .bm-jmf .bm-tip::after{left:auto;right:24px;transform:none}
  /* logotyp uppe till vänster i linje med operatörsnamnet, pris som egen fotrad */
  .bm-deal{padding:.9rem 1rem 1rem}
  .bm-deal-body{grid-template-columns:48px 1fr;grid-template-areas:"logo info" "price price";align-items:start;column-gap:.7rem;row-gap:0}
  .bm-deal-logo{grid-area:logo;width:48px;height:48px;padding:.3rem;align-self:start}
  .bm-deal-logo img{max-height:34px;max-width:40px}
  .bm-deal-info{grid-area:info;min-width:0}
  .bm-deal-info h3{margin-bottom:.4rem;font-size:1.08rem}
  .bm-deal-price{grid-area:price;flex-direction:row;flex-wrap:wrap;align-items:baseline;justify-content:flex-start;column-gap:.5rem;row-gap:.1rem;text-align:left;border-top:1px dashed var(--bm-line);margin-top:.8rem;padding-top:.8rem;min-width:0}
  .bm-deal-price .now{font-size:1.9rem}
  .bm-deal-price .camp{flex-basis:100%;max-width:none;margin-top:.1rem}
  .bm-deal-price .bm-btn{flex-basis:100%;margin-top:.6rem;align-self:stretch;justify-content:center;padding:.7rem 1rem}
}
@media (max-width:720px){
  /* tabeller får ALLTID plats i mobilvyn (även utan .bm-table-wrap) – ingen sid-scroll */
  table.bm-table{min-width:0;width:100%;table-layout:fixed;font-size:.9rem}
  table.bm-table th,table.bm-table td{padding:.55rem .6rem;overflow-wrap:anywhere;word-break:break-word}
}
@media (max-width:480px){
  .bm-foot-grid{grid-template-columns:1fr}
  table.bm-table{font-size:.85rem}
  table.bm-table th,table.bm-table td{padding:.5rem .45rem}
}
