/* =====================================================================
   JämförPriser.se — "Priskiosk"
   Editorial price-board: hairline ledger grid · billboard numerals ·
   one decisive red. Layered over Bootstrap 5.3.8.
   ===================================================================== */

/* ---------- Fonts (self-hosted) ---------- */
@font-face {
  font-family: 'Anton';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/jamforpriser-se/anton-latin.woff2') format('woff2');
}
@font-face {
  font-family: 'Instrument Sans';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('/fonts/jamforpriser-se/instrumentsans-latin.woff2') format('woff2');
}

/* ---------- Tokens ---------- */
:root {
  --jp-ink:        #15110F;   /* warm near-black */
  --jp-ink-soft:   #3A332E;
  --jp-muted:      #6B645D;   /* warm grey text */
  --jp-faint:      #6C655B;   /* subtil etikett-grå — AA-säker (≥4.5:1) på vitt/bone */
  --jp-red:        #E11219;   /* logo red — the signal */
  --jp-red-deep:   #B20B11;
  --jp-red-tint:   #FCEDEC;
  --jp-paper:      #FFFFFF;
  --jp-bone:       #F6F3EF;   /* warm off-white sections */
  --jp-bone-2:     #EFEAE3;
  --jp-line:       #E4DED5;   /* hairline */
  --jp-line-ink:   #2C2722;

  --jp-radius:     6px;
  --jp-radius-lg:  12px;
  --jp-maxw:       1180px;

  --bs-body-font-family: 'Instrument Sans', system-ui, -apple-system, sans-serif;
  --bs-body-color: var(--jp-ink);
  --bs-body-bg: var(--jp-paper);
  --bs-link-color: var(--jp-ink);
  --bs-link-hover-color: var(--jp-red);
  --bs-primary: var(--jp-red);
  --bs-border-color: var(--jp-line);
}

/* ---------- Base ---------- */
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Instrument Sans', system-ui, sans-serif;
  color: var(--jp-ink);
  background: var(--jp-paper);
  font-size: 1.0625rem;
  line-height: 1.65;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.container { max-width: var(--jp-maxw); }

