
:root{
  /* Voltage: midnatt-blå bas + elektrisk lime CTA */
  --teal-900:#101a3a;   /* deep midnight */
  --teal-700:#1d2c5c;   /* indigo */
  --teal-500:#3a4ea0;   /* electric blue */
  --teal-100:#dde3f5;   /* pale indigo */
  --amber:#1d2c5c;       /* reuse indigo where amber was decorative */
  --amber-100:#e7ecfb;
  --cta:#8fe04f;
  --cta-hover:#7ccc3f;
  --cta-ink:#101a3a;
  --ink:#141726;
  --ink-soft:#54596e;
  --paper:#f7f8fc;       /* cool warm-white */
  --paper-2:#eceef6;
  --white:#ffffff;
  --line:#e0e3ef;
  --star:#f4b740;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 1px 2px rgba(16,26,58,.04),0 8px 24px rgba(16,26,58,.07);
  --shadow-lg:0 14px 44px rgba(16,26,58,.13);
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.15;letter-spacing:-.01em}
a{color:inherit}
img{max-width:100%;display:block}

/* ---- Layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:34px 0}
.section--tight{padding:22px 0}

/* ---- Top bar ---- */
.topbar{background:#0c142e;color:#aab2d6;font-size:.85rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px;gap:16px}
.topbar strong{color:#fff;font-weight:600}
.topbar span{display:inline-flex;align-items:center;gap:7px}
.dot{width:7px;height:7px;border-radius:50%;background:#7cd348;box-shadow:0 0 0 3px rgba(143,224,79,.3)}

/* ---- Nav ---- */
header.nav{position:sticky;top:0;z-index:40;background:rgba(250,248,243,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:1.22rem;letter-spacing:-.02em;color:var(--teal-900);text-decoration:none}
.brand .mark{width:30px;height:30px;flex:0 0 auto}
.navlinks{display:flex;gap:30px;list-style:none;font-size:.94rem;font-weight:500}
.navlinks a{text-decoration:none;color:var(--ink-soft);transition:color .15s}
.navlinks a:hover{color:var(--teal-700)}
.nav-cta{background:var(--cta);color:var(--cta-ink);text-decoration:none;font-weight:600;font-size:.9rem;padding:11px 20px;border-radius:999px;transition:background .15s,transform .15s}
.nav-cta:hover{background:var(--cta-hover);transform:translateY(-1px)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:6px}
.burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px}

/* ---- Breadcrumb ---- */
.crumb{font-size:.82rem;color:var(--ink-soft);padding:18px 0 0}
.crumb a{text-decoration:none}
.crumb a:hover{text-decoration:underline}

/* ---- Hero ---- */
.hero{padding:18px 0 0}
.hero-card{
  position:relative;overflow:hidden;border-radius:28px;
  background:linear-gradient(125deg,#0c142e 0%,#1d2c5c 60%,#3a4ea0 135%);
  color:#eef1fb;padding:36px 46px;box-shadow:var(--shadow-lg);
}
.hero-card::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 1px,transparent 1px 64px);
  mask-image:linear-gradient(90deg,transparent,#000 40%);
}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.5fr .9fr;gap:40px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#7cd348;margin-bottom:18px}
.eyebrow::before{content:"";width:22px;height:1.5px;background:#7cd348}
.hero h1{font-size:clamp(2rem,4.4vw,3.1rem);color:#fff;margin-bottom:14px}
.hero h1 em{font-style:normal;color:#7cd348}
.hero p.lead{font-size:1.06rem;color:#c2c9e6;max-width:46ch;margin-bottom:22px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-weight:600;border-radius:999px;padding:14px 26px;font-size:.96rem;transition:transform .15s,box-shadow .15s,background .15s;cursor:pointer;border:0}
.btn-primary{background:var(--cta);color:var(--cta-ink)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(143,224,79,.45);background:var(--cta-hover)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.arrow{transition:transform .15s}
.btn:hover .arrow{transform:translateX(3px)}

/* hero stat panel */
.hero-panel{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:24px;backdrop-filter:blur(4px)}
.hero-panel h3{font-size:.82rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#7cd348;margin-bottom:16px;font-family:'Inter',sans-serif}
.hpstat{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0;border-bottom:1px dashed rgba(255,255,255,.16)}
.hpstat:last-child{border:0}
.hpstat .k{font-size:.9rem;color:#aab2d6}
.hpstat .v{font-family:'Fraunces',serif;font-weight:600;font-size:1.25rem;color:#fff}

/* trust strip */
.trust{display:flex;gap:30px;flex-wrap:wrap;align-items:center;justify-content:center;padding:26px 0;color:var(--ink-soft);font-size:.88rem}
.trust span{display:inline-flex;align-items:center;gap:9px}
.trust svg{flex:0 0 auto}

/* ---- Section heads ---- */
.shead{margin-bottom:22px}
.shead .eb{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--teal-500);margin-bottom:12px}
.shead .eb::before{content:"";width:20px;height:1.5px;background:var(--teal-500)}
.shead h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink)}
.shead p{color:var(--ink-soft);margin-top:10px;max-width:60ch}

/* ---- Installer list ---- */
.listbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:22px}
.found{font-weight:600;color:var(--teal-900);display:inline-flex;align-items:center;gap:9px}
.found .pill{background:var(--teal-100);color:var(--teal-700);font-size:.8rem;padding:3px 11px;border-radius:999px}
.sortsel{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;color:var(--ink-soft)}
.sortsel select{font-family:inherit;font-size:.86rem;border:1px solid var(--line);background:var(--white);border-radius:9px;padding:7px 12px;color:var(--ink);cursor:pointer}

.installer{
  display:grid;grid-template-columns:88px 1fr auto;gap:24px;align-items:center;
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 24px;margin-bottom:14px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s,border-color .15s;
}
.installer:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--teal-100)}
.ilogo{width:88px;height:64px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:700;font-size:1.1rem;color:#fff;text-align:center;line-height:1.05;padding:6px}
.ibody h3{font-size:1.16rem;margin-bottom:3px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.badge{font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:999px;font-family:'Inter',sans-serif}
.badge-top{background:#101a3a;color:#7cd348}
.badge-local{background:var(--teal-100);color:var(--teal-700)}
.iratings{display:flex;gap:18px;flex-wrap:wrap;margin:7px 0 9px;font-size:.82rem;color:var(--ink-soft);align-items:center}
.iratings b{color:var(--ink);font-weight:700}
.iratings > span:nth-child(2){color:#2b3f8f;font-weight:600}
.iratings > span:nth-child(2) b{color:#2b3f8f;font-size:.94rem}
.stars{display:inline-flex;gap:1px;vertical-align:middle;color:#f5a623;font-size:.92rem;letter-spacing:.5px}
.idesc{font-size:.9rem;color:var(--ink-soft);max-width:56ch}
.iactions{display:flex;flex-direction:column;gap:9px;align-items:stretch;min-width:150px}
.iactions .btn{padding:11px 18px;font-size:.88rem;justify-content:center;white-space:nowrap}
.btn-list{background:var(--cta);color:var(--cta-ink);font-weight:700}
.btn-list:hover{background:var(--cta-hover);box-shadow:0 6px 18px rgba(143,224,79,.45)}
.btn-outline{background:var(--white);color:var(--teal-700);border:1px solid var(--line)}
.btn-outline:hover{background:var(--paper-2)}
.imeta{font-size:.78rem;color:var(--ink-soft);text-align:center}

.disclosure{font-size:.78rem;color:var(--ink-soft);background:var(--paper-2);border-radius:var(--radius-sm);padding:13px 16px;margin-top:6px;display:flex;gap:10px;align-items:flex-start}
.disclosure svg{flex:0 0 auto;margin-top:1px}

/* ---- Avdrag calculator ---- */
.calc{background:linear-gradient(125deg,#0c142e,#1d2c5c);border-radius:24px;padding:42px;color:#eef1fb;box-shadow:var(--shadow-lg);display:grid;grid-template-columns:1fr 1fr;gap:38px;align-items:center}
.calc h2{color:#fff;font-size:1.9rem;margin-bottom:12px}
.calc p{color:#c2c9e6;font-size:.98rem;margin-bottom:8px}
.calc .panel{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:26px}
.calcrow{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px dashed rgba(255,255,255,.18);align-items:baseline}
.calcrow:last-child{border:0;padding-bottom:0}
.calcrow .lab{color:#aab2d6;font-size:.94rem}
.calcrow .num{font-family:'Fraunces',serif;font-weight:600;font-size:1.2rem;color:#fff}
.calcrow.total .num{color:#7cd348;font-size:1.7rem}
.calcrow.total .lab{color:#fff;font-weight:600}

/* ---- Pris cards ---- */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pcard{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s}
.pcard:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.pcard .ic{width:42px;height:42px;border-radius:11px;background:var(--teal-100);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.pcard h3{font-size:1.1rem;margin-bottom:8px}
.pcard p{font-size:.9rem;color:var(--ink-soft)}
.pcard .price{font-family:'Fraunces',serif;font-weight:600;font-size:1.5rem;color:var(--teal-700);margin-top:14px}
.pcard .price small{font-size:.78rem;color:var(--ink-soft);font-weight:400;font-family:'Inter',sans-serif}

/* ---- Boxes compare table ---- */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:560px}
thead th{background:var(--teal-900);color:#eafffb;font-weight:600;text-align:left;padding:15px 18px;font-size:.85rem;letter-spacing:.02em}
thead th:first-child{border-top-left-radius:var(--radius)}
thead th:last-child{border-top-right-radius:var(--radius)}
tbody td{padding:14px 18px;border-top:1px solid var(--line);color:var(--ink-soft)}
tbody tr:hover{background:var(--paper)}
tbody td b{color:var(--ink)}
.tick{color:#3a4ea0;font-weight:700}
.cross{color:#c25b4a;font-weight:700}

/* ---- Content prose ---- */
.prose{max-width:760px}
.prose h2{font-size:1.55rem;margin:38px 0 14px}
.prose h3{font-size:1.18rem;margin:26px 0 10px;color:var(--teal-900)}
.prose p{margin-bottom:15px;color:var(--ink-soft)}
.prose ul{margin:0 0 18px 0;padding-left:0;list-style:none}
.prose li{position:relative;padding-left:30px;margin-bottom:10px;color:var(--ink-soft)}
.prose li::before{content:"";position:absolute;left:0;top:9px;width:16px;height:16px;border-radius:5px;background:var(--teal-100);box-shadow:inset 0 0 0 2px var(--teal-500)}
.prose strong{color:var(--ink)}

/* ---- Areas served ---- */
.areas{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}
.areas span{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:7px 15px;font-size:.84rem;color:var(--ink-soft)}

/* ---- FAQ ---- */
.faq{max-width:780px;margin:0 auto}
.qa{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--white);margin-bottom:12px;overflow:hidden}
.qa summary{cursor:pointer;padding:18px 22px;font-weight:600;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:.98rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary .chev{flex:0 0 auto;transition:transform .2s;color:var(--teal-500)}
.qa[open] summary .chev{transform:rotate(180deg)}
.qa .ans{padding:0 22px 20px;color:var(--ink-soft);font-size:.93rem}

/* ---- Final CTA ---- */
.finalcta{background:linear-gradient(125deg,#0c142e,#1d2c5c);border-radius:24px;padding:50px;text-align:center;color:#eef1fb;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.finalcta::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(115deg,rgba(255,255,255,.04) 0 1px,transparent 1px 54px)}
.finalcta>*{position:relative;z-index:1}
.finalcta h2{color:#fff;font-size:2rem;margin-bottom:12px}
.finalcta p{color:#c2c9e6;max-width:50ch;margin:0 auto 26px}

/* ---- Footer ---- */
footer{background:#0c142e;color:#9aa3c7;padding:54px 0 30px;margin-top:64px}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
footer h4{color:#fff;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;font-family:'Inter',sans-serif;font-weight:600}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:#9aa3c7;text-decoration:none;font-size:.9rem;transition:color .15s}
footer a:hover{color:#fff}
.fbrand{font-family:'Fraunces',serif;font-weight:600;font-size:1.3rem;color:#fff;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.fbrand .mark{width:28px;height:28px}
.fabout{font-size:.9rem;color:#7681aa;max-width:34ch}
.fbottom{border-top:1px solid rgba(255,255,255,.12);margin-top:38px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.82rem;color:#5b6690}

/* ---- Responsive ---- */
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-card{padding:38px 28px}
  .calc{grid-template-columns:1fr;padding:30px}
  .cards3{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .installer{grid-template-columns:64px 1fr;gap:16px}
  .iactions{grid-column:1/-1;flex-direction:row;min-width:0}
  .iactions .btn{flex:1}
  .imeta{display:none}
  .navlinks{display:none}
  .burger{display:block}
}
@media(max-width:520px){
  .fgrid{grid-template-columns:1fr}
  .installer{grid-template-columns:1fr}
  .ilogo{width:100%;height:54px}
  .iactions{flex-direction:column}
  .section{padding:30px 0}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}

/* ---- Hub & home extras ---- */
.hero-card--slim{padding:30px 46px}
.hub-intro{max-width:70ch;color:var(--ink-soft);margin-bottom:26px;font-size:1rem}
.region-group{margin-bottom:30px}
.region-group h2{font-size:1.15rem;color:var(--teal-900);margin-bottom:6px;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:.02em;display:flex;align-items:center;gap:10px}
.region-group h2::before{content:"";width:10px;height:10px;border-radius:3px;background:var(--cta)}
.region-line{border:0;border-top:1px solid var(--line);margin:0 0 16px}
.city-links{display:flex;flex-wrap:wrap;gap:10px}
.city-links a{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:9px 18px;font-size:.92rem;color:var(--ink);text-decoration:none;font-weight:500;transition:border-color .15s,transform .15s,box-shadow .15s}
.city-links a:hover{border-color:var(--teal-500);transform:translateY(-1px);box-shadow:var(--shadow)}
.city-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.city-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:6px}
.city-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--teal-100)}
.city-card h3{font-size:1.15rem;color:var(--teal-900);margin:0}
.city-card p{font-size:.88rem;color:var(--ink-soft);margin:0}
.city-card .cc-go{margin-top:6px;color:var(--teal-700);font-weight:600;font-size:.86rem}
.txtlink{color:var(--teal-700);font-weight:600;text-decoration:none}
.txtlink:hover{text-decoration:underline}
@media(max-width:880px){.city-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.city-grid{grid-template-columns:1fr}}

/* ---- Ranked comparison (startsida) ---- */
.compare-list{display:flex;flex-direction:column;gap:14px}
.crow{display:grid;grid-template-columns:54px 1.4fr 1fr auto;gap:22px;align-items:center;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s,border-color .15s;position:relative}
.crow:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--teal-100)}
.crow--top{border-color:var(--teal-100);box-shadow:0 0 0 1px var(--teal-100),var(--shadow-lg)}
.crank{width:54px;height:54px;border-radius:14px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:700;font-size:1.5rem;color:var(--teal-700)}
.crow--top .crank{background:var(--teal-900);color:#fff}
.cinfo h3{font-size:1.18rem;margin:0 0 3px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cbest{font-size:.68rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 9px;border-radius:999px;background:var(--teal-100);color:var(--teal-700)}
.crow--top .cbest{background:var(--teal-100);color:var(--teal-700)}
.crating{display:flex;align-items:center;gap:8px;margin:4px 0 7px;font-size:.85rem}
.crating .stars{color:#f5a623;font-size:.92rem;letter-spacing:.5px}
.crating b{color:#2b3f8f;font-size:.95rem}
.cverdict{font-size:.9rem;color:var(--ink-soft);margin:0}
.cspecs{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--ink-soft)}
.cspecs span{display:flex;align-items:center;gap:7px}
.cspecs .tick{color:var(--teal-500);font-weight:700}
.cactions{display:flex;flex-direction:column;gap:8px;min-width:160px}
.cactions .btn{justify-content:center;padding:11px 18px;font-size:.88rem;white-space:nowrap}
@media(max-width:880px){
  .crow{grid-template-columns:44px 1fr;gap:14px}
  .cspecs{grid-column:1/-1;flex-direction:row;flex-wrap:wrap;gap:12px}
  .cactions{grid-column:1/-1;flex-direction:row}
  .cactions .btn{flex:1}
  .crank{width:44px;height:44px;font-size:1.2rem}
}

/* ---- Comparison matrix (startsida, längre ner) ---- */
.matrixwrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--white);box-shadow:var(--shadow);-webkit-overflow-scrolling:touch}
table.matrix{width:100%;border-collapse:collapse;font-size:.9rem;min-width:720px}
table.matrix thead th{background:var(--teal-900);color:#eef1fb;font-weight:600;text-align:center;padding:16px 14px;font-size:.86rem;position:sticky;left:auto}
table.matrix thead th:first-child{text-align:left;border-top-left-radius:var(--radius);position:sticky;left:0;z-index:2;background:var(--teal-900)}
table.matrix thead th:last-child{border-top-right-radius:var(--radius)}
table.matrix thead th .mname{font-family:'Fraunces',serif;font-size:1rem;display:block}
table.matrix thead th .mbest{font-weight:500;font-size:.72rem;color:#cfe0ff;display:block;margin-top:2px}
table.matrix th.rowlab{text-align:left;font-weight:600;color:var(--ink);background:var(--paper);position:sticky;left:0;z-index:1;padding:13px 16px;border-top:1px solid var(--line);white-space:nowrap}
table.matrix td{padding:13px 14px;border-top:1px solid var(--line);text-align:center;color:var(--ink-soft)}
table.matrix tbody tr:hover td,table.matrix tbody tr:hover th.rowlab{background:var(--paper-2)}
table.matrix td.top-col{background:rgba(143,224,79,.10)}
table.matrix thead th.top-col{background:var(--teal-900)}
table.matrix .tick{color:var(--teal-500);font-weight:700}
table.matrix .cross{color:#c25b4a;font-weight:700}
.matrix-rating{font-family:'Fraunces',serif;font-weight:700;color:#2b3f8f;font-size:1.05rem}
.pill-low{background:#e3f6d8;color:#3d7a1e;font-size:.76rem;font-weight:600;padding:3px 10px;border-radius:999px}
.pill-mid{background:#fff2d9;color:#a9741a;font-size:.76rem;font-weight:600;padding:3px 10px;border-radius:999px}
.pill-high{background:#fde4dd;color:#b0432c;font-size:.76rem;font-weight:600;padding:3px 10px;border-radius:999px}

/* ---- Guider ---- */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.guide-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;flex-direction:column}
.guide-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--teal-100)}
.guide-card .gc-top{height:158px;background:#101a3a;overflow:hidden;position:relative}
.guide-card .gc-top img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.guide-card:hover .gc-top img{transform:scale(1.04)}
.guide-card .gc-body{padding:20px 22px;flex:1;display:flex;flex-direction:column;gap:7px}
.guide-card h3{font-size:1.12rem;color:var(--teal-900);margin:0}
.guide-card p{font-size:.88rem;color:var(--ink-soft);margin:0;flex:1}
.guide-card .gc-go{color:var(--teal-700);font-weight:600;font-size:.86rem;margin-top:6px}
@media(max-width:880px){.guide-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.guide-grid{grid-template-columns:1fr}}

/* Guide article layout */
.guide-hero{background:linear-gradient(125deg,#0c142e,#1d2c5c 60%,#3a4ea0 135%);color:#eef1fb;border-radius:28px;padding:40px 46px;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.guide-hero::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0 1px,transparent 1px 64px);mask-image:linear-gradient(90deg,transparent,#000 40%);pointer-events:none}
.guide-hero>*{position:relative;z-index:1}
.guide-hero h1{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:12px}
.guide-hero p{color:#c2c9e6;max-width:60ch;font-size:1.05rem}
.guide-meta{display:flex;gap:20px;margin-top:18px;flex-wrap:wrap;font-size:.85rem;color:#aab2d6}
.guide-meta span{display:inline-flex;align-items:center;gap:7px}

.toc{background:var(--paper-2);border-radius:var(--radius);padding:22px 26px;margin:8px 0 4px}
.toc h2{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-700);margin-bottom:12px;font-family:'Inter',sans-serif;font-weight:600}
.toc ol{margin:0;padding-left:20px;columns:2;column-gap:30px}
.toc li{margin-bottom:7px}
.toc a{color:var(--ink);text-decoration:none;font-size:.92rem}
.toc a:hover{color:var(--teal-700);text-decoration:underline}
@media(max-width:640px){.toc ol{columns:1}}

/* Interactive widgets */
.widget{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);margin:24px 0}
.widget-title{font-family:'Fraunces',serif;font-weight:600;font-size:1.25rem;color:var(--teal-900);margin-bottom:6px}
.widget-sub{font-size:.9rem;color:var(--ink-soft);margin-bottom:22px}
.slider-row{margin-bottom:22px}
.slider-row label{display:flex;justify-content:space-between;align-items:baseline;font-size:.92rem;font-weight:600;color:var(--ink);margin-bottom:10px}
.slider-row label .val{font-family:'Fraunces',serif;font-size:1.15rem;color:var(--teal-700)}
input[type=range]{width:100%;height:6px;border-radius:6px;background:var(--paper-2);outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--cta);border:3px solid #fff;box-shadow:0 2px 6px rgba(16,26,58,.25);cursor:pointer}
input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--cta);border:3px solid #fff;box-shadow:0 2px 6px rgba(16,26,58,.25);cursor:pointer}
.seg{display:inline-flex;background:var(--paper-2);border-radius:10px;padding:4px;gap:4px}
.seg button{border:0;background:transparent;padding:8px 16px;border-radius:7px;font-family:inherit;font-size:.88rem;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:all .15s}
.seg button.active{background:var(--teal-700);color:#fff}
.result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.result-box{background:var(--paper);border-radius:var(--radius-sm);padding:18px;text-align:center;border:1px solid var(--line)}
.result-box .rlabel{font-size:.78rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.result-box .rval{font-family:'Fraunces',serif;font-weight:700;font-size:1.8rem;color:var(--teal-900);line-height:1}
.result-box .rval small{font-size:.9rem;font-weight:400;color:var(--ink-soft)}
.result-box.hl{background:linear-gradient(135deg,var(--teal-900),var(--teal-700));border:0}
.result-box.hl .rlabel{color:#9fb4e6}
.result-box.hl .rval{color:#fff}
@media(max-width:640px){.result-grid{grid-template-columns:1fr}}

/* Bar chart (cost) */
.barchart{display:flex;align-items:flex-end;gap:20px;height:220px;padding:20px 10px 0;border-bottom:2px solid var(--line);margin:10px 0 8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:10px}
.bar{width:100%;max-width:90px;border-radius:10px 10px 0 0;position:relative;transition:height .6s ease;display:flex;align-items:flex-start;justify-content:center}
.bar .bval{position:absolute;top:-26px;font-family:'Fraunces',serif;font-weight:700;font-size:1rem;color:var(--teal-900);white-space:nowrap}
.bar-full{background:linear-gradient(180deg,#5b85f5,#2554d4)}
.bar-after{background:linear-gradient(180deg,#8fe04f,#6bbf3a)}
.bar-label{font-size:.82rem;color:var(--ink-soft);text-align:center}

/* Line/effect chart */
.effectchart{width:100%;height:auto}
.chart-legend{display:flex;gap:20px;flex-wrap:wrap;margin-top:12px;font-size:.84rem;color:var(--ink-soft)}
.chart-legend span{display:inline-flex;align-items:center;gap:7px}
.chart-legend .dot-l{width:14px;height:3px;border-radius:2px}

.source-note{font-size:.8rem;color:var(--ink-soft);background:var(--paper-2);border-radius:var(--radius-sm);padding:12px 16px;margin-top:14px}
.source-note a{color:var(--teal-700)}

/* ---- Cookie-banner ---- */
.cookiebar{position:fixed;left:0;right:0;bottom:0;z-index:60;background:#101a3a;color:#cdd6ee;padding:14px 20px;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;box-shadow:0 -4px 20px rgba(16,26,58,.2);font-size:.9rem}
.cookiebar.hidden{display:none}
.cookiebar p{margin:0;max-width:70ch}
.cookiebar a{color:#8fe04f;text-decoration:underline}
.cookiebar .ck-btn{background:var(--cta);color:var(--cta-ink);border:0;font-family:inherit;font-weight:700;font-size:.88rem;padding:11px 22px;border-radius:999px;cursor:pointer;white-space:nowrap;transition:background .15s,transform .15s}
.cookiebar .ck-btn:hover{background:var(--cta-hover);transform:translateY(-1px)}
@media(max-width:620px){.cookiebar{flex-direction:column;text-align:center;gap:12px;padding:16px}}


/* Guide-hero med bild (två kolumner) */
.guide-hero.has-img{display:grid;grid-template-columns:1.25fr .85fr;gap:38px;align-items:center}
.guide-hero .gh-text{min-width:0}
.guide-hero .gh-img{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 14px 40px rgba(0,0,0,.32);aspect-ratio:4/3}
.guide-hero .gh-img img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:820px){
  .guide-hero.has-img{grid-template-columns:1fr;gap:24px}
  .guide-hero .gh-img{aspect-ratio:16/9;max-height:280px}
}

/* Diskret sökordsmening på stadssidor */
.prose .kw-note{font-size:.92rem;color:var(--ink-soft);background:var(--paper-2);border-left:3px solid var(--teal-100);padding:12px 16px;border-radius:0 8px 8px 0;margin-top:18px}

/* Footer matkassar-stil */
.fgrid{grid-template-columns:1.6fr 1fr 1fr}
.fcol-brand{max-width:38ch}
.fcopy{background:rgba(0,0,0,.18);text-align:center;padding:14px 20px;font-size:.85rem;color:#aeb6d6}
.fcopy span{opacity:.9}
@media(max-width:720px){.fgrid{grid-template-columns:1fr}}
