:root {
  --color-primary: #6d28d9;
  --color-border: #d0d7de;
  --color-bg: #f6f8fa;
}

* { box-sizing: border-box; }

body {
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  margin: 0;
  background: var(--color-bg);
  color: #1f2328;
}

.topbar {
  background: linear-gradient(90deg, #7c2ae8 0%, #5560e6 50%, #00c4cc 100%);
  color: white;
  padding: 0.75rem 1.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.topbar a, .topbar .bruger {
  color: white;
  text-decoration: none;
  margin-left: 1rem;
}

.topbar .brand {
  font-weight: bold;
  font-size: 1.2rem;
  margin-left: 0;
  display: flex;
  align-items: center;
}

.topbar .brand-logo {
  height: 32px;
  width: auto;
  display: block;
}

/* Co-branding: firma og Vejnet vises ligeværdigt (samme størrelse). */
.topbar .brand .firma-logo {
  height: 36px;
  background: white;
  border-radius: 4px;
  padding: 2px 4px;
}

.topbar .brand .firma-navn {
  font-weight: bold;
  font-size: 1.2rem;
  margin-left: 0.5rem;
}

.topbar .brand .brand-sep {
  font-size: 1.2rem;
  font-weight: normal;
  opacity: 0.6;
  margin: 0 0.6rem;
}

.topbar .brand .vejnet-logo {
  height: 36px;
  width: auto;
}

.logo-preview {
  max-height: 64px;
  max-width: 280px;
  width: auto;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  padding: 4px;
  background: white;
  display: block;
}

.firma-liste-logo {
  max-height: 32px;
  max-width: 120px;
  width: auto;
  vertical-align: middle;
}

.forsoegstype-detalje {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.25rem 1rem;
  margin: 0.5rem 0 1rem;
}

.forsoegstype-detalje dt {
  font-weight: bold;
  color: var(--color-primary);
}

.forsoegstype-detalje dd {
  margin: 0;
  white-space: pre-wrap;
}

.forsoegstype-behandl {
  display: inline-flex;
  gap: 0.5rem;
  margin-right: 1rem;
}

.topbar button {
  background: transparent;
  border: 1px solid white;
  color: white;
  padding: 0.2rem 0.6rem;
  border-radius: 4px;
  cursor: pointer;
}

/* Hamburger-knap: skjult på desktop, vises kun i mobil-breakpointet nedenfor. */
.topbar .nav-toggle {
  display: none;
}

/* Brede tabeller scroller vandret i stedet for at sprænge layoutet på smal
 * skærm. Wrapperen sættes på af app.js, så ingen skabeloner skal ændres. */
.table-scroll {
  max-width: 100%;
  overflow-x: auto;
}

.content {
  max-width: 1000px;
  margin: 2rem auto;
  padding: 0 1rem;
}

.login-box {
  max-width: 320px;
  margin: 4rem auto;
  background: white;
  padding: 2rem;
  border: 1px solid var(--color-border);
  border-radius: 8px;
}

.login-box label {
  display: block;
  margin-bottom: 1rem;
}

.login-box input,
.login-box textarea {
  display: block;
  width: 100%;
  padding: 0.4rem;
  margin-top: 0.25rem;
  font-family: inherit;
}

/* Anmod-om-adgang-formularen er bredere end login-boksen. */
.login-box:has(textarea) {
  max-width: 460px;
}

/* Afkrydsning (fx vilkår) i login-boksen: boks til venstre for teksten. */
.login-box label.afkryds {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
}

.login-box label.afkryds input[type="checkbox"] {
  display: inline-block;
  width: auto;
  margin-top: 0.2rem;
  flex: none;
}

/* Forklarende tekst under vilkår-afkrydsningen. */
.login-box .vilkaar-note {
  margin: 0.25rem 0 1rem;
  font-size: 0.85rem;
  color: #666;
}

.login-box button, .sogefelt button {
  background: var(--color-primary);
  color: white;
  border: none;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  cursor: pointer;
}

.fejl {
  color: #b3261e;
}

.subtitle {
  color: #666;
  margin-top: -0.5rem;
}

.sogefelt {
  margin-bottom: 1rem;
  display: flex;
  gap: 0.5rem;
  align-items: center;
}

.sogefelt input {
  padding: 0.4rem;
  flex: 1;
}

.sagstabel {
  width: 100%;
  border-collapse: collapse;
  background: white;
}

.sagstabel th, .sagstabel td {
  border: 1px solid var(--color-border);
  padding: 0.5rem;
  text-align: left;
}

.sagstabel th {
  background: #eaeef2;
}

/* Sagsdetalje / opret ny sag (fase 1) */

.brodkrumme {
  margin-bottom: 0.5rem;
  color: #666;
}

.brodkrumme a {
  color: var(--color-primary);
}

.sagsform fieldset {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  margin-bottom: 1rem;
  padding: 0.75rem 1rem 1rem;
}

.sagsform legend {
  font-weight: bold;
  padding: 0 0.4rem;
}

.formgrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.75rem 1rem;
}

.sagsform label {
  display: block;
  font-size: 0.9rem;
  color: #444;
}

.sagsform input,
.sagsform select,
.sagsform textarea {
  display: block;
  width: 100%;
  padding: 0.4rem;
  margin-top: 0.25rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  font: inherit;
}

.sagsform .fuldbredde {
  margin-top: 0.75rem;
}

.formknapper {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  margin: 1rem 0 2rem;
}

.formknapper button {
  background: var(--color-primary);
  color: white;
  border: none;
  padding: 0.5rem 1.25rem;
  border-radius: 4px;
  cursor: pointer;
}

.knap-sekundaer {
  display: inline-block;
  padding: 0.45rem 1rem;
  border: 1px solid var(--color-primary);
  border-radius: 4px;
  color: var(--color-primary);
  text-decoration: none;
  background: white;
}

.notits {
  background: #dafbe1;
  border: 1px solid #2da44e;
  border-radius: 4px;
  padding: 0.5rem 0.75rem;
}

.fejl-liste {
  background: #ffebe9;
  border: 1px solid #cf222e;
  border-radius: 4px;
  padding: 0.5rem 0.75rem 0.5rem 2rem;
}

.infoboks {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 0.25rem 1rem 0.75rem;
  margin-bottom: 1rem;
}

.infoboks h2 {
  font-size: 1.05rem;
}

.daempet {
  color: #666;
}

.farezone {
  border: 1px solid #cf222e;
  border-radius: 8px;
  padding: 0.25rem 1rem 1rem;
  margin: 2rem 0;
}

.farezone h2 {
  font-size: 1.05rem;
  color: #cf222e;
}

.knap-fare {
  background: white;
  color: #cf222e;
  border: 1px solid #cf222e;
  padding: 0.45rem 1rem;
  border-radius: 4px;
  cursor: pointer;
}

/* Forsøgssider (fase 2+) */

.status-udfyldt {
  color: #2da44e;
  font-weight: bold;
}

.resultatvaerdi {
  font-size: 1.3rem;
  font-weight: bold;
}

/* Forsøgsskemaer med kolonner pr. forsøg (Atterberg m.fl.) */

.forsoegsskema input[type="text"] {
  width: 100%;
  min-width: 4.5rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  padding: 0.3rem;
}

.forsoegsskema tbody th {
  font-weight: normal;
  white-space: nowrap;
}

.resultatraekke td {
  background: #f0f6ff;
  font-weight: bold;
  text-align: right;
}

/* Rapport / resultat-oversigt (fase 5) */

.rapportark {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 1rem;
}

.rapportark .kornkurve {
  width: 100%;
}

.resultattabel, .rapporthoved {
  width: 100%;
  border-collapse: collapse;
  margin-top: 0.75rem;
}

.resultattabel td, .rapporthoved td {
  border: 1px solid var(--color-border);
  padding: 0.4rem 0.5rem;
}

.resultattabel td.tal {
  text-align: right;
  white-space: nowrap;
  font-weight: bold;
}

.rapportark .beskrivelse {
  border: 1px solid var(--color-border);
  margin-top: 0.75rem;
  padding: 0.5rem;
  min-height: 4rem;
}

.rapportark .beskrivelse h2 {
  font-size: 1rem;
  margin: 0 0 0.25rem;
}

.rapporthoved .institution {
  font-weight: bold;
}

.institution-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

.institution-logo {
  max-height: 44px;
  max-width: 110px;
  width: auto;
}

.proctorgraf {
  display: block;
  width: 75%;
  margin: 0.5rem auto;
}

/* Opslagstabeller (fase 8) */

.opslag-faner {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  margin-bottom: 1rem;
}

.opslag-faner a {
  padding: 0.35rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  background: white;
  text-decoration: none;
  color: var(--color-primary);
}

.opslag-faner a.aktiv {
  background: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
}

.opslagstabel input {
  width: 100%;
  min-width: 5rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  padding: 0.3rem;
}

.opslagstabel button {
  background: var(--color-primary);
  color: white;
  border: none;
  padding: 0.3rem 0.8rem;
  border-radius: 4px;
  cursor: pointer;
}

.opslagstabel button.knap-fare {
  background: white;
  color: #cf222e;
  border: 1px solid #cf222e;
}

.opret-raekke td {
  background: #f0f6ff;
}

/* Enkle formularbokse + kvitteringer (rekvirent-, admin- og superadmin-sider) */

.boks {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 1rem;
  margin-bottom: 1rem;
  max-width: 480px;
}

.boks label {
  display: block;
  font-size: 0.9rem;
  color: #444;
  margin-bottom: 0.6rem;
}

.boks input:not([type="checkbox"]), .boks select, .boks textarea {
  display: block;
  width: 100%;
  padding: 0.4rem;
  margin-top: 0.2rem;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  font: inherit;
  box-sizing: border-box;
}

.boks textarea {
  min-height: 4.5rem;
  resize: vertical;
}

.boks label.afkryds {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

/* Bred, struktureret variant (fx anmod-om-forsøgstype). */
.boks-bred {
  max-width: 760px;
}

.boks-bred fieldset {
  border: 1px solid var(--color-border);
  border-radius: 6px;
  padding: 1rem 1.25rem 1.25rem;
  margin: 0 0 1.25rem;
}

.boks-bred legend {
  font-weight: bold;
  color: var(--color-primary);
  padding: 0 0.4rem;
}

.boks-bred label {
  font-size: 0.95rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 1rem;
}

.boks-bred .hjaelp {
  display: block;
  font-weight: normal;
  font-size: 0.82rem;
  color: #777;
  margin-bottom: 0.2rem;
}

.boks-bred input:not([type="checkbox"]),
.boks-bred textarea {
  padding: 0.6rem;
  font-size: 1rem;
}

.boks-bred textarea {
  min-height: 6rem;
}

.boks button {
  margin-top: 0.5rem;
  background: var(--color-primary);
  color: white;
  border: none;
  padding: 0.5rem 1.25rem;
  border-radius: 4px;
  cursor: pointer;
}

.ok {
  background: #dafbe1;
  border: 1px solid #2da44e;
  border-radius: 4px;
  padding: 0.5rem 0.75rem;
}

/* "Vis alle"-sammenklap (forsøgsoversigt m.fl.) */
details.vis-alle {
  margin-top: 0.75rem;
}

details.vis-alle summary {
  cursor: pointer;
  color: var(--color-primary);
}

/* FAQ-accordion (/faq) */
details.faq-post {
  max-width: 760px;
  margin-bottom: 0.6rem;
}

details.faq-post summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--color-primary);
}