::selection { background: var(--jp-red); color: #fff; }

h1, h2, h3, h4, h5 { color: var(--jp-ink); font-weight: 700; letter-spacing: -0.02em; line-height: 1.12; }
h1 { font-size: clamp(2.1rem, 5.2vw, 3.5rem); }
h2 { font-size: clamp(1.55rem, 3.4vw, 2.3rem); margin-top: .2em; }
h3 { font-size: clamp(1.2rem, 2.2vw, 1.5rem); }

p { color: var(--jp-ink-soft); }
a { text-decoration: none; transition: color .15s ease; }

/* Billboard display utility */
.jp-anton { font-family: 'Anton', 'Instrument Sans', sans-serif; font-weight: 400; letter-spacing: .01em; text-transform: uppercase; line-height: .96; }

/* small tracked label */
.jp-kicker {
  font-size: .72rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase;
  color: var(--jp-faint); display: inline-flex; align-items: center; gap: .5ch;
}
.jp-kicker::before { content: ""; width: 1.6rem; height: 2px; background: var(--jp-red); display: inline-block; }

/* swap glyph divider (echo of logo) */
.jp-swap::before { content: "⇄"; color: var(--jp-red); font-weight: 700; margin: 0 .4ch; }

/* ---------- Top hairline + nav ---------- */
.jp-topbar { height: 4px; background: var(--jp-red); }
.jp-nav {
  background: var(--jp-paper);
  border-bottom: 1px solid var(--jp-line);
  position: sticky; top: 0; z-index: 1030;
}
.jp-nav .container { display: flex; align-items: center; gap: 1.5rem; min-height: 72px; }
.jp-brand img { height: 40px; width: auto; }
.jp-nav-links { display: flex; gap: 1.6rem; margin-left: auto; align-items: center; }
.jp-nav-links a {
  font-weight: 600; font-size: .96rem; color: var(--jp-ink-soft);
  padding: .35rem 0; position: relative;
}
.jp-nav-links a:hover { color: var(--jp-ink); }
.jp-nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; height: 2px; width: 0;
  background: var(--jp-red); transition: width .2s ease;
}
.jp-nav-links a:hover::after, .jp-nav-links a.active::after { width: 100%; }
.jp-nav-toggle { margin-left: auto; border: 1px solid var(--jp-line); background: #fff; border-radius: var(--jp-radius); padding: .4rem .6rem; line-height: 0; }
@media (max-width: 991px) {
  .jp-nav-links { position: fixed; inset: 76px 0 auto 0; flex-direction: column; gap: 0; background: #fff; border-bottom: 1px solid var(--jp-line); padding: .5rem 1.25rem 1rem; display: none; box-shadow: 0 16px 30px -22px rgba(0,0,0,.4); }
  .jp-nav-links.open { display: flex; }
  .jp-nav-links a { width: 100%; padding: .8rem 0; border-bottom: 1px solid var(--jp-line); }
  .jp-nav-links a::after { display: none; }
}
@media (min-width: 992px) { .jp-nav-toggle { display: none; } }

/* ---------- Breadcrumbs ---------- */
.jp-crumbs { font-size: .82rem; color: var(--jp-faint); padding: 1rem 0 0; }
.jp-crumbs a { color: var(--jp-muted); }
.jp-crumbs a:hover { color: var(--jp-red); }
.jp-crumbs span { margin: 0 .5ch; color: var(--jp-faint); }

/* ---------- Hero ---------- */
.jp-hero { padding: clamp(2.4rem, 6vw, 4.6rem) 0 2.2rem; position: relative; }
.jp-hero-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 3rem; align-items: center; }
@media (max-width: 900px) { .jp-hero-grid { grid-template-columns: 1fr; gap: 0; } }
.jp-hero h1 { max-width: 16ch; }

/* Hero feature: senaste modellen som visuellt blickfång + röd prisflagga */
.jp-hero-feature { position: relative; }
.jp-feature-card {
  position: relative; display: block; background: var(--jp-bone);
  border: 1px solid var(--jp-line); border-radius: var(--jp-radius-lg);
  padding: 1.6rem 1.6rem 1.4rem; text-align: center; overflow: hidden;
  transition: box-shadow .18s ease, transform .18s ease;
}
.jp-feature-card:hover { box-shadow: 0 22px 40px -28px rgba(0,0,0,.45); transform: translateY(-2px); }
.jp-feature-card .tag { position: absolute; top: 0; left: 0; background: var(--jp-ink); color: #fff; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600; padding: .3rem .7rem; border-bottom-right-radius: var(--jp-radius); }
.jp-feature-card .ph { display: grid; place-items: center; height: 230px; margin-top: .8rem; }
.jp-feature-card .ph img { max-height: 230px; max-width: 70%; width: auto; object-fit: contain; }
.jp-feature-card .grp { font-size: .74rem; color: var(--jp-faint); letter-spacing: .08em; text-transform: uppercase; }
.jp-feature-card h2 { font-size: 1.3rem; margin: .25rem 0 .8rem; }
.jp-feature-card .flag { display: inline-flex; align-items: baseline; gap: .4ch; background: var(--jp-red); color: #fff; border-radius: 999px; padding: .45rem 1.1rem; }
.jp-feature-card .flag .l { font-size: .8rem; font-weight: 600; }
.jp-feature-card .flag .n { font-family: 'Anton', sans-serif; font-size: 1.5rem; line-height: 1; }
.jp-feature-card .flag .u { font-size: .78rem; font-weight: 600; }
@media (max-width: 900px) { .jp-hero-feature { display: none; } }
.jp-hero .lead { font-size: 1.18rem; color: var(--jp-muted); max-width: 56ch; margin-top: 1.1rem; }
.jp-hero-stats { display: flex; gap: 2.4rem; flex-wrap: wrap; margin-top: 2rem; padding-top: 1.6rem; border-top: 1px solid var(--jp-line); }
.jp-stat .n { font-family: 'Anton', sans-serif; font-size: 2.5rem; line-height: 1; color: var(--jp-ink); }
.jp-stat .n .u { color: var(--jp-red); }
.jp-stat .l { font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--jp-faint); margin-top: .3rem; }

/* ---------- Section header ---------- */
.jp-section { padding: clamp(2rem, 5vw, 3.6rem) 0; }
.jp-section.bone { background: var(--jp-bone); border-top: 1px solid var(--jp-line); border-bottom: 1px solid var(--jp-line); }
.jp-sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 1.8rem; padding-bottom: 1rem; border-bottom: 2px solid var(--jp-ink); }
.jp-sec-head h2 { margin: 0; }
.jp-sec-head .more { font-weight: 600; font-size: .92rem; white-space: nowrap; color: var(--jp-red-deep); }
.jp-sec-head .more:hover { color: var(--jp-red); }

/* ---------- Buttons ---------- */
.jp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5ch;
  font-weight: 600; font-size: .98rem; border-radius: var(--jp-radius);
  padding: .72rem 1.25rem; border: 1.5px solid transparent; cursor: pointer;
  transition: transform .12s ease, background .15s ease, color .15s ease, border-color .15s ease;
}
.jp-btn-red { background: var(--jp-red); color: #fff; border-color: var(--jp-red); }
.jp-btn-red:hover { background: var(--jp-red-deep); border-color: var(--jp-red-deep); color: #fff; transform: translateY(-1px); }
.jp-btn-ink { background: var(--jp-ink); color: #fff; border-color: var(--jp-ink); }
.jp-btn-ink:hover { background: #000; color: #fff; transform: translateY(-1px); }
.jp-btn-ghost { background: transparent; color: var(--jp-ink); border-color: var(--jp-line); }
.jp-btn-ghost:hover { border-color: var(--jp-red); color: var(--jp-red); }
.jp-btn-lg { padding: .9rem 1.6rem; font-size: 1.05rem; }
.jp-btn-block { width: 100%; }

/* ---------- Phone grid cards ---------- */
.jp-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--jp-line); border-left: 1px solid var(--jp-line); }
.jp-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 991px) { .jp-grid, .jp-grid.cols-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575px) { .jp-grid, .jp-grid.cols-3 { grid-template-columns: 1fr; } }

.jp-card {
  position: relative; background: var(--jp-paper);
  border-right: 1px solid var(--jp-line); border-bottom: 1px solid var(--jp-line);
  padding: 1.5rem 1.4rem 1.4rem; display: flex; flex-direction: column;
  transition: background .18s ease, box-shadow .18s ease;
}
.jp-card:hover { background: var(--jp-bone); z-index: 2; box-shadow: inset 0 0 0 2px var(--jp-red); }
.jp-card .idx { font-family: 'Anton', sans-serif; font-size: .95rem; color: var(--jp-faint); letter-spacing: .05em; }
.jp-card:hover .idx { color: var(--jp-red); }
.jp-card .ph { aspect-ratio: 1 / 1; display: grid; place-items: center; margin: .4rem 0 .6rem; }
.jp-card .ph img { max-height: 168px; max-width: 78%; width: auto; height: auto; object-fit: contain; }
.jp-card h3 { font-size: 1.08rem; margin: 0 0 .15rem; }
.jp-card .grp { font-size: .78rem; color: var(--jp-faint); letter-spacing: .04em; text-transform: uppercase; }
.jp-card .price-row { margin-top: auto; padding-top: 1rem; }
.jp-card .pl { font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--jp-faint); }
.jp-card .pv { font-family: 'Anton', sans-serif; font-size: 2rem; line-height: 1; color: var(--jp-ink); }
.jp-card .pv .u { font-family: 'Instrument Sans', sans-serif; font-size: .95rem; color: var(--jp-muted); font-weight: 600; letter-spacing: 0; text-transform: none; }
.jp-card .cta { margin-top: 1rem; }

