/* ===== Lovdata-inspirert stil ===== */

:root{
  --brand: #d71920;           /* Lovdata-rød */
  --ink: #0f172a;             /* nesten-svart */
  --muted-ink: #64748b;       /* sekundær tekst */
  --link: #1d4ed8;            /* blå lenker */
  --border: #e5e7eb;          /* kantlinjer */
  --bg: #ffffff;              /* bakgrunn */
  --panel: #ffffff;           /* paneler */
  --toc-bg: #fafafa;          /* venstrespalte */
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:var(--bg);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Inter, Arial, sans-serif;
  line-height:1.55;
}

/* ---------- Toppbanner ---------- */
header{
  position: sticky; top: 0; z-index: 50;
  display:flex; align-items:center; gap:12px;
  padding:12px 18px;
  background:var(--brand); color:#fff;
  border-bottom: 1px solid rgba(255,255,255,.15);
}
header .logo{
  font-weight:800; letter-spacing:.4px; font-size:1.15rem;
}
header .search{flex:1; display:flex; gap:10px}
header .search input{
  flex:1; padding:12px 14px; border:none; border-radius:8px;
}
header .search button{
  padding:12px 16px; border:none; border-radius:8px;
  background:#9b1117; color:#fff; font-weight:600; cursor:pointer;
}
header .search button:hover{ filter:brightness(.95) }

/* ---------- Layout ---------- */
.wrap{
  display:grid; grid-template-columns: 320px minmax(680px, 880px);
  gap:0; min-height:calc(100vh - 54px);
}
nav{
  background:var(--toc-bg);
  border-right:1px solid var(--border);
  padding:20px 18px;
  position:sticky; top:54px; height:calc(100vh - 54px); overflow:auto;
}
main{
  padding:28px 32px;
}

/* ---------- Innholdstopp ---------- */
h1{
  margin:6px 0 18px; font-size:1.45rem;
}
h2{
  font-size:1.15rem; margin:18px 0 10px;
  color:#1f2937; font-weight:700;
}

/* ---------- Select + TOC ---------- */
.law-select{
  width:100%;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#fff;
  margin-bottom:12px;
}
nav .toc-title{
  margin:16px 0 8px; font-size:.9rem; color:var(--muted-ink); text-transform:uppercase; letter-spacing:.04em;
}
nav .toc a{
  display:block; padding:8px 10px; border-radius:8px; color:#0f172a; text-decoration:none;
}
nav .toc a:hover{ background:#fff }

/* ---------- Paragrafer ---------- */
.chapter{ margin: 28px 0 40px; }
.section{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:12px;
  padding:16px 18px;
  margin:14px 0;
}
.section .meta{
  font-size:.9rem; color:var(--muted-ink); margin-bottom:4px;
}
.section h3{
  margin:0 0 8px;
  font-size:1.05rem; font-weight:700;
}
.section p{ margin:.55em 0; }
.section p + p{ margin-top:.7em }

/* Punktledd (a., b., c.) på egne linjer med liten innrykk-følelse */
.section .content{
  white-space:normal;            /* nl2br lager <br>, la de brytes vanlig */
}
.section .content br + br{      /* ekstra luft for tomlinje/nytt avsnitt */
  line-height:1.3;
  content:"";
}

/* ---------- Tekst & linker ---------- */
a{ color:var(--link); text-decoration:none }
a:hover{ text-decoration:underline }
mark{ background:#fff3a3; padding:0 .2em; border-radius:.2em }

/* ---------- Footer ---------- */
footer{
  margin-top:24px; padding-top:18px;
  border-top:1px solid var(--border);
  color:var(--muted-ink); font-size:.95rem;
}

/* ---------- Små skjermer ---------- */
@media (max-width: 900px){
  .wrap{ grid-template-columns: 1fr; }
  nav{ position:static; height:auto; border-right:none; border-bottom:1px solid var(--border); }
  main{ padding:20px; }
}

/* Smooth scroll til kapittel-lenker */
html{ scroll-behavior:smooth }