details.faq-post .faq-svar {
  margin-top: 0.6rem;
  color: #333;
  line-height: 1.5;
}

/* Delrapport-vælger på rapportsiden (fase 7) */

.delrapport-vaelger fieldset {
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  padding: 0.75rem 1rem 1rem;
  margin-bottom: 1rem;
}

.delrapport-vaelger legend {
  font-weight: bold;
  padding: 0 0.4rem;
}

.delrapport-vaelger label {
  display: block;
  margin: 0.25rem 0;
}

.delrapport-vaelger button {
  margin-top: 0.75rem;
  background: var(--color-primary);
  color: white;
  border: none;
  padding: 0.5rem 1.25rem;
  border-radius: 4px;
  cursor: pointer;
}

.rapport-brand {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 0.75rem;
}

.rapport-firma {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.rapport-firma-logo {
  max-height: 56px;
  max-width: 220px;
  width: auto;
}

.rapport-firma-navn {
  font-size: 1.3rem;
  font-weight: bold;
}

.rapport-vejnet {
  display: flex;
  align-items: center;
}

.rapport-vejnet svg {
  height: 56px;
  width: auto;
}

.login-logo {
  display: block;
  height: 48px;
  width: auto;
  margin: 0 auto 0.5rem;
}

.anmod-link {
  margin-top: 1rem;
  text-align: center;
  font-size: 0.9rem;
}

/* Hold hele linket (inkl. pil) samlet, så det aldrig brækker midt i frasen -
   den indledende tekst ombrydes i stedet over linket, hvis pladsen er trang. */
.anmod-link a {
  white-space: nowrap;
}

.drift-banner {
  padding: 0.6rem 1rem;
  border-radius: 6px;
  margin-bottom: 1rem;
  border: 1px solid;
}

.drift-info {
  background: #f3eefe;
  border-color: #6d28d9;
  color: #4c1d95;
}

.drift-advarsel {
  background: #fff4e5;
  border-color: #e09b3d;
  color: #7a4a00;
}

.forside-intro {
  max-width: 460px;
  margin: 1.5rem auto 0;
  text-align: center;
  color: #444;
}

.forside-intro h2 {
  font-size: 1.1rem;
  color: var(--color-primary);
}

/* Reference-bånd på forsiden: rolig, auto-rullende marquee. */
.ref-baand {
  margin: 2.5rem auto 0;
  max-width: 100%;
  overflow: hidden;
}

.ref-titel {
  text-align: center;
  font-size: 1rem;
  color: #666;
  font-weight: 600;
  margin-bottom: 1rem;
}

.ref-spor {
  width: 100%;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

/* Sporet = to identiske grupper side om side. Vi ruller hele sporet præcis
   halvdelen af dets bredde (= én gruppe) mod venstre; når gruppe 1 er kørt helt
   ud i venstre side, har gruppe 2 overtaget dens plads, og animationen
   nulstilles sømløst -> uendelig loop (kort kommer ind igen fra højre). Hver
   gruppe gentager referencerne, så den altid er bredere end skærmen og der
   aldrig opstår tomrum. */
.ref-track {
  display: flex;
  align-items: stretch;
  width: max-content;
  animation: ref-rul 50s linear infinite;
}

.ref-group {
  display: flex;
  align-items: stretch;
  gap: 1rem;
  padding-left: 1rem;
}

.ref-spor:hover .ref-track {
  animation-play-state: paused;
}

@keyframes ref-rul {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.ref-kort {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  background: white;
  border: 1px solid var(--color-border);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  min-height: 64px;
}

.ref-kort--citat {
  flex-direction: column;
  align-items: flex-start;
  max-width: 320px;
  gap: 0.5rem;
}

.ref-citat {
  margin: 0;
  font-style: italic;
  color: #333;
  font-size: 0.9rem;
  line-height: 1.35;
}

.ref-citat::before { content: "\201C"; }
.ref-citat::after { content: "\201D"; }

.ref-person {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.ref-foto {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex: 0 0 auto;
}

.ref-logo {
  max-height: 40px;
  max-width: 120px;
  width: auto;
}

.ref-navn {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  font-size: 0.85rem;
}

.ref-titel-person { color: #777; font-size: 0.8rem; }
.ref-firma { color: var(--color-primary); font-weight: 600; font-size: 0.8rem; }

@media (prefers-reduced-motion: reduce) {
  .ref-track { animation: none; }
  /* Ingen scroll-animation -> skjul loop-duplikatet og lad rækken kunne
     scrolles manuelt. */
  .ref-group--dup { display: none; }
  .ref-spor { overflow-x: auto; }
}

.badge {
  display: inline-block;
  min-width: 1.2em;
  padding: 0 0.4em;
  border-radius: 999px;
  background: #cf222e;
  color: white;
  font-size: 0.75rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.4;
}

.anmod-handlinger {
  white-space: nowrap;
}

.anmod-handlinger .knap-sekundaer,
.anmod-handlinger .knap-fare {
  padding: 0.3rem 0.7rem;
  font-size: 0.85rem;
}

/* --- Hjælpeklasser (flyttet fra inline styles, så CSP kan køre uden
   'unsafe-inline'). --- */
.inline-form { display: inline; }
.honeypot { position: absolute; left: -9999px; }
.mt-1 { margin-top: 1rem; }
.mt-0 { margin-top: 0; }
.mb-05 { margin-bottom: .5rem; }
.mt-neg { margin-top: -0.75rem; }
.logo-moerk-bg { background: #333; padding: .5rem; border-radius: 4px; display: inline-block; }

/* --- Vægt-integration (vaegt.js) --- */
.vaegt-bar { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap;
  background: #f3eefb; border: 1px solid #d9c9f0; border-radius: 8px;
  padding: .5rem .75rem; margin-bottom: 1rem; font-size: .9rem; }
.vaegt-bar .vaegt-status { font-weight: 600; }
.vaegt-bar .vaegt-til { color: #1a6b1a; }
.vaegt-bar .vaegt-fra { color: #7a5a1a; }
.vaegt-bar button { padding: .25rem .7rem; }
.vaegt-knap { margin-left: .35rem; padding: .2rem .55rem; cursor: pointer;
  border: 1px solid #b89adf; background: #efe7fb; border-radius: 6px; font-size: .85rem; }
.vaegt-knap:disabled { opacity: .5; cursor: progress; }

/* --- Vægt-testside (/vaegt-test) --- */
.vaegt-raa { min-width: 14rem; }
.vaegt-log { font-family: monospace; font-size: .85rem; background: #1e1e2e;
  color: #e0e0f0; padding: .75rem; border-radius: 6px; height: 16rem;
  overflow-y: auto; white-space: pre-wrap; }
.status { padding: .1rem .5rem; border-radius: 4px; font-weight: 600; }
.status-ok { background: #d6f5d6; color: #1a6b1a; }
.status-fra { background: #f0d6d6; color: #8b1a1a; }
.vaegt-log .ind { color: #9ad29a; }
.vaegt-log .ud { color: #9ab8f0; }
.vaegt-log .fejl { color: #f09a9a; }
.vaegt-log .ok { color: #9ad29a; }
.stabil-ja { color: #1a6b1a; font-weight: 600; }
.stabil-nej { color: #8b6b1a; }

/* --- Responsivt: smal skærm (telefon/tablet) ---------------------------- */
@media (max-width: 768px) {
  /* Topbaren bryder, så menuen kan folde ud på sin egen linje under brandet. */
  .topbar {
    flex-wrap: wrap;
    padding: 0.6rem 1rem;
  }
  .topbar .brand {
    font-size: 1.05rem;
    flex: 1 1 auto;
    min-width: 0;
  }
  .topbar .brand .firma-navn,
  .topbar .brand .brand-sep {
    font-size: 1.05rem;
  }

  /* Hamburger-knappen vises og overstyrer den generelle .topbar button-stil. */
  .topbar .nav-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    width: 42px;
    height: 38px;
    padding: 9px;
    border: 1px solid rgba(255, 255, 255, 0.7);
    border-radius: 6px;
    flex: 0 0 auto;
  }
  .topbar .nav-toggle-bar {
    display: block;
    width: 100%;
    height: 2px;
    background: white;
    border-radius: 2px;
  }

  /* Menuen ligger skjult, til hamburgeren åbner den; så bliver den en lodret
     liste i fuld bredde med tydelige tryk-flader. */
  .topbar nav {
    flex-basis: 100%;
    display: none;
    flex-direction: column;
    align-items: stretch;
    margin-top: 0.5rem;
  }
  .topbar.nav-open nav {
    display: flex;
  }
  .topbar nav a,
  .topbar nav .bruger {
    margin-left: 0;
    padding: 0.65rem 0.25rem;
    border-top: 1px solid rgba(255, 255, 255, 0.25);
  }
  .topbar nav .inline-form {
    display: block;
    padding-top: 0.6rem;
  }
  .topbar nav .inline-form button {
    width: 100%;
  }

  /* Giv hovedindholdet lidt mere plads og lad sektioner stå komfortabelt. */
  .content {
    margin: 1.25rem auto;
  }
}
