/* ==========================================================================
   Moppe.org — designkoncept "Färddatorn" (HUD / trip computer)
   Sporty elsparkcykel-instrumentpanel: asfaltsgrå bläck, signalorange,
   mörka displaypaneler med mono-avläsningar, körfältslinjer.
   Lokala typsnitt: Archivo (display), Figtree (brödtext), DM Mono (avläsning).
   ========================================================================== */

/* ---------- Typsnitt (lokala woff2) ---------- */
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/archivo-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:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/archivo-600-ext.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:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/archivo-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:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/archivo-700-ext.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:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/archivo-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:'Archivo';font-style:normal;font-weight:800;font-display:swap;src:url('/fonts/archivo-800-ext.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:'Archivo';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/archivo-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:'Archivo';font-style:normal;font-weight:900;font-display:swap;src:url('/fonts/archivo-900-ext.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:'Figtree';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/figtree-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:'Figtree';font-style:normal;font-weight:400;font-display:swap;src:url('/fonts/figtree-400-ext.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:'Figtree';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/figtree-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:'Figtree';font-style:normal;font-weight:500;font-display:swap;src:url('/fonts/figtree-500-ext.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:'Figtree';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/figtree-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:'Figtree';font-style:normal;font-weight:600;font-display:swap;src:url('/fonts/figtree-600-ext.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:'Figtree';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/figtree-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:'Figtree';font-style:normal;font-weight:700;font-display:swap;src:url('/fonts/figtree-700-ext.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('/fonts/dm-mono-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('/fonts/dm-mono-400-ext.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('/fonts/dm-mono-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('/fonts/dm-mono-500-ext.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;}

/* ---------- Designtokens ---------- */
:root{
  --paper:#F5F4EF;       /* varm off-white bas */
  --surface:#FFFFFF;
  --ink:#16171B;         /* asfaltsbläck */
  --ink-soft:#3A3D45;
  --panel:#191B20;       /* mörk displaypanel */
  --panel-2:#23262D;
  --panel-line:#34373F;
  --signal:#FF5A1F;      /* signalorange */
  --signal-deep:#E23E00;
  --signal-soft:#FFE7DB;
  --volt:#C8F23D;        /* hi-vis lime — batteri/eco, sparsamt */
  --muted:#666873;
  --line:#E5E2D9;        /* hårlinje */
  --track:#EBE8DF;
  --ok:#1E8E5A;
  --warn:#C2410C;
  --radius:14px;
  --radius-sm:9px;
  --maxw:1140px;
  --font-display:'Archivo',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-body:'Figtree',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --font-mono:'DM Mono','SFMono-Regular',ui-monospace,Menlo,monospace;
  --shadow-sm:0 1px 2px rgba(22,23,27,.06),0 2px 8px rgba(22,23,27,.05);
  --shadow:0 6px 24px rgba(22,23,27,.09);
  --shadow-lg:0 18px 48px rgba(22,23,27,.16);
}

/* ---------- Bas ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--font-body);font-size:1.0625rem;line-height:1.68;
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  display:flex;flex-direction:column;min-height:100vh;
}
img{max-width:100%;height:auto}
a{color:var(--signal-deep);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:20px;width:100%}
.container-narrow{max-width:760px;margin-inline:auto;padding-inline:20px;width:100%}

h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--ink);font-weight:800;line-height:1.1;letter-spacing:-.015em;margin:0 0 .55em}
h1{font-size:clamp(2.1rem,5.2vw,3.5rem);font-weight:900;letter-spacing:-.025em}
h2{font-size:clamp(1.6rem,3.4vw,2.3rem)}
h3{font-size:clamp(1.22rem,2.2vw,1.5rem);font-weight:700}
h4{font-size:1.13rem;font-weight:700}
p{margin:0 0 1.05rem}
main{display:block;flex:1 0 auto}
section{position:relative}
strong,b{font-weight:700}
hr{border:0;border-top:1px solid var(--line);margin:2rem 0}

/* ---------- Topp-speedbar ---------- */
.speedbar{height:4px;background:linear-gradient(90deg,var(--signal) 0%,var(--signal-deep) 45%,var(--ink) 100%);background-size:200% 100%;animation:speed 7s linear infinite}
@keyframes speed{0%{background-position:200% 0}100%{background-position:0 0}}

/* ---------- Masthead ---------- */
.masthead{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.masthead-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 20px;max-width:var(--maxw);margin-inline:auto}
.brand{display:inline-flex;align-items:center;flex:0 0 auto}
.brand img{height:46px;width:auto;display:block}
.mainnav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.mainnav a{
  font-family:var(--font-display);font-weight:700;font-size:.93rem;color:var(--ink);
  padding:9px 13px;border-radius:8px;letter-spacing:-.01em;line-height:1;white-space:nowrap;
  transition:background .15s,color .15s;text-decoration:none
}
.mainnav a:hover{background:var(--paper);color:var(--signal-deep);text-decoration:none}
.mainnav a.active{color:var(--signal-deep)}
.nav-toggle{display:none;border:1px solid var(--line);background:var(--surface);border-radius:9px;padding:9px 11px;cursor:pointer;font-size:1.2rem;line-height:1;color:var(--ink)}
@media(max-width:860px){
  .nav-toggle{display:inline-flex}
  .mainnav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:8px 14px 16px;box-shadow:var(--shadow)}
  .mainnav.open{display:flex}
  .mainnav a{padding:12px 10px;border-radius:8px;font-size:1rem}
}

/* ---------- Körfältslinje (signaturdelare) ---------- */
.lane{height:0;border:0;border-top:3px dashed var(--signal);opacity:.55;margin:0;width:100%}
.lane-wrap{display:flex;align-items:center;gap:14px;color:var(--muted);font-family:var(--font-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin:2.4rem 0}
.lane-wrap::before,.lane-wrap::after{content:"";flex:1;height:0;border-top:3px dashed var(--track)}

/* ---------- Eyebrow / kbd-etiketter ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-weight:500;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--signal-deep)}
.eyebrow::before{content:"";width:22px;height:3px;background:var(--signal);border-radius:2px}

/* ---------- Sektionsband ---------- */
.band{padding:clamp(2.6rem,6vw,4.6rem) 0}
.band-paper{background:var(--paper)}
.band-surface{background:var(--surface);border-block:1px solid var(--line)}
.band-dark{background:var(--panel);color:#EDEEF1}
.band-dark h1,.band-dark h2,.band-dark h3,.band-dark h4{color:#fff}
.band-dark p{color:#B9BCC4}
/* ljusa kort på mörkt band behåller mörk text */
.band-dark .m-card,.band-dark .linkcard{color:var(--ink)}
.band-dark .m-card h1,.band-dark .m-card h2,.band-dark .m-card h3,.band-dark .m-card h4,.band-dark .m-card p{color:var(--ink)}

/* ---------- HUD displaypanel (hero) ---------- */
.hud{
  position:relative;background:
    radial-gradient(120% 140% at 88% 8%,rgba(255,90,31,.22),transparent 46%),
    linear-gradient(180deg,#20232A,#191B20);
  color:#EDEEF1;border-radius:22px;padding:clamp(1.8rem,4vw,3rem);overflow:hidden;
  border:1px solid var(--panel-line);box-shadow:var(--shadow-lg)
}
.hud::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(115deg,rgba(255,255,255,.025) 0 2px,transparent 2px 26px);pointer-events:none}
.hud h1{color:#fff}
.hud p{color:#C3C6CE}
.hud .eyebrow{color:var(--signal)}
.hud-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:clamp(1.4rem,3vw,2.6rem);align-items:center;position:relative;z-index:1}
@media(max-width:820px){.hud-grid{grid-template-columns:1fr}}

/* ---------- Avläsningar (readouts, mono) ---------- */
.readout-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.4rem}
.readout{background:rgba(255,255,255,.05);border:1px solid var(--panel-line);border-radius:12px;padding:12px 15px;min-width:96px}
.readout .val{font-family:var(--font-mono);font-weight:500;font-size:1.5rem;color:#fff;line-height:1;letter-spacing:-.02em}
.readout .val .u{font-size:.78rem;color:var(--signal);margin-left:3px}
.readout .lbl{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#8C8F98;margin-top:7px}

/* spec-chips (ljus kontext) */
.spec-strip{display:flex;flex-wrap:wrap;gap:8px;margin:1rem 0}
.spec-chip{display:inline-flex;align-items:baseline;gap:6px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-family:var(--font-mono);font-size:.84rem;color:var(--ink);white-space:nowrap}
.spec-chip b{font-weight:500}
.spec-chip .k{color:var(--muted);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}

/* ---------- Knappar ---------- */
.btn{font-family:var(--font-display);font-weight:700;border-radius:11px;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:13px 22px;font-size:1rem;line-height:1;letter-spacing:-.01em;transition:transform .12s,box-shadow .15s,background .15s,color .15s;text-decoration:none}
.btn:hover{text-decoration:none}
.btn-signal{background:var(--signal);color:#fff;box-shadow:0 6px 16px rgba(255,90,31,.32)}
.btn-signal:hover{background:var(--signal-deep);color:#fff;transform:translateY(-2px);box-shadow:0 10px 22px rgba(255,90,31,.4)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:#fff}
.btn-light{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.25)}
.btn-light:hover{background:#fff;color:var(--ink)}
.btn-lg{padding:16px 28px;font-size:1.08rem}
.btn-block{display:flex;width:100%}
.btn .arr{transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- Toplista ---------- */
.toplist{display:flex;flex-direction:column;gap:16px;margin-top:1.6rem}
.rankcard{position:relative;display:grid;grid-template-columns:auto 92px 1fr auto;gap:20px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm);transition:box-shadow .18s,transform .18s,border-color .18s}
.rankcard:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:#D9D5C8}
.rankcard.is-top{border-color:var(--signal);box-shadow:0 0 0 1px var(--signal),var(--shadow)}
.rank-no{font-family:var(--font-mono);font-weight:500;font-size:1.5rem;color:var(--muted);width:38px;text-align:center}
.rankcard.is-top .rank-no{color:var(--signal-deep)}
.rank-badge{position:absolute;top:-11px;left:64px;background:var(--signal);color:#fff;font-family:var(--font-display);font-weight:700;font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;padding:4px 11px;border-radius:999px}
.rank-img{width:92px;height:92px;display:flex;align-items:center;justify-content:center;background:var(--paper);border-radius:10px;border:1px solid var(--line)}
.rank-img img{max-width:84px;max-height:84px;object-fit:contain;mix-blend-mode:multiply}
.rank-body h3{margin:0 0 4px;font-size:1.2rem}
.rank-body .muted{color:var(--muted);font-size:.94rem;margin:0}
.rank-meta{display:flex;flex-direction:column;align-items:flex-end;gap:9px;text-align:right;min-width:150px}
@media(max-width:720px){
  .rankcard{grid-template-columns:auto 64px 1fr;row-gap:14px}
  .rank-img{width:64px;height:64px}.rank-img img{max-width:56px;max-height:56px}
  .rank-meta{grid-column:1 / -1;align-items:stretch;flex-direction:row;flex-wrap:wrap;justify-content:space-between;text-align:left;border-top:1px solid var(--line);padding-top:13px}
  .rank-badge{left:54px}
}

/* ---------- Stjärnor (glyf, moppeStars/.rate) + betyg ---------- */
.rate{position:relative;display:inline-block;vertical-align:middle;font-size:18px;line-height:1;white-space:nowrap}
.rate::before{content:"\2605\2605\2605\2605\2605";color:var(--track);letter-spacing:1px}
.rate>i{position:absolute;left:0;top:0;height:100%;overflow:hidden;white-space:nowrap}
.rate>i::before{content:"\2605\2605\2605\2605\2605";color:var(--signal);letter-spacing:1px}
.rate-sm{font-size:15px}.rate-md{font-size:18px}.rate-lg{font-size:24px}
.grade{font-family:var(--font-mono);font-weight:500;font-size:.92rem;color:var(--ink)}
.grade .of{color:var(--muted);font-size:.78em}
.rating-line{display:inline-flex;align-items:center;gap:9px;flex-wrap:wrap}

/* ---------- HUD-gauge (cirkulär betygsmätare) ---------- */
.gauge{--p:0;--c:var(--signal);position:relative;width:74px;height:74px;border-radius:50%;background:conic-gradient(var(--c) calc(var(--p)*1%),var(--track) 0);display:flex;align-items:center;justify-content:center}
.gauge::before{content:"";position:absolute;inset:9px;background:var(--surface);border-radius:50%}
.gauge span{position:relative;font-family:var(--font-mono);font-weight:500;font-size:1.05rem;color:var(--ink)}
.gauge-row{display:flex;flex-wrap:wrap;gap:18px;margin:1.2rem 0}
.gauge-item{text-align:center}
.gauge-item .gl{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:7px}

/* ---------- Generiska kort ---------- */
.m-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);transition:box-shadow .18s,transform .18s}
.m-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.m-card h3{margin-top:0}
.card-grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.cols-3,.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* länkkort (hub/guide-listor) */
.linkcard{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px 18px;color:var(--ink);font-weight:500;transition:border-color .15s,transform .15s,box-shadow .15s}
.linkcard:hover{border-color:var(--signal);transform:translateX(3px);box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink)}
.linkcard .arr{color:var(--signal);font-family:var(--font-mono)}

/* ---------- Taggar/badges ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.04em;padding:4px 10px;border-radius:999px;text-transform:uppercase}
.tag-ok{background:rgba(30,142,90,.12);color:var(--ok)}
.tag-warn{background:rgba(194,65,12,.12);color:var(--warn)}
.tag-volt{background:#EEF7C9;color:#5a6e10}
.tag-neutral{background:var(--track);color:var(--ink-soft)}

/* ---------- Prose (artiklar) ---------- */
.prose{max-width:none}
.prose h2{margin-top:2.4rem;padding-top:.2rem}
.prose h3{margin-top:1.7rem}
.prose ul,.prose ol{margin:0 0 1.15rem;padding-left:1.3rem}
.prose li{margin-bottom:.5rem}
.prose a{color:var(--signal-deep);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px;font-weight:500}
.prose img{border-radius:var(--radius);margin:1.4rem 0;box-shadow:var(--shadow-sm)}
.prose blockquote{margin:1.6rem 0;padding:14px 20px;border-left:4px solid var(--signal);background:var(--surface);border-radius:0 10px 10px 0;font-size:1.05rem}

/* faktaruta */
.factbox{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--signal);border-radius:0 var(--radius) var(--radius) 0;padding:18px 22px;margin:1.6rem 0;box-shadow:var(--shadow-sm)}
.factbox h4{margin:0 0 .5rem;font-family:var(--font-display)}

/* ---------- Tabeller (responsiva) ---------- */
.m-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.4rem 0;border:1px solid var(--line);border-radius:var(--radius)}
table.m-table{width:100%;border-collapse:collapse;background:var(--surface);font-size:.97rem;min-width:540px}
table.m-table th,table.m-table td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--line)}
table.m-table thead th{font-family:var(--font-display);font-weight:700;font-size:.82rem;letter-spacing:.02em;text-transform:uppercase;color:var(--muted);background:var(--paper)}
table.m-table tbody tr:last-child td{border-bottom:0}
table.m-table tbody tr:hover{background:var(--paper)}
table.m-table td .num{font-family:var(--font-mono)}

/* ---------- FAQ ---------- */
.faq{margin-top:1.4rem}
.faq .qa{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.faq .qa:hover{border-color:#D9D5C8}
.faq .qa.open{border-color:var(--signal);box-shadow:var(--shadow-sm)}
.faq .qa h3{margin:0;font-size:1.06rem;font-family:var(--font-display);font-weight:700}
.faq .qa .q{padding:16px 20px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:14px;user-select:none;list-style:none}
.faq .qa .q::-webkit-details-marker{display:none}
.faq .qa .q::after{content:"";flex:0 0 auto;width:11px;height:11px;border-right:2.5px solid var(--signal-deep);border-bottom:2.5px solid var(--signal-deep);transform:rotate(45deg);transition:transform .2s;margin-top:-4px}
.faq .qa.open .q::after{transform:rotate(225deg);margin-top:2px}
.faq .qa .a{display:none;padding:0 20px 16px;color:var(--ink-soft)}
.faq .qa.open .a{display:block;animation:faqIn .22s ease}
.faq .qa .a p:last-child{margin-bottom:0}
@keyframes faqIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ---------- CTA-band ---------- */
.cta-band{background:
  radial-gradient(120% 160% at 90% 0%,rgba(255,90,31,.26),transparent 50%),
  linear-gradient(180deg,#20232A,#16171B);
  color:#fff;border-radius:22px;padding:clamp(1.8rem,4vw,2.8rem);text-align:center;box-shadow:var(--shadow-lg)}
.cta-band h2{color:#fff}
.cta-band p{color:#C3C6CE;max-width:560px;margin-inline:auto}

/* ---------- Lokal NAP (kommun) ---------- */
.nap-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:1.2rem}
@media(max-width:640px){.nap-grid{grid-template-columns:1fr}}
.nap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px}
.nap .nm{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin:0 0 4px}
.nap .meta{font-family:var(--font-mono);font-size:.85rem;color:var(--ink-soft);margin:2px 0;display:flex;gap:8px}
.nap .meta .ic{color:var(--signal-deep)}

/* hyrtjänst-kort */
.rental{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px}
.rental .code{font-family:var(--font-mono);font-weight:500;background:var(--ink);color:var(--volt);padding:5px 11px;border-radius:7px;letter-spacing:.06em}

/* ---------- TOC ---------- */
.toc{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;margin:1.6rem 0}
.toc .toc-h{font-family:var(--font-display);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.toc ul{list-style:none;margin:0;padding:0;columns:2;column-gap:28px}
.toc li{margin-bottom:7px;break-inside:avoid}
.toc a{color:var(--ink);font-weight:500}
.toc a:hover{color:var(--signal-deep)}
@media(max-width:600px){.toc ul{columns:1}}

/* ---------- Breadcrumb ---------- */
.crumb{font-family:var(--font-mono);font-size:.8rem;color:var(--muted);padding:14px 0 0}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--signal-deep)}
.crumb .sep{margin:0 7px;color:var(--track)}

/* ---------- Footer ---------- */
.site-footer{background:var(--panel);color:#B9BCC4;padding:48px 0 26px;margin-top:auto;flex-shrink:0}
.site-footer .brand img{height:42px;filter:brightness(0) invert(1);opacity:.92}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-h{font-family:var(--font-display);font-weight:700;color:#fff;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;margin:0 0 14px}
.site-footer a{color:#B9BCC4;display:block;padding:5px 0;font-size:.95rem}
.site-footer a:hover{color:var(--signal);text-decoration:none}
.foot-bottom{border-top:1px solid var(--panel-line);margin-top:34px;padding-top:18px;font-family:var(--font-mono);font-size:.8rem;color:#7C7F88;display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between}
.foot-bottom a{display:inline}

/* ---------- Hjälpklasser ---------- */
.mono{font-family:var(--font-mono)}
.text-center{text-align:center}
.muted{color:var(--muted)}
.lead{font-size:1.18rem;line-height:1.6;color:var(--ink-soft)}
.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2.2rem}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}
.stack-sm>*+*{margin-top:.6rem}
.fade-up{opacity:0;transform:translateY(14px);animation:fadeUp .6s cubic-bezier(.2,.7,.3,1) forwards}
.fade-up.d1{animation-delay:.08s}.fade-up.d2{animation-delay:.16s}.fade-up.d3{animation-delay:.24s}.fade-up.d4{animation-delay:.32s}
@keyframes fadeUp{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.fade-up{animation:none;opacity:1;transform:none}.speedbar{animation:none}}

/* ---------- Webbplatskarta ---------- */
.sitemap-cols{list-style:none;margin:.6rem 0 0;padding:0;columns:3;column-gap:34px}
.sitemap-cols-tight{columns:4;font-size:.93rem}
.sitemap-cols li{margin-bottom:8px;break-inside:avoid}
.sitemap-cols a{color:var(--ink);font-weight:500}
.sitemap-cols a:hover{color:var(--signal-deep)}
@media(max-width:760px){.sitemap-cols{columns:2;column-gap:24px}.sitemap-cols-tight{columns:2}}
@media(max-width:460px){.sitemap-cols{columns:1}.sitemap-cols-tight{columns:2;column-gap:18px}}

/* right-col-h: undantag från [table-of-contents]-generatorn i public/index.php */
.right-col-h{}