/* ---------- Price ledger (per-phone comparison) ---------- */
.jp-ledger { border: 1px solid var(--jp-line); border-radius: var(--jp-radius-lg); overflow: hidden; background: #fff; }
.jp-ledger-head {
  display: grid; grid-template-columns: 3rem 1fr auto; gap: 1rem; align-items: center;
  padding: .85rem 1.25rem; background: var(--jp-ink); color: #fff;
  font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
}
.jp-ledger-head .r { text-align: right; }
.jp-row {
  display: grid; grid-template-columns: 3rem 1fr auto; gap: 1rem; align-items: center;
  padding: 1.05rem 1.25rem; border-top: 1px solid var(--jp-line);
  position: relative; transition: background .15s ease;
}
.jp-row:hover { background: var(--jp-bone); }
.jp-row .rank { font-family: 'Anton', sans-serif; font-size: 1.3rem; color: var(--jp-faint); }
.jp-row.win { background: var(--jp-red-tint); }
.jp-row.win::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--jp-red); }
.jp-row.win .rank { color: var(--jp-red-deep); }
.jp-op { display: flex; align-items: center; gap: .85rem; min-width: 0; }
.jp-op img { height: 30px; width: auto; max-width: 92px; object-fit: contain; }
.jp-op .nm { font-weight: 700; font-size: 1.02rem; }
.jp-op .sub { font-size: .82rem; color: var(--jp-muted); }
.jp-flag { display: inline-block; font-size: .66rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: #fff; background: var(--jp-red); padding: .14rem .5rem; border-radius: 3px; margin-left: .4rem; vertical-align: middle; }
.jp-pills { display: flex; flex-wrap: wrap; gap: .4rem; }
.jp-pill { font-size: .74rem; font-weight: 600; color: var(--jp-ink-soft); background: var(--jp-bone-2); border-radius: 999px; padding: .18rem .6rem; }
.jp-pill.red { background: var(--jp-red); color: #fff; }
.jp-price { text-align: right; display: flex; flex-direction: column; align-items: flex-end; gap: .1rem; }
.jp-price .pv { font-family: 'Anton', sans-serif; font-size: 1.95rem; line-height: 1; color: var(--jp-ink); }
.jp-price .pu { font-size: .8rem; color: var(--jp-muted); font-weight: 600; }
.jp-price .after { font-size: .76rem; color: var(--jp-faint); margin-top: .15rem; }
.jp-jmf-note { font-size: .74rem; color: var(--jp-muted); font-weight: 600; cursor: help; display: inline-flex; align-items: center; gap: .4ch; white-space: nowrap; }
.jp-jmf-note .qm { display: inline-grid; place-items: center; width: 15px; height: 15px; border-radius: 50%; background: var(--jp-bone-2); color: var(--jp-muted); font-size: .62rem; font-style: italic; font-family: Georgia, serif; }
.jp-row .go { margin-top: .55rem; }

/* jämförpris badge (center desktop / right mobile) */
.jp-jmf {
  display: inline-flex; align-items: center; gap: .4ch; cursor: help;
  font-size: .73rem; font-weight: 600; color: var(--jp-ink-soft);
  border: 1px solid var(--jp-line); background: #fff; border-radius: 999px; padding: .2rem .6rem;
}
.jp-jmf b { color: var(--jp-red); }
.jp-ledger-head .jmf-col, .jp-row .jmf-col { text-align: center; }
@media (max-width: 767px) {
  /* Stapla raden som ett kort på mobil — kolumn-grid blir för trångt */
  .jp-ledger-head { display: none; }
  .jp-row {
    grid-template-columns: 2rem 1fr;
    grid-template-areas: "rank op" "price price";
    column-gap: .8rem; row-gap: .7rem; padding: 1.15rem 1.15rem 1.25rem;
  }
  .jp-row .rank { grid-area: rank; font-size: 1.15rem; align-self: start; }
  .jp-op { grid-area: op; }
  .jp-op img { height: 26px; }
  .jp-price { grid-area: price; align-items: stretch; text-align: left; padding-top: .8rem; border-top: 1px solid var(--jp-line); }
  .jp-price .pv { font-size: 1.7rem; }
  .jp-jmf-note { margin-top: .15rem; }
  .jp-price .go { display: flex; width: 100%; margin: .8rem 0 0 !important; }
  .jp-row.win .jp-price { border-top-color: rgba(225,18,25,.25); }
}

/* ---------- Compare strip / mini cards (operator hubs) ---------- */
.jp-oprail { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--jp-line); border: 1px solid var(--jp-line); border-radius: var(--jp-radius-lg); overflow: hidden; }
@media (max-width: 767px) { .jp-oprail { grid-template-columns: repeat(2, 1fr); } }
.jp-opcell { background: #fff; padding: 1.3rem 1.1rem; text-align: center; transition: background .15s; }
.jp-opcell:hover { background: var(--jp-bone); }
.jp-opcell img { height: 32px; width: auto; max-width: 110px; object-fit: contain; }
.jp-opcell .n { font-family: 'Anton', sans-serif; font-size: 1.4rem; margin-top: .6rem; }
.jp-opcell .l { font-size: .74rem; color: var(--jp-faint); text-transform: uppercase; letter-spacing: .08em; }

/* ---------- Article / prose ---------- */
.jp-article { padding: 2.4rem 0 1rem; }
.jp-article .jp-prose { max-width: 70ch; margin: 0 auto; }
.jp-prose { font-size: 1.09rem; }
.jp-prose h2 { margin: 2.2rem 0 .8rem; padding-top: 1.2rem; border-top: 1px solid var(--jp-line); }
.jp-prose h3 { margin: 1.6rem 0 .5rem; }
.jp-prose p { margin: 0 0 1.05rem; }
.jp-prose ul, .jp-prose ol { margin: 0 0 1.1rem; padding-left: 1.2rem; }
.jp-prose li { margin-bottom: .45rem; color: var(--jp-ink-soft); }
.jp-prose a:not(.jp-btn) { color: var(--jp-red-deep); border-bottom: 1px solid var(--jp-red-tint); }
.jp-prose a:not(.jp-btn):hover { color: var(--jp-red); border-bottom-color: var(--jp-red); }
.jp-prose img { max-width: 100%; height: auto; border-radius: var(--jp-radius-lg); }
.jp-prose strong { color: var(--jp-ink); }
.jp-prose blockquote { border-left: 3px solid var(--jp-red); margin: 1.4rem 0; padding: .3rem 0 .3rem 1.1rem; color: var(--jp-muted); font-size: 1.12rem; }

.jp-figure { margin: 0 0 1.6rem; }
.jp-figure img { width: 100%; height: auto; border-radius: var(--jp-radius-lg); display: block; }
.jp-figure figcaption { font-size: .82rem; color: var(--jp-faint); margin-top: .5rem; }

.jp-meta { font-size: .85rem; color: var(--jp-faint); display: flex; gap: .8rem; flex-wrap: wrap; align-items: center; margin: 0 auto 1.6rem; max-width: 70ch; }
.jp-meta time { color: var(--jp-muted); }

/* hero band for article/hub */
.jp-pagehead { background: var(--jp-ink); color: #fff; padding: clamp(2.6rem, 6vw, 4rem) 0; }
.jp-pagehead h1 { color: #fff; }
.jp-pagehead .lead { color: rgba(255,255,255,.74); font-size: 1.15rem; max-width: 60ch; margin-top: 1rem; }
.jp-pagehead .jp-kicker { color: rgba(255,255,255,.66); }
.jp-pagehead .jp-crumbs, .jp-pagehead .jp-crumbs a { color: rgba(255,255,255,.66); }
/* röd accent måste vara ljusare på mörk botten för AA-kontrast (slår .text-red !important) */
.jp-pagehead .text-red, .jp-pagehead strong.text-red { color: #ff5a5f !important; }

/* ---------- FAQ ---------- */
.jp-faq { border-top: 1px solid var(--jp-line); }
.jp-faq details { border-bottom: 1px solid var(--jp-line); padding: 1.1rem 0; }
.jp-faq summary { font-weight: 700; font-size: 1.1rem; cursor: pointer; list-style: none; display: flex; justify-content: space-between; gap: 1rem; color: var(--jp-ink); }
.jp-faq summary::-webkit-details-marker { display: none; }
.jp-faq summary::after { content: "+"; font-family: 'Anton', sans-serif; color: var(--jp-red); font-size: 1.5rem; line-height: 1; }
.jp-faq details[open] summary::after { content: "–"; }
.jp-faq details p { margin: .8rem 0 0; color: var(--jp-ink-soft); }

/* ---------- Callout / CTA band ---------- */
.jp-callout { background: var(--jp-bone); border: 1px solid var(--jp-line); border-radius: var(--jp-radius-lg); padding: 1.6rem 1.5rem; display: flex; gap: 1.2rem; align-items: center; flex-wrap: wrap; justify-content: space-between; }
.jp-callout h3 { margin: 0; }
.jp-callout p { margin: .25rem 0 0; color: var(--jp-muted); }

/* ---------- Footer ---------- */
.jp-footer { background: var(--jp-ink); color: rgba(255,255,255,.7); padding: 3rem 0 1.6rem; margin-top: 3rem; }
.jp-footer p { color: rgba(255,255,255,.82); }
.jp-footer a { color: rgba(255,255,255,.82); }
.jp-footer a:hover { color: #fff; }
.jp-footer h4 { color: #fff; font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1rem; }
.jp-footer .brand img { height: 36px; filter: brightness(0) invert(1); margin-bottom: 1rem; }
.jp-footer ul { list-style: none; padding: 0; margin: 0; }
.jp-footer li { margin-bottom: .5rem; font-size: .94rem; }
.jp-footer .fine { border-top: 1px solid rgba(255,255,255,.18); margin-top: 2rem; padding-top: 1.4rem; font-size: .82rem; }
.jp-footer .fine, .jp-footer .fine p { color: rgba(255,255,255,.72); }

/* ---------- Tooltip color (bootstrap) ---------- */
.tooltip-inner { background: var(--jp-ink); font-size: .84rem; max-width: 280px; text-align: left; }
.tooltip.bs-tooltip-top .tooltip-arrow::before { border-top-color: var(--jp-ink); }
.tooltip.bs-tooltip-bottom .tooltip-arrow::before { border-bottom-color: var(--jp-ink); }

/* ---------- Mobil: bekväm kant (inget innehåll exakt i kanten) ---------- */
@media (max-width: 575.98px) {
  .container { padding-left: 1.15rem; padding-right: 1.15rem; }
  h1 { font-size: clamp(2rem, 8vw, 2.6rem); }
  .jp-sec-head { flex-wrap: wrap; }
  .jp-price .pv { font-size: 1.5rem; }
}

/* ---------- Helpers ---------- */
.jp-hairline { border: 0; border-top: 1px solid var(--jp-line); margin: 2rem 0; }
.text-red { color: var(--jp-red) !important; }
.bg-bone { background: var(--jp-bone); }
.jp-mt-section { margin-top: clamp(2rem, 5vw, 3.4rem); }
